{"version":3,"file":"app-80b3782953860dc7d48b.js","mappings":"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","sources":["webpack://riot-tournament-eu/./node_modules/@apollo/client/errors/index.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/react/context/ApolloContext.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/caching/caches.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/caching/getMemoryInternals.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/caching/sizes.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/canUse.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/compact.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/makeUniqueId.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/mergeOptions.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/objects.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/stringifyForDisplay.js","webpack://riot-tournament-eu/./node_modules/ts-invariant/lib/invariant.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/globals/maybe.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/globals/global.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/globals/invariantWrappers.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/globals/index.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/version.js","webpack://riot-tournament-eu/./node_modules/@gatsbyjs/reach-router/lib/history.js","webpack://riot-tournament-eu/./node_modules/@gatsbyjs/reach-router/lib/utils.js","webpack://riot-tournament-eu/./node_modules/@wry/caches/lib/strong.js","webpack://riot-tournament-eu/./node_modules/@wry/caches/lib/weak.js","webpack://riot-tournament-eu/./node_modules/@wry/equality/lib/index.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/core-js/object/assign.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/helpers/extends.js","webpack://riot-tournament-eu/./node_modules/camelcase/index.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/TemplateTag/TemplateTag.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/inlineArrayTransformer/inlineArrayTransformer.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/stripIndentTransformer/stripIndentTransformer.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/trimResultTransformer/trimResultTransformer.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/splitStringTransformer/splitStringTransformer.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/commaLists/commaLists.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/commaListsAnd/commaListsAnd.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/commaListsOr/commaListsOr.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/removeNonPrintingValuesTransformer/removeNonPrintingValuesTransformer.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/replaceSubstitutionTransformer/replaceSubstitutionTransformer.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/html/html.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/replaceResultTransformer/replaceResultTransformer.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/safeHtml/safeHtml.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/oneLine/oneLine.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/oneLineTrim/oneLineTrim.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/oneLineCommaLists/oneLineCommaLists.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/oneLineCommaListsOr/oneLineCommaListsOr.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/oneLineCommaListsAnd/oneLineCommaListsAnd.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/inlineLists/inlineLists.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/oneLineInlineLists/oneLineInlineLists.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/stripIndent/stripIndent.js","webpack://riot-tournament-eu/./node_modules/common-tags/es/stripIndents/stripIndents.js","webpack://riot-tournament-eu/./node_modules/gatsby/dist/internal-plugins/bundle-optimisations/polyfills/object-assign.js","webpack://riot-tournament-eu/./node_modules/gatsby/dist/internal-plugins/bundle-optimisations/polyfills/whatwg-fetch.js","webpack://riot-tournament-eu/./node_modules/graphql/jsutils/inspect.mjs","webpack://riot-tournament-eu/./node_modules/graphql/jsutils/nodejsCustomInspectSymbol.mjs","webpack://riot-tournament-eu/./node_modules/graphql/jsutils/defineInspect.mjs","webpack://riot-tournament-eu/./node_modules/graphql/jsutils/invariant.mjs","webpack://riot-tournament-eu/./node_modules/graphql/language/ast.mjs","webpack://riot-tournament-eu/./node_modules/graphql/language/blockString.mjs","webpack://riot-tournament-eu/./node_modules/graphql/language/kinds.mjs","webpack://riot-tournament-eu/./node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","webpack://riot-tournament-eu/./node_modules/isomorphic-fetch/fetch-npm-browserify.js","webpack://riot-tournament-eu/./node_modules/react-is/cjs/react-is.production.min.js","webpack://riot-tournament-eu/./node_modules/react-is/index.js","webpack://riot-tournament-eu/./node_modules/rehackt/index.js","webpack://riot-tournament-eu/./node_modules/shallowequal/index.js","webpack://riot-tournament-eu/./node_modules/@emotion/stylis/dist/stylis.browser.esm.js","webpack://riot-tournament-eu/./node_modules/@emotion/unitless/dist/unitless.browser.esm.js","webpack://riot-tournament-eu/./node_modules/@emotion/memoize/dist/emotion-memoize.esm.js","webpack://riot-tournament-eu/./node_modules/@emotion/is-prop-valid/dist/emotion-is-prop-valid.esm.js","webpack://riot-tournament-eu/./node_modules/styled-components/dist/styled-components.browser.esm.js","webpack://riot-tournament-eu/./node_modules/tslib/tslib.es6.js","webpack://riot-tournament-eu/./node_modules/webfontloader/webfontloader.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/fn/object/assign.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_a-function.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_an-object.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_array-includes.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_cof.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_core.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_ctx.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_defined.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_descriptors.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_dom-create.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_enum-bug-keys.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_export.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_fails.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_global.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_has.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_hide.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_ie8-dom-define.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_iobject.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_is-object.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_library.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_object-assign.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_object-dp.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_object-gops.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_object-keys-internal.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_object-keys.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_object-pie.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_property-desc.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_shared-key.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_shared.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_to-absolute-index.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_to-integer.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_to-iobject.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_to-length.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_to-object.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_to-primitive.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/_uid.js","webpack://riot-tournament-eu/./node_modules/babel-runtime/node_modules/core-js/library/modules/es6.object.assign.js","webpack://riot-tournament-eu/./node_modules/gatsby-link/index.js","webpack://riot-tournament-eu/./node_modules/gatsby-link/parse-path.js","webpack://riot-tournament-eu/./node_modules/gatsby-react-router-scroll/index.js","webpack://riot-tournament-eu/./node_modules/gatsby-react-router-scroll/scroll-handler.js","webpack://riot-tournament-eu/./node_modules/gatsby-react-router-scroll/session-storage.js","webpack://riot-tournament-eu/./node_modules/gatsby-react-router-scroll/use-scroll-restoration.js","webpack://riot-tournament-eu/./.cache/_this_is_virtual_fs_path_/$virtual/async-requires.js","webpack://riot-tournament-eu/./.cache/api-runner-browser-plugins.js","webpack://riot-tournament-eu/./.cache/api-runner-browser.js","webpack://riot-tournament-eu/./.cache/emitter.js","webpack://riot-tournament-eu/./node_modules/mitt/dist/mitt.es.js","webpack://riot-tournament-eu/./.cache/normalize-page-path.js","webpack://riot-tournament-eu/./.cache/find-path.js","webpack://riot-tournament-eu/./.cache/gatsby-browser-entry.js","webpack://riot-tournament-eu/./.cache/prefetch.js","webpack://riot-tournament-eu/./.cache/loader.js","webpack://riot-tournament-eu/./.cache/page-renderer.js","webpack://riot-tournament-eu/./.cache/route-announcer-props.js","webpack://riot-tournament-eu/./.cache/navigation.js","webpack://riot-tournament-eu/./node_modules/shallow-compare/es/index.js","webpack://riot-tournament-eu/./.cache/ensure-resources.js","webpack://riot-tournament-eu/./.cache/production-app.js","webpack://riot-tournament-eu/./.cache/public-page-renderer-prod.js","webpack://riot-tournament-eu/./.cache/public-page-renderer.js","webpack://riot-tournament-eu/./.cache/react-lifecycles-compat.js","webpack://riot-tournament-eu/./.cache/redirect-utils.js","webpack://riot-tournament-eu/./.cache/register-service-worker.js","webpack://riot-tournament-eu/./.cache/strip-prefix.js","webpack://riot-tournament-eu/./node_modules/@wry/trie/lib/index.js","webpack://riot-tournament-eu/./node_modules/@wry/context/lib/slot.js","webpack://riot-tournament-eu/./node_modules/@wry/context/lib/index.js","webpack://riot-tournament-eu/./node_modules/optimism/lib/context.js","webpack://riot-tournament-eu/./node_modules/optimism/lib/helpers.js","webpack://riot-tournament-eu/./node_modules/optimism/lib/entry.js","webpack://riot-tournament-eu/./node_modules/optimism/lib/dep.js","webpack://riot-tournament-eu/./node_modules/optimism/lib/index.js","webpack://riot-tournament-eu/./node_modules/graphql/language/visitor.mjs","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/graphql/fragments.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/canonicalStringify.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/graphql/storeUtils.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/graphql/getFromAST.js","webpack://riot-tournament-eu/./node_modules/zen-observable-ts/module.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/mergeDeep.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/graphql/directives.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/core/equalByQuery.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/masking/utils.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/maybeDeepFreeze.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/masking/maskDefinition.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/masking/maskFragment.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/cache/core/cache.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/cache/core/types/common.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/graphql/DocumentTransform.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/arrays.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/graphql/transform.js","webpack://riot-tournament-eu/./node_modules/graphql/language/printer.mjs","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/graphql/print.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/cache/inmemory/helpers.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/cache/inmemory/entityStore.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/cache/inmemory/object-canon.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/cache/inmemory/readFromStore.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/cloneDeep.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/cache/inmemory/reactiveVars.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/cache/inmemory/key-extractor.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/cache/inmemory/policies.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/cache/inmemory/writeToStore.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/cache/inmemory/inMemoryCache.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/core/ApolloLink.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/utils/createOperation.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/utils/transformOperation.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/utils/validateOperation.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/core/execute.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/serializeFetchParameter.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/iterators/nodeStream.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/iterators/reader.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/responseIterator.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/iterators/async.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/iterators/promise.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/utils/throwServerError.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/incrementalResult.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/parseAndCheckHttpResponse.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/checkFetcher.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/selectHttpOptionsAndBody.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/utils/fromError.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/createHttpLink.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/selectURI.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/utils/filterOperationVariables.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/rewriteURIForGET.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/link/http/HttpLink.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/observables/asyncMap.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/common/errorHandling.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/observables/iteration.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/observables/subclassing.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/observables/Concast.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/core/networkStatus.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/core/ObservableQuery.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/utilities/promises/preventUnhandledRejection.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/core/QueryInfo.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/core/QueryManager.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/masking/maskOperation.js","webpack://riot-tournament-eu/./node_modules/graphql/language/predicates.mjs","webpack://riot-tournament-eu/./node_modules/@apollo/client/core/LocalState.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/core/ApolloClient.js","webpack://riot-tournament-eu/./node_modules/@apollo/client/react/context/ApolloProvider.js","webpack://riot-tournament-eu/./node_modules/gatsby-plugin-apollo/gatsby-browser.js","webpack://riot-tournament-eu/../src/image-utils.ts","webpack://riot-tournament-eu/../src/components/hooks.ts","webpack://riot-tournament-eu/../src/components/layout-wrapper.tsx","webpack://riot-tournament-eu/../src/components/picture.tsx","webpack://riot-tournament-eu/../src/components/placeholder.tsx","webpack://riot-tournament-eu/../src/components/main-image.tsx","webpack://riot-tournament-eu/../src/components/gatsby-image.server.tsx","webpack://riot-tournament-eu/../src/components/gatsby-image.browser.tsx","webpack://riot-tournament-eu/../src/components/static-image.server.tsx","webpack://riot-tournament-eu/../src/components/static-image.tsx","webpack://riot-tournament-eu/../src/components/later-hydrator.tsx","webpack://riot-tournament-eu/./node_modules/gatsby-plugin-image/gatsby-browser.js","webpack://riot-tournament-eu/./node_modules/gatsby-plugin-styled-components/gatsby-browser.js","webpack://riot-tournament-eu/src/gatsby-browser.js","webpack://riot-tournament-eu/./node_modules/@gatsbyjs/reach-router/es/lib/utils.js","webpack://riot-tournament-eu/./node_modules/@gatsbyjs/reach-router/es/lib/history.js","webpack://riot-tournament-eu/./node_modules/@gatsbyjs/reach-router/es/index.js","webpack://riot-tournament-eu/./node_modules/invariant/browser.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/assertThisInitialized.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/extends.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/inheritsLoose.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/interopRequireDefault.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/setPrototypeOf.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/esm/iterableToArray.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","webpack://riot-tournament-eu/./node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js"],"sourcesContent":["import { __extends, __spreadArray } from \"tslib\";\nimport \"../utilities/globals/index.js\";\nimport { isNonNullObject } from \"../utilities/index.js\";\n// This Symbol allows us to pass transport-specific errors from the link chain\n// into QueryManager/client internals without risking a naming collision within\n// extensions (which implementers can use as they see fit).\nexport var PROTOCOL_ERRORS_SYMBOL = Symbol();\nexport function graphQLResultHasProtocolErrors(result) {\n if (result.extensions) {\n return Array.isArray(result.extensions[PROTOCOL_ERRORS_SYMBOL]);\n }\n return false;\n}\nexport function isApolloError(err) {\n return err.hasOwnProperty(\"graphQLErrors\");\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.\nvar generateErrorMessage = function (err) {\n var errors = __spreadArray(__spreadArray(__spreadArray([], err.graphQLErrors, true), err.clientErrors, true), err.protocolErrors, true);\n if (err.networkError) errors.push(err.networkError);\n return errors\n // The rest of the code sometimes unsafely types non-Error objects as GraphQLErrors\n .map(function (err) {\n return isNonNullObject(err) && err.message || \"Error message not found.\";\n }).join(\"\\n\");\n};\nvar ApolloError = /** @class */function (_super) {\n __extends(ApolloError, _super);\n // Constructs an instance of ApolloError given serialized GraphQL errors,\n // client errors, protocol errors or network errors.\n // Note that one of these has to be a valid\n // value or the constructed error will be meaningless.\n function ApolloError(_a) {\n var graphQLErrors = _a.graphQLErrors,\n protocolErrors = _a.protocolErrors,\n clientErrors = _a.clientErrors,\n networkError = _a.networkError,\n errorMessage = _a.errorMessage,\n extraInfo = _a.extraInfo;\n var _this = _super.call(this, errorMessage) || this;\n _this.name = \"ApolloError\";\n _this.graphQLErrors = graphQLErrors || [];\n _this.protocolErrors = protocolErrors || [];\n _this.clientErrors = clientErrors || [];\n _this.networkError = networkError || null;\n _this.message = errorMessage || generateErrorMessage(_this);\n _this.extraInfo = extraInfo;\n _this.cause = __spreadArray(__spreadArray(__spreadArray([networkError], graphQLErrors || [], true), protocolErrors || [], true), clientErrors || [], true).find(function (e) {\n return !!e;\n }) || null;\n // We're not using `Object.setPrototypeOf` here as it isn't fully\n // supported on Android (see issue #3236).\n _this.__proto__ = ApolloError.prototype;\n return _this;\n }\n return ApolloError;\n}(Error);\nexport { ApolloError };","import * as React from \"rehackt\";\nimport { canUseSymbol } from \"../../utilities/index.js\";\nimport { invariant } from \"../../utilities/globals/index.js\";\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.\nvar contextKey = canUseSymbol ? Symbol.for(\"__APOLLO_CONTEXT__\") : \"__APOLLO_CONTEXT__\";\nexport function getApolloContext() {\n invariant(\"createContext\" in React, 54);\n var context = React.createContext[contextKey];\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/**\n * @deprecated This function has no \"resetting\" effect since Apollo Client 3.4.12,\n * and will be removed in the next major version of Apollo Client.\n * If you want to get the Apollo Context, use `getApolloContext` instead.\n */\nexport var resetApolloContext = getApolloContext;","import { WeakCache, StrongCache } from \"@wry/caches\";\nvar scheduledCleanup = new WeakSet();\nfunction schedule(cache) {\n if (cache.size <= (cache.max || -1)) {\n return;\n }\n if (!scheduledCleanup.has(cache)) {\n scheduledCleanup.add(cache);\n setTimeout(function () {\n cache.clean();\n scheduledCleanup.delete(cache);\n }, 100);\n }\n}\n/**\n * @internal\n * A version of WeakCache that will auto-schedule a cleanup of the cache when\n * a new item is added and the cache reached maximum size.\n * Throttled to once per 100ms.\n *\n * @privateRemarks\n * Should be used throughout the rest of the codebase instead of WeakCache,\n * with the notable exception of usage in `wrap` from `optimism` - that one\n * already handles cleanup and should remain a `WeakCache`.\n */\nexport var AutoCleanedWeakCache = function (max, dispose) {\n /*\n Some builds of `WeakCache` are function prototypes, some are classes.\n This library still builds with an ES5 target, so we can't extend the\n real classes.\n Instead, we have to use this workaround until we switch to a newer build\n target.\n */\n var cache = new WeakCache(max, dispose);\n cache.set = function (key, value) {\n var ret = WeakCache.prototype.set.call(this, key, value);\n schedule(this);\n return ret;\n };\n return cache;\n};\n/**\n * @internal\n * A version of StrongCache that will auto-schedule a cleanup of the cache when\n * a new item is added and the cache reached maximum size.\n * Throttled to once per 100ms.\n *\n * @privateRemarks\n * Should be used throughout the rest of the codebase instead of StrongCache,\n * with the notable exception of usage in `wrap` from `optimism` - that one\n * already handles cleanup and should remain a `StrongCache`.\n */\nexport var AutoCleanedStrongCache = function (max, dispose) {\n /*\n Some builds of `StrongCache` are function prototypes, some are classes.\n This library still builds with an ES5 target, so we can't extend the\n real classes.\n Instead, we have to use this workaround until we switch to a newer build\n target.\n */\n var cache = new StrongCache(max, dispose);\n cache.set = function (key, value) {\n var ret = StrongCache.prototype.set.call(this, key, value);\n schedule(this);\n return ret;\n };\n return cache;\n};","import { __assign, __spreadArray } from \"tslib\";\nimport { cacheSizes } from \"./sizes.js\";\nvar globalCaches = {};\nexport function registerGlobalCache(name, getSize) {\n globalCaches[name] = getSize;\n}\n/**\n * For internal purposes only - please call `ApolloClient.getMemoryInternals` instead\n * @internal\n */\nexport var getApolloClientMemoryInternals = globalThis.__DEV__ !== false ? _getApolloClientMemoryInternals : undefined;\n/**\n * For internal purposes only - please call `ApolloClient.getMemoryInternals` instead\n * @internal\n */\nexport var getInMemoryCacheMemoryInternals = globalThis.__DEV__ !== false ? _getInMemoryCacheMemoryInternals : undefined;\n/**\n * For internal purposes only - please call `ApolloClient.getMemoryInternals` instead\n * @internal\n */\nexport var getApolloCacheMemoryInternals = globalThis.__DEV__ !== false ? _getApolloCacheMemoryInternals : undefined;\nfunction getCurrentCacheSizes() {\n // `defaultCacheSizes` is a `const enum` that will be inlined during build, so we have to reconstruct it's shape here\n var defaults = {\n parser: 1000 /* defaultCacheSizes[\"parser\"] */,\n canonicalStringify: 1000 /* defaultCacheSizes[\"canonicalStringify\"] */,\n print: 2000 /* defaultCacheSizes[\"print\"] */,\n \"documentTransform.cache\": 2000 /* defaultCacheSizes[\"documentTransform.cache\"] */,\n \"queryManager.getDocumentInfo\": 2000 /* defaultCacheSizes[\"queryManager.getDocumentInfo\"] */,\n \"PersistedQueryLink.persistedQueryHashes\": 2000 /* defaultCacheSizes[\"PersistedQueryLink.persistedQueryHashes\"] */,\n \"fragmentRegistry.transform\": 2000 /* defaultCacheSizes[\"fragmentRegistry.transform\"] */,\n \"fragmentRegistry.lookup\": 1000 /* defaultCacheSizes[\"fragmentRegistry.lookup\"] */,\n \"fragmentRegistry.findFragmentSpreads\": 4000 /* defaultCacheSizes[\"fragmentRegistry.findFragmentSpreads\"] */,\n \"cache.fragmentQueryDocuments\": 1000 /* defaultCacheSizes[\"cache.fragmentQueryDocuments\"] */,\n \"removeTypenameFromVariables.getVariableDefinitions\": 2000 /* defaultCacheSizes[\"removeTypenameFromVariables.getVariableDefinitions\"] */,\n \"inMemoryCache.maybeBroadcastWatch\": 5000 /* defaultCacheSizes[\"inMemoryCache.maybeBroadcastWatch\"] */,\n \"inMemoryCache.executeSelectionSet\": 50000 /* defaultCacheSizes[\"inMemoryCache.executeSelectionSet\"] */,\n \"inMemoryCache.executeSubSelectedArray\": 10000 /* defaultCacheSizes[\"inMemoryCache.executeSubSelectedArray\"] */\n };\n\n return Object.fromEntries(Object.entries(defaults).map(function (_a) {\n var k = _a[0],\n v = _a[1];\n return [k, cacheSizes[k] || v];\n }));\n}\nfunction _getApolloClientMemoryInternals() {\n var _a, _b, _c, _d, _e;\n if (!(globalThis.__DEV__ !== false)) throw new Error(\"only supported in development mode\");\n return {\n limits: getCurrentCacheSizes(),\n sizes: __assign({\n print: (_a = globalCaches.print) === null || _a === void 0 ? void 0 : _a.call(globalCaches),\n parser: (_b = globalCaches.parser) === null || _b === void 0 ? void 0 : _b.call(globalCaches),\n canonicalStringify: (_c = globalCaches.canonicalStringify) === null || _c === void 0 ? void 0 : _c.call(globalCaches),\n links: linkInfo(this.link),\n queryManager: {\n getDocumentInfo: this[\"queryManager\"][\"transformCache\"].size,\n documentTransforms: transformInfo(this[\"queryManager\"].documentTransform)\n }\n }, (_e = (_d = this.cache).getMemoryInternals) === null || _e === void 0 ? void 0 : _e.call(_d))\n };\n}\nfunction _getApolloCacheMemoryInternals() {\n return {\n cache: {\n fragmentQueryDocuments: getWrapperInformation(this[\"getFragmentDoc\"])\n }\n };\n}\nfunction _getInMemoryCacheMemoryInternals() {\n var fragments = this.config.fragments;\n return __assign(__assign({}, _getApolloCacheMemoryInternals.apply(this)), {\n addTypenameDocumentTransform: transformInfo(this[\"addTypenameTransform\"]),\n inMemoryCache: {\n executeSelectionSet: getWrapperInformation(this[\"storeReader\"][\"executeSelectionSet\"]),\n executeSubSelectedArray: getWrapperInformation(this[\"storeReader\"][\"executeSubSelectedArray\"]),\n maybeBroadcastWatch: getWrapperInformation(this[\"maybeBroadcastWatch\"])\n },\n fragmentRegistry: {\n findFragmentSpreads: getWrapperInformation(fragments === null || fragments === void 0 ? void 0 : fragments.findFragmentSpreads),\n lookup: getWrapperInformation(fragments === null || fragments === void 0 ? void 0 : fragments.lookup),\n transform: getWrapperInformation(fragments === null || fragments === void 0 ? void 0 : fragments.transform)\n }\n });\n}\nfunction isWrapper(f) {\n return !!f && \"dirtyKey\" in f;\n}\nfunction getWrapperInformation(f) {\n return isWrapper(f) ? f.size : undefined;\n}\nfunction isDefined(value) {\n return value != null;\n}\nfunction transformInfo(transform) {\n return recurseTransformInfo(transform).map(function (cache) {\n return {\n cache: cache\n };\n });\n}\nfunction recurseTransformInfo(transform) {\n return transform ? __spreadArray(__spreadArray([getWrapperInformation(transform === null || transform === void 0 ? void 0 : transform[\"performWork\"])], recurseTransformInfo(transform === null || transform === void 0 ? void 0 : transform[\"left\"]), true), recurseTransformInfo(transform === null || transform === void 0 ? void 0 : transform[\"right\"]), true).filter(isDefined) : [];\n}\nfunction linkInfo(link) {\n var _a;\n return link ? __spreadArray(__spreadArray([(_a = link === null || link === void 0 ? void 0 : link.getMemoryInternals) === null || _a === void 0 ? void 0 : _a.call(link)], linkInfo(link === null || link === void 0 ? void 0 : link.left), true), linkInfo(link === null || link === void 0 ? void 0 : link.right), true).filter(isDefined) : [];\n}","import { __assign } from \"tslib\";\nimport { global } from \"../globals/index.js\";\nvar cacheSizeSymbol = Symbol.for(\"apollo.cacheSize\");\n/**\n *\n * The global cache size configuration for Apollo Client.\n *\n * @remarks\n *\n * You can directly modify this object, but any modification will\n * only have an effect on caches that are created after the modification.\n *\n * So for global caches, such as `parser`, `canonicalStringify` and `print`,\n * you might need to call `.reset` on them, which will essentially re-create them.\n *\n * Alternatively, you can set `globalThis[Symbol.for(\"apollo.cacheSize\")]` before\n * you load the Apollo Client package:\n *\n * @example\n * ```ts\n * globalThis[Symbol.for(\"apollo.cacheSize\")] = {\n * parser: 100\n * } satisfies Partial // the `satisfies` is optional if using TypeScript\n * ```\n */\nexport var cacheSizes = __assign({}, global[cacheSizeSymbol]);","import { maybe } from \"../globals/index.js\";\nvar isReactNative = maybe(function () {\n return navigator.product;\n}) == \"ReactNative\";\nexport var canUseWeakMap = typeof WeakMap === \"function\" && !(isReactNative && !global.HermesInternal);\nexport var canUseWeakSet = typeof WeakSet === \"function\";\nexport var canUseSymbol = typeof Symbol === \"function\" && typeof Symbol.for === \"function\";\nexport var canUseAsyncIteratorSymbol = canUseSymbol && Symbol.asyncIterator;\nexport var canUseDOM = typeof maybe(function () {\n return window.document.createElement;\n}) === \"function\";\nvar usingJSDOM =\n// Following advice found in this comment from @domenic (maintainer of jsdom):\n// https://github.com/jsdom/jsdom/issues/1537#issuecomment-229405327\n//\n// Since we control the version of Jest and jsdom used when running Apollo\n// Client tests, and that version is recent enought to include \" jsdom/x.y.z\"\n// at the end of the user agent string, I believe this case is all we need to\n// check. Testing for \"Node.js\" was recommended for backwards compatibility\n// with older version of jsdom, but we don't have that problem.\nmaybe(function () {\n return navigator.userAgent.indexOf(\"jsdom\") >= 0;\n}) || false;\n// Our tests should all continue to pass if we remove this !usingJSDOM\n// condition, thereby allowing useLayoutEffect when using jsdom. Unfortunately,\n// if we allow useLayoutEffect, then useSyncExternalStore generates many\n// warnings about useLayoutEffect doing nothing on the server. While these\n// warnings are harmless, this !usingJSDOM condition seems to be the best way to\n// prevent them (i.e. skipping useLayoutEffect when using jsdom).\nexport var canUseLayoutEffect = (canUseDOM || isReactNative) && !usingJSDOM;","/**\n * Merges the provided objects shallowly and removes\n * all properties with an `undefined` value\n */\nexport function compact() {\n var objects = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n objects[_i] = arguments[_i];\n }\n var result = Object.create(null);\n objects.forEach(function (obj) {\n if (!obj) return;\n Object.keys(obj).forEach(function (key) {\n var value = obj[key];\n if (value !== void 0) {\n result[key] = value;\n }\n });\n });\n return result;\n}","var prefixCounts = new Map();\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) {\n var count = prefixCounts.get(prefix) || 1;\n prefixCounts.set(prefix, count + 1);\n return \"\".concat(prefix, \":\").concat(count, \":\").concat(Math.random().toString(36).slice(2));\n}","import { __assign } from \"tslib\";\nimport { compact } from \"./compact.js\";\nexport function mergeOptions(defaults, options) {\n return compact(defaults, options, options.variables && {\n variables: compact(__assign(__assign({}, defaults && defaults.variables), options.variables))\n });\n}","export function isNonNullObject(obj) {\n return obj !== null && typeof obj === \"object\";\n}\nexport function isPlainObject(obj) {\n return obj !== null && typeof obj === \"object\" && (Object.getPrototypeOf(obj) === Object.prototype || Object.getPrototypeOf(obj) === null);\n}","import { makeUniqueId } from \"./makeUniqueId.js\";\nexport function stringifyForDisplay(value, space) {\n if (space === void 0) {\n space = 0;\n }\n var undefId = makeUniqueId(\"stringifyForDisplay\");\n return JSON.stringify(value, function (key, value) {\n return value === void 0 ? undefId : value;\n }, space).split(JSON.stringify(undefId)).join(\"\");\n}","import { __extends } from \"tslib\";\nvar genericMessage = \"Invariant Violation\";\nvar _a = Object.setPrototypeOf,\n setPrototypeOf = _a === void 0 ? function (obj, proto) {\n obj.__proto__ = proto;\n return obj;\n } : _a;\nvar InvariantError = /** @class */function (_super) {\n __extends(InvariantError, _super);\n function InvariantError(message) {\n if (message === void 0) {\n message = genericMessage;\n }\n var _this = _super.call(this, typeof message === \"number\" ? genericMessage + \": \" + message + \" (see https://github.com/apollographql/invariant-packages)\" : message) || this;\n _this.framesToPop = 1;\n _this.name = genericMessage;\n setPrototypeOf(_this, InvariantError.prototype);\n return _this;\n }\n return InvariantError;\n}(Error);\nexport { InvariantError };\nexport function invariant(condition, message) {\n if (!condition) {\n throw new InvariantError(message);\n }\n}\nvar verbosityLevels = [\"debug\", \"log\", \"warn\", \"error\", \"silent\"];\nvar verbosityLevel = verbosityLevels.indexOf(\"log\");\nfunction wrapConsoleMethod(name) {\n return function () {\n if (verbosityLevels.indexOf(name) >= verbosityLevel) {\n // Default to console.log if this host environment happens not to provide\n // all the console.* methods we need.\n var method = console[name] || console.log;\n return method.apply(console, arguments);\n }\n };\n}\n(function (invariant) {\n invariant.debug = wrapConsoleMethod(\"debug\");\n invariant.log = wrapConsoleMethod(\"log\");\n invariant.warn = wrapConsoleMethod(\"warn\");\n invariant.error = wrapConsoleMethod(\"error\");\n})(invariant || (invariant = {}));\nexport function setVerbosity(level) {\n var old = verbosityLevels[verbosityLevel];\n verbosityLevel = Math.max(0, verbosityLevels.indexOf(level));\n return old;\n}\nexport default invariant;","export function maybe(thunk) {\n try {\n return thunk();\n } catch (_a) {}\n}","import { maybe } from \"./maybe.js\";\nexport default maybe(function () {\n return globalThis;\n}) || maybe(function () {\n return window;\n}) || maybe(function () {\n return self;\n}) || maybe(function () {\n return global;\n}) ||\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.\nmaybe(function () {\n return maybe.constructor(\"return this\")();\n});","import { invariant as originalInvariant, InvariantError } from \"ts-invariant\";\nimport { version } from \"../../version.js\";\nimport global from \"./global.js\";\nimport { stringifyForDisplay } from \"../common/stringifyForDisplay.js\";\nfunction wrap(fn) {\n return function (message) {\n var args = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n args[_i - 1] = arguments[_i];\n }\n if (typeof message === \"number\") {\n var arg0 = message;\n message = getHandledErrorMsg(arg0);\n if (!message) {\n message = getFallbackErrorMsg(arg0, args);\n args = [];\n }\n }\n fn.apply(void 0, [message].concat(args));\n };\n}\nvar invariant = Object.assign(function invariant(condition, message) {\n var args = [];\n for (var _i = 2; _i < arguments.length; _i++) {\n args[_i - 2] = arguments[_i];\n }\n if (!condition) {\n originalInvariant(condition, getHandledErrorMsg(message, args) || getFallbackErrorMsg(message, args));\n }\n}, {\n debug: wrap(originalInvariant.debug),\n log: wrap(originalInvariant.log),\n warn: wrap(originalInvariant.warn),\n error: wrap(originalInvariant.error)\n});\n/**\n * Returns an InvariantError.\n *\n * `message` can only be a string, a concatenation of strings, or a ternary statement\n * that results in a string. This will be enforced on build, where the message will\n * be replaced with a message number.\n * String substitutions with %s are supported and will also return\n * pretty-stringified objects.\n * Excess `optionalParams` will be swallowed.\n */\nfunction newInvariantError(message) {\n var optionalParams = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n optionalParams[_i - 1] = arguments[_i];\n }\n return new InvariantError(getHandledErrorMsg(message, optionalParams) || getFallbackErrorMsg(message, optionalParams));\n}\nvar ApolloErrorMessageHandler = Symbol.for(\"ApolloErrorMessageHandler_\" + version);\nfunction stringify(arg) {\n if (typeof arg == \"string\") {\n return arg;\n }\n try {\n return stringifyForDisplay(arg, 2).slice(0, 1000);\n } catch (_a) {\n return \"\";\n }\n}\nfunction getHandledErrorMsg(message, messageArgs) {\n if (messageArgs === void 0) {\n messageArgs = [];\n }\n if (!message) return;\n return global[ApolloErrorMessageHandler] && global[ApolloErrorMessageHandler](message, messageArgs.map(stringify));\n}\nfunction getFallbackErrorMsg(message, messageArgs) {\n if (messageArgs === void 0) {\n messageArgs = [];\n }\n if (!message) return;\n return \"An error occurred! For more details, see the full error text at https://go.apollo.dev/c/err#\".concat(encodeURIComponent(JSON.stringify({\n version: version,\n message: message,\n args: messageArgs.map(stringify)\n })));\n}\nexport { invariant, InvariantError, newInvariantError, ApolloErrorMessageHandler };","import { invariant, newInvariantError, InvariantError } from \"./invariantWrappers.js\";\nexport { maybe } from \"./maybe.js\";\nexport { default as global } from \"./global.js\";\nexport { invariant, newInvariantError, InvariantError };\n/**\n * @deprecated we do not use this internally anymore,\n * it is just exported for backwards compatibility\n */\n// this file is extempt from automatic `__DEV__` replacement\n// so we have to write it out here\n// @ts-ignore\nexport var DEV = globalThis.__DEV__ !== false;\nexport { DEV as __DEV__ };","export var version = \"3.12.6\";","\"use strict\";\n\nexports.__esModule = true;\nvar _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n};\nvar getLocation = function getLocation(source) {\n var _source$location = source.location,\n search = _source$location.search,\n hash = _source$location.hash,\n href = _source$location.href,\n origin = _source$location.origin,\n protocol = _source$location.protocol,\n host = _source$location.host,\n hostname = _source$location.hostname,\n port = _source$location.port;\n var pathname = source.location.pathname;\n if (!pathname && href && canUseDOM) {\n var url = new URL(href);\n pathname = url.pathname;\n }\n return {\n pathname: encodeURI(decodeURI(pathname)),\n search: search,\n hash: hash,\n href: href,\n origin: origin,\n protocol: protocol,\n host: host,\n hostname: hostname,\n port: port,\n state: source.history.state,\n key: source.history.state && source.history.state.key || \"initial\"\n };\n};\nvar createHistory = function createHistory(source, options) {\n var listeners = [];\n var location = getLocation(source);\n var transitioning = false;\n var resolveTransition = function resolveTransition() {};\n return {\n get location() {\n return location;\n },\n get transitioning() {\n return transitioning;\n },\n _onTransitionComplete: function _onTransitionComplete() {\n transitioning = false;\n resolveTransition();\n },\n listen: function listen(listener) {\n listeners.push(listener);\n var popstateListener = function popstateListener() {\n location = getLocation(source);\n listener({\n location: location,\n action: \"POP\"\n });\n };\n source.addEventListener(\"popstate\", popstateListener);\n return function () {\n source.removeEventListener(\"popstate\", popstateListener);\n listeners = listeners.filter(function (fn) {\n return fn !== listener;\n });\n };\n },\n navigate: function navigate(to) {\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n state = _ref.state,\n _ref$replace = _ref.replace,\n replace = _ref$replace === undefined ? false : _ref$replace;\n if (typeof to === \"number\") {\n source.history.go(to);\n } else {\n state = _extends({}, state, {\n key: Date.now() + \"\"\n });\n // try...catch iOS Safari limits to 100 pushState calls\n try {\n if (transitioning || replace) {\n source.history.replaceState(state, null, to);\n } else {\n source.history.pushState(state, null, to);\n }\n } catch (e) {\n source.location[replace ? \"replace\" : \"assign\"](to);\n }\n }\n location = getLocation(source);\n transitioning = true;\n var transition = new Promise(function (res) {\n return resolveTransition = res;\n });\n listeners.forEach(function (listener) {\n return listener({\n location: location,\n action: \"PUSH\"\n });\n });\n return transition;\n }\n };\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// Stores history entries in memory for testing or other platforms like Native\nvar createMemorySource = function createMemorySource() {\n var initialPath = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : \"/\";\n var searchIndex = initialPath.indexOf(\"?\");\n var initialLocation = {\n pathname: searchIndex > -1 ? initialPath.substr(0, searchIndex) : initialPath,\n search: searchIndex > -1 ? initialPath.substr(searchIndex) : \"\"\n };\n var index = 0;\n var stack = [initialLocation];\n var states = [null];\n return {\n get location() {\n return stack[index];\n },\n addEventListener: function addEventListener(name, fn) {},\n removeEventListener: function removeEventListener(name, fn) {},\n history: {\n get entries() {\n return stack;\n },\n get index() {\n return index;\n },\n get state() {\n return states[index];\n },\n pushState: function pushState(state, _, uri) {\n var _uri$split = uri.split(\"?\"),\n pathname = _uri$split[0],\n _uri$split$ = _uri$split[1],\n search = _uri$split$ === undefined ? \"\" : _uri$split$;\n index++;\n stack.push({\n pathname: pathname,\n search: search.length ? \"?\" + search : search\n });\n states.push(state);\n },\n replaceState: function replaceState(state, _, uri) {\n var _uri$split2 = uri.split(\"?\"),\n pathname = _uri$split2[0],\n _uri$split2$ = _uri$split2[1],\n search = _uri$split2$ === undefined ? \"\" : _uri$split2$;\n stack[index] = {\n pathname: pathname,\n search: search\n };\n states[index] = state;\n },\n go: function go(to) {\n var newIndex = index + to;\n if (newIndex < 0 || newIndex > states.length - 1) {\n return;\n }\n index = newIndex;\n }\n }\n };\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// global history - uses window.history as the source if available, otherwise a\n// memory history\nvar canUseDOM = !!(typeof window !== \"undefined\" && window.document && window.document.createElement);\nvar getSource = function getSource() {\n return canUseDOM ? window : createMemorySource();\n};\nvar globalHistory = createHistory(getSource());\nvar navigate = globalHistory.navigate;\n\n////////////////////////////////////////////////////////////////////////////////\n\nexports.globalHistory = globalHistory;\nexports.navigate = navigate;\nexports.createHistory = createHistory;\nexports.createMemorySource = createMemorySource;","\"use strict\";\n\nexports.__esModule = true;\nexports.shallowCompare = exports.validateRedirect = exports.insertParams = exports.resolve = exports.match = exports.pick = exports.startsWith = undefined;\nvar _invariant = require(\"invariant\");\nvar _invariant2 = _interopRequireDefault(_invariant);\nfunction _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n}\n\n////////////////////////////////////////////////////////////////////////////////\n// startsWith(string, search) - Check if `string` starts with `search`\nvar startsWith = function startsWith(string, search) {\n return string.substr(0, search.length) === search;\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// pick(routes, uri)\n//\n// Ranks and picks the best route to match. Each segment gets the highest\n// amount of points, then the type of segment gets an additional amount of\n// points where\n//\n// static > dynamic > splat > root\n//\n// This way we don't have to worry about the order of our routes, let the\n// computers do it.\n//\n// A route looks like this\n//\n// { path, default, value }\n//\n// And a returned match looks like:\n//\n// { route, params, uri }\n//\n// I know, I should use TypeScript not comments for these types.\nvar pick = function pick(routes, uri) {\n var match = void 0;\n var default_ = void 0;\n var _uri$split = uri.split(\"?\"),\n uriPathname = _uri$split[0];\n var uriSegments = segmentize(uriPathname);\n var isRootUri = uriSegments[0] === \"\";\n var ranked = rankRoutes(routes);\n for (var i = 0, l = ranked.length; i < l; i++) {\n var missed = false;\n var route = ranked[i].route;\n if (route.default) {\n default_ = {\n route: route,\n params: {},\n uri: uri\n };\n continue;\n }\n var routeSegments = segmentize(route.path);\n var params = {};\n var max = Math.max(uriSegments.length, routeSegments.length);\n var index = 0;\n for (; index < max; index++) {\n var routeSegment = routeSegments[index];\n var uriSegment = uriSegments[index];\n if (isSplat(routeSegment)) {\n // Hit a splat, just grab the rest, and return a match\n // uri: /files/documents/work\n // route: /files/*\n var param = routeSegment.slice(1) || \"*\";\n params[param] = uriSegments.slice(index).map(decodeURIComponent).join(\"/\");\n break;\n }\n if (uriSegment === undefined) {\n // URI is shorter than the route, no match\n // uri: /users\n // route: /users/:userId\n missed = true;\n break;\n }\n var dynamicMatch = paramRe.exec(routeSegment);\n if (dynamicMatch && !isRootUri) {\n var matchIsNotReserved = reservedNames.indexOf(dynamicMatch[1]) === -1;\n !matchIsNotReserved ? process.env.NODE_ENV !== \"production\" ? (0, _invariant2.default)(false, \" dynamic segment \\\"\" + dynamicMatch[1] + \"\\\" is a reserved name. Please use a different name in path \\\"\" + route.path + \"\\\".\") : (0, _invariant2.default)(false) : void 0;\n var value = decodeURIComponent(uriSegment);\n params[dynamicMatch[1]] = value;\n } else if (routeSegment !== uriSegment) {\n // Current segments don't match, not dynamic, not splat, so no match\n // uri: /users/123/settings\n // route: /users/:id/profile\n missed = true;\n break;\n }\n }\n if (!missed) {\n match = {\n route: route,\n params: params,\n uri: \"/\" + uriSegments.slice(0, index).join(\"/\")\n };\n break;\n }\n }\n return match || default_ || null;\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// match(path, uri) - Matches just one path to a uri, also lol\nvar match = function match(path, uri) {\n return pick([{\n path: path\n }], uri);\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// resolve(to, basepath)\n//\n// Resolves URIs as though every path is a directory, no files. Relative URIs\n// in the browser can feel awkward because not only can you be \"in a directory\"\n// you can be \"at a file\", too. For example\n//\n// browserSpecResolve('foo', '/bar/') => /bar/foo\n// browserSpecResolve('foo', '/bar') => /foo\n//\n// But on the command line of a file system, it's not as complicated, you can't\n// `cd` from a file, only directories. This way, links have to know less about\n// their current path. To go deeper you can do this:\n//\n// \n// // instead of\n// \n//\n// Just like `cd`, if you want to go deeper from the command line, you do this:\n//\n// cd deeper\n// # not\n// cd $(pwd)/deeper\n//\n// By treating every path as a directory, linking to relative paths should\n// require less contextual information and (fingers crossed) be more intuitive.\nvar resolve = function resolve(to, base) {\n // /foo/bar, /baz/qux => /foo/bar\n if (startsWith(to, \"/\")) {\n return to;\n }\n var _to$split = to.split(\"?\"),\n toPathname = _to$split[0],\n toQuery = _to$split[1];\n var _base$split = base.split(\"?\"),\n basePathname = _base$split[0];\n var toSegments = segmentize(toPathname);\n var baseSegments = segmentize(basePathname);\n\n // ?a=b, /users?b=c => /users?a=b\n if (toSegments[0] === \"\") {\n return addQuery(basePathname, toQuery);\n }\n\n // profile, /users/789 => /users/789/profile\n if (!startsWith(toSegments[0], \".\")) {\n var pathname = baseSegments.concat(toSegments).join(\"/\");\n return addQuery((basePathname === \"/\" ? \"\" : \"/\") + pathname, toQuery);\n }\n\n // ./ /users/123 => /users/123\n // ../ /users/123 => /users\n // ../.. /users/123 => /\n // ../../one /a/b/c/d => /a/b/one\n // .././one /a/b/c/d => /a/b/c/one\n var allSegments = baseSegments.concat(toSegments);\n var segments = [];\n for (var i = 0, l = allSegments.length; i < l; i++) {\n var segment = allSegments[i];\n if (segment === \"..\") segments.pop();else if (segment !== \".\") segments.push(segment);\n }\n return addQuery(\"/\" + segments.join(\"/\"), toQuery);\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// insertParams(path, params)\n\nvar insertParams = function insertParams(path, params) {\n var _path$split = path.split(\"?\"),\n pathBase = _path$split[0],\n _path$split$ = _path$split[1],\n query = _path$split$ === undefined ? \"\" : _path$split$;\n var segments = segmentize(pathBase);\n var constructedPath = \"/\" + segments.map(function (segment) {\n var match = paramRe.exec(segment);\n return match ? params[match[1]] : segment;\n }).join(\"/\");\n var _params$location = params.location;\n _params$location = _params$location === undefined ? {} : _params$location;\n var _params$location$sear = _params$location.search,\n search = _params$location$sear === undefined ? \"\" : _params$location$sear;\n var searchSplit = search.split(\"?\")[1] || \"\";\n constructedPath = addQuery(constructedPath, query, searchSplit);\n return constructedPath;\n};\nvar validateRedirect = function validateRedirect(from, to) {\n var filter = function filter(segment) {\n return isDynamic(segment);\n };\n var fromString = segmentize(from).filter(filter).sort().join(\"/\");\n var toString = segmentize(to).filter(filter).sort().join(\"/\");\n return fromString === toString;\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// Junk\nvar paramRe = /^:(.+)/;\nvar SEGMENT_POINTS = 4;\nvar STATIC_POINTS = 3;\nvar DYNAMIC_POINTS = 2;\nvar SPLAT_PENALTY = 1;\nvar ROOT_POINTS = 1;\nvar isRootSegment = function isRootSegment(segment) {\n return segment === \"\";\n};\nvar isDynamic = function isDynamic(segment) {\n return paramRe.test(segment);\n};\nvar isSplat = function isSplat(segment) {\n return segment && segment[0] === \"*\";\n};\nvar rankRoute = function rankRoute(route, index) {\n var score = route.default ? 0 : segmentize(route.path).reduce(function (score, segment) {\n score += SEGMENT_POINTS;\n if (isRootSegment(segment)) score += ROOT_POINTS;else if (isDynamic(segment)) score += DYNAMIC_POINTS;else if (isSplat(segment)) score -= SEGMENT_POINTS + SPLAT_PENALTY;else score += STATIC_POINTS;\n return score;\n }, 0);\n return {\n route: route,\n score: score,\n index: index\n };\n};\nvar rankRoutes = function rankRoutes(routes) {\n return routes.map(rankRoute).sort(function (a, b) {\n return a.score < b.score ? 1 : a.score > b.score ? -1 : a.index - b.index;\n });\n};\nvar segmentize = function segmentize(uri) {\n return uri\n // strip starting/ending slashes\n .replace(/(^\\/+|\\/+$)/g, \"\").split(\"/\");\n};\nvar addQuery = function addQuery(pathname) {\n for (var _len = arguments.length, query = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n query[_key - 1] = arguments[_key];\n }\n query = query.filter(function (q) {\n return q && q.length > 0;\n });\n return pathname + (query && query.length > 0 ? \"?\" + query.join(\"&\") : \"\");\n};\nvar reservedNames = [\"uri\", \"path\"];\n\n/**\n * Shallow compares two objects.\n * @param {Object} obj1 The first object to compare.\n * @param {Object} obj2 The second object to compare.\n */\nvar shallowCompare = function shallowCompare(obj1, obj2) {\n var obj1Keys = Object.keys(obj1);\n return obj1Keys.length === Object.keys(obj2).length && obj1Keys.every(function (key) {\n return obj2.hasOwnProperty(key) && obj1[key] === obj2[key];\n });\n};\n\n////////////////////////////////////////////////////////////////////////////////\nexports.startsWith = startsWith;\nexports.pick = pick;\nexports.match = match;\nexports.resolve = resolve;\nexports.insertParams = insertParams;\nexports.validateRedirect = validateRedirect;\nexports.shallowCompare = shallowCompare;","function defaultDispose() {}\nexport class StrongCache {\n constructor() {\n let max = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : Infinity;\n let dispose = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultDispose;\n this.max = max;\n this.dispose = dispose;\n this.map = new Map();\n this.newest = null;\n this.oldest = null;\n }\n has(key) {\n return this.map.has(key);\n }\n get(key) {\n const node = this.getNode(key);\n return node && node.value;\n }\n get size() {\n return this.map.size;\n }\n getNode(key) {\n const node = this.map.get(key);\n if (node && node !== this.newest) {\n const {\n older,\n newer\n } = node;\n if (newer) {\n newer.older = older;\n }\n if (older) {\n older.newer = newer;\n }\n node.older = this.newest;\n node.older.newer = node;\n node.newer = null;\n this.newest = node;\n if (node === this.oldest) {\n this.oldest = newer;\n }\n }\n return node;\n }\n set(key, value) {\n let node = this.getNode(key);\n if (node) {\n return node.value = value;\n }\n node = {\n key,\n value,\n newer: null,\n older: this.newest\n };\n if (this.newest) {\n this.newest.newer = node;\n }\n this.newest = node;\n this.oldest = this.oldest || node;\n this.map.set(key, node);\n return node.value;\n }\n clean() {\n while (this.oldest && this.map.size > this.max) {\n this.delete(this.oldest.key);\n }\n }\n delete(key) {\n const node = this.map.get(key);\n if (node) {\n if (node === this.newest) {\n this.newest = node.older;\n }\n if (node === this.oldest) {\n this.oldest = node.newer;\n }\n if (node.newer) {\n node.newer.older = node.older;\n }\n if (node.older) {\n node.older.newer = node.newer;\n }\n this.map.delete(key);\n this.dispose(node.value, key);\n return true;\n }\n return false;\n }\n}","function noop() {}\nconst defaultDispose = noop;\nconst _WeakRef = typeof WeakRef !== \"undefined\" ? WeakRef : function (value) {\n return {\n deref: () => value\n };\n};\nconst _WeakMap = typeof WeakMap !== \"undefined\" ? WeakMap : Map;\nconst _FinalizationRegistry = typeof FinalizationRegistry !== \"undefined\" ? FinalizationRegistry : function () {\n return {\n register: noop,\n unregister: noop\n };\n};\nconst finalizationBatchSize = 10024;\nexport class WeakCache {\n constructor() {\n let max = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : Infinity;\n let dispose = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultDispose;\n this.max = max;\n this.dispose = dispose;\n this.map = new _WeakMap();\n this.newest = null;\n this.oldest = null;\n this.unfinalizedNodes = new Set();\n this.finalizationScheduled = false;\n this.size = 0;\n this.finalize = () => {\n const iterator = this.unfinalizedNodes.values();\n for (let i = 0; i < finalizationBatchSize; i++) {\n const node = iterator.next().value;\n if (!node) break;\n this.unfinalizedNodes.delete(node);\n const key = node.key;\n delete node.key;\n node.keyRef = new _WeakRef(key);\n this.registry.register(key, node, node);\n }\n if (this.unfinalizedNodes.size > 0) {\n queueMicrotask(this.finalize);\n } else {\n this.finalizationScheduled = false;\n }\n };\n this.registry = new _FinalizationRegistry(this.deleteNode.bind(this));\n }\n has(key) {\n return this.map.has(key);\n }\n get(key) {\n const node = this.getNode(key);\n return node && node.value;\n }\n getNode(key) {\n const node = this.map.get(key);\n if (node && node !== this.newest) {\n const {\n older,\n newer\n } = node;\n if (newer) {\n newer.older = older;\n }\n if (older) {\n older.newer = newer;\n }\n node.older = this.newest;\n node.older.newer = node;\n node.newer = null;\n this.newest = node;\n if (node === this.oldest) {\n this.oldest = newer;\n }\n }\n return node;\n }\n set(key, value) {\n let node = this.getNode(key);\n if (node) {\n return node.value = value;\n }\n node = {\n key,\n value,\n newer: null,\n older: this.newest\n };\n if (this.newest) {\n this.newest.newer = node;\n }\n this.newest = node;\n this.oldest = this.oldest || node;\n this.scheduleFinalization(node);\n this.map.set(key, node);\n this.size++;\n return node.value;\n }\n clean() {\n while (this.oldest && this.size > this.max) {\n this.deleteNode(this.oldest);\n }\n }\n deleteNode(node) {\n if (node === this.newest) {\n this.newest = node.older;\n }\n if (node === this.oldest) {\n this.oldest = node.newer;\n }\n if (node.newer) {\n node.newer.older = node.older;\n }\n if (node.older) {\n node.older.newer = node.newer;\n }\n this.size--;\n const key = node.key || node.keyRef && node.keyRef.deref();\n this.dispose(node.value, key);\n if (!node.keyRef) {\n this.unfinalizedNodes.delete(node);\n } else {\n this.registry.unregister(node);\n }\n if (key) this.map.delete(key);\n }\n delete(key) {\n const node = this.map.get(key);\n if (node) {\n this.deleteNode(node);\n return true;\n }\n return false;\n }\n scheduleFinalization(node) {\n this.unfinalizedNodes.add(node);\n if (!this.finalizationScheduled) {\n this.finalizationScheduled = true;\n queueMicrotask(this.finalize);\n }\n }\n}","const {\n toString,\n hasOwnProperty\n} = Object.prototype;\nconst fnToStr = Function.prototype.toString;\nconst previousComparisons = new Map();\n/**\n * Performs a deep equality check on two JavaScript values, tolerating cycles.\n */\nexport function equal(a, b) {\n try {\n return check(a, b);\n } finally {\n previousComparisons.clear();\n }\n}\n// Allow default imports as well.\nexport default equal;\nfunction check(a, b) {\n // If the two values are strictly equal, our job is easy.\n if (a === b) {\n return true;\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 // 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 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 {\n if (previouslyCompared(a, b)) return true;\n const aKeys = definedKeys(a);\n const bKeys = definedKeys(b);\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 // 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 // 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 return true;\n }\n case '[object Error]':\n return a.name === b.name && a.message === b.message;\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 case '[object RegExp]':\n case '[object String]':\n return a == `${b}`;\n case '[object Map]':\n case '[object Set]':\n {\n if (a.size !== b.size) return false;\n if (previouslyCompared(a, b)) return true;\n const aIterator = a.entries();\n const isMap = aTag === '[object Map]';\n while (true) {\n const info = aIterator.next();\n if (info.done) break;\n // If a instanceof Set, aValue === aKey.\n const [aKey, aValue] = info.value;\n // So this works the same way for both Set and Map.\n if (!b.has(aKey)) {\n return false;\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 return true;\n }\n case '[object Uint16Array]':\n case '[object Uint8Array]': // Buffer, in Node.js.\n case '[object Uint32Array]':\n case '[object Int32Array]':\n case '[object Int8Array]':\n case '[object Int16Array]':\n case '[object ArrayBuffer]':\n // DataView doesn't need these conversions, but the equality check is\n // otherwise the same.\n a = new Uint8Array(a);\n b = new Uint8Array(b);\n // Fall through...\n case '[object DataView]':\n {\n let len = a.byteLength;\n if (len === b.byteLength) {\n while (len-- && a[len] === b[len]) {\n // Keep looping as long as the bytes are equal.\n }\n }\n return len === -1;\n }\n case '[object AsyncFunction]':\n case '[object GeneratorFunction]':\n case '[object AsyncGeneratorFunction]':\n case '[object Function]':\n {\n const aCode = fnToStr.call(a);\n if (aCode !== fnToStr.call(b)) {\n return false;\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 // Otherwise the values are not equal.\n return false;\n}\nfunction definedKeys(obj) {\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(key) {\n return this[key] !== void 0;\n}\nconst nativeCodeSuffix = \"{ [native code] }\";\nfunction endsWith(full, suffix) {\n const fromIndex = full.length - suffix.length;\n return fromIndex >= 0 && full.indexOf(suffix, fromIndex) === fromIndex;\n}\nfunction previouslyCompared(a, b) {\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}","module.exports = {\n \"default\": require(\"core-js/library/fn/object/assign\"),\n __esModule: true\n};","\"use strict\";\n\nexports.__esModule = true;\nvar _assign = require(\"../core-js/object/assign\");\nvar _assign2 = _interopRequireDefault(_assign);\nfunction _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n default: obj\n };\n}\nexports.default = _assign2.default || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n};","'use strict';\n\nconst preserveCamelCase = string => {\n let isLastCharLower = false;\n let isLastCharUpper = false;\n let isLastLastCharUpper = false;\n for (let i = 0; i < string.length; i++) {\n const character = string[i];\n if (isLastCharLower && /[a-zA-Z]/.test(character) && character.toUpperCase() === character) {\n string = string.slice(0, i) + '-' + string.slice(i);\n isLastCharLower = false;\n isLastLastCharUpper = isLastCharUpper;\n isLastCharUpper = true;\n i++;\n } else if (isLastCharUpper && isLastLastCharUpper && /[a-zA-Z]/.test(character) && character.toLowerCase() === character) {\n string = string.slice(0, i - 1) + '-' + string.slice(i - 1);\n isLastLastCharUpper = isLastCharUpper;\n isLastCharUpper = false;\n isLastCharLower = true;\n } else {\n isLastCharLower = character.toLowerCase() === character && character.toUpperCase() !== character;\n isLastLastCharUpper = isLastCharUpper;\n isLastCharUpper = character.toUpperCase() === character && character.toLowerCase() !== character;\n }\n }\n return string;\n};\nconst camelCase = (input, options) => {\n if (!(typeof input === 'string' || Array.isArray(input))) {\n throw new TypeError('Expected the input to be `string | string[]`');\n }\n options = Object.assign({\n pascalCase: false\n }, options);\n const postProcess = x => options.pascalCase ? x.charAt(0).toUpperCase() + x.slice(1) : x;\n if (Array.isArray(input)) {\n input = input.map(x => x.trim()).filter(x => x.length).join('-');\n } else {\n input = input.trim();\n }\n if (input.length === 0) {\n return '';\n }\n if (input.length === 1) {\n return options.pascalCase ? input.toUpperCase() : input.toLowerCase();\n }\n const hasUpperCase = input !== input.toLowerCase();\n if (hasUpperCase) {\n input = preserveCamelCase(input);\n }\n input = input.replace(/^[_.\\- ]+/, '').toLowerCase().replace(/[_.\\- ]+(\\w|$)/g, (_, p1) => p1.toUpperCase()).replace(/\\d+(\\w|$)/g, m => m.toUpperCase());\n return postProcess(input);\n};\nmodule.exports = camelCase;\n// TODO: Remove this for the next major release\nmodule.exports.default = camelCase;","var _createClass = function () {\n function defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n }\n return function (Constructor, protoProps, staticProps) {\n if (protoProps) defineProperties(Constructor.prototype, protoProps);\n if (staticProps) defineProperties(Constructor, staticProps);\n return Constructor;\n };\n}();\nvar _templateObject = _taggedTemplateLiteral(['', ''], ['', '']);\nfunction _taggedTemplateLiteral(strings, raw) {\n return Object.freeze(Object.defineProperties(strings, {\n raw: {\n value: Object.freeze(raw)\n }\n }));\n}\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\n/**\n * @class TemplateTag\n * @classdesc Consumes a pipeline of composable transformer plugins and produces a template tag.\n */\nvar TemplateTag = function () {\n /**\n * constructs a template tag\n * @constructs TemplateTag\n * @param {...Object} [...transformers] - an array or arguments list of transformers\n * @return {Function} - a template tag\n */\n function TemplateTag() {\n var _this = this;\n for (var _len = arguments.length, transformers = Array(_len), _key = 0; _key < _len; _key++) {\n transformers[_key] = arguments[_key];\n }\n _classCallCheck(this, TemplateTag);\n this.tag = function (strings) {\n for (var _len2 = arguments.length, expressions = Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n expressions[_key2 - 1] = arguments[_key2];\n }\n if (typeof strings === 'function') {\n // if the first argument passed is a function, assume it is a template tag and return\n // an intermediary tag that processes the template using the aforementioned tag, passing the\n // result to our tag\n return _this.interimTag.bind(_this, strings);\n }\n if (typeof strings === 'string') {\n // if the first argument passed is a string, just transform it\n return _this.transformEndResult(strings);\n }\n\n // else, return a transformed end result of processing the template with our tag\n strings = strings.map(_this.transformString.bind(_this));\n return _this.transformEndResult(strings.reduce(_this.processSubstitutions.bind(_this, expressions)));\n };\n\n // if first argument is an array, extrude it as a list of transformers\n if (transformers.length > 0 && Array.isArray(transformers[0])) {\n transformers = transformers[0];\n }\n\n // if any transformers are functions, this means they are not initiated - automatically initiate them\n this.transformers = transformers.map(function (transformer) {\n return typeof transformer === 'function' ? transformer() : transformer;\n });\n\n // return an ES2015 template tag\n return this.tag;\n }\n\n /**\n * Applies all transformers to a template literal tagged with this method.\n * If a function is passed as the first argument, assumes the function is a template tag\n * and applies it to the template, returning a template tag.\n * @param {(Function|String|Array)} strings - Either a template tag or an array containing template strings separated by identifier\n * @param {...*} ...expressions - Optional list of substitution values.\n * @return {(String|Function)} - Either an intermediary tag function or the results of processing the template.\n */\n\n _createClass(TemplateTag, [{\n key: 'interimTag',\n /**\n * An intermediary template tag that receives a template tag and passes the result of calling the template with the received\n * template tag to our own template tag.\n * @param {Function} nextTag - the received template tag\n * @param {Array} template - the template to process\n * @param {...*} ...substitutions - `substitutions` is an array of all substitutions in the template\n * @return {*} - the final processed value\n */\n value: function interimTag(previousTag, template) {\n for (var _len3 = arguments.length, substitutions = Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) {\n substitutions[_key3 - 2] = arguments[_key3];\n }\n return this.tag(_templateObject, previousTag.apply(undefined, [template].concat(substitutions)));\n }\n\n /**\n * Performs bulk processing on the tagged template, transforming each substitution and then\n * concatenating the resulting values into a string.\n * @param {Array<*>} substitutions - an array of all remaining substitutions present in this template\n * @param {String} resultSoFar - this iteration's result string so far\n * @param {String} remainingPart - the template chunk after the current substitution\n * @return {String} - the result of joining this iteration's processed substitution with the result\n */\n }, {\n key: 'processSubstitutions',\n value: function processSubstitutions(substitutions, resultSoFar, remainingPart) {\n var substitution = this.transformSubstitution(substitutions.shift(), resultSoFar);\n return ''.concat(resultSoFar, substitution, remainingPart);\n }\n\n /**\n * Iterate through each transformer, applying the transformer's `onString` method to the template\n * strings before all substitutions are processed.\n * @param {String} str - The input string\n * @return {String} - The final results of processing each transformer\n */\n }, {\n key: 'transformString',\n value: function transformString(str) {\n var cb = function cb(res, transform) {\n return transform.onString ? transform.onString(res) : res;\n };\n return this.transformers.reduce(cb, str);\n }\n\n /**\n * When a substitution is encountered, iterates through each transformer and applies the transformer's\n * `onSubstitution` method to the substitution.\n * @param {*} substitution - The current substitution\n * @param {String} resultSoFar - The result up to and excluding this substitution.\n * @return {*} - The final result of applying all substitution transformations.\n */\n }, {\n key: 'transformSubstitution',\n value: function transformSubstitution(substitution, resultSoFar) {\n var cb = function cb(res, transform) {\n return transform.onSubstitution ? transform.onSubstitution(res, resultSoFar) : res;\n };\n return this.transformers.reduce(cb, substitution);\n }\n\n /**\n * Iterates through each transformer, applying the transformer's `onEndResult` method to the\n * template literal after all substitutions have finished processing.\n * @param {String} endResult - The processed template, just before it is returned from the tag\n * @return {String} - The final results of processing each transformer\n */\n }, {\n key: 'transformEndResult',\n value: function transformEndResult(endResult) {\n var cb = function cb(res, transform) {\n return transform.onEndResult ? transform.onEndResult(res) : res;\n };\n return this.transformers.reduce(cb, endResult);\n }\n }]);\n return TemplateTag;\n}();\nexport default TemplateTag;","var defaults = {\n separator: '',\n conjunction: '',\n serial: false\n};\n\n/**\n * Converts an array substitution to a string containing a list\n * @param {String} [opts.separator = ''] - the character that separates each item\n * @param {String} [opts.conjunction = ''] - replace the last separator with this\n * @param {Boolean} [opts.serial = false] - include the separator before the conjunction? (Oxford comma use-case)\n *\n * @return {Object} - a TemplateTag transformer\n */\nvar inlineArrayTransformer = function inlineArrayTransformer() {\n var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : defaults;\n return {\n onSubstitution: function onSubstitution(substitution, resultSoFar) {\n // only operate on arrays\n if (Array.isArray(substitution)) {\n var arrayLength = substitution.length;\n var separator = opts.separator;\n var conjunction = opts.conjunction;\n var serial = opts.serial;\n // join each item in the array into a string where each item is separated by separator\n // be sure to maintain indentation\n var indent = resultSoFar.match(/(\\n?[^\\S\\n]+)$/);\n if (indent) {\n substitution = substitution.join(separator + indent[1]);\n } else {\n substitution = substitution.join(separator + ' ');\n }\n // if conjunction is set, replace the last separator with conjunction, but only if there is more than one substitution\n if (conjunction && arrayLength > 1) {\n var separatorIndex = substitution.lastIndexOf(separator);\n substitution = substitution.slice(0, separatorIndex) + (serial ? separator : '') + ' ' + conjunction + substitution.slice(separatorIndex + 1);\n }\n }\n return substitution;\n }\n };\n};\nexport default inlineArrayTransformer;","function _toConsumableArray(arr) {\n if (Array.isArray(arr)) {\n for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) {\n arr2[i] = arr[i];\n }\n return arr2;\n } else {\n return Array.from(arr);\n }\n}\n\n/**\n * strips indentation from a template literal\n * @param {String} type = 'initial' - whether to remove all indentation or just leading indentation. can be 'all' or 'initial'\n * @return {Object} - a TemplateTag transformer\n */\nvar stripIndentTransformer = function stripIndentTransformer() {\n var type = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'initial';\n return {\n onEndResult: function onEndResult(endResult) {\n if (type === 'initial') {\n // remove the shortest leading indentation from each line\n var match = endResult.match(/^[^\\S\\n]*(?=\\S)/gm);\n var indent = match && Math.min.apply(Math, _toConsumableArray(match.map(function (el) {\n return el.length;\n })));\n if (indent) {\n var regexp = new RegExp('^.{' + indent + '}', 'gm');\n return endResult.replace(regexp, '');\n }\n return endResult;\n }\n if (type === 'all') {\n // remove all indentation from each line\n return endResult.replace(/^[^\\S\\n]+/gm, '');\n }\n throw new Error('Unknown type: ' + type);\n }\n };\n};\nexport default stripIndentTransformer;","/**\n * TemplateTag transformer that trims whitespace on the end result of a tagged template\n * @param {String} side = '' - The side of the string to trim. Can be 'start' or 'end' (alternatively 'left' or 'right')\n * @return {Object} - a TemplateTag transformer\n */\nvar trimResultTransformer = function trimResultTransformer() {\n var side = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';\n return {\n onEndResult: function onEndResult(endResult) {\n if (side === '') {\n return endResult.trim();\n }\n side = side.toLowerCase();\n if (side === 'start' || side === 'left') {\n return endResult.replace(/^\\s*/, '');\n }\n if (side === 'end' || side === 'right') {\n return endResult.replace(/\\s*$/, '');\n }\n throw new Error('Side not supported: ' + side);\n }\n };\n};\nexport default trimResultTransformer;","var splitStringTransformer = function splitStringTransformer(splitBy) {\n return {\n onSubstitution: function onSubstitution(substitution, resultSoFar) {\n if (splitBy != null && typeof splitBy === 'string') {\n if (typeof substitution === 'string' && substitution.includes(splitBy)) {\n substitution = substitution.split(splitBy);\n }\n } else {\n throw new Error('You need to specify a string character to split by.');\n }\n return substitution;\n }\n };\n};\nexport default splitStringTransformer;","import TemplateTag from '../TemplateTag';\nimport stripIndentTransformer from '../stripIndentTransformer';\nimport inlineArrayTransformer from '../inlineArrayTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nvar commaLists = new TemplateTag(inlineArrayTransformer({\n separator: ','\n}), stripIndentTransformer, trimResultTransformer);\nexport default commaLists;","import TemplateTag from '../TemplateTag';\nimport stripIndentTransformer from '../stripIndentTransformer';\nimport inlineArrayTransformer from '../inlineArrayTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nvar commaListsAnd = new TemplateTag(inlineArrayTransformer({\n separator: ',',\n conjunction: 'and'\n}), stripIndentTransformer, trimResultTransformer);\nexport default commaListsAnd;","import TemplateTag from '../TemplateTag';\nimport stripIndentTransformer from '../stripIndentTransformer';\nimport inlineArrayTransformer from '../inlineArrayTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nvar commaListsOr = new TemplateTag(inlineArrayTransformer({\n separator: ',',\n conjunction: 'or'\n}), stripIndentTransformer, trimResultTransformer);\nexport default commaListsOr;","var isValidValue = function isValidValue(x) {\n return x != null && !Number.isNaN(x) && typeof x !== 'boolean';\n};\nvar removeNonPrintingValuesTransformer = function removeNonPrintingValuesTransformer() {\n return {\n onSubstitution: function onSubstitution(substitution) {\n if (Array.isArray(substitution)) {\n return substitution.filter(isValidValue);\n }\n if (isValidValue(substitution)) {\n return substitution;\n }\n return '';\n }\n };\n};\nexport default removeNonPrintingValuesTransformer;","var replaceSubstitutionTransformer = function replaceSubstitutionTransformer(replaceWhat, replaceWith) {\n return {\n onSubstitution: function onSubstitution(substitution, resultSoFar) {\n if (replaceWhat == null || replaceWith == null) {\n throw new Error('replaceSubstitutionTransformer requires at least 2 arguments.');\n }\n\n // Do not touch if null or undefined\n if (substitution == null) {\n return substitution;\n } else {\n return substitution.toString().replace(replaceWhat, replaceWith);\n }\n }\n };\n};\nexport default replaceSubstitutionTransformer;","import TemplateTag from '../TemplateTag';\nimport stripIndentTransformer from '../stripIndentTransformer';\nimport inlineArrayTransformer from '../inlineArrayTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nimport splitStringTransformer from '../splitStringTransformer';\nimport removeNonPrintingValuesTransformer from '../removeNonPrintingValuesTransformer';\nvar html = new TemplateTag(splitStringTransformer('\\n'), removeNonPrintingValuesTransformer, inlineArrayTransformer, stripIndentTransformer, trimResultTransformer);\nexport default html;","/**\n * Replaces tabs, newlines and spaces with the chosen value when they occur in sequences\n * @param {(String|RegExp)} replaceWhat - the value or pattern that should be replaced\n * @param {*} replaceWith - the replacement value\n * @return {Object} - a TemplateTag transformer\n */\nvar replaceResultTransformer = function replaceResultTransformer(replaceWhat, replaceWith) {\n return {\n onEndResult: function onEndResult(endResult) {\n if (replaceWhat == null || replaceWith == null) {\n throw new Error('replaceResultTransformer requires at least 2 arguments.');\n }\n return endResult.replace(replaceWhat, replaceWith);\n }\n };\n};\nexport default replaceResultTransformer;","import TemplateTag from '../TemplateTag';\nimport stripIndentTransformer from '../stripIndentTransformer';\nimport inlineArrayTransformer from '../inlineArrayTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nimport splitStringTransformer from '../splitStringTransformer';\nimport replaceSubstitutionTransformer from '../replaceSubstitutionTransformer';\nvar safeHtml = new TemplateTag(splitStringTransformer('\\n'), inlineArrayTransformer, stripIndentTransformer, trimResultTransformer, replaceSubstitutionTransformer(/&/g, '&'), replaceSubstitutionTransformer(//g, '>'), replaceSubstitutionTransformer(/\"/g, '"'), replaceSubstitutionTransformer(/'/g, '''), replaceSubstitutionTransformer(/`/g, '`'));\nexport default safeHtml;","import TemplateTag from '../TemplateTag';\nimport trimResultTransformer from '../trimResultTransformer';\nimport replaceResultTransformer from '../replaceResultTransformer';\nvar oneLine = new TemplateTag(replaceResultTransformer(/(?:\\n(?:\\s*))+/g, ' '), trimResultTransformer);\nexport default oneLine;","import TemplateTag from '../TemplateTag';\nimport trimResultTransformer from '../trimResultTransformer';\nimport replaceResultTransformer from '../replaceResultTransformer';\nvar oneLineTrim = new TemplateTag(replaceResultTransformer(/(?:\\n\\s*)/g, ''), trimResultTransformer);\nexport default oneLineTrim;","import TemplateTag from '../TemplateTag';\nimport inlineArrayTransformer from '../inlineArrayTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nimport replaceResultTransformer from '../replaceResultTransformer';\nvar oneLineCommaLists = new TemplateTag(inlineArrayTransformer({\n separator: ','\n}), replaceResultTransformer(/(?:\\s+)/g, ' '), trimResultTransformer);\nexport default oneLineCommaLists;","import TemplateTag from '../TemplateTag';\nimport inlineArrayTransformer from '../inlineArrayTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nimport replaceResultTransformer from '../replaceResultTransformer';\nvar oneLineCommaListsOr = new TemplateTag(inlineArrayTransformer({\n separator: ',',\n conjunction: 'or'\n}), replaceResultTransformer(/(?:\\s+)/g, ' '), trimResultTransformer);\nexport default oneLineCommaListsOr;","import TemplateTag from '../TemplateTag';\nimport inlineArrayTransformer from '../inlineArrayTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nimport replaceResultTransformer from '../replaceResultTransformer';\nvar oneLineCommaListsAnd = new TemplateTag(inlineArrayTransformer({\n separator: ',',\n conjunction: 'and'\n}), replaceResultTransformer(/(?:\\s+)/g, ' '), trimResultTransformer);\nexport default oneLineCommaListsAnd;","import TemplateTag from '../TemplateTag';\nimport stripIndentTransformer from '../stripIndentTransformer';\nimport inlineArrayTransformer from '../inlineArrayTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nvar inlineLists = new TemplateTag(inlineArrayTransformer, stripIndentTransformer, trimResultTransformer);\nexport default inlineLists;","import TemplateTag from '../TemplateTag';\nimport inlineArrayTransformer from '../inlineArrayTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nimport replaceResultTransformer from '../replaceResultTransformer';\nvar oneLineInlineLists = new TemplateTag(inlineArrayTransformer, replaceResultTransformer(/(?:\\s+)/g, ' '), trimResultTransformer);\nexport default oneLineInlineLists;","import TemplateTag from '../TemplateTag';\nimport stripIndentTransformer from '../stripIndentTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nvar stripIndent = new TemplateTag(stripIndentTransformer, trimResultTransformer);\nexport default stripIndent;","import TemplateTag from '../TemplateTag';\nimport stripIndentTransformer from '../stripIndentTransformer';\nimport trimResultTransformer from '../trimResultTransformer';\nvar stripIndents = new TemplateTag(stripIndentTransformer('all'), trimResultTransformer);\nexport default stripIndents;","\"use strict\";\n\nmodule.exports = Object.assign;","\"use strict\";\n\nmodule.exports = {\n fetch: global.fetch\n};","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n _typeof = function _typeof(obj) {\n return typeof obj;\n };\n } else {\n _typeof = function _typeof(obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n }\n return _typeof(obj);\n}\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}\nfunction formatValue(value, seenValues) {\n switch (_typeof(value)) {\n case 'string':\n return JSON.stringify(value);\n case 'function':\n return value.name ? \"[function \".concat(value.name, \"]\") : '[function]';\n case 'object':\n if (value === null) {\n return 'null';\n }\n return formatObjectValue(value, seenValues);\n default:\n return String(value);\n }\n}\nfunction formatObjectValue(value, previouslySeenValues) {\n if (previouslySeenValues.indexOf(value) !== -1) {\n return '[Circular]';\n }\n var seenValues = [].concat(previouslySeenValues, [value]);\n var customInspectFn = getCustomFn(value);\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 return formatObject(value, seenValues);\n}\nfunction formatObject(object, seenValues) {\n var keys = Object.keys(object);\n if (keys.length === 0) {\n return '{}';\n }\n if (seenValues.length > MAX_RECURSIVE_DEPTH) {\n return '[' + getObjectTag(object) + ']';\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}\nfunction formatArray(array, seenValues) {\n if (array.length === 0) {\n return '[]';\n }\n if (seenValues.length > MAX_RECURSIVE_DEPTH) {\n return '[Array]';\n }\n var len = Math.min(MAX_ARRAY_LENGTH, array.length);\n var remaining = array.length - len;\n var items = [];\n for (var i = 0; i < len; ++i) {\n items.push(formatValue(array[i], seenValues));\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 return '[' + items.join(', ') + ']';\n}\nfunction getCustomFn(object) {\n var customInspectFn = object[String(nodejsCustomInspectSymbol)];\n if (typeof customInspectFn === 'function') {\n return customInspectFn;\n }\n if (typeof object.inspect === 'function') {\n return object.inspect;\n }\n}\nfunction getObjectTag(object) {\n var tag = Object.prototype.toString.call(object).replace(/^\\[object /, '').replace(/]$/, '');\n if (tag === 'Object' && typeof object.constructor === 'function') {\n var name = object.constructor.name;\n if (typeof name === 'string' && name !== '') {\n return name;\n }\n }\n return tag;\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;","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}","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}","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 var _proto = Location.prototype;\n _proto.toJSON = function toJSON() {\n return {\n start: this.start,\n end: this.end\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 var _proto2 = Token.prototype;\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 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 * 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 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 var startLine = 0;\n while (startLine < lines.length && isBlank(lines[startLine])) {\n ++startLine;\n }\n var endLine = lines.length;\n while (endLine > startLine && isBlank(lines[endLine - 1])) {\n --endLine;\n } // Return a string of the lines joined with U+000A.\n\n return lines.slice(startLine, endLine).join('\\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 return true;\n}\n/**\n * @internal\n */\n\nexport function getBlockStringIndentation(value) {\n var _commonIndent;\n var isFirstLine = true;\n var isEmptyLine = true;\n var indent = 0;\n var commonIndent = null;\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 case 9: // \\t\n\n case 32:\n // \n ++indent;\n break;\n default:\n if (isEmptyLine && !isFirstLine && (commonIndent === null || indent < commonIndent)) {\n commonIndent = indent;\n }\n isEmptyLine = false;\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 result += indentation ? value.replace(/\\n/g, '\\n' + indentation) : value;\n if (printAsMultipleLines) {\n result += '\\n';\n }\n return '\"\"\"' + result.replace(/\"\"\"/g, '\\\\\"\"\"') + '\"\"\"';\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 */","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\nTYPE_STATICS[reactIs.Memo] = MEMO_STATICS;\nfunction getStatics(component) {\n // React v16.11 and below\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n } // React v16.12 and above\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n var keys = getOwnPropertyNames(sourceComponent);\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n return targetComponent;\n}\nmodule.exports = hoistNonReactStatics;","// the whatwg-fetch polyfill installs the fetch() function\n// on the global object (window or self)\n//\n// Return that as the export for use in Webpack, Browserify etc.\nrequire('whatwg-fetch');\nmodule.exports = self.fetch.bind(self);","/** @license React v16.13.1\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar b = \"function\" === typeof Symbol && Symbol.for,\n c = b ? Symbol.for(\"react.element\") : 60103,\n d = b ? Symbol.for(\"react.portal\") : 60106,\n e = b ? Symbol.for(\"react.fragment\") : 60107,\n f = b ? Symbol.for(\"react.strict_mode\") : 60108,\n g = b ? Symbol.for(\"react.profiler\") : 60114,\n h = b ? Symbol.for(\"react.provider\") : 60109,\n k = b ? Symbol.for(\"react.context\") : 60110,\n l = b ? Symbol.for(\"react.async_mode\") : 60111,\n m = b ? Symbol.for(\"react.concurrent_mode\") : 60111,\n n = b ? Symbol.for(\"react.forward_ref\") : 60112,\n p = b ? Symbol.for(\"react.suspense\") : 60113,\n q = b ? Symbol.for(\"react.suspense_list\") : 60120,\n r = b ? Symbol.for(\"react.memo\") : 60115,\n t = b ? Symbol.for(\"react.lazy\") : 60116,\n v = b ? Symbol.for(\"react.block\") : 60121,\n w = b ? Symbol.for(\"react.fundamental\") : 60117,\n x = b ? Symbol.for(\"react.responder\") : 60118,\n y = b ? Symbol.for(\"react.scope\") : 60119;\nfunction z(a) {\n if (\"object\" === typeof a && null !== a) {\n var u = a.$$typeof;\n switch (u) {\n case c:\n switch (a = a.type, a) {\n case l:\n case m:\n case e:\n case g:\n case f:\n case p:\n return a;\n default:\n switch (a = a && a.$$typeof, a) {\n case k:\n case n:\n case t:\n case r:\n case h:\n return a;\n default:\n return u;\n }\n }\n case d:\n return u;\n }\n }\n}\nfunction A(a) {\n return z(a) === m;\n}\nexports.AsyncMode = l;\nexports.ConcurrentMode = m;\nexports.ContextConsumer = k;\nexports.ContextProvider = h;\nexports.Element = c;\nexports.ForwardRef = n;\nexports.Fragment = e;\nexports.Lazy = t;\nexports.Memo = r;\nexports.Portal = d;\nexports.Profiler = g;\nexports.StrictMode = f;\nexports.Suspense = p;\nexports.isAsyncMode = function (a) {\n return A(a) || z(a) === l;\n};\nexports.isConcurrentMode = A;\nexports.isContextConsumer = function (a) {\n return z(a) === k;\n};\nexports.isContextProvider = function (a) {\n return z(a) === h;\n};\nexports.isElement = function (a) {\n return \"object\" === typeof a && null !== a && a.$$typeof === c;\n};\nexports.isForwardRef = function (a) {\n return z(a) === n;\n};\nexports.isFragment = function (a) {\n return z(a) === e;\n};\nexports.isLazy = function (a) {\n return z(a) === t;\n};\nexports.isMemo = function (a) {\n return z(a) === r;\n};\nexports.isPortal = function (a) {\n return z(a) === d;\n};\nexports.isProfiler = function (a) {\n return z(a) === g;\n};\nexports.isStrictMode = function (a) {\n return z(a) === f;\n};\nexports.isSuspense = function (a) {\n return z(a) === p;\n};\nexports.isValidElementType = function (a) {\n return \"string\" === typeof a || \"function\" === typeof a || a === e || a === m || a === g || a === f || a === p || a === q || \"object\" === typeof a && null !== a && (a.$$typeof === t || a.$$typeof === r || a.$$typeof === h || a.$$typeof === k || a.$$typeof === n || a.$$typeof === w || a.$$typeof === x || a.$$typeof === y || a.$$typeof === v);\n};\nexports.typeOf = z;","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}","\"use strict\";\n\nif (0) {\n // Trick cjs-module-lexer into adding named exports for all React exports.\n // (if imported with `import()`, they will appear in `.default` as well.)\n // This way, cjs-module-lexer will let all of react's (named) exports through unchanged.\n module.exports = require(\"react\");\n}\n// We don't want bundlers to error when they encounter usage of any of these exports.\n// It's up to the package author to ensure that if they access React internals,\n// they do so in a safe way that won't break if React changes how they use these internals.\n// (e.g. only access them in development, and only in an optional way that won't\n// break if internals are not there or do not have the expected structure)\n// @ts-ignore\nmodule.exports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED = undefined;\n// @ts-ignore\nmodule.exports.__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE = undefined;\n// @ts-ignore\nmodule.exports.__SERVER_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE = undefined;\n// Here we actually pull in the React library and add everything\n// it exports to our own `module.exports`.\n// If React suddenly were to add one of the above \"polyfilled\" exports,\n// the React version would overwrite our version, so this should be\n// future-proof.\nObject.assign(module.exports, require(\"react\"));","//\n\nmodule.exports = function shallowEqual(objA, objB, compare, compareContext) {\n var ret = compare ? compare.call(compareContext, objA, objB) : void 0;\n if (ret !== void 0) {\n return !!ret;\n }\n if (objA === objB) {\n return true;\n }\n if (typeof objA !== \"object\" || !objA || typeof objB !== \"object\" || !objB) {\n return false;\n }\n var keysA = Object.keys(objA);\n var keysB = Object.keys(objB);\n if (keysA.length !== keysB.length) {\n return false;\n }\n var bHasOwnProperty = Object.prototype.hasOwnProperty.bind(objB);\n\n // Test for A's keys different from B.\n for (var idx = 0; idx < keysA.length; idx++) {\n var key = keysA[idx];\n if (!bHasOwnProperty(key)) {\n return false;\n }\n var valueA = objA[key];\n var valueB = objB[key];\n ret = compare ? compare.call(compareContext, valueA, valueB, key) : void 0;\n if (ret === false || ret === void 0 && valueA !== valueB) {\n return false;\n }\n }\n return true;\n};","function stylis_min(W) {\n function M(d, c, e, h, a) {\n for (var m = 0, b = 0, v = 0, n = 0, q, g, x = 0, K = 0, k, u = k = q = 0, l = 0, r = 0, I = 0, t = 0, B = e.length, J = B - 1, y, f = '', p = '', F = '', G = '', C; l < B;) {\n g = e.charCodeAt(l);\n l === J && 0 !== b + n + v + m && (0 !== b && (g = 47 === b ? 10 : 47), n = v = m = 0, B++, J++);\n if (0 === b + n + v + m) {\n if (l === J && (0 < r && (f = f.replace(N, '')), 0 < f.trim().length)) {\n switch (g) {\n case 32:\n case 9:\n case 59:\n case 13:\n case 10:\n break;\n default:\n f += e.charAt(l);\n }\n g = 59;\n }\n switch (g) {\n case 123:\n f = f.trim();\n q = f.charCodeAt(0);\n k = 1;\n for (t = ++l; l < B;) {\n switch (g = e.charCodeAt(l)) {\n case 123:\n k++;\n break;\n case 125:\n k--;\n break;\n case 47:\n switch (g = e.charCodeAt(l + 1)) {\n case 42:\n case 47:\n a: {\n for (u = l + 1; u < J; ++u) {\n switch (e.charCodeAt(u)) {\n case 47:\n if (42 === g && 42 === e.charCodeAt(u - 1) && l + 2 !== u) {\n l = u + 1;\n break a;\n }\n break;\n case 10:\n if (47 === g) {\n l = u + 1;\n break a;\n }\n }\n }\n l = u;\n }\n }\n break;\n case 91:\n g++;\n case 40:\n g++;\n case 34:\n case 39:\n for (; l++ < J && e.charCodeAt(l) !== g;) {}\n }\n if (0 === k) break;\n l++;\n }\n k = e.substring(t, l);\n 0 === q && (q = (f = f.replace(ca, '').trim()).charCodeAt(0));\n switch (q) {\n case 64:\n 0 < r && (f = f.replace(N, ''));\n g = f.charCodeAt(1);\n switch (g) {\n case 100:\n case 109:\n case 115:\n case 45:\n r = c;\n break;\n default:\n r = O;\n }\n k = M(c, r, k, g, a + 1);\n t = k.length;\n 0 < A && (r = X(O, f, I), C = H(3, k, r, c, D, z, t, g, a, h), f = r.join(''), void 0 !== C && 0 === (t = (k = C.trim()).length) && (g = 0, k = ''));\n if (0 < t) switch (g) {\n case 115:\n f = f.replace(da, ea);\n case 100:\n case 109:\n case 45:\n k = f + '{' + k + '}';\n break;\n case 107:\n f = f.replace(fa, '$1 $2');\n k = f + '{' + k + '}';\n k = 1 === w || 2 === w && L('@' + k, 3) ? '@-webkit-' + k + '@' + k : '@' + k;\n break;\n default:\n k = f + k, 112 === h && (k = (p += k, ''));\n } else k = '';\n break;\n default:\n k = M(c, X(c, f, I), k, h, a + 1);\n }\n F += k;\n k = I = r = u = q = 0;\n f = '';\n g = e.charCodeAt(++l);\n break;\n case 125:\n case 59:\n f = (0 < r ? f.replace(N, '') : f).trim();\n if (1 < (t = f.length)) switch (0 === u && (q = f.charCodeAt(0), 45 === q || 96 < q && 123 > q) && (t = (f = f.replace(' ', ':')).length), 0 < A && void 0 !== (C = H(1, f, c, d, D, z, p.length, h, a, h)) && 0 === (t = (f = C.trim()).length) && (f = '\\x00\\x00'), q = f.charCodeAt(0), g = f.charCodeAt(1), q) {\n case 0:\n break;\n case 64:\n if (105 === g || 99 === g) {\n G += f + e.charAt(l);\n break;\n }\n default:\n 58 !== f.charCodeAt(t - 1) && (p += P(f, q, g, f.charCodeAt(2)));\n }\n I = r = u = q = 0;\n f = '';\n g = e.charCodeAt(++l);\n }\n }\n switch (g) {\n case 13:\n case 10:\n 47 === b ? b = 0 : 0 === 1 + q && 107 !== h && 0 < f.length && (r = 1, f += '\\x00');\n 0 < A * Y && H(0, f, c, d, D, z, p.length, h, a, h);\n z = 1;\n D++;\n break;\n case 59:\n case 125:\n if (0 === b + n + v + m) {\n z++;\n break;\n }\n default:\n z++;\n y = e.charAt(l);\n switch (g) {\n case 9:\n case 32:\n if (0 === n + m + b) switch (x) {\n case 44:\n case 58:\n case 9:\n case 32:\n y = '';\n break;\n default:\n 32 !== g && (y = ' ');\n }\n break;\n case 0:\n y = '\\\\0';\n break;\n case 12:\n y = '\\\\f';\n break;\n case 11:\n y = '\\\\v';\n break;\n case 38:\n 0 === n + b + m && (r = I = 1, y = '\\f' + y);\n break;\n case 108:\n if (0 === n + b + m + E && 0 < u) switch (l - u) {\n case 2:\n 112 === x && 58 === e.charCodeAt(l - 3) && (E = x);\n case 8:\n 111 === K && (E = K);\n }\n break;\n case 58:\n 0 === n + b + m && (u = l);\n break;\n case 44:\n 0 === b + v + n + m && (r = 1, y += '\\r');\n break;\n case 34:\n case 39:\n 0 === b && (n = n === g ? 0 : 0 === n ? g : n);\n break;\n case 91:\n 0 === n + b + v && m++;\n break;\n case 93:\n 0 === n + b + v && m--;\n break;\n case 41:\n 0 === n + b + m && v--;\n break;\n case 40:\n if (0 === n + b + m) {\n if (0 === q) switch (2 * x + 3 * K) {\n case 533:\n break;\n default:\n q = 1;\n }\n v++;\n }\n break;\n case 64:\n 0 === b + v + n + m + u + k && (k = 1);\n break;\n case 42:\n case 47:\n if (!(0 < n + m + v)) switch (b) {\n case 0:\n switch (2 * g + 3 * e.charCodeAt(l + 1)) {\n case 235:\n b = 47;\n break;\n case 220:\n t = l, b = 42;\n }\n break;\n case 42:\n 47 === g && 42 === x && t + 2 !== l && (33 === e.charCodeAt(t + 2) && (p += e.substring(t, l + 1)), y = '', b = 0);\n }\n }\n 0 === b && (f += y);\n }\n K = x;\n x = g;\n l++;\n }\n t = p.length;\n if (0 < t) {\n r = c;\n if (0 < A && (C = H(2, p, r, d, D, z, t, h, a, h), void 0 !== C && 0 === (p = C).length)) return G + p + F;\n p = r.join(',') + '{' + p + '}';\n if (0 !== w * E) {\n 2 !== w || L(p, 2) || (E = 0);\n switch (E) {\n case 111:\n p = p.replace(ha, ':-moz-$1') + p;\n break;\n case 112:\n p = p.replace(Q, '::-webkit-input-$1') + p.replace(Q, '::-moz-$1') + p.replace(Q, ':-ms-input-$1') + p;\n }\n E = 0;\n }\n }\n return G + p + F;\n }\n function X(d, c, e) {\n var h = c.trim().split(ia);\n c = h;\n var a = h.length,\n m = d.length;\n switch (m) {\n case 0:\n case 1:\n var b = 0;\n for (d = 0 === m ? '' : d[0] + ' '; b < a; ++b) {\n c[b] = Z(d, c[b], e).trim();\n }\n break;\n default:\n var v = b = 0;\n for (c = []; b < a; ++b) {\n for (var n = 0; n < m; ++n) {\n c[v++] = Z(d[n] + ' ', h[b], e).trim();\n }\n }\n }\n return c;\n }\n function Z(d, c, e) {\n var h = c.charCodeAt(0);\n 33 > h && (h = (c = c.trim()).charCodeAt(0));\n switch (h) {\n case 38:\n return c.replace(F, '$1' + d.trim());\n case 58:\n return d.trim() + c.replace(F, '$1' + d.trim());\n default:\n if (0 < 1 * e && 0 < c.indexOf('\\f')) return c.replace(F, (58 === d.charCodeAt(0) ? '' : '$1') + d.trim());\n }\n return d + c;\n }\n function P(d, c, e, h) {\n var a = d + ';',\n m = 2 * c + 3 * e + 4 * h;\n if (944 === m) {\n d = a.indexOf(':', 9) + 1;\n var b = a.substring(d, a.length - 1).trim();\n b = a.substring(0, d).trim() + b + ';';\n return 1 === w || 2 === w && L(b, 1) ? '-webkit-' + b + b : b;\n }\n if (0 === w || 2 === w && !L(a, 1)) return a;\n switch (m) {\n case 1015:\n return 97 === a.charCodeAt(10) ? '-webkit-' + a + a : a;\n case 951:\n return 116 === a.charCodeAt(3) ? '-webkit-' + a + a : a;\n case 963:\n return 110 === a.charCodeAt(5) ? '-webkit-' + a + a : a;\n case 1009:\n if (100 !== a.charCodeAt(4)) break;\n case 969:\n case 942:\n return '-webkit-' + a + a;\n case 978:\n return '-webkit-' + a + '-moz-' + a + a;\n case 1019:\n case 983:\n return '-webkit-' + a + '-moz-' + a + '-ms-' + a + a;\n case 883:\n if (45 === a.charCodeAt(8)) return '-webkit-' + a + a;\n if (0 < a.indexOf('image-set(', 11)) return a.replace(ja, '$1-webkit-$2') + a;\n break;\n case 932:\n if (45 === a.charCodeAt(4)) switch (a.charCodeAt(5)) {\n case 103:\n return '-webkit-box-' + a.replace('-grow', '') + '-webkit-' + a + '-ms-' + a.replace('grow', 'positive') + a;\n case 115:\n return '-webkit-' + a + '-ms-' + a.replace('shrink', 'negative') + a;\n case 98:\n return '-webkit-' + a + '-ms-' + a.replace('basis', 'preferred-size') + a;\n }\n return '-webkit-' + a + '-ms-' + a + a;\n case 964:\n return '-webkit-' + a + '-ms-flex-' + a + a;\n case 1023:\n if (99 !== a.charCodeAt(8)) break;\n b = a.substring(a.indexOf(':', 15)).replace('flex-', '').replace('space-between', 'justify');\n return '-webkit-box-pack' + b + '-webkit-' + a + '-ms-flex-pack' + b + a;\n case 1005:\n return ka.test(a) ? a.replace(aa, ':-webkit-') + a.replace(aa, ':-moz-') + a : a;\n case 1e3:\n b = a.substring(13).trim();\n c = b.indexOf('-') + 1;\n switch (b.charCodeAt(0) + b.charCodeAt(c)) {\n case 226:\n b = a.replace(G, 'tb');\n break;\n case 232:\n b = a.replace(G, 'tb-rl');\n break;\n case 220:\n b = a.replace(G, 'lr');\n break;\n default:\n return a;\n }\n return '-webkit-' + a + '-ms-' + b + a;\n case 1017:\n if (-1 === a.indexOf('sticky', 9)) break;\n case 975:\n c = (a = d).length - 10;\n b = (33 === a.charCodeAt(c) ? a.substring(0, c) : a).substring(d.indexOf(':', 7) + 1).trim();\n switch (m = b.charCodeAt(0) + (b.charCodeAt(7) | 0)) {\n case 203:\n if (111 > b.charCodeAt(8)) break;\n case 115:\n a = a.replace(b, '-webkit-' + b) + ';' + a;\n break;\n case 207:\n case 102:\n a = a.replace(b, '-webkit-' + (102 < m ? 'inline-' : '') + 'box') + ';' + a.replace(b, '-webkit-' + b) + ';' + a.replace(b, '-ms-' + b + 'box') + ';' + a;\n }\n return a + ';';\n case 938:\n if (45 === a.charCodeAt(5)) switch (a.charCodeAt(6)) {\n case 105:\n return b = a.replace('-items', ''), '-webkit-' + a + '-webkit-box-' + b + '-ms-flex-' + b + a;\n case 115:\n return '-webkit-' + a + '-ms-flex-item-' + a.replace(ba, '') + a;\n default:\n return '-webkit-' + a + '-ms-flex-line-pack' + a.replace('align-content', '').replace(ba, '') + a;\n }\n break;\n case 973:\n case 989:\n if (45 !== a.charCodeAt(3) || 122 === a.charCodeAt(4)) break;\n case 931:\n case 953:\n if (!0 === la.test(d)) return 115 === (b = d.substring(d.indexOf(':') + 1)).charCodeAt(0) ? P(d.replace('stretch', 'fill-available'), c, e, h).replace(':fill-available', ':stretch') : a.replace(b, '-webkit-' + b) + a.replace(b, '-moz-' + b.replace('fill-', '')) + a;\n break;\n case 962:\n if (a = '-webkit-' + a + (102 === a.charCodeAt(5) ? '-ms-' + a : '') + a, 211 === e + h && 105 === a.charCodeAt(13) && 0 < a.indexOf('transform', 10)) return a.substring(0, a.indexOf(';', 27) + 1).replace(ma, '$1-webkit-$2') + a;\n }\n return a;\n }\n function L(d, c) {\n var e = d.indexOf(1 === c ? ':' : '{'),\n h = d.substring(0, 3 !== c ? e : 10);\n e = d.substring(e + 1, d.length - 1);\n return R(2 !== c ? h : h.replace(na, '$1'), e, c);\n }\n function ea(d, c) {\n var e = P(c, c.charCodeAt(0), c.charCodeAt(1), c.charCodeAt(2));\n return e !== c + ';' ? e.replace(oa, ' or ($1)').substring(4) : '(' + c + ')';\n }\n function H(d, c, e, h, a, m, b, v, n, q) {\n for (var g = 0, x = c, w; g < A; ++g) {\n switch (w = S[g].call(B, d, x, e, h, a, m, b, v, n, q)) {\n case void 0:\n case !1:\n case !0:\n case null:\n break;\n default:\n x = w;\n }\n }\n if (x !== c) return x;\n }\n function T(d) {\n switch (d) {\n case void 0:\n case null:\n A = S.length = 0;\n break;\n default:\n if ('function' === typeof d) S[A++] = d;else if ('object' === typeof d) for (var c = 0, e = d.length; c < e; ++c) {\n T(d[c]);\n } else Y = !!d | 0;\n }\n return T;\n }\n function U(d) {\n d = d.prefix;\n void 0 !== d && (R = null, d ? 'function' !== typeof d ? w = 1 : (w = 2, R = d) : w = 0);\n return U;\n }\n function B(d, c) {\n var e = d;\n 33 > e.charCodeAt(0) && (e = e.trim());\n V = e;\n e = [V];\n if (0 < A) {\n var h = H(-1, c, e, e, D, z, 0, 0, 0, 0);\n void 0 !== h && 'string' === typeof h && (c = h);\n }\n var a = M(O, e, c, 0, 0);\n 0 < A && (h = H(-2, a, e, e, D, z, a.length, 0, 0, 0), void 0 !== h && (a = h));\n V = '';\n E = 0;\n z = D = 1;\n return a;\n }\n var ca = /^\\0+/g,\n N = /[\\0\\r\\f]/g,\n aa = /: */g,\n ka = /zoo|gra/,\n ma = /([,: ])(transform)/g,\n ia = /,\\r+?/g,\n F = /([\\t\\r\\n ])*\\f?&/g,\n fa = /@(k\\w+)\\s*(\\S*)\\s*/,\n Q = /::(place)/g,\n ha = /:(read-only)/g,\n G = /[svh]\\w+-[tblr]{2}/,\n da = /\\(\\s*(.*)\\s*\\)/g,\n oa = /([\\s\\S]*?);/g,\n ba = /-self|flex-/g,\n na = /[^]*?(:[rp][el]a[\\w-]+)[^]*/,\n la = /stretch|:\\s*\\w+\\-(?:conte|avail)/,\n ja = /([^-])(image-set\\()/,\n z = 1,\n D = 1,\n E = 0,\n w = 1,\n O = [],\n S = [],\n A = 0,\n R = null,\n Y = 0,\n V = '';\n B.use = T;\n B.set = U;\n void 0 !== W && U(W);\n return B;\n}\nexport default stylis_min;","var unitlessKeys = {\n animationIterationCount: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\nexport default unitlessKeys;","function memoize(fn) {\n var cache = Object.create(null);\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\nexport { memoize as default };","import memoize from '@emotion/memoize';\nvar reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|abbr|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|download|draggable|encType|enterKeyHint|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|translate|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|incremental|fallback|inert|itemProp|itemScope|itemType|itemID|itemRef|on|option|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; // https://esbench.com/bench/5bfee68a4cd7e6009ef61d23\n\nvar isPropValid = /* #__PURE__ */memoize(function (prop) {\n return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111\n /* o */ && prop.charCodeAt(1) === 110\n /* n */ && prop.charCodeAt(2) < 91;\n}\n/* Z+1 */);\n\nexport { isPropValid as default };","import { typeOf as e, isElement as t, isValidElementType as n } from \"react-is\";\nimport r, { useState as o, useContext as s, useMemo as i, useEffect as a, useRef as c, createElement as u, useLayoutEffect as l } from \"react\";\nimport d from \"shallowequal\";\nimport h from \"@emotion/stylis\";\nimport p from \"@emotion/unitless\";\nimport f from \"@emotion/is-prop-valid\";\nimport m from \"hoist-non-react-statics\";\nfunction y() {\n return (y = Object.assign || function (e) {\n for (var t = 1; t < arguments.length; t++) {\n var n = arguments[t];\n for (var r in n) Object.prototype.hasOwnProperty.call(n, r) && (e[r] = n[r]);\n }\n return e;\n }).apply(this, arguments);\n}\nvar v = function (e, t) {\n for (var n = [e[0]], r = 0, o = t.length; r < o; r += 1) n.push(t[r], e[r + 1]);\n return n;\n },\n g = function (t) {\n return null !== t && \"object\" == typeof t && \"[object Object]\" === (t.toString ? t.toString() : Object.prototype.toString.call(t)) && !e(t);\n },\n S = Object.freeze([]),\n w = Object.freeze({});\nfunction E(e) {\n return \"function\" == typeof e;\n}\nfunction b(e) {\n return \"production\" !== process.env.NODE_ENV && \"string\" == typeof e && e || e.displayName || e.name || \"Component\";\n}\nfunction _(e) {\n return e && \"string\" == typeof e.styledComponentId;\n}\nvar N = \"undefined\" != typeof process && void 0 !== process.env && (process.env.REACT_APP_SC_ATTR || process.env.SC_ATTR) || \"data-styled\",\n A = \"5.3.11\",\n C = \"undefined\" != typeof window && \"HTMLElement\" in window,\n I = Boolean(\"boolean\" == typeof SC_DISABLE_SPEEDY ? SC_DISABLE_SPEEDY : \"undefined\" != typeof process && void 0 !== process.env && (void 0 !== process.env.REACT_APP_SC_DISABLE_SPEEDY && \"\" !== process.env.REACT_APP_SC_DISABLE_SPEEDY ? \"false\" !== process.env.REACT_APP_SC_DISABLE_SPEEDY && process.env.REACT_APP_SC_DISABLE_SPEEDY : void 0 !== process.env.SC_DISABLE_SPEEDY && \"\" !== process.env.SC_DISABLE_SPEEDY ? \"false\" !== process.env.SC_DISABLE_SPEEDY && process.env.SC_DISABLE_SPEEDY : \"production\" !== process.env.NODE_ENV)),\n P = {},\n O = \"production\" !== process.env.NODE_ENV ? {\n 1: \"Cannot create styled-component for component: %s.\\n\\n\",\n 2: \"Can't collect styles once you've consumed a `ServerStyleSheet`'s styles! `ServerStyleSheet` is a one off instance for each server-side render cycle.\\n\\n- Are you trying to reuse it across renders?\\n- Are you accidentally calling collectStyles twice?\\n\\n\",\n 3: \"Streaming SSR is only supported in a Node.js environment; Please do not try to call this method in the browser.\\n\\n\",\n 4: \"The `StyleSheetManager` expects a valid target or sheet prop!\\n\\n- Does this error occur on the client and is your target falsy?\\n- Does this error occur on the server and is the sheet falsy?\\n\\n\",\n 5: \"The clone method cannot be used on the client!\\n\\n- Are you running in a client-like environment on the server?\\n- Are you trying to run SSR on the client?\\n\\n\",\n 6: \"Trying to insert a new style tag, but the given Node is unmounted!\\n\\n- Are you using a custom target that isn't mounted?\\n- Does your document not have a valid head element?\\n- Have you accidentally removed a style tag manually?\\n\\n\",\n 7: 'ThemeProvider: Please return an object from your \"theme\" prop function, e.g.\\n\\n```js\\ntheme={() => ({})}\\n```\\n\\n',\n 8: 'ThemeProvider: Please make your \"theme\" prop an object.\\n\\n',\n 9: \"Missing document ``\\n\\n\",\n 10: \"Cannot find a StyleSheet instance. Usually this happens if there are multiple copies of styled-components loaded at once. Check out this issue for how to troubleshoot and fix the common cases where this situation can happen: https://github.com/styled-components/styled-components/issues/1941#issuecomment-417862021\\n\\n\",\n 11: \"_This error was replaced with a dev-time warning, it will be deleted for v4 final._ [createGlobalStyle] received children which will not be rendered. Please use the component without passing children elements.\\n\\n\",\n 12: \"It seems you are interpolating a keyframe declaration (%s) into an untagged string. This was supported in styled-components v3, but is not longer supported in v4 as keyframes are now injected on-demand. Please wrap your string in the css\\\\`\\\\` helper which ensures the styles are injected correctly. See https://www.styled-components.com/docs/api#css\\n\\n\",\n 13: \"%s is not a styled component and cannot be referred to via component selector. See https://www.styled-components.com/docs/advanced#referring-to-other-components for more details.\\n\\n\",\n 14: 'ThemeProvider: \"theme\" prop is required.\\n\\n',\n 15: \"A stylis plugin has been supplied that is not named. We need a name for each plugin to be able to prevent styling collisions between different stylis configurations within the same app. Before you pass your plugin to ``, please make sure each plugin is uniquely-named, e.g.\\n\\n```js\\nObject.defineProperty(importedPlugin, 'name', { value: 'some-unique-name' });\\n```\\n\\n\",\n 16: \"Reached the limit of how many styled components may be created at group %s.\\nYou may only create up to 1,073,741,824 components. If you're creating components dynamically,\\nas for instance in your render method then you may be running into this limitation.\\n\\n\",\n 17: \"CSSStyleSheet could not be found on HTMLStyleElement.\\nHas styled-components' style tag been unmounted or altered by another script?\\n\"\n } : {};\nfunction R() {\n for (var e = arguments.length <= 0 ? void 0 : arguments[0], t = [], n = 1, r = arguments.length; n < r; n += 1) t.push(n < 0 || arguments.length <= n ? void 0 : arguments[n]);\n return t.forEach(function (t) {\n e = e.replace(/%[a-z]/, t);\n }), e;\n}\nfunction D(e) {\n for (var t = arguments.length, n = new Array(t > 1 ? t - 1 : 0), r = 1; r < t; r++) n[r - 1] = arguments[r];\n throw \"production\" === process.env.NODE_ENV ? new Error(\"An error occurred. See https://git.io/JUIaE#\" + e + \" for more information.\" + (n.length > 0 ? \" Args: \" + n.join(\", \") : \"\")) : new Error(R.apply(void 0, [O[e]].concat(n)).trim());\n}\nvar j = function () {\n function e(e) {\n this.groupSizes = new Uint32Array(512), this.length = 512, this.tag = e;\n }\n var t = e.prototype;\n return t.indexOfGroup = function (e) {\n for (var t = 0, n = 0; n < e; n++) t += this.groupSizes[n];\n return t;\n }, t.insertRules = function (e, t) {\n if (e >= this.groupSizes.length) {\n for (var n = this.groupSizes, r = n.length, o = r; e >= o;) (o <<= 1) < 0 && D(16, \"\" + e);\n this.groupSizes = new Uint32Array(o), this.groupSizes.set(n), this.length = o;\n for (var s = r; s < o; s++) this.groupSizes[s] = 0;\n }\n for (var i = this.indexOfGroup(e + 1), a = 0, c = t.length; a < c; a++) this.tag.insertRule(i, t[a]) && (this.groupSizes[e]++, i++);\n }, t.clearGroup = function (e) {\n if (e < this.length) {\n var t = this.groupSizes[e],\n n = this.indexOfGroup(e),\n r = n + t;\n this.groupSizes[e] = 0;\n for (var o = n; o < r; o++) this.tag.deleteRule(n);\n }\n }, t.getGroup = function (e) {\n var t = \"\";\n if (e >= this.length || 0 === this.groupSizes[e]) return t;\n for (var n = this.groupSizes[e], r = this.indexOfGroup(e), o = r + n, s = r; s < o; s++) t += this.tag.getRule(s) + \"/*!sc*/\\n\";\n return t;\n }, e;\n }(),\n T = new Map(),\n x = new Map(),\n k = 1,\n V = function (e) {\n if (T.has(e)) return T.get(e);\n for (; x.has(k);) k++;\n var t = k++;\n return \"production\" !== process.env.NODE_ENV && ((0 | t) < 0 || t > 1 << 30) && D(16, \"\" + t), T.set(e, t), x.set(t, e), t;\n },\n B = function (e) {\n return x.get(e);\n },\n z = function (e, t) {\n t >= k && (k = t + 1), T.set(e, t), x.set(t, e);\n },\n M = \"style[\" + N + '][data-styled-version=\"5.3.11\"]',\n G = new RegExp(\"^\" + N + '\\\\.g(\\\\d+)\\\\[id=\"([\\\\w\\\\d-]+)\"\\\\].*?\"([^\"]*)'),\n L = function (e, t, n) {\n for (var r, o = n.split(\",\"), s = 0, i = o.length; s < i; s++) (r = o[s]) && e.registerName(t, r);\n },\n F = function (e, t) {\n for (var n = (t.textContent || \"\").split(\"/*!sc*/\\n\"), r = [], o = 0, s = n.length; o < s; o++) {\n var i = n[o].trim();\n if (i) {\n var a = i.match(G);\n if (a) {\n var c = 0 | parseInt(a[1], 10),\n u = a[2];\n 0 !== c && (z(u, c), L(e, u, a[3]), e.getTag().insertRules(c, r)), r.length = 0;\n } else r.push(i);\n }\n }\n },\n Y = function () {\n return \"undefined\" != typeof __webpack_nonce__ ? __webpack_nonce__ : null;\n },\n q = function (e) {\n var t = document.head,\n n = e || t,\n r = document.createElement(\"style\"),\n o = function (e) {\n for (var t = e.childNodes, n = t.length; n >= 0; n--) {\n var r = t[n];\n if (r && 1 === r.nodeType && r.hasAttribute(N)) return r;\n }\n }(n),\n s = void 0 !== o ? o.nextSibling : null;\n r.setAttribute(N, \"active\"), r.setAttribute(\"data-styled-version\", \"5.3.11\");\n var i = Y();\n return i && r.setAttribute(\"nonce\", i), n.insertBefore(r, s), r;\n },\n H = function () {\n function e(e) {\n var t = this.element = q(e);\n t.appendChild(document.createTextNode(\"\")), this.sheet = function (e) {\n if (e.sheet) return e.sheet;\n for (var t = document.styleSheets, n = 0, r = t.length; n < r; n++) {\n var o = t[n];\n if (o.ownerNode === e) return o;\n }\n D(17);\n }(t), this.length = 0;\n }\n var t = e.prototype;\n return t.insertRule = function (e, t) {\n try {\n return this.sheet.insertRule(t, e), this.length++, !0;\n } catch (e) {\n return !1;\n }\n }, t.deleteRule = function (e) {\n this.sheet.deleteRule(e), this.length--;\n }, t.getRule = function (e) {\n var t = this.sheet.cssRules[e];\n return void 0 !== t && \"string\" == typeof t.cssText ? t.cssText : \"\";\n }, e;\n }(),\n $ = function () {\n function e(e) {\n var t = this.element = q(e);\n this.nodes = t.childNodes, this.length = 0;\n }\n var t = e.prototype;\n return t.insertRule = function (e, t) {\n if (e <= this.length && e >= 0) {\n var n = document.createTextNode(t),\n r = this.nodes[e];\n return this.element.insertBefore(n, r || null), this.length++, !0;\n }\n return !1;\n }, t.deleteRule = function (e) {\n this.element.removeChild(this.nodes[e]), this.length--;\n }, t.getRule = function (e) {\n return e < this.length ? this.nodes[e].textContent : \"\";\n }, e;\n }(),\n W = function () {\n function e(e) {\n this.rules = [], this.length = 0;\n }\n var t = e.prototype;\n return t.insertRule = function (e, t) {\n return e <= this.length && (this.rules.splice(e, 0, t), this.length++, !0);\n }, t.deleteRule = function (e) {\n this.rules.splice(e, 1), this.length--;\n }, t.getRule = function (e) {\n return e < this.length ? this.rules[e] : \"\";\n }, e;\n }(),\n U = C,\n J = {\n isServer: !C,\n useCSSOMInjection: !I\n },\n X = function () {\n function e(e, t, n) {\n void 0 === e && (e = w), void 0 === t && (t = {}), this.options = y({}, J, {}, e), this.gs = t, this.names = new Map(n), this.server = !!e.isServer, !this.server && C && U && (U = !1, function (e) {\n for (var t = document.querySelectorAll(M), n = 0, r = t.length; n < r; n++) {\n var o = t[n];\n o && \"active\" !== o.getAttribute(N) && (F(e, o), o.parentNode && o.parentNode.removeChild(o));\n }\n }(this));\n }\n e.registerId = function (e) {\n return V(e);\n };\n var t = e.prototype;\n return t.reconstructWithOptions = function (t, n) {\n return void 0 === n && (n = !0), new e(y({}, this.options, {}, t), this.gs, n && this.names || void 0);\n }, t.allocateGSInstance = function (e) {\n return this.gs[e] = (this.gs[e] || 0) + 1;\n }, t.getTag = function () {\n return this.tag || (this.tag = (n = (t = this.options).isServer, r = t.useCSSOMInjection, o = t.target, e = n ? new W(o) : r ? new H(o) : new $(o), new j(e)));\n var e, t, n, r, o;\n }, t.hasNameForId = function (e, t) {\n return this.names.has(e) && this.names.get(e).has(t);\n }, t.registerName = function (e, t) {\n if (V(e), this.names.has(e)) this.names.get(e).add(t);else {\n var n = new Set();\n n.add(t), this.names.set(e, n);\n }\n }, t.insertRules = function (e, t, n) {\n this.registerName(e, t), this.getTag().insertRules(V(e), n);\n }, t.clearNames = function (e) {\n this.names.has(e) && this.names.get(e).clear();\n }, t.clearRules = function (e) {\n this.getTag().clearGroup(V(e)), this.clearNames(e);\n }, t.clearTag = function () {\n this.tag = void 0;\n }, t.toString = function () {\n return function (e) {\n for (var t = e.getTag(), n = t.length, r = \"\", o = 0; o < n; o++) {\n var s = B(o);\n if (void 0 !== s) {\n var i = e.names.get(s),\n a = t.getGroup(o);\n if (i && a && i.size) {\n var c = N + \".g\" + o + '[id=\"' + s + '\"]',\n u = \"\";\n void 0 !== i && i.forEach(function (e) {\n e.length > 0 && (u += e + \",\");\n }), r += \"\" + a + c + '{content:\"' + u + '\"}/*!sc*/\\n';\n }\n }\n }\n return r;\n }(this);\n }, e;\n }(),\n Z = /(a)(d)/gi,\n K = function (e) {\n return String.fromCharCode(e + (e > 25 ? 39 : 97));\n };\nfunction Q(e) {\n var t,\n n = \"\";\n for (t = Math.abs(e); t > 52; t = t / 52 | 0) n = K(t % 52) + n;\n return (K(t % 52) + n).replace(Z, \"$1-$2\");\n}\nvar ee = function (e, t) {\n for (var n = t.length; n;) e = 33 * e ^ t.charCodeAt(--n);\n return e;\n },\n te = function (e) {\n return ee(5381, e);\n };\nfunction ne(e) {\n for (var t = 0; t < e.length; t += 1) {\n var n = e[t];\n if (E(n) && !_(n)) return !1;\n }\n return !0;\n}\nvar re = te(\"5.3.11\"),\n oe = function () {\n function e(e, t, n) {\n this.rules = e, this.staticRulesId = \"\", this.isStatic = \"production\" === process.env.NODE_ENV && (void 0 === n || n.isStatic) && ne(e), this.componentId = t, this.baseHash = ee(re, t), this.baseStyle = n, X.registerId(t);\n }\n return e.prototype.generateAndInjectStyles = function (e, t, n) {\n var r = this.componentId,\n o = [];\n if (this.baseStyle && o.push(this.baseStyle.generateAndInjectStyles(e, t, n)), this.isStatic && !n.hash) {\n if (this.staticRulesId && t.hasNameForId(r, this.staticRulesId)) o.push(this.staticRulesId);else {\n var s = _e(this.rules, e, t, n).join(\"\"),\n i = Q(ee(this.baseHash, s) >>> 0);\n if (!t.hasNameForId(r, i)) {\n var a = n(s, \".\" + i, void 0, r);\n t.insertRules(r, i, a);\n }\n o.push(i), this.staticRulesId = i;\n }\n } else {\n for (var c = this.rules.length, u = ee(this.baseHash, n.hash), l = \"\", d = 0; d < c; d++) {\n var h = this.rules[d];\n if (\"string\" == typeof h) l += h, \"production\" !== process.env.NODE_ENV && (u = ee(u, h + d));else if (h) {\n var p = _e(h, e, t, n),\n f = Array.isArray(p) ? p.join(\"\") : p;\n u = ee(u, f + d), l += f;\n }\n }\n if (l) {\n var m = Q(u >>> 0);\n if (!t.hasNameForId(r, m)) {\n var y = n(l, \".\" + m, void 0, r);\n t.insertRules(r, m, y);\n }\n o.push(m);\n }\n }\n return o.join(\" \");\n }, e;\n }(),\n se = /^\\s*\\/\\/.*$/gm,\n ie = [\":\", \"[\", \".\", \"#\"];\nfunction ae(e) {\n var t,\n n,\n r,\n o,\n s = void 0 === e ? w : e,\n i = s.options,\n a = void 0 === i ? w : i,\n c = s.plugins,\n u = void 0 === c ? S : c,\n l = new h(a),\n d = [],\n p = function (e) {\n function t(t) {\n if (t) try {\n e(t + \"}\");\n } catch (e) {}\n }\n return function (n, r, o, s, i, a, c, u, l, d) {\n switch (n) {\n case 1:\n if (0 === l && 64 === r.charCodeAt(0)) return e(r + \";\"), \"\";\n break;\n case 2:\n if (0 === u) return r + \"/*|*/\";\n break;\n case 3:\n switch (u) {\n case 102:\n case 112:\n return e(o[0] + r), \"\";\n default:\n return r + (0 === d ? \"/*|*/\" : \"\");\n }\n case -2:\n r.split(\"/*|*/}\").forEach(t);\n }\n };\n }(function (e) {\n d.push(e);\n }),\n f = function (e, r, s) {\n return 0 === r && -1 !== ie.indexOf(s[n.length]) || s.match(o) ? e : \".\" + t;\n };\n function m(e, s, i, a) {\n void 0 === a && (a = \"&\");\n var c = e.replace(se, \"\"),\n u = s && i ? i + \" \" + s + \" { \" + c + \" }\" : c;\n return t = a, n = s, r = new RegExp(\"\\\\\" + n + \"\\\\b\", \"g\"), o = new RegExp(\"(\\\\\" + n + \"\\\\b){2,}\"), l(i || !s ? \"\" : s, u);\n }\n return l.use([].concat(u, [function (e, t, o) {\n 2 === e && o.length && o[0].lastIndexOf(n) > 0 && (o[0] = o[0].replace(r, f));\n }, p, function (e) {\n if (-2 === e) {\n var t = d;\n return d = [], t;\n }\n }])), m.hash = u.length ? u.reduce(function (e, t) {\n return t.name || D(15), ee(e, t.name);\n }, 5381).toString() : \"\", m;\n}\nvar ce = r.createContext(),\n ue = ce.Consumer,\n le = r.createContext(),\n de = (le.Consumer, new X()),\n he = ae();\nfunction pe() {\n return s(ce) || de;\n}\nfunction fe() {\n return s(le) || he;\n}\nfunction me(e) {\n var t = o(e.stylisPlugins),\n n = t[0],\n s = t[1],\n c = pe(),\n u = i(function () {\n var t = c;\n return e.sheet ? t = e.sheet : e.target && (t = t.reconstructWithOptions({\n target: e.target\n }, !1)), e.disableCSSOMInjection && (t = t.reconstructWithOptions({\n useCSSOMInjection: !1\n })), t;\n }, [e.disableCSSOMInjection, e.sheet, e.target]),\n l = i(function () {\n return ae({\n options: {\n prefix: !e.disableVendorPrefixes\n },\n plugins: n\n });\n }, [e.disableVendorPrefixes, n]);\n return a(function () {\n d(n, e.stylisPlugins) || s(e.stylisPlugins);\n }, [e.stylisPlugins]), r.createElement(ce.Provider, {\n value: u\n }, r.createElement(le.Provider, {\n value: l\n }, \"production\" !== process.env.NODE_ENV ? r.Children.only(e.children) : e.children));\n}\nvar ye = function () {\n function e(e, t) {\n var n = this;\n this.inject = function (e, t) {\n void 0 === t && (t = he);\n var r = n.name + t.hash;\n e.hasNameForId(n.id, r) || e.insertRules(n.id, r, t(n.rules, r, \"@keyframes\"));\n }, this.toString = function () {\n return D(12, String(n.name));\n }, this.name = e, this.id = \"sc-keyframes-\" + e, this.rules = t;\n }\n return e.prototype.getName = function (e) {\n return void 0 === e && (e = he), this.name + e.hash;\n }, e;\n }(),\n ve = /([A-Z])/,\n ge = /([A-Z])/g,\n Se = /^ms-/,\n we = function (e) {\n return \"-\" + e.toLowerCase();\n };\nfunction Ee(e) {\n return ve.test(e) ? e.replace(ge, we).replace(Se, \"-ms-\") : e;\n}\nvar be = function (e) {\n return null == e || !1 === e || \"\" === e;\n};\nfunction _e(e, n, r, o) {\n if (Array.isArray(e)) {\n for (var s, i = [], a = 0, c = e.length; a < c; a += 1) \"\" !== (s = _e(e[a], n, r, o)) && (Array.isArray(s) ? i.push.apply(i, s) : i.push(s));\n return i;\n }\n if (be(e)) return \"\";\n if (_(e)) return \".\" + e.styledComponentId;\n if (E(e)) {\n if (\"function\" != typeof (l = e) || l.prototype && l.prototype.isReactComponent || !n) return e;\n var u = e(n);\n return \"production\" !== process.env.NODE_ENV && t(u) && console.warn(b(e) + \" is not a styled component and cannot be referred to via component selector. See https://www.styled-components.com/docs/advanced#referring-to-other-components for more details.\"), _e(u, n, r, o);\n }\n var l;\n return e instanceof ye ? r ? (e.inject(r, o), e.getName(o)) : e : g(e) ? function e(t, n) {\n var r,\n o,\n s = [];\n for (var i in t) t.hasOwnProperty(i) && !be(t[i]) && (Array.isArray(t[i]) && t[i].isCss || E(t[i]) ? s.push(Ee(i) + \":\", t[i], \";\") : g(t[i]) ? s.push.apply(s, e(t[i], i)) : s.push(Ee(i) + \": \" + (r = i, null == (o = t[i]) || \"boolean\" == typeof o || \"\" === o ? \"\" : \"number\" != typeof o || 0 === o || r in p || r.startsWith(\"--\") ? String(o).trim() : o + \"px\") + \";\"));\n return n ? [n + \" {\"].concat(s, [\"}\"]) : s;\n }(e) : e.toString();\n}\nvar Ne = function (e) {\n return Array.isArray(e) && (e.isCss = !0), e;\n};\nfunction Ae(e) {\n for (var t = arguments.length, n = new Array(t > 1 ? t - 1 : 0), r = 1; r < t; r++) n[r - 1] = arguments[r];\n return E(e) || g(e) ? Ne(_e(v(S, [e].concat(n)))) : 0 === n.length && 1 === e.length && \"string\" == typeof e[0] ? e : Ne(_e(v(e, n)));\n}\nvar Ce = /invalid hook call/i,\n Ie = new Set(),\n Pe = function (e, t) {\n if (\"production\" !== process.env.NODE_ENV) {\n var n = \"The component \" + e + (t ? ' with the id of \"' + t + '\"' : \"\") + \" has been created dynamically.\\nYou may see this warning because you've called styled inside another component.\\nTo resolve this only create new StyledComponents outside of any render method and function component.\",\n r = console.error;\n try {\n var o = !0;\n console.error = function (e) {\n if (Ce.test(e)) o = !1, Ie.delete(n);else {\n for (var t = arguments.length, s = new Array(t > 1 ? t - 1 : 0), i = 1; i < t; i++) s[i - 1] = arguments[i];\n r.apply(void 0, [e].concat(s));\n }\n }, c(), o && !Ie.has(n) && (console.warn(n), Ie.add(n));\n } catch (e) {\n Ce.test(e.message) && Ie.delete(n);\n } finally {\n console.error = r;\n }\n }\n },\n Oe = function (e, t, n) {\n return void 0 === n && (n = w), e.theme !== n.theme && e.theme || t || n.theme;\n },\n Re = /[!\"#$%&'()*+,./:;<=>?@[\\\\\\]^`{|}~-]+/g,\n De = /(^-|-$)/g;\nfunction je(e) {\n return e.replace(Re, \"-\").replace(De, \"\");\n}\nvar Te = function (e) {\n return Q(te(e) >>> 0);\n};\nfunction xe(e) {\n return \"string\" == typeof e && (\"production\" === process.env.NODE_ENV || e.charAt(0) === e.charAt(0).toLowerCase());\n}\nvar ke = function (e) {\n return \"function\" == typeof e || \"object\" == typeof e && null !== e && !Array.isArray(e);\n },\n Ve = function (e) {\n return \"__proto__\" !== e && \"constructor\" !== e && \"prototype\" !== e;\n };\nfunction Be(e, t, n) {\n var r = e[n];\n ke(t) && ke(r) ? ze(r, t) : e[n] = t;\n}\nfunction ze(e) {\n for (var t = arguments.length, n = new Array(t > 1 ? t - 1 : 0), r = 1; r < t; r++) n[r - 1] = arguments[r];\n for (var o = 0, s = n; o < s.length; o++) {\n var i = s[o];\n if (ke(i)) for (var a in i) Ve(a) && Be(e, i[a], a);\n }\n return e;\n}\nvar Me = r.createContext(),\n Ge = Me.Consumer;\nfunction Le(e) {\n var t = s(Me),\n n = i(function () {\n return function (e, t) {\n if (!e) return D(14);\n if (E(e)) {\n var n = e(t);\n return \"production\" === process.env.NODE_ENV || null !== n && !Array.isArray(n) && \"object\" == typeof n ? n : D(7);\n }\n return Array.isArray(e) || \"object\" != typeof e ? D(8) : t ? y({}, t, {}, e) : e;\n }(e.theme, t);\n }, [e.theme, t]);\n return e.children ? r.createElement(Me.Provider, {\n value: n\n }, e.children) : null;\n}\nvar Fe = {};\nfunction Ye(e, t, n) {\n var o = _(e),\n i = !xe(e),\n a = t.attrs,\n c = void 0 === a ? S : a,\n l = t.componentId,\n d = void 0 === l ? function (e, t) {\n var n = \"string\" != typeof e ? \"sc\" : je(e);\n Fe[n] = (Fe[n] || 0) + 1;\n var r = n + \"-\" + Te(\"5.3.11\" + n + Fe[n]);\n return t ? t + \"-\" + r : r;\n }(t.displayName, t.parentComponentId) : l,\n h = t.displayName,\n p = void 0 === h ? function (e) {\n return xe(e) ? \"styled.\" + e : \"Styled(\" + b(e) + \")\";\n }(e) : h,\n v = t.displayName && t.componentId ? je(t.displayName) + \"-\" + t.componentId : t.componentId || d,\n g = o && e.attrs ? Array.prototype.concat(e.attrs, c).filter(Boolean) : c,\n N = t.shouldForwardProp;\n o && e.shouldForwardProp && (N = t.shouldForwardProp ? function (n, r, o) {\n return e.shouldForwardProp(n, r, o) && t.shouldForwardProp(n, r, o);\n } : e.shouldForwardProp);\n var A,\n C = new oe(n, v, o ? e.componentStyle : void 0),\n I = C.isStatic && 0 === c.length,\n P = function (e, t) {\n return function (e, t, n, r) {\n var o = e.attrs,\n i = e.componentStyle,\n a = e.defaultProps,\n c = e.foldedComponentIds,\n l = e.shouldForwardProp,\n d = e.styledComponentId,\n h = e.target,\n p = function (e, t, n) {\n void 0 === e && (e = w);\n var r = y({}, t, {\n theme: e\n }),\n o = {};\n return n.forEach(function (e) {\n var t,\n n,\n s,\n i = e;\n for (t in E(i) && (i = i(r)), i) r[t] = o[t] = \"className\" === t ? (n = o[t], s = i[t], n && s ? n + \" \" + s : n || s) : i[t];\n }), [r, o];\n }(Oe(t, s(Me), a) || w, t, o),\n m = p[0],\n v = p[1],\n g = function (e, t, n, r) {\n var o = pe(),\n s = fe(),\n i = t ? e.generateAndInjectStyles(w, o, s) : e.generateAndInjectStyles(n, o, s);\n return \"production\" !== process.env.NODE_ENV && !t && r && r(i), i;\n }(i, r, m, \"production\" !== process.env.NODE_ENV ? e.warnTooManyClasses : void 0),\n S = n,\n b = v.$as || t.$as || v.as || t.as || h,\n _ = xe(b),\n N = v !== t ? y({}, t, {}, v) : t,\n A = {};\n for (var C in N) \"$\" !== C[0] && \"as\" !== C && (\"forwardedAs\" === C ? A.as = N[C] : (l ? l(C, f, b) : !_ || f(C)) && (A[C] = N[C]));\n return t.style && v.style !== t.style && (A.style = y({}, t.style, {}, v.style)), A.className = Array.prototype.concat(c, d, g !== d ? g : null, t.className, v.className).filter(Boolean).join(\" \"), A.ref = S, u(b, A);\n }(A, e, t, I);\n };\n return P.displayName = p, (A = r.forwardRef(P)).attrs = g, A.componentStyle = C, A.displayName = p, A.shouldForwardProp = N, A.foldedComponentIds = o ? Array.prototype.concat(e.foldedComponentIds, e.styledComponentId) : S, A.styledComponentId = v, A.target = o ? e.target : e, A.withComponent = function (e) {\n var r = t.componentId,\n o = function (e, t) {\n if (null == e) return {};\n var n,\n r,\n o = {},\n s = Object.keys(e);\n for (r = 0; r < s.length; r++) n = s[r], t.indexOf(n) >= 0 || (o[n] = e[n]);\n return o;\n }(t, [\"componentId\"]),\n s = r && r + \"-\" + (xe(e) ? e : je(b(e)));\n return Ye(e, y({}, o, {\n attrs: g,\n componentId: s\n }), n);\n }, Object.defineProperty(A, \"defaultProps\", {\n get: function () {\n return this._foldedDefaultProps;\n },\n set: function (t) {\n this._foldedDefaultProps = o ? ze({}, e.defaultProps, t) : t;\n }\n }), \"production\" !== process.env.NODE_ENV && (Pe(p, v), A.warnTooManyClasses = function (e, t) {\n var n = {},\n r = !1;\n return function (o) {\n if (!r && (n[o] = !0, Object.keys(n).length >= 200)) {\n var s = t ? ' with the id of \"' + t + '\"' : \"\";\n console.warn(\"Over 200 classes were generated for component \" + e + s + \".\\nConsider using the attrs method, together with a style object for frequently changed styles.\\nExample:\\n const Component = styled.div.attrs(props => ({\\n style: {\\n background: props.background,\\n },\\n }))`width: 100%;`\\n\\n \"), r = !0, n = {};\n }\n };\n }(p, v)), Object.defineProperty(A, \"toString\", {\n value: function () {\n return \".\" + A.styledComponentId;\n }\n }), i && m(A, e, {\n attrs: !0,\n componentStyle: !0,\n displayName: !0,\n foldedComponentIds: !0,\n shouldForwardProp: !0,\n styledComponentId: !0,\n target: !0,\n withComponent: !0\n }), A;\n}\nvar qe = function (e) {\n return function e(t, r, o) {\n if (void 0 === o && (o = w), !n(r)) return D(1, String(r));\n var s = function () {\n return t(r, o, Ae.apply(void 0, arguments));\n };\n return s.withConfig = function (n) {\n return e(t, r, y({}, o, {}, n));\n }, s.attrs = function (n) {\n return e(t, r, y({}, o, {\n attrs: Array.prototype.concat(o.attrs, n).filter(Boolean)\n }));\n }, s;\n }(Ye, e);\n};\n[\"a\", \"abbr\", \"address\", \"area\", \"article\", \"aside\", \"audio\", \"b\", \"base\", \"bdi\", \"bdo\", \"big\", \"blockquote\", \"body\", \"br\", \"button\", \"canvas\", \"caption\", \"cite\", \"code\", \"col\", \"colgroup\", \"data\", \"datalist\", \"dd\", \"del\", \"details\", \"dfn\", \"dialog\", \"div\", \"dl\", \"dt\", \"em\", \"embed\", \"fieldset\", \"figcaption\", \"figure\", \"footer\", \"form\", \"h1\", \"h2\", \"h3\", \"h4\", \"h5\", \"h6\", \"head\", \"header\", \"hgroup\", \"hr\", \"html\", \"i\", \"iframe\", \"img\", \"input\", \"ins\", \"kbd\", \"keygen\", \"label\", \"legend\", \"li\", \"link\", \"main\", \"map\", \"mark\", \"marquee\", \"menu\", \"menuitem\", \"meta\", \"meter\", \"nav\", \"noscript\", \"object\", \"ol\", \"optgroup\", \"option\", \"output\", \"p\", \"param\", \"picture\", \"pre\", \"progress\", \"q\", \"rp\", \"rt\", \"ruby\", \"s\", \"samp\", \"script\", \"section\", \"select\", \"small\", \"source\", \"span\", \"strong\", \"style\", \"sub\", \"summary\", \"sup\", \"table\", \"tbody\", \"td\", \"textarea\", \"tfoot\", \"th\", \"thead\", \"time\", \"title\", \"tr\", \"track\", \"u\", \"ul\", \"var\", \"video\", \"wbr\", \"circle\", \"clipPath\", \"defs\", \"ellipse\", \"foreignObject\", \"g\", \"image\", \"line\", \"linearGradient\", \"marker\", \"mask\", \"path\", \"pattern\", \"polygon\", \"polyline\", \"radialGradient\", \"rect\", \"stop\", \"svg\", \"text\", \"textPath\", \"tspan\"].forEach(function (e) {\n qe[e] = qe(e);\n});\nvar He = function () {\n function e(e, t) {\n this.rules = e, this.componentId = t, this.isStatic = ne(e), X.registerId(this.componentId + 1);\n }\n var t = e.prototype;\n return t.createStyles = function (e, t, n, r) {\n var o = r(_e(this.rules, t, n, r).join(\"\"), \"\"),\n s = this.componentId + e;\n n.insertRules(s, s, o);\n }, t.removeStyles = function (e, t) {\n t.clearRules(this.componentId + e);\n }, t.renderStyles = function (e, t, n, r) {\n e > 2 && X.registerId(this.componentId + e), this.removeStyles(e, n), this.createStyles(e, t, n, r);\n }, e;\n}();\nfunction $e(e) {\n for (var t = arguments.length, n = new Array(t > 1 ? t - 1 : 0), o = 1; o < t; o++) n[o - 1] = arguments[o];\n var i = Ae.apply(void 0, [e].concat(n)),\n a = \"sc-global-\" + Te(JSON.stringify(i)),\n u = new He(i, a);\n function d(e) {\n var t = pe(),\n n = fe(),\n o = s(Me),\n d = c(t.allocateGSInstance(a)).current;\n return \"production\" !== process.env.NODE_ENV && r.Children.count(e.children) && console.warn(\"The global style component \" + a + \" was given child JSX. createGlobalStyle does not render children.\"), \"production\" !== process.env.NODE_ENV && i.some(function (e) {\n return \"string\" == typeof e && -1 !== e.indexOf(\"@import\");\n }) && console.warn(\"Please do not use @import CSS syntax in createGlobalStyle at this time, as the CSSOM APIs we use in production do not handle it well. Instead, we recommend using a library such as react-helmet to inject a typical meta tag to the stylesheet, or simply embedding it manually in your index.html section for a simpler app.\"), t.server && h(d, e, t, o, n), l(function () {\n if (!t.server) return h(d, e, t, o, n), function () {\n return u.removeStyles(d, t);\n };\n }, [d, e, t, o, n]), null;\n }\n function h(e, t, n, r, o) {\n if (u.isStatic) u.renderStyles(e, P, n, o);else {\n var s = y({}, t, {\n theme: Oe(t, r, d.defaultProps)\n });\n u.renderStyles(e, s, n, o);\n }\n }\n return \"production\" !== process.env.NODE_ENV && Pe(a), r.memo(d);\n}\nfunction We(e) {\n \"production\" !== process.env.NODE_ENV && \"undefined\" != typeof navigator && \"ReactNative\" === navigator.product && console.warn(\"`keyframes` cannot be used on ReactNative, only on the web. To do animation in ReactNative please use Animated.\");\n for (var t = arguments.length, n = new Array(t > 1 ? t - 1 : 0), r = 1; r < t; r++) n[r - 1] = arguments[r];\n var o = Ae.apply(void 0, [e].concat(n)).join(\"\"),\n s = Te(o);\n return new ye(s, o);\n}\nvar Ue = function () {\n function e() {\n var e = this;\n this._emitSheetCSS = function () {\n var t = e.instance.toString();\n if (!t) return \"\";\n var n = Y();\n return \"\";\n }, this.getStyleTags = function () {\n return e.sealed ? D(2) : e._emitSheetCSS();\n }, this.getStyleElement = function () {\n var t;\n if (e.sealed) return D(2);\n var n = ((t = {})[N] = \"\", t[\"data-styled-version\"] = \"5.3.11\", t.dangerouslySetInnerHTML = {\n __html: e.instance.toString()\n }, t),\n o = Y();\n return o && (n.nonce = o), [r.createElement(\"style\", y({}, n, {\n key: \"sc-0-0\"\n }))];\n }, this.seal = function () {\n e.sealed = !0;\n }, this.instance = new X({\n isServer: !0\n }), this.sealed = !1;\n }\n var t = e.prototype;\n return t.collectStyles = function (e) {\n return this.sealed ? D(2) : r.createElement(me, {\n sheet: this.instance\n }, e);\n }, t.interleaveWithNodeStream = function (e) {\n return D(3);\n }, e;\n }(),\n Je = function (e) {\n var t = r.forwardRef(function (t, n) {\n var o = s(Me),\n i = e.defaultProps,\n a = Oe(t, o, i);\n return \"production\" !== process.env.NODE_ENV && void 0 === a && console.warn('[withTheme] You are not using a ThemeProvider nor passing a theme prop or a theme in defaultProps in component class \"' + b(e) + '\"'), r.createElement(e, y({}, t, {\n theme: a,\n ref: n\n }));\n });\n return m(t, e), t.displayName = \"WithTheme(\" + b(e) + \")\", t;\n },\n Xe = function () {\n return s(Me);\n },\n Ze = {\n StyleSheet: X,\n masterSheet: de\n };\n\"production\" !== process.env.NODE_ENV && \"undefined\" != typeof navigator && \"ReactNative\" === navigator.product && console.warn(\"It looks like you've imported 'styled-components' on React Native.\\nPerhaps you're looking to import 'styled-components/native'?\\nRead more about this at https://www.styled-components.com/docs/basics#react-native\"), \"production\" !== process.env.NODE_ENV && \"test\" !== process.env.NODE_ENV && \"undefined\" != typeof window && (window[\"__styled-components-init__\"] = window[\"__styled-components-init__\"] || 0, 1 === window[\"__styled-components-init__\"] && console.warn(\"It looks like there are several instances of 'styled-components' initialized in this application. This may cause dynamic styles to not render properly, errors during the rehydration process, a missing theme prop, and makes your application bigger without good reason.\\n\\nSee https://s-c.sh/2BAXzed for more info.\"), window[\"__styled-components-init__\"] += 1);\nexport default qe;\nexport { Ue as ServerStyleSheet, ue as StyleSheetConsumer, ce as StyleSheetContext, me as StyleSheetManager, Ge as ThemeConsumer, Me as ThemeContext, Le as ThemeProvider, Ze as __PRIVATE__, $e as createGlobalStyle, Ae as css, _ as isStyledComponent, We as keyframes, Xe as useTheme, A as version, Je as withTheme };","/******************************************************************************\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***************************************************************************** */\n/* global Reflect, Promise */\n\nvar extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf || {\n __proto__: []\n } instanceof Array && function (d, b) {\n d.__proto__ = b;\n } || function (d, b) {\n for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p];\n };\n return extendStatics(d, b);\n};\nexport function __extends(d, b) {\n if (typeof b !== \"function\" && b !== null) throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() {\n this.constructor = d;\n }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\nexport var __assign = function () {\n __assign = Object.assign || function __assign(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];\n }\n return t;\n}\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length,\n r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc,\n d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);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;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\nexport function __param(paramIndex, decorator) {\n return function (target, key) {\n decorator(target, key, paramIndex);\n };\n}\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) {\n return value instanceof P ? value : new P(function (resolve) {\n resolve(value);\n });\n }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) {\n try {\n step(generator.next(value));\n } catch (e) {\n reject(e);\n }\n }\n function rejected(value) {\n try {\n step(generator[\"throw\"](value));\n } catch (e) {\n reject(e);\n }\n }\n function step(result) {\n result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);\n }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\nexport function __generator(thisArg, body) {\n var _ = {\n label: 0,\n sent: function () {\n if (t[0] & 1) throw t[1];\n return t[1];\n },\n trys: [],\n ops: []\n },\n f,\n y,\n t,\n g;\n return g = {\n next: verb(0),\n \"throw\": verb(1),\n \"return\": verb(2)\n }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function () {\n return this;\n }), g;\n function verb(n) {\n return function (v) {\n return step([n, v]);\n };\n }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (_) try {\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;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0:\n case 1:\n t = op;\n break;\n case 4:\n _.label++;\n return {\n value: op[1],\n done: false\n };\n case 5:\n _.label++;\n y = op[1];\n op = [0];\n continue;\n case 7:\n op = _.ops.pop();\n _.trys.pop();\n continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {\n _ = 0;\n continue;\n }\n if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {\n _.label = op[1];\n break;\n }\n if (op[0] === 6 && _.label < t[1]) {\n _.label = t[1];\n t = op;\n break;\n }\n if (t && _.label < t[2]) {\n _.label = t[2];\n _.ops.push(op);\n break;\n }\n if (t[2]) _.ops.pop();\n _.trys.pop();\n continue;\n }\n op = body.call(thisArg, _);\n } catch (e) {\n op = [6, e];\n y = 0;\n } finally {\n f = t = 0;\n }\n if (op[0] & 5) throw op[1];\n return {\n value: op[0] ? op[1] : void 0,\n done: true\n };\n }\n}\nexport var __createBinding = Object.create ? function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = {\n enumerable: true,\n get: function () {\n return m[k];\n }\n };\n }\n Object.defineProperty(o, k2, desc);\n} : function (o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n};\nexport function __exportStar(m, o) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n}\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator,\n m = s && o[s],\n i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return {\n value: o && o[i++],\n done: !o\n };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o),\n r,\n ar = [],\n e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n } catch (error) {\n e = {\n error: error\n };\n } finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n } finally {\n if (e) throw e.error;\n }\n }\n return ar;\n}\n\n/** @deprecated */\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++) ar = ar.concat(__read(arguments[i]));\n return ar;\n}\n\n/** @deprecated */\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++) for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) r[k] = a[j];\n return r;\n}\nexport function __spreadArray(to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n}\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []),\n i,\n q = [];\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () {\n return this;\n }, i;\n function verb(n) {\n if (g[n]) i[n] = function (v) {\n return new Promise(function (a, b) {\n q.push([n, v, a, b]) > 1 || resume(n, v);\n });\n };\n }\n function resume(n, v) {\n try {\n step(g[n](v));\n } catch (e) {\n settle(q[0][3], e);\n }\n }\n function step(r) {\n r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r);\n }\n function fulfill(value) {\n resume(\"next\", value);\n }\n function reject(value) {\n resume(\"throw\", value);\n }\n function settle(f, v) {\n if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]);\n }\n}\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) {\n throw e;\n }), verb(\"return\"), i[Symbol.iterator] = function () {\n return this;\n }, i;\n function verb(n, f) {\n i[n] = o[n] ? function (v) {\n return (p = !p) ? {\n value: __await(o[n](v)),\n done: n === \"return\"\n } : f ? f(v) : v;\n } : f;\n }\n}\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator],\n i;\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 () {\n return this;\n }, i);\n function verb(n) {\n i[n] = o[n] && function (v) {\n return new Promise(function (resolve, reject) {\n v = o[n](v), settle(resolve, reject, v.done, v.value);\n });\n };\n }\n function settle(resolve, reject, d, v) {\n Promise.resolve(v).then(function (v) {\n resolve({\n value: v,\n done: d\n });\n }, reject);\n }\n}\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) {\n Object.defineProperty(cooked, \"raw\", {\n value: raw\n });\n } else {\n cooked.raw = raw;\n }\n return cooked;\n}\n;\nvar __setModuleDefault = Object.create ? function (o, v) {\n Object.defineProperty(o, \"default\", {\n enumerable: true,\n value: v\n });\n} : function (o, v) {\n o[\"default\"] = v;\n};\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n}\nexport function __importDefault(mod) {\n return mod && mod.__esModule ? mod : {\n default: mod\n };\n}\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\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\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n}\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\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\");\n return kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value), value;\n}\nexport function __classPrivateFieldIn(state, receiver) {\n if (receiver === null || typeof receiver !== \"object\" && typeof receiver !== \"function\") throw new TypeError(\"Cannot use 'in' operator on non-object\");\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\n}","/* Web Font Loader v1.6.28 - (c) Adobe Systems, Google. License: Apache 2.0 */(function () {\n function aa(a, b, c) {\n return a.call.apply(a.bind, arguments);\n }\n function ba(a, b, c) {\n if (!a) throw Error();\n if (2 < arguments.length) {\n var d = Array.prototype.slice.call(arguments, 2);\n return function () {\n var c = Array.prototype.slice.call(arguments);\n Array.prototype.unshift.apply(c, d);\n return a.apply(b, c);\n };\n }\n return function () {\n return a.apply(b, arguments);\n };\n }\n function p(a, b, c) {\n p = Function.prototype.bind && -1 != Function.prototype.bind.toString().indexOf(\"native code\") ? aa : ba;\n return p.apply(null, arguments);\n }\n var q = Date.now || function () {\n return +new Date();\n };\n function ca(a, b) {\n this.a = a;\n this.o = b || a;\n this.c = this.o.document;\n }\n var da = !!window.FontFace;\n function t(a, b, c, d) {\n b = a.c.createElement(b);\n if (c) for (var e in c) c.hasOwnProperty(e) && (\"style\" == e ? b.style.cssText = c[e] : b.setAttribute(e, c[e]));\n d && b.appendChild(a.c.createTextNode(d));\n return b;\n }\n function u(a, b, c) {\n a = a.c.getElementsByTagName(b)[0];\n a || (a = document.documentElement);\n a.insertBefore(c, a.lastChild);\n }\n function v(a) {\n a.parentNode && a.parentNode.removeChild(a);\n }\n function w(a, b, c) {\n b = b || [];\n c = c || [];\n for (var d = a.className.split(/\\s+/), e = 0; e < b.length; e += 1) {\n for (var f = !1, g = 0; g < d.length; g += 1) if (b[e] === d[g]) {\n f = !0;\n break;\n }\n f || d.push(b[e]);\n }\n b = [];\n for (e = 0; e < d.length; e += 1) {\n f = !1;\n for (g = 0; g < c.length; g += 1) if (d[e] === c[g]) {\n f = !0;\n break;\n }\n f || b.push(d[e]);\n }\n a.className = b.join(\" \").replace(/\\s+/g, \" \").replace(/^\\s+|\\s+$/, \"\");\n }\n function y(a, b) {\n for (var c = a.className.split(/\\s+/), d = 0, e = c.length; d < e; d++) if (c[d] == b) return !0;\n return !1;\n }\n function ea(a) {\n return a.o.location.hostname || a.a.location.hostname;\n }\n function z(a, b, c) {\n function d() {\n m && e && f && (m(g), m = null);\n }\n b = t(a, \"link\", {\n rel: \"stylesheet\",\n href: b,\n media: \"all\"\n });\n var e = !1,\n f = !0,\n g = null,\n m = c || null;\n da ? (b.onload = function () {\n e = !0;\n d();\n }, b.onerror = function () {\n e = !0;\n g = Error(\"Stylesheet failed to load\");\n d();\n }) : setTimeout(function () {\n e = !0;\n d();\n }, 0);\n u(a, \"head\", b);\n }\n function A(a, b, c, d) {\n var e = a.c.getElementsByTagName(\"head\")[0];\n if (e) {\n var f = t(a, \"script\", {\n src: b\n }),\n g = !1;\n f.onload = f.onreadystatechange = function () {\n g || this.readyState && \"loaded\" != this.readyState && \"complete\" != this.readyState || (g = !0, c && c(null), f.onload = f.onreadystatechange = null, \"HEAD\" == f.parentNode.tagName && e.removeChild(f));\n };\n e.appendChild(f);\n setTimeout(function () {\n g || (g = !0, c && c(Error(\"Script load timeout\")));\n }, d || 5E3);\n return f;\n }\n return null;\n }\n ;\n function B() {\n this.a = 0;\n this.c = null;\n }\n function C(a) {\n a.a++;\n return function () {\n a.a--;\n D(a);\n };\n }\n function E(a, b) {\n a.c = b;\n D(a);\n }\n function D(a) {\n 0 == a.a && a.c && (a.c(), a.c = null);\n }\n ;\n function F(a) {\n this.a = a || \"-\";\n }\n F.prototype.c = function (a) {\n for (var b = [], c = 0; c < arguments.length; c++) b.push(arguments[c].replace(/[\\W_]+/g, \"\").toLowerCase());\n return b.join(this.a);\n };\n function G(a, b) {\n this.c = a;\n this.f = 4;\n this.a = \"n\";\n var c = (b || \"n4\").match(/^([nio])([1-9])$/i);\n c && (this.a = c[1], this.f = parseInt(c[2], 10));\n }\n function fa(a) {\n return H(a) + \" \" + (a.f + \"00\") + \" 300px \" + I(a.c);\n }\n function I(a) {\n var b = [];\n a = a.split(/,\\s*/);\n for (var c = 0; c < a.length; c++) {\n var d = a[c].replace(/['\"]/g, \"\");\n -1 != d.indexOf(\" \") || /^\\d/.test(d) ? b.push(\"'\" + d + \"'\") : b.push(d);\n }\n return b.join(\",\");\n }\n function J(a) {\n return a.a + a.f;\n }\n function H(a) {\n var b = \"normal\";\n \"o\" === a.a ? b = \"oblique\" : \"i\" === a.a && (b = \"italic\");\n return b;\n }\n function ga(a) {\n var b = 4,\n c = \"n\",\n d = null;\n a && ((d = a.match(/(normal|oblique|italic)/i)) && d[1] && (c = d[1].substr(0, 1).toLowerCase()), (d = a.match(/([1-9]00|normal|bold)/i)) && d[1] && (/bold/i.test(d[1]) ? b = 7 : /[1-9]00/.test(d[1]) && (b = parseInt(d[1].substr(0, 1), 10))));\n return c + b;\n }\n ;\n function ha(a, b) {\n this.c = a;\n this.f = a.o.document.documentElement;\n this.h = b;\n this.a = new F(\"-\");\n this.j = !1 !== b.events;\n this.g = !1 !== b.classes;\n }\n function ia(a) {\n a.g && w(a.f, [a.a.c(\"wf\", \"loading\")]);\n K(a, \"loading\");\n }\n function L(a) {\n if (a.g) {\n var b = y(a.f, a.a.c(\"wf\", \"active\")),\n c = [],\n d = [a.a.c(\"wf\", \"loading\")];\n b || c.push(a.a.c(\"wf\", \"inactive\"));\n w(a.f, c, d);\n }\n K(a, \"inactive\");\n }\n function K(a, b, c) {\n if (a.j && a.h[b]) if (c) a.h[b](c.c, J(c));else a.h[b]();\n }\n ;\n function ja() {\n this.c = {};\n }\n function ka(a, b, c) {\n var d = [],\n e;\n for (e in b) if (b.hasOwnProperty(e)) {\n var f = a.c[e];\n f && d.push(f(b[e], c));\n }\n return d;\n }\n ;\n function M(a, b) {\n this.c = a;\n this.f = b;\n this.a = t(this.c, \"span\", {\n \"aria-hidden\": \"true\"\n }, this.f);\n }\n function N(a) {\n u(a.c, \"body\", a.a);\n }\n function O(a) {\n return \"display:block;position:absolute;top:-9999px;left:-9999px;font-size:300px;width:auto;height:auto;line-height:normal;margin:0;padding:0;font-variant:normal;white-space:nowrap;font-family:\" + I(a.c) + \";\" + (\"font-style:\" + H(a) + \";font-weight:\" + (a.f + \"00\") + \";\");\n }\n ;\n function P(a, b, c, d, e, f) {\n this.g = a;\n this.j = b;\n this.a = d;\n this.c = c;\n this.f = e || 3E3;\n this.h = f || void 0;\n }\n P.prototype.start = function () {\n var a = this.c.o.document,\n b = this,\n c = q(),\n d = new Promise(function (d, e) {\n function f() {\n q() - c >= b.f ? e() : a.fonts.load(fa(b.a), b.h).then(function (a) {\n 1 <= a.length ? d() : setTimeout(f, 25);\n }, function () {\n e();\n });\n }\n f();\n }),\n e = null,\n f = new Promise(function (a, d) {\n e = setTimeout(d, b.f);\n });\n Promise.race([f, d]).then(function () {\n e && (clearTimeout(e), e = null);\n b.g(b.a);\n }, function () {\n b.j(b.a);\n });\n };\n function Q(a, b, c, d, e, f, g) {\n this.v = a;\n this.B = b;\n this.c = c;\n this.a = d;\n this.s = g || \"BESbswy\";\n this.f = {};\n this.w = e || 3E3;\n this.u = f || null;\n this.m = this.j = this.h = this.g = null;\n this.g = new M(this.c, this.s);\n this.h = new M(this.c, this.s);\n this.j = new M(this.c, this.s);\n this.m = new M(this.c, this.s);\n a = new G(this.a.c + \",serif\", J(this.a));\n a = O(a);\n this.g.a.style.cssText = a;\n a = new G(this.a.c + \",sans-serif\", J(this.a));\n a = O(a);\n this.h.a.style.cssText = a;\n a = new G(\"serif\", J(this.a));\n a = O(a);\n this.j.a.style.cssText = a;\n a = new G(\"sans-serif\", J(this.a));\n a = O(a);\n this.m.a.style.cssText = a;\n N(this.g);\n N(this.h);\n N(this.j);\n N(this.m);\n }\n var R = {\n D: \"serif\",\n C: \"sans-serif\"\n },\n S = null;\n function T() {\n if (null === S) {\n var a = /AppleWebKit\\/([0-9]+)(?:\\.([0-9]+))/.exec(window.navigator.userAgent);\n S = !!a && (536 > parseInt(a[1], 10) || 536 === parseInt(a[1], 10) && 11 >= parseInt(a[2], 10));\n }\n return S;\n }\n Q.prototype.start = function () {\n this.f.serif = this.j.a.offsetWidth;\n this.f[\"sans-serif\"] = this.m.a.offsetWidth;\n this.A = q();\n U(this);\n };\n function la(a, b, c) {\n for (var d in R) if (R.hasOwnProperty(d) && b === a.f[R[d]] && c === a.f[R[d]]) return !0;\n return !1;\n }\n function U(a) {\n var b = a.g.a.offsetWidth,\n c = a.h.a.offsetWidth,\n d;\n (d = b === a.f.serif && c === a.f[\"sans-serif\"]) || (d = T() && la(a, b, c));\n d ? q() - a.A >= a.w ? T() && la(a, b, c) && (null === a.u || a.u.hasOwnProperty(a.a.c)) ? V(a, a.v) : V(a, a.B) : ma(a) : V(a, a.v);\n }\n function ma(a) {\n setTimeout(p(function () {\n U(this);\n }, a), 50);\n }\n function V(a, b) {\n setTimeout(p(function () {\n v(this.g.a);\n v(this.h.a);\n v(this.j.a);\n v(this.m.a);\n b(this.a);\n }, a), 0);\n }\n ;\n function W(a, b, c) {\n this.c = a;\n this.a = b;\n this.f = 0;\n this.m = this.j = !1;\n this.s = c;\n }\n var X = null;\n W.prototype.g = function (a) {\n var b = this.a;\n b.g && w(b.f, [b.a.c(\"wf\", a.c, J(a).toString(), \"active\")], [b.a.c(\"wf\", a.c, J(a).toString(), \"loading\"), b.a.c(\"wf\", a.c, J(a).toString(), \"inactive\")]);\n K(b, \"fontactive\", a);\n this.m = !0;\n na(this);\n };\n W.prototype.h = function (a) {\n var b = this.a;\n if (b.g) {\n var c = y(b.f, b.a.c(\"wf\", a.c, J(a).toString(), \"active\")),\n d = [],\n e = [b.a.c(\"wf\", a.c, J(a).toString(), \"loading\")];\n c || d.push(b.a.c(\"wf\", a.c, J(a).toString(), \"inactive\"));\n w(b.f, d, e);\n }\n K(b, \"fontinactive\", a);\n na(this);\n };\n function na(a) {\n 0 == --a.f && a.j && (a.m ? (a = a.a, a.g && w(a.f, [a.a.c(\"wf\", \"active\")], [a.a.c(\"wf\", \"loading\"), a.a.c(\"wf\", \"inactive\")]), K(a, \"active\")) : L(a.a));\n }\n ;\n function oa(a) {\n this.j = a;\n this.a = new ja();\n this.h = 0;\n this.f = this.g = !0;\n }\n oa.prototype.load = function (a) {\n this.c = new ca(this.j, a.context || this.j);\n this.g = !1 !== a.events;\n this.f = !1 !== a.classes;\n pa(this, new ha(this.c, a), a);\n };\n function qa(a, b, c, d, e) {\n var f = 0 == --a.h;\n (a.f || a.g) && setTimeout(function () {\n var a = e || null,\n m = d || null || {};\n if (0 === c.length && f) L(b.a);else {\n b.f += c.length;\n f && (b.j = f);\n var h,\n l = [];\n for (h = 0; h < c.length; h++) {\n var k = c[h],\n n = m[k.c],\n r = b.a,\n x = k;\n r.g && w(r.f, [r.a.c(\"wf\", x.c, J(x).toString(), \"loading\")]);\n K(r, \"fontloading\", x);\n r = null;\n if (null === X) if (window.FontFace) {\n var x = /Gecko.*Firefox\\/(\\d+)/.exec(window.navigator.userAgent),\n xa = /OS X.*Version\\/10\\..*Safari/.exec(window.navigator.userAgent) && /Apple/.exec(window.navigator.vendor);\n X = x ? 42 < parseInt(x[1], 10) : xa ? !1 : !0;\n } else X = !1;\n X ? r = new P(p(b.g, b), p(b.h, b), b.c, k, b.s, n) : r = new Q(p(b.g, b), p(b.h, b), b.c, k, b.s, a, n);\n l.push(r);\n }\n for (h = 0; h < l.length; h++) l[h].start();\n }\n }, 0);\n }\n function pa(a, b, c) {\n var d = [],\n e = c.timeout;\n ia(b);\n var d = ka(a.a, c, a.c),\n f = new W(a.c, b, e);\n a.h = d.length;\n b = 0;\n for (c = d.length; b < c; b++) d[b].load(function (b, d, c) {\n qa(a, f, b, d, c);\n });\n }\n ;\n function ra(a, b) {\n this.c = a;\n this.a = b;\n }\n ra.prototype.load = function (a) {\n function b() {\n if (f[\"__mti_fntLst\" + d]) {\n var c = f[\"__mti_fntLst\" + d](),\n e = [],\n h;\n if (c) for (var l = 0; l < c.length; l++) {\n var k = c[l].fontfamily;\n void 0 != c[l].fontStyle && void 0 != c[l].fontWeight ? (h = c[l].fontStyle + c[l].fontWeight, e.push(new G(k, h))) : e.push(new G(k));\n }\n a(e);\n } else setTimeout(function () {\n b();\n }, 50);\n }\n var c = this,\n d = c.a.projectId,\n e = c.a.version;\n if (d) {\n var f = c.c.o;\n A(this.c, (c.a.api || \"https://fast.fonts.net/jsapi\") + \"/\" + d + \".js\" + (e ? \"?v=\" + e : \"\"), function (e) {\n e ? a([]) : (f[\"__MonotypeConfiguration__\" + d] = function () {\n return c.a;\n }, b());\n }).id = \"__MonotypeAPIScript__\" + d;\n } else a([]);\n };\n function sa(a, b) {\n this.c = a;\n this.a = b;\n }\n sa.prototype.load = function (a) {\n var b,\n c,\n d = this.a.urls || [],\n e = this.a.families || [],\n f = this.a.testStrings || {},\n g = new B();\n b = 0;\n for (c = d.length; b < c; b++) z(this.c, d[b], C(g));\n var m = [];\n b = 0;\n for (c = e.length; b < c; b++) if (d = e[b].split(\":\"), d[1]) for (var h = d[1].split(\",\"), l = 0; l < h.length; l += 1) m.push(new G(d[0], h[l]));else m.push(new G(d[0]));\n E(g, function () {\n a(m, f);\n });\n };\n function ta(a, b) {\n a ? this.c = a : this.c = ua;\n this.a = [];\n this.f = [];\n this.g = b || \"\";\n }\n var ua = \"https://fonts.googleapis.com/css\";\n function va(a, b) {\n for (var c = b.length, d = 0; d < c; d++) {\n var e = b[d].split(\":\");\n 3 == e.length && a.f.push(e.pop());\n var f = \"\";\n 2 == e.length && \"\" != e[1] && (f = \":\");\n a.a.push(e.join(f));\n }\n }\n function wa(a) {\n if (0 == a.a.length) throw Error(\"No fonts to load!\");\n if (-1 != a.c.indexOf(\"kit=\")) return a.c;\n for (var b = a.a.length, c = [], d = 0; d < b; d++) c.push(a.a[d].replace(/ /g, \"+\"));\n b = a.c + \"?family=\" + c.join(\"%7C\");\n 0 < a.f.length && (b += \"&subset=\" + a.f.join(\",\"));\n 0 < a.g.length && (b += \"&text=\" + encodeURIComponent(a.g));\n return b;\n }\n ;\n function ya(a) {\n this.f = a;\n this.a = [];\n this.c = {};\n }\n var za = {\n latin: \"BESbswy\",\n \"latin-ext\": \"\\u00e7\\u00f6\\u00fc\\u011f\\u015f\",\n cyrillic: \"\\u0439\\u044f\\u0416\",\n greek: \"\\u03b1\\u03b2\\u03a3\",\n khmer: \"\\u1780\\u1781\\u1782\",\n Hanuman: \"\\u1780\\u1781\\u1782\"\n },\n Aa = {\n thin: \"1\",\n extralight: \"2\",\n \"extra-light\": \"2\",\n ultralight: \"2\",\n \"ultra-light\": \"2\",\n light: \"3\",\n regular: \"4\",\n book: \"4\",\n medium: \"5\",\n \"semi-bold\": \"6\",\n semibold: \"6\",\n \"demi-bold\": \"6\",\n demibold: \"6\",\n bold: \"7\",\n \"extra-bold\": \"8\",\n extrabold: \"8\",\n \"ultra-bold\": \"8\",\n ultrabold: \"8\",\n black: \"9\",\n heavy: \"9\",\n l: \"3\",\n r: \"4\",\n b: \"7\"\n },\n Ba = {\n i: \"i\",\n italic: \"i\",\n n: \"n\",\n normal: \"n\"\n },\n Ca = /^(thin|(?:(?:extra|ultra)-?)?light|regular|book|medium|(?:(?:semi|demi|extra|ultra)-?)?bold|black|heavy|l|r|b|[1-9]00)?(n|i|normal|italic)?$/;\n function Da(a) {\n for (var b = a.f.length, c = 0; c < b; c++) {\n var d = a.f[c].split(\":\"),\n e = d[0].replace(/\\+/g, \" \"),\n f = [\"n4\"];\n if (2 <= d.length) {\n var g;\n var m = d[1];\n g = [];\n if (m) for (var m = m.split(\",\"), h = m.length, l = 0; l < h; l++) {\n var k;\n k = m[l];\n if (k.match(/^[\\w-]+$/)) {\n var n = Ca.exec(k.toLowerCase());\n if (null == n) k = \"\";else {\n k = n[2];\n k = null == k || \"\" == k ? \"n\" : Ba[k];\n n = n[1];\n if (null == n || \"\" == n) n = \"4\";else var r = Aa[n],\n n = r ? r : isNaN(n) ? \"4\" : n.substr(0, 1);\n k = [k, n].join(\"\");\n }\n } else k = \"\";\n k && g.push(k);\n }\n 0 < g.length && (f = g);\n 3 == d.length && (d = d[2], g = [], d = d ? d.split(\",\") : g, 0 < d.length && (d = za[d[0]]) && (a.c[e] = d));\n }\n a.c[e] || (d = za[e]) && (a.c[e] = d);\n for (d = 0; d < f.length; d += 1) a.a.push(new G(e, f[d]));\n }\n }\n ;\n function Ea(a, b) {\n this.c = a;\n this.a = b;\n }\n var Fa = {\n Arimo: !0,\n Cousine: !0,\n Tinos: !0\n };\n Ea.prototype.load = function (a) {\n var b = new B(),\n c = this.c,\n d = new ta(this.a.api, this.a.text),\n e = this.a.families;\n va(d, e);\n var f = new ya(e);\n Da(f);\n z(c, wa(d), C(b));\n E(b, function () {\n a(f.a, f.c, Fa);\n });\n };\n function Ga(a, b) {\n this.c = a;\n this.a = b;\n }\n Ga.prototype.load = function (a) {\n var b = this.a.id,\n c = this.c.o;\n b ? A(this.c, (this.a.api || \"https://use.typekit.net\") + \"/\" + b + \".js\", function (b) {\n if (b) a([]);else if (c.Typekit && c.Typekit.config && c.Typekit.config.fn) {\n b = c.Typekit.config.fn;\n for (var e = [], f = 0; f < b.length; f += 2) for (var g = b[f], m = b[f + 1], h = 0; h < m.length; h++) e.push(new G(g, m[h]));\n try {\n c.Typekit.load({\n events: !1,\n classes: !1,\n async: !0\n });\n } catch (l) {}\n a(e);\n }\n }, 2E3) : a([]);\n };\n function Ha(a, b) {\n this.c = a;\n this.f = b;\n this.a = [];\n }\n Ha.prototype.load = function (a) {\n var b = this.f.id,\n c = this.c.o,\n d = this;\n b ? (c.__webfontfontdeckmodule__ || (c.__webfontfontdeckmodule__ = {}), c.__webfontfontdeckmodule__[b] = function (b, c) {\n for (var g = 0, m = c.fonts.length; g < m; ++g) {\n var h = c.fonts[g];\n d.a.push(new G(h.name, ga(\"font-weight:\" + h.weight + \";font-style:\" + h.style)));\n }\n a(d.a);\n }, A(this.c, (this.f.api || \"https://f.fontdeck.com/s/css/js/\") + ea(this.c) + \"/\" + b + \".js\", function (b) {\n b && a([]);\n })) : a([]);\n };\n var Y = new oa(window);\n Y.a.c.custom = function (a, b) {\n return new sa(b, a);\n };\n Y.a.c.fontdeck = function (a, b) {\n return new Ha(b, a);\n };\n Y.a.c.monotype = function (a, b) {\n return new ra(b, a);\n };\n Y.a.c.typekit = function (a, b) {\n return new Ga(b, a);\n };\n Y.a.c.google = function (a, b) {\n return new Ea(b, a);\n };\n var Z = {\n load: p(Y.load, Y)\n };\n \"function\" === typeof define && define.amd ? define(function () {\n return Z;\n }) : \"undefined\" !== typeof module && module.exports ? module.exports = Z : (window.WebFont = Z, window.WebFontConfig && Y.load(window.WebFontConfig));\n})();","require('../../modules/es6.object.assign');\nmodule.exports = require('../../modules/_core').Object.assign;\n","module.exports = function (it) {\n if (typeof it != 'function') throw TypeError(it + ' is not a function!');\n return it;\n};\n","var isObject = require('./_is-object');\nmodule.exports = function (it) {\n if (!isObject(it)) throw TypeError(it + ' is not an object!');\n return it;\n};\n","// false -> Array#indexOf\n// true -> Array#includes\nvar toIObject = require('./_to-iobject');\nvar toLength = require('./_to-length');\nvar toAbsoluteIndex = require('./_to-absolute-index');\nmodule.exports = function (IS_INCLUDES) {\n return function ($this, el, fromIndex) {\n var O = toIObject($this);\n var length = toLength(O.length);\n var index = toAbsoluteIndex(fromIndex, length);\n var value;\n // Array#includes uses SameValueZero equality algorithm\n // eslint-disable-next-line no-self-compare\n if (IS_INCLUDES && el != el) while (length > index) {\n value = O[index++];\n // eslint-disable-next-line no-self-compare\n if (value != value) return true;\n // Array#indexOf ignores holes, Array#includes - not\n } else for (;length > index; index++) if (IS_INCLUDES || index in O) {\n if (O[index] === el) return IS_INCLUDES || index || 0;\n } return !IS_INCLUDES && -1;\n };\n};\n","var toString = {}.toString;\n\nmodule.exports = function (it) {\n return toString.call(it).slice(8, -1);\n};\n","var core = module.exports = { version: '2.6.12' };\nif (typeof __e == 'number') __e = core; // eslint-disable-line no-undef\n","// optional / simple context binding\nvar aFunction = require('./_a-function');\nmodule.exports = function (fn, that, length) {\n aFunction(fn);\n if (that === undefined) return fn;\n switch (length) {\n case 1: return function (a) {\n return fn.call(that, a);\n };\n case 2: return function (a, b) {\n return fn.call(that, a, b);\n };\n case 3: return function (a, b, c) {\n return fn.call(that, a, b, c);\n };\n }\n return function (/* ...args */) {\n return fn.apply(that, arguments);\n };\n};\n","// 7.2.1 RequireObjectCoercible(argument)\nmodule.exports = function (it) {\n if (it == undefined) throw TypeError(\"Can't call method on \" + it);\n return it;\n};\n","// Thank's IE8 for his funny defineProperty\nmodule.exports = !require('./_fails')(function () {\n return Object.defineProperty({}, 'a', { get: function () { return 7; } }).a != 7;\n});\n","var isObject = require('./_is-object');\nvar document = require('./_global').document;\n// typeof document.createElement is 'object' in old IE\nvar is = isObject(document) && isObject(document.createElement);\nmodule.exports = function (it) {\n return is ? document.createElement(it) : {};\n};\n","// IE 8- don't enum bug keys\nmodule.exports = (\n 'constructor,hasOwnProperty,isPrototypeOf,propertyIsEnumerable,toLocaleString,toString,valueOf'\n).split(',');\n","var global = require('./_global');\nvar core = require('./_core');\nvar ctx = require('./_ctx');\nvar hide = require('./_hide');\nvar has = require('./_has');\nvar PROTOTYPE = 'prototype';\n\nvar $export = function (type, name, source) {\n var IS_FORCED = type & $export.F;\n var IS_GLOBAL = type & $export.G;\n var IS_STATIC = type & $export.S;\n var IS_PROTO = type & $export.P;\n var IS_BIND = type & $export.B;\n var IS_WRAP = type & $export.W;\n var exports = IS_GLOBAL ? core : core[name] || (core[name] = {});\n var expProto = exports[PROTOTYPE];\n var target = IS_GLOBAL ? global : IS_STATIC ? global[name] : (global[name] || {})[PROTOTYPE];\n var key, own, out;\n if (IS_GLOBAL) source = name;\n for (key in source) {\n // contains in native\n own = !IS_FORCED && target && target[key] !== undefined;\n if (own && has(exports, key)) continue;\n // export native or passed\n out = own ? target[key] : source[key];\n // prevent global pollution for namespaces\n exports[key] = IS_GLOBAL && typeof target[key] != 'function' ? source[key]\n // bind timers to global for call from export context\n : IS_BIND && own ? ctx(out, global)\n // wrap global constructors for prevent change them in library\n : IS_WRAP && target[key] == out ? (function (C) {\n var F = function (a, b, c) {\n if (this instanceof C) {\n switch (arguments.length) {\n case 0: return new C();\n case 1: return new C(a);\n case 2: return new C(a, b);\n } return new C(a, b, c);\n } return C.apply(this, arguments);\n };\n F[PROTOTYPE] = C[PROTOTYPE];\n return F;\n // make static versions for prototype methods\n })(out) : IS_PROTO && typeof out == 'function' ? ctx(Function.call, out) : out;\n // export proto methods to core.%CONSTRUCTOR%.methods.%NAME%\n if (IS_PROTO) {\n (exports.virtual || (exports.virtual = {}))[key] = out;\n // export proto methods to core.%CONSTRUCTOR%.prototype.%NAME%\n if (type & $export.R && expProto && !expProto[key]) hide(expProto, key, out);\n }\n }\n};\n// type bitmap\n$export.F = 1; // forced\n$export.G = 2; // global\n$export.S = 4; // static\n$export.P = 8; // proto\n$export.B = 16; // bind\n$export.W = 32; // wrap\n$export.U = 64; // safe\n$export.R = 128; // real proto method for `library`\nmodule.exports = $export;\n","module.exports = function (exec) {\n try {\n return !!exec();\n } catch (e) {\n return true;\n }\n};\n","// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\nvar global = module.exports = typeof window != 'undefined' && window.Math == Math\n ? window : typeof self != 'undefined' && self.Math == Math ? self\n // eslint-disable-next-line no-new-func\n : Function('return this')();\nif (typeof __g == 'number') __g = global; // eslint-disable-line no-undef\n","var hasOwnProperty = {}.hasOwnProperty;\nmodule.exports = function (it, key) {\n return hasOwnProperty.call(it, key);\n};\n","var dP = require('./_object-dp');\nvar createDesc = require('./_property-desc');\nmodule.exports = require('./_descriptors') ? function (object, key, value) {\n return dP.f(object, key, createDesc(1, value));\n} : function (object, key, value) {\n object[key] = value;\n return object;\n};\n","module.exports = !require('./_descriptors') && !require('./_fails')(function () {\n return Object.defineProperty(require('./_dom-create')('div'), 'a', { get: function () { return 7; } }).a != 7;\n});\n","// fallback for non-array-like ES3 and non-enumerable old V8 strings\nvar cof = require('./_cof');\n// eslint-disable-next-line no-prototype-builtins\nmodule.exports = Object('z').propertyIsEnumerable(0) ? Object : function (it) {\n return cof(it) == 'String' ? it.split('') : Object(it);\n};\n","module.exports = function (it) {\n return typeof it === 'object' ? it !== null : typeof it === 'function';\n};\n","module.exports = true;\n","'use strict';\n// 19.1.2.1 Object.assign(target, source, ...)\nvar DESCRIPTORS = require('./_descriptors');\nvar getKeys = require('./_object-keys');\nvar gOPS = require('./_object-gops');\nvar pIE = require('./_object-pie');\nvar toObject = require('./_to-object');\nvar IObject = require('./_iobject');\nvar $assign = Object.assign;\n\n// should work with symbols and should have deterministic property order (V8 bug)\nmodule.exports = !$assign || require('./_fails')(function () {\n var A = {};\n var B = {};\n // eslint-disable-next-line no-undef\n var S = Symbol();\n var K = 'abcdefghijklmnopqrst';\n A[S] = 7;\n K.split('').forEach(function (k) { B[k] = k; });\n return $assign({}, A)[S] != 7 || Object.keys($assign({}, B)).join('') != K;\n}) ? function assign(target, source) { // eslint-disable-line no-unused-vars\n var T = toObject(target);\n var aLen = arguments.length;\n var index = 1;\n var getSymbols = gOPS.f;\n var isEnum = pIE.f;\n while (aLen > index) {\n var S = IObject(arguments[index++]);\n var keys = getSymbols ? getKeys(S).concat(getSymbols(S)) : getKeys(S);\n var length = keys.length;\n var j = 0;\n var key;\n while (length > j) {\n key = keys[j++];\n if (!DESCRIPTORS || isEnum.call(S, key)) T[key] = S[key];\n }\n } return T;\n} : $assign;\n","var anObject = require('./_an-object');\nvar IE8_DOM_DEFINE = require('./_ie8-dom-define');\nvar toPrimitive = require('./_to-primitive');\nvar dP = Object.defineProperty;\n\nexports.f = require('./_descriptors') ? Object.defineProperty : function defineProperty(O, P, Attributes) {\n anObject(O);\n P = toPrimitive(P, true);\n anObject(Attributes);\n if (IE8_DOM_DEFINE) try {\n return dP(O, P, Attributes);\n } catch (e) { /* empty */ }\n if ('get' in Attributes || 'set' in Attributes) throw TypeError('Accessors not supported!');\n if ('value' in Attributes) O[P] = Attributes.value;\n return O;\n};\n","exports.f = Object.getOwnPropertySymbols;\n","var has = require('./_has');\nvar toIObject = require('./_to-iobject');\nvar arrayIndexOf = require('./_array-includes')(false);\nvar IE_PROTO = require('./_shared-key')('IE_PROTO');\n\nmodule.exports = function (object, names) {\n var O = toIObject(object);\n var i = 0;\n var result = [];\n var key;\n for (key in O) if (key != IE_PROTO) has(O, key) && result.push(key);\n // Don't enum bug & hidden keys\n while (names.length > i) if (has(O, key = names[i++])) {\n ~arrayIndexOf(result, key) || result.push(key);\n }\n return result;\n};\n","// 19.1.2.14 / 15.2.3.14 Object.keys(O)\nvar $keys = require('./_object-keys-internal');\nvar enumBugKeys = require('./_enum-bug-keys');\n\nmodule.exports = Object.keys || function keys(O) {\n return $keys(O, enumBugKeys);\n};\n","exports.f = {}.propertyIsEnumerable;\n","module.exports = function (bitmap, value) {\n return {\n enumerable: !(bitmap & 1),\n configurable: !(bitmap & 2),\n writable: !(bitmap & 4),\n value: value\n };\n};\n","var shared = require('./_shared')('keys');\nvar uid = require('./_uid');\nmodule.exports = function (key) {\n return shared[key] || (shared[key] = uid(key));\n};\n","var core = require('./_core');\nvar global = require('./_global');\nvar SHARED = '__core-js_shared__';\nvar store = global[SHARED] || (global[SHARED] = {});\n\n(module.exports = function (key, value) {\n return store[key] || (store[key] = value !== undefined ? value : {});\n})('versions', []).push({\n version: core.version,\n mode: require('./_library') ? 'pure' : 'global',\n copyright: '© 2020 Denis Pushkarev (zloirock.ru)'\n});\n","var toInteger = require('./_to-integer');\nvar max = Math.max;\nvar min = Math.min;\nmodule.exports = function (index, length) {\n index = toInteger(index);\n return index < 0 ? max(index + length, 0) : min(index, length);\n};\n","// 7.1.4 ToInteger\nvar ceil = Math.ceil;\nvar floor = Math.floor;\nmodule.exports = function (it) {\n return isNaN(it = +it) ? 0 : (it > 0 ? floor : ceil)(it);\n};\n","// to indexed object, toObject with fallback for non-array-like ES3 strings\nvar IObject = require('./_iobject');\nvar defined = require('./_defined');\nmodule.exports = function (it) {\n return IObject(defined(it));\n};\n","// 7.1.15 ToLength\nvar toInteger = require('./_to-integer');\nvar min = Math.min;\nmodule.exports = function (it) {\n return it > 0 ? min(toInteger(it), 0x1fffffffffffff) : 0; // pow(2, 53) - 1 == 9007199254740991\n};\n","// 7.1.13 ToObject(argument)\nvar defined = require('./_defined');\nmodule.exports = function (it) {\n return Object(defined(it));\n};\n","// 7.1.1 ToPrimitive(input [, PreferredType])\nvar isObject = require('./_is-object');\n// instead of the ES6 spec version, we didn't implement @@toPrimitive case\n// and the second argument - flag - preferred type is a string\nmodule.exports = function (it, S) {\n if (!isObject(it)) return it;\n var fn, val;\n if (S && typeof (fn = it.toString) == 'function' && !isObject(val = fn.call(it))) return val;\n if (typeof (fn = it.valueOf) == 'function' && !isObject(val = fn.call(it))) return val;\n if (!S && typeof (fn = it.toString) == 'function' && !isObject(val = fn.call(it))) return val;\n throw TypeError(\"Can't convert object to primitive value\");\n};\n","var id = 0;\nvar px = Math.random();\nmodule.exports = function (key) {\n return 'Symbol('.concat(key === undefined ? '' : key, ')_', (++id + px).toString(36));\n};\n","// 19.1.3.1 Object.assign(target, source)\nvar $export = require('./_export');\n\n$export($export.S + $export.F, 'Object', { assign: require('./_object-assign') });\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nexports.__esModule = true;\nexports.withPrefix = withPrefix;\nexports.withAssetPrefix = withAssetPrefix;\nexports.navigate = exports.default = void 0;\n\nvar _objectWithoutPropertiesLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutPropertiesLoose\"));\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar _extends2 = _interopRequireDefault(require(\"@babel/runtime/helpers/extends\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _reachRouter = require(\"@gatsbyjs/reach-router\");\n\nvar _utils = require(\"@gatsbyjs/reach-router/lib/utils\");\n\nvar _parsePath = require(\"./parse-path\");\n\nexports.parsePath = _parsePath.parsePath;\nvar _excluded = [\"to\", \"getProps\", \"onClick\", \"onMouseEnter\", \"activeClassName\", \"activeStyle\", \"innerRef\", \"partiallyActive\", \"state\", \"replace\", \"_location\"];\n\nvar isAbsolutePath = function isAbsolutePath(path) {\n return path === null || path === void 0 ? void 0 : path.startsWith(\"/\");\n};\n\nfunction withPrefix(path, prefix) {\n var _ref, _prefix;\n\n if (prefix === void 0) {\n prefix = getGlobalBasePrefix();\n }\n\n if (!isLocalLink(path)) {\n return path;\n }\n\n if (path.startsWith(\"./\") || path.startsWith(\"../\")) {\n return path;\n }\n\n var base = (_ref = (_prefix = prefix) !== null && _prefix !== void 0 ? _prefix : getGlobalPathPrefix()) !== null && _ref !== void 0 ? _ref : \"/\";\n return \"\" + (base !== null && base !== void 0 && base.endsWith(\"/\") ? base.slice(0, -1) : base) + (path.startsWith(\"/\") ? path : \"/\" + path);\n} // These global values are wrapped in typeof clauses to ensure the values exist.\n// This is especially problematic in unit testing of this component.\n\n\nvar getGlobalPathPrefix = function getGlobalPathPrefix() {\n return process.env.NODE_ENV !== \"production\" ? typeof __PATH_PREFIX__ !== \"undefined\" ? __PATH_PREFIX__ : undefined : __PATH_PREFIX__;\n};\n\nvar getGlobalBasePrefix = function getGlobalBasePrefix() {\n return process.env.NODE_ENV !== \"production\" ? typeof __BASE_PATH__ !== \"undefined\" ? __BASE_PATH__ : undefined : __BASE_PATH__;\n};\n\nvar isLocalLink = function isLocalLink(path) {\n return path && !path.startsWith(\"http://\") && !path.startsWith(\"https://\") && !path.startsWith(\"//\");\n};\n\nfunction withAssetPrefix(path) {\n return withPrefix(path, getGlobalPathPrefix());\n}\n\nfunction absolutify(path, current) {\n // If it's already absolute, return as-is\n if (isAbsolutePath(path)) {\n return path;\n }\n\n return (0, _utils.resolve)(path, current);\n}\n\nvar rewriteLinkPath = function rewriteLinkPath(path, relativeTo) {\n if (typeof path === \"number\") {\n return path;\n }\n\n if (!isLocalLink(path)) {\n return path;\n }\n\n return isAbsolutePath(path) ? withPrefix(path) : absolutify(path, relativeTo);\n};\n\nvar NavLinkPropTypes = {\n activeClassName: _propTypes.default.string,\n activeStyle: _propTypes.default.object,\n partiallyActive: _propTypes.default.bool\n}; // Set up IntersectionObserver\n\nvar createIntersectionObserver = function createIntersectionObserver(el, cb) {\n var io = new window.IntersectionObserver(function (entries) {\n entries.forEach(function (entry) {\n if (el === entry.target) {\n // Check if element is within viewport, remove listener, destroy observer, and run link callback.\n // MSEdge doesn't currently support isIntersecting, so also test for an intersectionRatio > 0\n if (entry.isIntersecting || entry.intersectionRatio > 0) {\n io.unobserve(el);\n io.disconnect();\n cb();\n }\n }\n });\n }); // Add element to the observer\n\n io.observe(el);\n return {\n instance: io,\n el: el\n };\n};\n\nfunction GatsbyLinkLocationWrapper(props) {\n return /*#__PURE__*/_react.default.createElement(_reachRouter.Location, null, function (_ref2) {\n var location = _ref2.location;\n return /*#__PURE__*/_react.default.createElement(GatsbyLink, (0, _extends2.default)({}, props, {\n _location: location\n }));\n });\n}\n\nvar GatsbyLink = /*#__PURE__*/function (_React$Component) {\n (0, _inheritsLoose2.default)(GatsbyLink, _React$Component);\n\n function GatsbyLink(props) {\n var _this;\n\n _this = _React$Component.call(this, props) || this; // Default to no support for IntersectionObserver\n\n _this.defaultGetProps = function (_ref3) {\n var isPartiallyCurrent = _ref3.isPartiallyCurrent,\n isCurrent = _ref3.isCurrent;\n\n if (_this.props.partiallyActive ? isPartiallyCurrent : isCurrent) {\n return {\n className: [_this.props.className, _this.props.activeClassName].filter(Boolean).join(\" \"),\n style: (0, _extends2.default)({}, _this.props.style, _this.props.activeStyle)\n };\n }\n\n return null;\n };\n\n var IOSupported = false;\n\n if (typeof window !== \"undefined\" && window.IntersectionObserver) {\n IOSupported = true;\n }\n\n _this.state = {\n IOSupported: IOSupported\n };\n _this.handleRef = _this.handleRef.bind((0, _assertThisInitialized2.default)(_this));\n return _this;\n }\n\n var _proto = GatsbyLink.prototype;\n\n _proto._prefetch = function _prefetch() {\n var currentPath = window.location.pathname; // reach router should have the correct state\n\n if (this.props._location && this.props._location.pathname) {\n currentPath = this.props._location.pathname;\n }\n\n var rewrittenPath = rewriteLinkPath(this.props.to, currentPath);\n var newPathName = (0, _parsePath.parsePath)(rewrittenPath).pathname; // Prefech is used to speed up next navigations. When you use it on the current navigation,\n // there could be a race-condition where Chrome uses the stale data instead of waiting for the network to complete\n\n if (currentPath !== newPathName) {\n ___loader.enqueue(newPathName);\n }\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n // Preserve non IO functionality if no support\n if (this.props.to !== prevProps.to && !this.state.IOSupported) {\n this._prefetch();\n }\n };\n\n _proto.componentDidMount = function componentDidMount() {\n // Preserve non IO functionality if no support\n if (!this.state.IOSupported) {\n this._prefetch();\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n if (!this.io) {\n return;\n }\n\n var _this$io = this.io,\n instance = _this$io.instance,\n el = _this$io.el;\n instance.unobserve(el);\n instance.disconnect();\n };\n\n _proto.handleRef = function handleRef(ref) {\n var _this2 = this;\n\n if (this.props.innerRef && this.props.innerRef.hasOwnProperty(\"current\")) {\n this.props.innerRef.current = ref;\n } else if (this.props.innerRef) {\n this.props.innerRef(ref);\n }\n\n if (this.state.IOSupported && ref) {\n // If IO supported and element reference found, setup Observer functionality\n this.io = createIntersectionObserver(ref, function () {\n _this2._prefetch();\n });\n }\n };\n\n _proto.render = function render() {\n var _this3 = this;\n\n var _this$props = this.props,\n to = _this$props.to,\n _this$props$getProps = _this$props.getProps,\n getProps = _this$props$getProps === void 0 ? this.defaultGetProps : _this$props$getProps,\n _onClick = _this$props.onClick,\n _onMouseEnter = _this$props.onMouseEnter,\n $activeClassName = _this$props.activeClassName,\n $activeStyle = _this$props.activeStyle,\n $innerRef = _this$props.innerRef,\n partiallyActive = _this$props.partiallyActive,\n state = _this$props.state,\n replace = _this$props.replace,\n _location = _this$props._location,\n rest = (0, _objectWithoutPropertiesLoose2.default)(_this$props, _excluded);\n\n if (process.env.NODE_ENV !== \"production\" && !isLocalLink(to)) {\n console.warn(\"External link \" + to + \" was detected in a Link component. Use the Link component only for internal links. See: https://gatsby.dev/internal-links\");\n }\n\n var prefixedTo = rewriteLinkPath(to, _location.pathname);\n\n if (!isLocalLink(prefixedTo)) {\n return /*#__PURE__*/_react.default.createElement(\"a\", (0, _extends2.default)({\n href: prefixedTo\n }, rest));\n }\n\n return /*#__PURE__*/_react.default.createElement(_reachRouter.Link, (0, _extends2.default)({\n to: prefixedTo,\n state: state,\n getProps: getProps,\n innerRef: this.handleRef,\n onMouseEnter: function onMouseEnter(e) {\n if (_onMouseEnter) {\n _onMouseEnter(e);\n }\n\n ___loader.hovering((0, _parsePath.parsePath)(prefixedTo).pathname);\n },\n onClick: function onClick(e) {\n if (_onClick) {\n _onClick(e);\n }\n\n if (e.button === 0 && // ignore right clicks\n !_this3.props.target && // let browser handle \"target=_blank\"\n !e.defaultPrevented && // onClick prevented default\n !e.metaKey && // ignore clicks with modifier keys...\n !e.altKey && !e.ctrlKey && !e.shiftKey) {\n e.preventDefault();\n var shouldReplace = replace;\n\n var isCurrent = encodeURI(prefixedTo) === _location.pathname;\n\n if (typeof replace !== \"boolean\" && isCurrent) {\n shouldReplace = true;\n } // Make sure the necessary scripts and data are\n // loaded before continuing.\n\n\n window.___navigate(prefixedTo, {\n state: state,\n replace: shouldReplace\n });\n }\n\n return true;\n }\n }, rest));\n };\n\n return GatsbyLink;\n}(_react.default.Component);\n\nGatsbyLink.propTypes = (0, _extends2.default)({}, NavLinkPropTypes, {\n onClick: _propTypes.default.func,\n to: _propTypes.default.string.isRequired,\n replace: _propTypes.default.bool,\n state: _propTypes.default.object\n});\n\nvar _default = /*#__PURE__*/_react.default.forwardRef(function (props, ref) {\n return /*#__PURE__*/_react.default.createElement(GatsbyLinkLocationWrapper, (0, _extends2.default)({\n innerRef: ref\n }, props));\n});\n\nexports.default = _default;\n\nvar navigate = function navigate(to, options) {\n window.___navigate(rewriteLinkPath(to, window.location.pathname), options);\n};\n\nexports.navigate = navigate;","\"use strict\";\n\nexports.__esModule = true;\nexports.parsePath = parsePath;\n\nfunction parsePath(path) {\n var pathname = path || \"/\";\n var search = \"\";\n var hash = \"\";\n var hashIndex = pathname.indexOf(\"#\");\n\n if (hashIndex !== -1) {\n hash = pathname.substr(hashIndex);\n pathname = pathname.substr(0, hashIndex);\n }\n\n var searchIndex = pathname.indexOf(\"?\");\n\n if (searchIndex !== -1) {\n search = pathname.substr(searchIndex);\n pathname = pathname.substr(0, searchIndex);\n }\n\n return {\n pathname: pathname,\n search: search === \"?\" ? \"\" : search,\n hash: hash === \"#\" ? \"\" : hash\n };\n}","\"use strict\";\n\nexports.__esModule = true;\nexports.useScrollRestoration = exports.ScrollContext = void 0;\n\nvar _scrollHandler = require(\"./scroll-handler\");\n\nexports.ScrollContext = _scrollHandler.ScrollHandler;\n\nvar _useScrollRestoration = require(\"./use-scroll-restoration\");\n\nexports.useScrollRestoration = _useScrollRestoration.useScrollRestoration;","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nexports.__esModule = true;\nexports.ScrollHandler = exports.ScrollContext = void 0;\n\nvar _assertThisInitialized2 = _interopRequireDefault(require(\"@babel/runtime/helpers/assertThisInitialized\"));\n\nvar _inheritsLoose2 = _interopRequireDefault(require(\"@babel/runtime/helpers/inheritsLoose\"));\n\nvar React = _interopRequireWildcard(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _sessionStorage = require(\"./session-storage\");\n\nfunction _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== \"function\") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }\n\nfunction _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== \"object\" && typeof obj !== \"function\") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== \"default\" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }\n\nvar ScrollContext = /*#__PURE__*/React.createContext(new _sessionStorage.SessionStorage());\nexports.ScrollContext = ScrollContext;\nScrollContext.displayName = \"GatsbyScrollContext\";\n\nvar ScrollHandler = /*#__PURE__*/function (_React$Component) {\n (0, _inheritsLoose2.default)(ScrollHandler, _React$Component);\n\n function ScrollHandler() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n _this._stateStorage = new _sessionStorage.SessionStorage();\n _this._isTicking = false;\n _this._latestKnownScrollY = 0;\n\n _this.scrollListener = function () {\n _this._latestKnownScrollY = window.scrollY;\n\n if (!_this._isTicking) {\n _this._isTicking = true;\n requestAnimationFrame(_this._saveScroll.bind((0, _assertThisInitialized2.default)(_this)));\n }\n };\n\n _this.windowScroll = function (position, prevProps) {\n if (_this.shouldUpdateScroll(prevProps, _this.props)) {\n window.scrollTo(0, position);\n }\n };\n\n _this.scrollToHash = function (hash, prevProps) {\n var node = document.getElementById(hash.substring(1));\n\n if (node && _this.shouldUpdateScroll(prevProps, _this.props)) {\n node.scrollIntoView();\n }\n };\n\n _this.shouldUpdateScroll = function (prevRouterProps, routerProps) {\n var shouldUpdateScroll = _this.props.shouldUpdateScroll;\n\n if (!shouldUpdateScroll) {\n return true;\n } // Hack to allow accessing this._stateStorage.\n\n\n return shouldUpdateScroll.call((0, _assertThisInitialized2.default)(_this), prevRouterProps, routerProps);\n };\n\n return _this;\n }\n\n var _proto = ScrollHandler.prototype;\n\n _proto._saveScroll = function _saveScroll() {\n var key = this.props.location.key || null;\n\n if (key) {\n this._stateStorage.save(this.props.location, key, this._latestKnownScrollY);\n }\n\n this._isTicking = false;\n };\n\n _proto.componentDidMount = function componentDidMount() {\n window.addEventListener(\"scroll\", this.scrollListener);\n var scrollPosition;\n var _this$props$location = this.props.location,\n key = _this$props$location.key,\n hash = _this$props$location.hash;\n\n if (key) {\n scrollPosition = this._stateStorage.read(this.props.location, key);\n }\n\n if (scrollPosition) {\n this.windowScroll(scrollPosition, undefined);\n } else if (hash) {\n this.scrollToHash(decodeURI(hash), undefined);\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n window.removeEventListener(\"scroll\", this.scrollListener);\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n var _this$props$location2 = this.props.location,\n hash = _this$props$location2.hash,\n key = _this$props$location2.key;\n var scrollPosition;\n\n if (key) {\n scrollPosition = this._stateStorage.read(this.props.location, key);\n }\n /** There are two pieces of state: the browser url and\n * history state which keeps track of scroll position\n * Native behaviour prescribes that we ought to restore scroll position\n * when a user navigates back in their browser (this is the `POP` action)\n * Currently, reach router has a bug that prevents this at https://github.com/reach/router/issues/228\n * So we _always_ stick to the url as a source of truth — if the url\n * contains a hash, we scroll to it\n */\n\n\n if (hash) {\n this.scrollToHash(decodeURI(hash), prevProps);\n } else {\n this.windowScroll(scrollPosition, prevProps);\n }\n };\n\n _proto.render = function render() {\n return /*#__PURE__*/React.createElement(ScrollContext.Provider, {\n value: this._stateStorage\n }, this.props.children);\n };\n\n return ScrollHandler;\n}(React.Component);\n\nexports.ScrollHandler = ScrollHandler;\nScrollHandler.propTypes = {\n shouldUpdateScroll: _propTypes.default.func,\n children: _propTypes.default.element.isRequired,\n location: _propTypes.default.object.isRequired\n};","\"use strict\";\n\nexports.__esModule = true;\nexports.SessionStorage = void 0;\nvar STATE_KEY_PREFIX = \"@@scroll|\";\nvar GATSBY_ROUTER_SCROLL_STATE = \"___GATSBY_REACT_ROUTER_SCROLL\";\n\nvar SessionStorage = /*#__PURE__*/function () {\n function SessionStorage() {}\n\n var _proto = SessionStorage.prototype;\n\n _proto.read = function read(location, key) {\n var stateKey = this.getStateKey(location, key);\n\n try {\n var value = window.sessionStorage.getItem(stateKey);\n return value ? JSON.parse(value) : 0;\n } catch (e) {\n if (process.env.NODE_ENV !== \"production\") {\n console.warn(\"[gatsby-react-router-scroll] Unable to access sessionStorage; sessionStorage is not available.\");\n }\n\n if (window && window[GATSBY_ROUTER_SCROLL_STATE] && window[GATSBY_ROUTER_SCROLL_STATE][stateKey]) {\n return window[GATSBY_ROUTER_SCROLL_STATE][stateKey];\n }\n\n return 0;\n }\n };\n\n _proto.save = function save(location, key, value) {\n var stateKey = this.getStateKey(location, key);\n var storedValue = JSON.stringify(value);\n\n try {\n window.sessionStorage.setItem(stateKey, storedValue);\n } catch (e) {\n if (window && window[GATSBY_ROUTER_SCROLL_STATE]) {\n window[GATSBY_ROUTER_SCROLL_STATE][stateKey] = JSON.parse(storedValue);\n } else {\n window[GATSBY_ROUTER_SCROLL_STATE] = {};\n window[GATSBY_ROUTER_SCROLL_STATE][stateKey] = JSON.parse(storedValue);\n }\n\n if (process.env.NODE_ENV !== \"production\") {\n console.warn(\"[gatsby-react-router-scroll] Unable to save state in sessionStorage; sessionStorage is not available.\");\n }\n }\n };\n\n _proto.getStateKey = function getStateKey(location, key) {\n var stateKeyBase = \"\" + STATE_KEY_PREFIX + location.pathname;\n return key === null || typeof key === \"undefined\" ? stateKeyBase : stateKeyBase + \"|\" + key;\n };\n\n return SessionStorage;\n}();\n\nexports.SessionStorage = SessionStorage;","\"use strict\";\n\nexports.__esModule = true;\nexports.useScrollRestoration = useScrollRestoration;\n\nvar _scrollHandler = require(\"./scroll-handler\");\n\nvar _react = require(\"react\");\n\nvar _reachRouter = require(\"@gatsbyjs/reach-router\");\n\nfunction useScrollRestoration(identifier) {\n var location = (0, _reachRouter.useLocation)();\n var state = (0, _react.useContext)(_scrollHandler.ScrollContext);\n var ref = (0, _react.useRef)(null);\n (0, _react.useLayoutEffect)(function () {\n if (ref.current) {\n var position = state.read(location, identifier);\n ref.current.scrollTo(0, position || 0);\n }\n }, [location.key]);\n return {\n ref: ref,\n onScroll: function onScroll() {\n if (ref.current) {\n state.save(location, identifier, ref.current.scrollTop);\n }\n }\n };\n}","// prefer default export if available\nconst preferDefault = m => (m && m.default) || m\n\nexports.components = {\n \"component---src-templates-404-404-tsx\": () => import(\"./../../../src/templates/404/404.tsx\" /* webpackChunkName: \"component---src-templates-404-404-tsx\" */),\n \"component---src-templates-calendar-index-tsx\": () => import(\"./../../../src/templates/calendar/index.tsx\" /* webpackChunkName: \"component---src-templates-calendar-index-tsx\" */),\n \"component---src-templates-form-completed-tsx\": () => import(\"./../../../src/templates/form/completed.tsx\" /* webpackChunkName: \"component---src-templates-form-completed-tsx\" */),\n \"component---src-templates-form-form-tsx\": () => import(\"./../../../src/templates/form/form.tsx\" /* webpackChunkName: \"component---src-templates-form-form-tsx\" */),\n \"component---src-templates-games-game-tsx\": () => import(\"./../../../src/templates/games/game.tsx\" /* webpackChunkName: \"component---src-templates-games-game-tsx\" */),\n \"component---src-templates-guideline-guideline-tsx\": () => import(\"./../../../src/templates/guideline/guideline.tsx\" /* webpackChunkName: \"component---src-templates-guideline-guideline-tsx\" */),\n \"component---src-templates-index-index-tsx\": () => import(\"./../../../src/templates/index/index.tsx\" /* webpackChunkName: \"component---src-templates-index-index-tsx\" */)\n}\n\n","module.exports = [{\n plugin: require('../node_modules/gatsby-plugin-web-font-loader/gatsby-browser.js'),\n options: {\"plugins\":[],\"typekit\":{}},\n },{\n plugin: require('../node_modules/gatsby-plugin-apollo/gatsby-browser.js'),\n options: {\"plugins\":[],\"uri\":\"https://craft.eurcommunitycompetition.com/api\",\"headers\":{\"Authorization\":\"Bearer TexPz3LtJr03XTVUeHM-0WsYcMXLtHxI\"}},\n },{\n plugin: require('../node_modules/gatsby-plugin-styled-components/gatsby-browser.js'),\n options: {\"plugins\":[],\"displayName\":true,\"fileName\":true,\"minify\":true,\"namespace\":\"\",\"transpileTemplateLiterals\":true,\"topLevelImportPaths\":[],\"pure\":false,\"disableVendorPrefixes\":false},\n },{\n plugin: require('../node_modules/gatsby-plugin-image/gatsby-browser.js'),\n options: {\"plugins\":[]},\n },{\n plugin: require('../gatsby-browser.js'),\n options: {\"plugins\":[]},\n }]\n","const plugins = require(`./api-runner-browser-plugins`)\nconst { getResourceURLsForPathname, loadPage, loadPageSync } =\n require(`./loader`).publicLoader\n\nexports.apiRunner = (api, args = {}, defaultReturn, argTransform) => {\n // Hooks for gatsby-cypress's API handler\n if (process.env.CYPRESS_SUPPORT) {\n if (window.___apiHandler) {\n window.___apiHandler(api)\n } else if (window.___resolvedAPIs) {\n window.___resolvedAPIs.push(api)\n } else {\n window.___resolvedAPIs = [api]\n }\n }\n\n let results = plugins.map(plugin => {\n if (!plugin.plugin[api]) {\n return undefined\n }\n\n args.getResourceURLsForPathname = getResourceURLsForPathname\n args.loadPage = loadPage\n args.loadPageSync = loadPageSync\n\n const result = plugin.plugin[api](args, plugin.options)\n if (result && argTransform) {\n args = argTransform({ args, result, plugin })\n }\n return result\n })\n\n // Filter out undefined results.\n results = results.filter(result => typeof result !== `undefined`)\n\n if (results.length > 0) {\n return results\n } else if (defaultReturn) {\n return [defaultReturn]\n } else {\n return []\n }\n}\n\nexports.apiRunnerAsync = (api, args, defaultReturn) =>\n plugins.reduce(\n (previous, next) =>\n next.plugin[api]\n ? previous.then(() => next.plugin[api](args, next.options))\n : previous,\n Promise.resolve()\n )\n","import mitt from \"mitt\"\n\nconst emitter = mitt()\nexport default emitter\n","// \n// An event handler can take an optional event argument\n// and should not return a value\n \n \n\n// An array of all currently registered event handlers for a type\n \n \n// A map of event types and their corresponding event handlers.\n \n \n \n \n\n/** Mitt: Tiny (~200b) functional event emitter / pubsub.\n * @name mitt\n * @returns {Mitt}\n */\nfunction mitt(all ) {\n\tall = all || Object.create(null);\n\n\treturn {\n\t\t/**\n\t\t * Register an event handler for the given type.\n\t\t *\n\t\t * @param {String} type\tType of event to listen for, or `\"*\"` for all events\n\t\t * @param {Function} handler Function to call in response to given event\n\t\t * @memberOf mitt\n\t\t */\n\t\ton: function on(type , handler ) {\n\t\t\t(all[type] || (all[type] = [])).push(handler);\n\t\t},\n\n\t\t/**\n\t\t * Remove an event handler for the given type.\n\t\t *\n\t\t * @param {String} type\tType of event to unregister `handler` from, or `\"*\"`\n\t\t * @param {Function} handler Handler function to remove\n\t\t * @memberOf mitt\n\t\t */\n\t\toff: function off(type , handler ) {\n\t\t\tif (all[type]) {\n\t\t\t\tall[type].splice(all[type].indexOf(handler) >>> 0, 1);\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Invoke all handlers for the given type.\n\t\t * If present, `\"*\"` handlers are invoked after type-matched handlers.\n\t\t *\n\t\t * @param {String} type The event type to invoke\n\t\t * @param {Any} [evt] Any value (object is recommended and powerful), passed to each handler\n\t\t * @memberOf mitt\n\t\t */\n\t\temit: function emit(type , evt ) {\n\t\t\t(all[type] || []).slice().map(function (handler) { handler(evt); });\n\t\t\t(all['*'] || []).slice().map(function (handler) { handler(type, evt); });\n\t\t}\n\t};\n}\n\nexport default mitt;\n//# sourceMappingURL=mitt.es.js.map\n","export default path => {\n if (path === undefined) {\n return path\n }\n if (path === `/`) {\n return `/`\n }\n if (path.charAt(path.length - 1) === `/`) {\n return path.slice(0, -1)\n }\n return path\n}\n","import { pick } from \"@gatsbyjs/reach-router/lib/utils\"\nimport stripPrefix from \"./strip-prefix\"\nimport normalizePagePath from \"./normalize-page-path\"\nimport { maybeGetBrowserRedirect } from \"./redirect-utils.js\"\n\nconst pathCache = new Map()\nlet matchPaths = []\n\nconst trimPathname = rawPathname => {\n const pathname = decodeURIComponent(rawPathname)\n // Remove the pathPrefix from the pathname.\n const trimmedPathname = stripPrefix(\n pathname,\n decodeURIComponent(__BASE_PATH__)\n )\n // Remove any hashfragment\n .split(`#`)[0]\n // Remove search query\n .split(`?`)[0]\n\n return trimmedPathname\n}\n\nfunction absolutify(path) {\n // If it's already absolute, return as-is\n if (\n path.startsWith(`/`) ||\n path.startsWith(`https://`) ||\n path.startsWith(`http://`)\n ) {\n return path\n }\n // Calculate path relative to current location, adding a trailing slash to\n // match behavior of @reach/router\n return new URL(\n path,\n window.location.href + (window.location.href.endsWith(`/`) ? `` : `/`)\n ).pathname\n}\n\n/**\n * Set list of matchPaths\n *\n * @param {Array<{path: string, matchPath: string}>} value collection of matchPaths\n */\nexport const setMatchPaths = value => {\n matchPaths = value\n}\n\n/**\n * Return a matchpath url\n * if `match-paths.json` contains `{ \"/foo*\": \"/page1\", ...}`, then\n * `/foo?bar=far` => `/page1`\n *\n * @param {string} rawPathname A raw pathname\n * @return {string|null}\n */\nexport const findMatchPath = rawPathname => {\n const trimmedPathname = cleanPath(rawPathname)\n\n const pickPaths = matchPaths.map(({ path, matchPath }) => {\n return {\n path: matchPath,\n originalPath: path,\n }\n })\n\n const path = pick(pickPaths, trimmedPathname)\n\n if (path) {\n return normalizePagePath(path.route.originalPath)\n }\n\n return null\n}\n\n/**\n * Return a matchpath params from reach/router rules\n * if `match-paths.json` contains `{ \":bar/*foo\" }`, and the path is /baz/zaz/zoo\n * then it returns\n * { bar: baz, foo: zaz/zoo }\n *\n * @param {string} rawPathname A raw pathname\n * @return {object}\n */\nexport const grabMatchParams = rawPathname => {\n const trimmedPathname = cleanPath(rawPathname)\n\n const pickPaths = matchPaths.map(({ path, matchPath }) => {\n return {\n path: matchPath,\n originalPath: path,\n }\n })\n\n const path = pick(pickPaths, trimmedPathname)\n\n if (path) {\n return path.params\n }\n\n return {}\n}\n\n// Given a raw URL path, returns the cleaned version of it (trim off\n// `#` and query params), or if it matches an entry in\n// `match-paths.json`, its matched path is returned\n//\n// E.g. `/foo?bar=far` => `/foo`\n//\n// Or if `match-paths.json` contains `{ \"/foo*\": \"/page1\", ...}`, then\n// `/foo?bar=far` => `/page1`\nexport const findPath = rawPathname => {\n const trimmedPathname = trimPathname(absolutify(rawPathname))\n if (pathCache.has(trimmedPathname)) {\n return pathCache.get(trimmedPathname)\n }\n\n const redirect = maybeGetBrowserRedirect(rawPathname)\n if (redirect) {\n return findPath(redirect.toPath)\n }\n\n let foundPath = findMatchPath(trimmedPathname)\n\n if (!foundPath) {\n foundPath = cleanPath(rawPathname)\n }\n\n pathCache.set(trimmedPathname, foundPath)\n\n return foundPath\n}\n\n/**\n * Clean a url and converts /index.html => /\n * E.g. `/foo?bar=far` => `/foo`\n *\n * @param {string} rawPathname A raw pathname\n * @return {string}\n */\nexport const cleanPath = rawPathname => {\n const trimmedPathname = trimPathname(absolutify(rawPathname))\n\n let foundPath = trimmedPathname\n if (foundPath === `/index.html`) {\n foundPath = `/`\n }\n\n foundPath = normalizePagePath(foundPath)\n\n return foundPath\n}\n","import React from \"react\"\nimport PropTypes from \"prop-types\"\nimport Link, {\n withPrefix,\n withAssetPrefix,\n navigate,\n push,\n replace,\n navigateTo,\n parsePath,\n} from \"gatsby-link\"\nimport { useScrollRestoration } from \"gatsby-react-router-scroll\"\nimport PageRenderer from \"./public-page-renderer\"\nimport loader from \"./loader\"\n\nconst prefetchPathname = loader.enqueue\n\nconst StaticQueryContext = React.createContext({})\n\nfunction StaticQueryDataRenderer({ staticQueryData, data, query, render }) {\n const finalData = data\n ? data.data\n : staticQueryData[query] && staticQueryData[query].data\n\n return (\n \n {finalData && render(finalData)}\n {!finalData &&
Loading (StaticQuery)
}\n
\n )\n}\n\nconst StaticQuery = props => {\n const { data, query, render, children } = props\n\n return (\n \n {staticQueryData => (\n \n )}\n \n )\n}\n\nconst useStaticQuery = query => {\n if (\n typeof React.useContext !== `function` &&\n process.env.NODE_ENV === `development`\n ) {\n throw new Error(\n `You're likely using a version of React that doesn't support Hooks\\n` +\n `Please update React and ReactDOM to 16.8.0 or later to use the useStaticQuery hook.`\n )\n }\n const context = React.useContext(StaticQueryContext)\n\n // query is a stringified number like `3303882` when wrapped with graphql, If a user forgets\n // to wrap the query in a grqphql, then casting it to a Number results in `NaN` allowing us to\n // catch the misuse of the API and give proper direction\n if (isNaN(Number(query))) {\n throw new Error(`useStaticQuery was called with a string but expects to be called using \\`graphql\\`. Try this:\n\nimport { useStaticQuery, graphql } from 'gatsby';\n\nuseStaticQuery(graphql\\`${query}\\`);\n`)\n }\n\n if (context[query]?.data) {\n return context[query].data\n } else {\n throw new Error(\n `The result of this StaticQuery could not be fetched.\\n\\n` +\n `This is likely a bug in Gatsby and if refreshing the page does not fix it, ` +\n `please open an issue in https://github.com/gatsbyjs/gatsby/issues`\n )\n }\n}\n\nStaticQuery.propTypes = {\n data: PropTypes.object,\n query: PropTypes.string.isRequired,\n render: PropTypes.func,\n children: PropTypes.func,\n}\n\nfunction graphql() {\n throw new Error(\n `It appears like Gatsby is misconfigured. Gatsby related \\`graphql\\` calls ` +\n `are supposed to only be evaluated at compile time, and then compiled away. ` +\n `Unfortunately, something went wrong and the query was left in the compiled code.\\n\\n` +\n `Unless your site has a complex or custom babel/Gatsby configuration this is likely a bug in Gatsby.`\n )\n}\n\nexport {\n Link,\n withAssetPrefix,\n withPrefix,\n graphql,\n parsePath,\n navigate,\n useScrollRestoration,\n StaticQueryContext,\n StaticQuery,\n PageRenderer,\n useStaticQuery,\n prefetchPathname,\n}\n","const support = function (feature) {\n if (typeof document === `undefined`) {\n return false\n }\n const fakeLink = document.createElement(`link`)\n try {\n if (fakeLink.relList && typeof fakeLink.relList.supports === `function`) {\n return fakeLink.relList.supports(feature)\n }\n } catch (err) {\n return false\n }\n return false\n}\n\nconst linkPrefetchStrategy = function (url, options) {\n return new Promise((resolve, reject) => {\n if (typeof document === `undefined`) {\n reject()\n return\n }\n\n const link = document.createElement(`link`)\n link.setAttribute(`rel`, `prefetch`)\n link.setAttribute(`href`, url)\n\n Object.keys(options).forEach(key => {\n link.setAttribute(key, options[key])\n })\n\n link.onload = resolve\n link.onerror = reject\n\n const parentElement =\n document.getElementsByTagName(`head`)[0] ||\n document.getElementsByName(`script`)[0].parentNode\n parentElement.appendChild(link)\n })\n}\n\nconst xhrPrefetchStrategy = function (url) {\n return new Promise((resolve, reject) => {\n const req = new XMLHttpRequest()\n req.open(`GET`, url, true)\n\n req.onload = () => {\n if (req.status === 200) {\n resolve()\n } else {\n reject()\n }\n }\n\n req.send(null)\n })\n}\n\nconst supportedPrefetchStrategy = support(`prefetch`)\n ? linkPrefetchStrategy\n : xhrPrefetchStrategy\n\nconst preFetched = {}\n\nconst prefetch = function (url, options) {\n return new Promise(resolve => {\n if (preFetched[url]) {\n resolve()\n return\n }\n\n supportedPrefetchStrategy(url, options)\n .then(() => {\n resolve()\n preFetched[url] = true\n })\n .catch(() => {}) // 404s are logged to the console anyway\n })\n}\n\nexport default prefetch\n","import prefetchHelper from \"./prefetch\"\nimport emitter from \"./emitter\"\nimport { setMatchPaths, findPath, findMatchPath } from \"./find-path\"\n\n/**\n * Available resource loading statuses\n */\nexport const PageResourceStatus = {\n /**\n * At least one of critical resources failed to load\n */\n Error: `error`,\n /**\n * Resources loaded successfully\n */\n Success: `success`,\n}\n\nconst preferDefault = m => (m && m.default) || m\n\nconst stripSurroundingSlashes = s => {\n s = s[0] === `/` ? s.slice(1) : s\n s = s.endsWith(`/`) ? s.slice(0, -1) : s\n return s\n}\n\nconst createPageDataUrl = path => {\n const fixedPath = path === `/` ? `index` : stripSurroundingSlashes(path)\n return `${__PATH_PREFIX__}/page-data/${fixedPath}/page-data.json`\n}\n\nfunction doFetch(url, method = `GET`) {\n return new Promise((resolve, reject) => {\n const req = new XMLHttpRequest()\n req.open(method, url, true)\n req.onreadystatechange = () => {\n if (req.readyState == 4) {\n resolve(req)\n }\n }\n req.send(null)\n })\n}\n\nconst doesConnectionSupportPrefetch = () => {\n if (\n `connection` in navigator &&\n typeof navigator.connection !== `undefined`\n ) {\n if ((navigator.connection.effectiveType || ``).includes(`2g`)) {\n return false\n }\n if (navigator.connection.saveData) {\n return false\n }\n }\n return true\n}\n\nconst toPageResources = (pageData, component = null) => {\n const page = {\n componentChunkName: pageData.componentChunkName,\n path: pageData.path,\n webpackCompilationHash: pageData.webpackCompilationHash,\n matchPath: pageData.matchPath,\n staticQueryHashes: pageData.staticQueryHashes,\n }\n\n return {\n component,\n json: pageData.result,\n page,\n }\n}\n\nexport class BaseLoader {\n constructor(loadComponent, matchPaths) {\n // Map of pagePath -> Page. Where Page is an object with: {\n // status: PageResourceStatus.Success || PageResourceStatus.Error,\n // payload: PageResources, // undefined if PageResourceStatus.Error\n // }\n // PageResources is {\n // component,\n // json: pageData.result,\n // page: {\n // componentChunkName,\n // path,\n // webpackCompilationHash,\n // staticQueryHashes\n // },\n // staticQueryResults\n // }\n this.pageDb = new Map()\n this.inFlightDb = new Map()\n this.staticQueryDb = {}\n this.pageDataDb = new Map()\n this.prefetchTriggered = new Set()\n this.prefetchCompleted = new Set()\n this.loadComponent = loadComponent\n setMatchPaths(matchPaths)\n }\n\n inFlightNetworkRequests = new Map()\n\n memoizedGet(url) {\n let inFlightPromise = this.inFlightNetworkRequests.get(url)\n\n if (!inFlightPromise) {\n inFlightPromise = doFetch(url, `GET`)\n this.inFlightNetworkRequests.set(url, inFlightPromise)\n }\n\n // Prefer duplication with then + catch over .finally to prevent problems in ie11 + firefox\n return inFlightPromise\n .then(response => {\n this.inFlightNetworkRequests.delete(url)\n return response\n })\n .catch(err => {\n this.inFlightNetworkRequests.delete(url)\n throw err\n })\n }\n\n setApiRunner(apiRunner) {\n this.apiRunner = apiRunner\n this.prefetchDisabled = apiRunner(`disableCorePrefetching`).some(a => a)\n }\n\n fetchPageDataJson(loadObj) {\n const { pagePath, retries = 0 } = loadObj\n const url = createPageDataUrl(pagePath)\n return this.memoizedGet(url).then(req => {\n const { status, responseText } = req\n\n // Handle 200\n if (status === 200) {\n try {\n const jsonPayload = JSON.parse(responseText)\n if (jsonPayload.path === undefined) {\n throw new Error(`not a valid pageData response`)\n }\n\n return Object.assign(loadObj, {\n status: PageResourceStatus.Success,\n payload: jsonPayload,\n })\n } catch (err) {\n // continue regardless of error\n }\n }\n\n // Handle 404\n if (status === 404 || status === 200) {\n // If the request was for a 404 page and it doesn't exist, we're done\n if (pagePath === `/404.html`) {\n return Object.assign(loadObj, {\n status: PageResourceStatus.Error,\n })\n }\n\n // Need some code here to cache the 404 request. In case\n // multiple loadPageDataJsons result in 404s\n return this.fetchPageDataJson(\n Object.assign(loadObj, { pagePath: `/404.html`, notFound: true })\n )\n }\n\n // handle 500 response (Unrecoverable)\n if (status === 500) {\n return Object.assign(loadObj, {\n status: PageResourceStatus.Error,\n })\n }\n\n // Handle everything else, including status === 0, and 503s. Should retry\n if (retries < 3) {\n return this.fetchPageDataJson(\n Object.assign(loadObj, { retries: retries + 1 })\n )\n }\n\n // Retried 3 times already, result is an error.\n return Object.assign(loadObj, {\n status: PageResourceStatus.Error,\n })\n })\n }\n\n loadPageDataJson(rawPath) {\n const pagePath = findPath(rawPath)\n if (this.pageDataDb.has(pagePath)) {\n const pageData = this.pageDataDb.get(pagePath)\n if (process.env.BUILD_STAGE !== `develop` || !pageData.stale) {\n return Promise.resolve(pageData)\n }\n }\n\n return this.fetchPageDataJson({ pagePath }).then(pageData => {\n this.pageDataDb.set(pagePath, pageData)\n\n return pageData\n })\n }\n\n findMatchPath(rawPath) {\n return findMatchPath(rawPath)\n }\n\n // TODO check all uses of this and whether they use undefined for page resources not exist\n loadPage(rawPath) {\n const pagePath = findPath(rawPath)\n if (this.pageDb.has(pagePath)) {\n const page = this.pageDb.get(pagePath)\n if (process.env.BUILD_STAGE !== `develop` || !page.payload.stale) {\n if (page.error) {\n return {\n error: page.error,\n status: page.status,\n }\n }\n\n return Promise.resolve(page.payload)\n }\n }\n\n if (this.inFlightDb.has(pagePath)) {\n return this.inFlightDb.get(pagePath)\n }\n\n const inFlightPromise = Promise.all([\n this.loadAppData(),\n this.loadPageDataJson(pagePath),\n ]).then(allData => {\n const result = allData[1]\n if (result.status === PageResourceStatus.Error) {\n return {\n status: PageResourceStatus.Error,\n }\n }\n\n let pageData = result.payload\n const { componentChunkName, staticQueryHashes = [] } = pageData\n\n const finalResult = {}\n\n const componentChunkPromise = this.loadComponent(componentChunkName).then(\n component => {\n finalResult.createdAt = new Date()\n let pageResources\n if (!component || component instanceof Error) {\n finalResult.status = PageResourceStatus.Error\n finalResult.error = component\n } else {\n finalResult.status = PageResourceStatus.Success\n if (result.notFound === true) {\n finalResult.notFound = true\n }\n pageData = Object.assign(pageData, {\n webpackCompilationHash: allData[0]\n ? allData[0].webpackCompilationHash\n : ``,\n })\n pageResources = toPageResources(pageData, component)\n }\n // undefined if final result is an error\n return pageResources\n }\n )\n\n const staticQueryBatchPromise = Promise.all(\n staticQueryHashes.map(staticQueryHash => {\n // Check for cache in case this static query result has already been loaded\n if (this.staticQueryDb[staticQueryHash]) {\n const jsonPayload = this.staticQueryDb[staticQueryHash]\n return { staticQueryHash, jsonPayload }\n }\n\n return this.memoizedGet(\n `${__PATH_PREFIX__}/page-data/sq/d/${staticQueryHash}.json`\n )\n .then(req => {\n const jsonPayload = JSON.parse(req.responseText)\n return { staticQueryHash, jsonPayload }\n })\n .catch(() => {\n throw new Error(\n `We couldn't load \"${__PATH_PREFIX__}/page-data/sq/d/${staticQueryHash}.json\"`\n )\n })\n })\n ).then(staticQueryResults => {\n const staticQueryResultsMap = {}\n\n staticQueryResults.forEach(({ staticQueryHash, jsonPayload }) => {\n staticQueryResultsMap[staticQueryHash] = jsonPayload\n this.staticQueryDb[staticQueryHash] = jsonPayload\n })\n\n return staticQueryResultsMap\n })\n\n return (\n Promise.all([componentChunkPromise, staticQueryBatchPromise])\n .then(([pageResources, staticQueryResults]) => {\n let payload\n if (pageResources) {\n payload = { ...pageResources, staticQueryResults }\n finalResult.payload = payload\n emitter.emit(`onPostLoadPageResources`, {\n page: payload,\n pageResources: payload,\n })\n }\n\n this.pageDb.set(pagePath, finalResult)\n\n if (finalResult.error) {\n return {\n error: finalResult.error,\n status: finalResult.status,\n }\n }\n\n return payload\n })\n // when static-query fail to load we throw a better error\n .catch(err => {\n return {\n error: err,\n status: PageResourceStatus.Error,\n }\n })\n )\n })\n\n inFlightPromise\n .then(() => {\n this.inFlightDb.delete(pagePath)\n })\n .catch(error => {\n this.inFlightDb.delete(pagePath)\n throw error\n })\n\n this.inFlightDb.set(pagePath, inFlightPromise)\n\n return inFlightPromise\n }\n\n // returns undefined if the page does not exists in cache\n loadPageSync(rawPath, options = {}) {\n const pagePath = findPath(rawPath)\n if (this.pageDb.has(pagePath)) {\n const pageData = this.pageDb.get(pagePath)\n\n if (pageData.payload) {\n return pageData.payload\n }\n\n if (options?.withErrorDetails) {\n return {\n error: pageData.error,\n status: pageData.status,\n }\n }\n }\n return undefined\n }\n\n shouldPrefetch(pagePath) {\n // Skip prefetching if we know user is on slow or constrained connection\n if (!doesConnectionSupportPrefetch()) {\n return false\n }\n\n // Check if the page exists.\n if (this.pageDb.has(pagePath)) {\n return false\n }\n\n return true\n }\n\n prefetch(pagePath) {\n if (!this.shouldPrefetch(pagePath)) {\n return false\n }\n\n // Tell plugins with custom prefetching logic that they should start\n // prefetching this path.\n if (!this.prefetchTriggered.has(pagePath)) {\n this.apiRunner(`onPrefetchPathname`, { pathname: pagePath })\n this.prefetchTriggered.add(pagePath)\n }\n\n // If a plugin has disabled core prefetching, stop now.\n if (this.prefetchDisabled) {\n return false\n }\n\n const realPath = findPath(pagePath)\n // Todo make doPrefetch logic cacheable\n // eslint-disable-next-line consistent-return\n this.doPrefetch(realPath).then(() => {\n if (!this.prefetchCompleted.has(pagePath)) {\n this.apiRunner(`onPostPrefetchPathname`, { pathname: pagePath })\n this.prefetchCompleted.add(pagePath)\n }\n })\n\n return true\n }\n\n doPrefetch(pagePath) {\n const pageDataUrl = createPageDataUrl(pagePath)\n return prefetchHelper(pageDataUrl, {\n crossOrigin: `anonymous`,\n as: `fetch`,\n }).then(() =>\n // This was just prefetched, so will return a response from\n // the cache instead of making another request to the server\n this.loadPageDataJson(pagePath)\n )\n }\n\n hovering(rawPath) {\n this.loadPage(rawPath)\n }\n\n getResourceURLsForPathname(rawPath) {\n const pagePath = findPath(rawPath)\n const page = this.pageDataDb.get(pagePath)\n if (page) {\n const pageResources = toPageResources(page.payload)\n\n return [\n ...createComponentUrls(pageResources.page.componentChunkName),\n createPageDataUrl(pagePath),\n ]\n } else {\n return null\n }\n }\n\n isPageNotFound(rawPath) {\n const pagePath = findPath(rawPath)\n const page = this.pageDb.get(pagePath)\n return !page || page.notFound\n }\n\n loadAppData(retries = 0) {\n return this.memoizedGet(`${__PATH_PREFIX__}/page-data/app-data.json`).then(\n req => {\n const { status, responseText } = req\n\n let appData\n\n if (status !== 200 && retries < 3) {\n // Retry 3 times incase of non-200 responses\n return this.loadAppData(retries + 1)\n }\n\n // Handle 200\n if (status === 200) {\n try {\n const jsonPayload = JSON.parse(responseText)\n if (jsonPayload.webpackCompilationHash === undefined) {\n throw new Error(`not a valid app-data response`)\n }\n\n appData = jsonPayload\n } catch (err) {\n // continue regardless of error\n }\n }\n\n return appData\n }\n )\n }\n}\n\nconst createComponentUrls = componentChunkName =>\n (window.___chunkMapping[componentChunkName] || []).map(\n chunk => __PATH_PREFIX__ + chunk\n )\n\nexport class ProdLoader extends BaseLoader {\n constructor(asyncRequires, matchPaths, pageData) {\n const loadComponent = chunkName => {\n if (!asyncRequires.components[chunkName]) {\n throw new Error(\n `We couldn't find the correct component chunk with the name ${chunkName}`\n )\n }\n\n return (\n asyncRequires.components[chunkName]()\n .then(preferDefault)\n // loader will handle the case when component is error\n .catch(err => err)\n )\n }\n\n super(loadComponent, matchPaths)\n\n if (pageData) {\n this.pageDataDb.set(pageData.path, {\n pagePath: pageData.path,\n payload: pageData,\n status: `success`,\n })\n }\n }\n\n doPrefetch(pagePath) {\n return super.doPrefetch(pagePath).then(result => {\n if (result.status !== PageResourceStatus.Success) {\n return Promise.resolve()\n }\n const pageData = result.payload\n const chunkName = pageData.componentChunkName\n const componentUrls = createComponentUrls(chunkName)\n return Promise.all(componentUrls.map(prefetchHelper)).then(() => pageData)\n })\n }\n\n loadPageDataJson(rawPath) {\n return super.loadPageDataJson(rawPath).then(data => {\n if (data.notFound) {\n // check if html file exist using HEAD request:\n // if it does we should navigate to it instead of showing 404\n return doFetch(rawPath, `HEAD`).then(req => {\n if (req.status === 200) {\n // page (.html file) actually exist (or we asked for 404 )\n // returning page resources status as errored to trigger\n // regular browser navigation to given page\n return {\n status: PageResourceStatus.Error,\n }\n }\n\n // if HEAD request wasn't 200, return notFound result\n // and show 404 page\n return data\n })\n }\n return data\n })\n }\n}\n\nlet instance\n\nexport const setLoader = _loader => {\n instance = _loader\n}\n\nexport const publicLoader = {\n enqueue: rawPath => instance.prefetch(rawPath),\n\n // Real methods\n getResourceURLsForPathname: rawPath =>\n instance.getResourceURLsForPathname(rawPath),\n loadPage: rawPath => instance.loadPage(rawPath),\n // TODO add deprecation to v4 so people use withErrorDetails and then we can remove in v5 and change default behaviour\n loadPageSync: (rawPath, options = {}) =>\n instance.loadPageSync(rawPath, options),\n prefetch: rawPath => instance.prefetch(rawPath),\n isPageNotFound: rawPath => instance.isPageNotFound(rawPath),\n hovering: rawPath => instance.hovering(rawPath),\n loadAppData: () => instance.loadAppData(),\n}\n\nexport default publicLoader\n\nexport function getStaticQueryResults() {\n if (instance) {\n return instance.staticQueryDb\n } else {\n return {}\n }\n}\n","import React, { createElement } from \"react\"\nimport PropTypes from \"prop-types\"\nimport { apiRunner } from \"./api-runner-browser\"\nimport { grabMatchParams } from \"./find-path\"\n\n// Renders page\nclass PageRenderer extends React.Component {\n render() {\n const props = {\n ...this.props,\n params: {\n ...grabMatchParams(this.props.location.pathname),\n ...this.props.pageResources.json.pageContext.__params,\n },\n }\n\n const pageElement = createElement(this.props.pageResources.component, {\n ...props,\n key: this.props.path || this.props.pageResources.page.path,\n })\n\n const wrappedPage = apiRunner(\n `wrapPageElement`,\n { element: pageElement, props },\n pageElement,\n ({ result }) => {\n return { element: result, props }\n }\n ).pop()\n\n return wrappedPage\n }\n}\n\nPageRenderer.propTypes = {\n location: PropTypes.object.isRequired,\n pageResources: PropTypes.object.isRequired,\n data: PropTypes.object,\n pageContext: PropTypes.object.isRequired,\n}\n\nexport default PageRenderer\n","// This is extracted to separate module because it's shared\n// between browser and SSR code\nexport const RouteAnnouncerProps = {\n id: `gatsby-announcer`,\n style: {\n position: `absolute`,\n top: 0,\n width: 1,\n height: 1,\n padding: 0,\n overflow: `hidden`,\n clip: `rect(0, 0, 0, 0)`,\n whiteSpace: `nowrap`,\n border: 0,\n },\n \"aria-live\": `assertive`,\n \"aria-atomic\": `true`,\n}\n","import React from \"react\"\nimport PropTypes from \"prop-types\"\nimport loader, { PageResourceStatus } from \"./loader\"\nimport { maybeGetBrowserRedirect } from \"./redirect-utils.js\"\nimport { apiRunner } from \"./api-runner-browser\"\nimport emitter from \"./emitter\"\nimport { RouteAnnouncerProps } from \"./route-announcer-props\"\nimport { navigate as reachNavigate } from \"@gatsbyjs/reach-router\"\nimport { globalHistory } from \"@gatsbyjs/reach-router/lib/history\"\nimport { parsePath } from \"gatsby-link\"\n\nfunction maybeRedirect(pathname) {\n const redirect = maybeGetBrowserRedirect(pathname)\n const { hash, search } = window.location\n\n if (redirect != null) {\n window.___replace(redirect.toPath + search + hash)\n return true\n } else {\n return false\n }\n}\n\n// Catch unhandled chunk loading errors and force a restart of the app.\nlet nextRoute = ``\n\nwindow.addEventListener(`unhandledrejection`, event => {\n if (/loading chunk \\d* failed./i.test(event.reason)) {\n if (nextRoute) {\n window.location.pathname = nextRoute\n }\n }\n})\n\nconst onPreRouteUpdate = (location, prevLocation) => {\n if (!maybeRedirect(location.pathname)) {\n nextRoute = location.pathname\n apiRunner(`onPreRouteUpdate`, { location, prevLocation })\n }\n}\n\nconst onRouteUpdate = (location, prevLocation) => {\n if (!maybeRedirect(location.pathname)) {\n apiRunner(`onRouteUpdate`, { location, prevLocation })\n if (\n process.env.GATSBY_EXPERIMENTAL_QUERY_ON_DEMAND &&\n process.env.GATSBY_QUERY_ON_DEMAND_LOADING_INDICATOR === `true`\n ) {\n emitter.emit(`onRouteUpdate`, { location, prevLocation })\n }\n }\n}\n\nconst navigate = (to, options = {}) => {\n // Support forward/backward navigation with numbers\n // navigate(-2) (jumps back 2 history steps)\n // navigate(2) (jumps forward 2 history steps)\n if (typeof to === `number`) {\n globalHistory.navigate(to)\n return\n }\n\n const { pathname, search, hash } = parsePath(to)\n const redirect = maybeGetBrowserRedirect(pathname)\n\n // If we're redirecting, just replace the passed in pathname\n // to the one we want to redirect to.\n if (redirect) {\n to = redirect.toPath + search + hash\n }\n\n // If we had a service worker update, no matter the path, reload window and\n // reset the pathname whitelist\n if (window.___swUpdated) {\n window.location = pathname + search + hash\n return\n }\n\n // Start a timer to wait for a second before transitioning and showing a\n // loader in case resources aren't around yet.\n const timeoutId = setTimeout(() => {\n emitter.emit(`onDelayedLoadPageResources`, { pathname })\n apiRunner(`onRouteUpdateDelayed`, {\n location: window.location,\n })\n }, 1000)\n\n loader.loadPage(pathname).then(pageResources => {\n // If no page resources, then refresh the page\n // Do this, rather than simply `window.location.reload()`, so that\n // pressing the back/forward buttons work - otherwise when pressing\n // back, the browser will just change the URL and expect JS to handle\n // the change, which won't always work since it might not be a Gatsby\n // page.\n if (!pageResources || pageResources.status === PageResourceStatus.Error) {\n window.history.replaceState({}, ``, location.href)\n window.location = pathname\n clearTimeout(timeoutId)\n return\n }\n\n // If the loaded page has a different compilation hash to the\n // window, then a rebuild has occurred on the server. Reload.\n if (process.env.NODE_ENV === `production` && pageResources) {\n // window.___webpackCompilationHash gets set in production-app.js after navigationInit() is called\n // So on a direct visit of a page with a browser redirect this check is truthy and thus the codepath is hit\n // While the resource actually exists, but only too late\n // TODO: This should probably be fixed by setting ___webpackCompilationHash before navigationInit() is called\n if (\n pageResources.page.webpackCompilationHash !==\n window.___webpackCompilationHash\n ) {\n // Purge plugin-offline cache\n if (\n `serviceWorker` in navigator &&\n navigator.serviceWorker.controller !== null &&\n navigator.serviceWorker.controller.state === `activated`\n ) {\n navigator.serviceWorker.controller.postMessage({\n gatsbyApi: `clearPathResources`,\n })\n }\n\n window.location = pathname + search + hash\n }\n }\n reachNavigate(to, options)\n clearTimeout(timeoutId)\n })\n}\n\nfunction shouldUpdateScroll(prevRouterProps, { location }) {\n const { pathname, hash } = location\n const results = apiRunner(`shouldUpdateScroll`, {\n prevRouterProps,\n // `pathname` for backwards compatibility\n pathname,\n routerProps: { location },\n getSavedScrollPosition: args => [\n 0,\n // FIXME this is actually a big code smell, we should fix this\n // eslint-disable-next-line @babel/no-invalid-this\n this._stateStorage.read(args, args.key),\n ],\n })\n if (results.length > 0) {\n // Use the latest registered shouldUpdateScroll result, this allows users to override plugin's configuration\n // @see https://github.com/gatsbyjs/gatsby/issues/12038\n return results[results.length - 1]\n }\n\n if (prevRouterProps) {\n const {\n location: { pathname: oldPathname },\n } = prevRouterProps\n if (oldPathname === pathname) {\n // Scroll to element if it exists, if it doesn't, or no hash is provided,\n // scroll to top.\n return hash ? decodeURI(hash.slice(1)) : [0, 0]\n }\n }\n return true\n}\n\nfunction init() {\n // The \"scroll-behavior\" package expects the \"action\" to be on the location\n // object so let's copy it over.\n globalHistory.listen(args => {\n args.location.action = args.action\n })\n\n window.___push = to => navigate(to, { replace: false })\n window.___replace = to => navigate(to, { replace: true })\n window.___navigate = (to, options) => navigate(to, options)\n\n // Check for initial page-load redirect\n maybeRedirect(window.location.pathname)\n}\n\nclass RouteAnnouncer extends React.Component {\n constructor(props) {\n super(props)\n this.announcementRef = React.createRef()\n }\n\n componentDidUpdate(prevProps, nextProps) {\n requestAnimationFrame(() => {\n let pageName = `new page at ${this.props.location.pathname}`\n if (document.title) {\n pageName = document.title\n }\n const pageHeadings = document.querySelectorAll(`#gatsby-focus-wrapper h1`)\n if (pageHeadings && pageHeadings.length) {\n pageName = pageHeadings[0].textContent\n }\n const newAnnouncement = `Navigated to ${pageName}`\n if (this.announcementRef.current) {\n const oldAnnouncement = this.announcementRef.current.innerText\n if (oldAnnouncement !== newAnnouncement) {\n this.announcementRef.current.innerText = newAnnouncement\n }\n }\n })\n }\n\n render() {\n return
\n }\n}\n\nconst compareLocationProps = (prevLocation, nextLocation) => {\n if (prevLocation.href !== nextLocation.href) {\n return true\n }\n\n if (prevLocation?.state?.key !== nextLocation?.state?.key) {\n return true\n }\n\n return false\n}\n\n// Fire on(Pre)RouteUpdate APIs\nclass RouteUpdates extends React.Component {\n constructor(props) {\n super(props)\n onPreRouteUpdate(props.location, null)\n }\n\n componentDidMount() {\n onRouteUpdate(this.props.location, null)\n }\n\n shouldComponentUpdate(prevProps) {\n if (compareLocationProps(prevProps.location, this.props.location)) {\n onPreRouteUpdate(this.props.location, prevProps.location)\n return true\n }\n return false\n }\n\n componentDidUpdate(prevProps) {\n if (compareLocationProps(prevProps.location, this.props.location)) {\n onRouteUpdate(this.props.location, prevProps.location)\n }\n }\n\n render() {\n return (\n \n {this.props.children}\n \n \n )\n }\n}\n\nRouteUpdates.propTypes = {\n location: PropTypes.object.isRequired,\n}\n\nexport { init, shouldUpdateScroll, RouteUpdates, maybeGetBrowserRedirect }\n","// Pulled from react-compat\n// https://github.com/developit/preact-compat/blob/7c5de00e7c85e2ffd011bf3af02899b63f699d3a/src/index.js#L349\nfunction shallowDiffers(a, b) {\n for (var i in a) {\n if (!(i in b)) return true;\n }for (var _i in b) {\n if (a[_i] !== b[_i]) return true;\n }return false;\n}\n\nexport default (function (instance, nextProps, nextState) {\n return shallowDiffers(instance.props, nextProps) || shallowDiffers(instance.state, nextState);\n});","import React from \"react\"\nimport loader, { PageResourceStatus } from \"./loader\"\nimport shallowCompare from \"shallow-compare\"\n\nclass EnsureResources extends React.Component {\n constructor(props) {\n super()\n const { location, pageResources } = props\n this.state = {\n location: { ...location },\n pageResources:\n pageResources ||\n loader.loadPageSync(location.pathname, { withErrorDetails: true }),\n }\n }\n\n static getDerivedStateFromProps({ location }, prevState) {\n if (prevState.location.href !== location.href) {\n const pageResources = loader.loadPageSync(location.pathname, {\n withErrorDetails: true,\n })\n\n return {\n pageResources,\n location: { ...location },\n }\n }\n\n return {\n location: { ...location },\n }\n }\n\n loadResources(rawPath) {\n loader.loadPage(rawPath).then(pageResources => {\n if (pageResources && pageResources.status !== PageResourceStatus.Error) {\n this.setState({\n location: { ...window.location },\n pageResources,\n })\n } else {\n window.history.replaceState({}, ``, location.href)\n window.location = rawPath\n }\n })\n }\n\n shouldComponentUpdate(nextProps, nextState) {\n // Always return false if we're missing resources.\n if (!nextState.pageResources) {\n this.loadResources(nextProps.location.pathname)\n return false\n }\n\n if (\n process.env.BUILD_STAGE === `develop` &&\n nextState.pageResources.stale\n ) {\n this.loadResources(nextProps.location.pathname)\n return false\n }\n\n // Check if the component or json have changed.\n if (this.state.pageResources !== nextState.pageResources) {\n return true\n }\n if (\n this.state.pageResources.component !== nextState.pageResources.component\n ) {\n return true\n }\n\n if (this.state.pageResources.json !== nextState.pageResources.json) {\n return true\n }\n // Check if location has changed on a page using internal routing\n // via matchPath configuration.\n if (\n this.state.location.key !== nextState.location.key &&\n nextState.pageResources.page &&\n (nextState.pageResources.page.matchPath ||\n nextState.pageResources.page.path)\n ) {\n return true\n }\n return shallowCompare(this, nextProps, nextState)\n }\n\n render() {\n if (\n process.env.NODE_ENV !== `production` &&\n (!this.state.pageResources ||\n this.state.pageResources.status === PageResourceStatus.Error)\n ) {\n const message = `EnsureResources was not able to find resources for path: \"${this.props.location.pathname}\"\nThis typically means that an issue occurred building components for that path.\nRun \\`gatsby clean\\` to remove any cached elements.`\n if (this.state.pageResources?.error) {\n console.error(message)\n throw this.state.pageResources.error\n }\n\n throw new Error(message)\n }\n\n return this.props.children(this.state)\n }\n}\n\nexport default EnsureResources\n","import { apiRunner, apiRunnerAsync } from \"./api-runner-browser\"\nimport React from \"react\"\nimport ReactDOM from \"react-dom\"\nimport { Router, navigate, Location, BaseContext } from \"@gatsbyjs/reach-router\"\nimport { ScrollContext } from \"gatsby-react-router-scroll\"\nimport { StaticQueryContext } from \"gatsby\"\nimport {\n shouldUpdateScroll,\n init as navigationInit,\n RouteUpdates,\n} from \"./navigation\"\nimport emitter from \"./emitter\"\nimport PageRenderer from \"./page-renderer\"\nimport asyncRequires from \"$virtual/async-requires\"\nimport {\n setLoader,\n ProdLoader,\n publicLoader,\n PageResourceStatus,\n getStaticQueryResults,\n} from \"./loader\"\nimport EnsureResources from \"./ensure-resources\"\nimport stripPrefix from \"./strip-prefix\"\n\n// Generated during bootstrap\nimport matchPaths from \"$virtual/match-paths.json\"\n\nconst loader = new ProdLoader(asyncRequires, matchPaths, window.pageData)\nsetLoader(loader)\nloader.setApiRunner(apiRunner)\n\nwindow.asyncRequires = asyncRequires\nwindow.___emitter = emitter\nwindow.___loader = publicLoader\n\nnavigationInit()\n\napiRunnerAsync(`onClientEntry`).then(() => {\n // Let plugins register a service worker. The plugin just needs\n // to return true.\n if (apiRunner(`registerServiceWorker`).filter(Boolean).length > 0) {\n require(`./register-service-worker`)\n }\n\n // In gatsby v2 if Router is used in page using matchPaths\n // paths need to contain full path.\n // For example:\n // - page have `/app/*` matchPath\n // - inside template user needs to use `/app/xyz` as path\n // Resetting `basepath`/`baseuri` keeps current behaviour\n // to not introduce breaking change.\n // Remove this in v3\n const RouteHandler = props => (\n \n \n \n )\n\n const DataContext = React.createContext({})\n\n class GatsbyRoot extends React.Component {\n render() {\n const { children } = this.props\n return (\n \n {({ location }) => (\n \n {({ pageResources, location }) => {\n const staticQueryResults = getStaticQueryResults()\n return (\n \n \n {children}\n \n \n )\n }}\n \n )}\n \n )\n }\n }\n\n class LocationHandler extends React.Component {\n render() {\n return (\n \n {({ pageResources, location }) => (\n \n \n \n \n
\n \n \n )}\n \n )\n }\n }\n\n const { pagePath, location: browserLoc } = window\n\n // Explicitly call navigate if the canonical path (window.pagePath)\n // is different to the browser path (window.location.pathname). But\n // only if NONE of the following conditions hold:\n //\n // - The url matches a client side route (page.matchPath)\n // - it's a 404 page\n // - it's the offline plugin shell (/offline-plugin-app-shell-fallback/)\n if (\n pagePath &&\n __BASE_PATH__ + pagePath !== browserLoc.pathname &&\n !(\n loader.findMatchPath(stripPrefix(browserLoc.pathname, __BASE_PATH__)) ||\n pagePath === `/404.html` ||\n pagePath.match(/^\\/404\\/?$/) ||\n pagePath.match(/^\\/offline-plugin-app-shell-fallback\\/?$/)\n )\n ) {\n navigate(__BASE_PATH__ + pagePath + browserLoc.search + browserLoc.hash, {\n replace: true,\n })\n }\n\n publicLoader.loadPage(browserLoc.pathname).then(page => {\n if (!page || page.status === PageResourceStatus.Error) {\n const message = `page resources for ${browserLoc.pathname} not found. Not rendering React`\n\n // if the chunk throws an error we want to capture the real error\n // This should help with https://github.com/gatsbyjs/gatsby/issues/19618\n if (page && page.error) {\n console.error(message)\n throw page.error\n }\n\n throw new Error(message)\n }\n\n window.___webpackCompilationHash = page.page.webpackCompilationHash\n\n const SiteRoot = apiRunner(\n `wrapRootElement`,\n { element: },\n ,\n ({ result }) => {\n return { element: result }\n }\n ).pop()\n\n const App = function App() {\n const onClientEntryRanRef = React.useRef(false)\n\n React.useEffect(() => {\n if (!onClientEntryRanRef.current) {\n onClientEntryRanRef.current = true\n if (performance.mark) {\n performance.mark(`onInitialClientRender`)\n }\n\n apiRunner(`onInitialClientRender`)\n }\n }, [])\n\n return {SiteRoot}\n }\n\n const renderer = apiRunner(\n `replaceHydrateFunction`,\n undefined,\n ReactDOM.hydrateRoot ? ReactDOM.hydrateRoot : ReactDOM.hydrate\n )[0]\n\n function runRender() {\n const rootElement =\n typeof window !== `undefined`\n ? document.getElementById(`___gatsby`)\n : null\n\n if (renderer === ReactDOM.hydrateRoot) {\n renderer(rootElement, )\n } else {\n renderer(, rootElement)\n }\n }\n\n // https://github.com/madrobby/zepto/blob/b5ed8d607f67724788ec9ff492be297f64d47dfc/src/zepto.js#L439-L450\n // TODO remove IE 10 support\n const doc = document\n if (\n doc.readyState === `complete` ||\n (doc.readyState !== `loading` && !doc.documentElement.doScroll)\n ) {\n setTimeout(function () {\n runRender()\n }, 0)\n } else {\n const handler = function () {\n doc.removeEventListener(`DOMContentLoaded`, handler, false)\n window.removeEventListener(`load`, handler, false)\n\n runRender()\n }\n\n doc.addEventListener(`DOMContentLoaded`, handler, false)\n window.addEventListener(`load`, handler, false)\n }\n })\n})\n","import React from \"react\"\nimport PropTypes from \"prop-types\"\n\nimport loader from \"./loader\"\nimport InternalPageRenderer from \"./page-renderer\"\n\nconst ProdPageRenderer = ({ location }) => {\n const pageResources = loader.loadPageSync(location.pathname)\n if (!pageResources) {\n return null\n }\n return React.createElement(InternalPageRenderer, {\n location,\n pageResources,\n ...pageResources.json,\n })\n}\n\nProdPageRenderer.propTypes = {\n location: PropTypes.shape({\n pathname: PropTypes.string.isRequired,\n }).isRequired,\n}\n\nexport default ProdPageRenderer\n","const preferDefault = m => (m && m.default) || m\n\nif (process.env.BUILD_STAGE === `develop`) {\n module.exports = preferDefault(require(`./public-page-renderer-dev`))\n} else if (process.env.BUILD_STAGE === `build-javascript`) {\n module.exports = preferDefault(require(`./public-page-renderer-prod`))\n} else {\n module.exports = () => null\n}\n","exports.polyfill = Component => Component\n","import redirects from \"./redirects.json\"\n\n// Convert to a map for faster lookup in maybeRedirect()\n\nconst redirectMap = new Map()\nconst redirectIgnoreCaseMap = new Map()\n\nredirects.forEach(redirect => {\n if (redirect.ignoreCase) {\n redirectIgnoreCaseMap.set(redirect.fromPath, redirect)\n } else {\n redirectMap.set(redirect.fromPath, redirect)\n }\n})\n\nexport function maybeGetBrowserRedirect(pathname) {\n let redirect = redirectMap.get(pathname)\n if (!redirect) {\n redirect = redirectIgnoreCaseMap.get(pathname.toLowerCase())\n }\n return redirect\n}\n","import { apiRunner } from \"./api-runner-browser\"\n\nif (\n window.location.protocol !== `https:` &&\n window.location.hostname !== `localhost`\n) {\n console.error(\n `Service workers can only be used over HTTPS, or on localhost for development`\n )\n} else if (`serviceWorker` in navigator) {\n navigator.serviceWorker\n .register(`${__BASE_PATH__}/sw.js`)\n .then(function (reg) {\n reg.addEventListener(`updatefound`, () => {\n apiRunner(`onServiceWorkerUpdateFound`, { serviceWorker: reg })\n // The updatefound event implies that reg.installing is set; see\n // https://w3c.github.io/ServiceWorker/#service-worker-registration-updatefound-event\n const installingWorker = reg.installing\n console.log(`installingWorker`, installingWorker)\n installingWorker.addEventListener(`statechange`, () => {\n switch (installingWorker.state) {\n case `installed`:\n if (navigator.serviceWorker.controller) {\n // At this point, the old content will have been purged and the fresh content will\n // have been added to the cache.\n\n // We set a flag so Gatsby Link knows to refresh the page on next navigation attempt\n window.___swUpdated = true\n // We call the onServiceWorkerUpdateReady API so users can show update prompts.\n apiRunner(`onServiceWorkerUpdateReady`, { serviceWorker: reg })\n\n // If resources failed for the current page, reload.\n if (window.___failedResources) {\n console.log(`resources failed, SW updated - reloading`)\n window.location.reload()\n }\n } else {\n // At this point, everything has been precached.\n // It's the perfect time to display a \"Content is cached for offline use.\" message.\n console.log(`Content is now available offline!`)\n\n // Post to service worker that install is complete.\n // Delay to allow time for the event listener to be added --\n // otherwise fetch is called too soon and resources aren't cached.\n apiRunner(`onServiceWorkerInstalled`, { serviceWorker: reg })\n }\n break\n\n case `redundant`:\n console.error(`The installing service worker became redundant.`)\n apiRunner(`onServiceWorkerRedundant`, { serviceWorker: reg })\n break\n\n case `activated`:\n apiRunner(`onServiceWorkerActive`, { serviceWorker: reg })\n break\n }\n })\n })\n })\n .catch(function (e) {\n console.error(`Error during service worker registration:`, e)\n })\n}\n","/**\n * Remove a prefix from a string. Return the input string if the given prefix\n * isn't found.\n */\n\nexport default function stripPrefix(str, prefix = ``) {\n if (!prefix) {\n return str\n }\n\n if (str === prefix) {\n return `/`\n }\n\n if (str.startsWith(`${prefix}/`)) {\n return str.slice(prefix.length)\n }\n\n return str\n}\n","// A [trie](https://en.wikipedia.org/wiki/Trie) data structure that holds\n// object keys weakly, yet can also hold non-object keys, unlike the\n// native `WeakMap`.\n// If no makeData function is supplied, the looked-up data will be an empty,\n// null-prototype Object.\nconst defaultMakeData = () => Object.create(null);\n// Useful for processing arguments objects as well as arrays.\nconst {\n forEach,\n slice\n} = Array.prototype;\nconst {\n hasOwnProperty\n} = Object.prototype;\nexport class Trie {\n constructor() {\n let weakness = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;\n let makeData = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultMakeData;\n this.weakness = weakness;\n this.makeData = makeData;\n }\n lookup() {\n return this.lookupArray(arguments);\n }\n lookupArray(array) {\n let node = this;\n forEach.call(array, key => node = node.getChildTrie(key));\n return hasOwnProperty.call(node, \"data\") ? node.data : node.data = this.makeData(slice.call(array));\n }\n peek() {\n return this.peekArray(arguments);\n }\n peekArray(array) {\n let node = this;\n for (let i = 0, len = array.length; node && i < len; ++i) {\n const map = node.mapFor(array[i], false);\n node = map && map.get(array[i]);\n }\n return node && node.data;\n }\n remove() {\n return this.removeArray(arguments);\n }\n removeArray(array) {\n let data;\n if (array.length) {\n const head = array[0];\n const map = this.mapFor(head, false);\n const child = map && map.get(head);\n if (child) {\n data = child.removeArray(slice.call(array, 1));\n if (!child.data && !child.weak && !(child.strong && child.strong.size)) {\n map.delete(head);\n }\n }\n } else {\n data = this.data;\n delete this.data;\n }\n return data;\n }\n getChildTrie(key) {\n const map = this.mapFor(key, true);\n let child = map.get(key);\n if (!child) map.set(key, child = new Trie(this.weakness, this.makeData));\n return child;\n }\n mapFor(key, create) {\n return this.weakness && isObjRef(key) ? this.weak || (create ? this.weak = new WeakMap() : void 0) : this.strong || (create ? this.strong = new Map() : void 0);\n }\n}\nfunction isObjRef(value) {\n switch (typeof value) {\n case \"object\":\n if (value === null) break;\n // Fall through to return true...\n case \"function\":\n return true;\n }\n return false;\n}","// This currentContext variable will only be used if the makeSlotClass\n// function is called, which happens only if this is the first copy of the\n// @wry/context package to be imported.\nlet currentContext = null;\n// This unique internal object is used to denote the absence of a value\n// for a given Slot, and is never exposed to outside code.\nconst MISSING_VALUE = {};\nlet idCounter = 1;\n// Although we can't do anything about the cost of duplicated code from\n// accidentally bundling multiple copies of the @wry/context package, we can\n// avoid creating the Slot class more than once using makeSlotClass.\nconst makeSlotClass = () => class Slot {\n constructor() {\n // If you have a Slot object, you can find out its slot.id, but you cannot\n // guess the slot.id of a Slot you don't have access to, thanks to the\n // randomized suffix.\n this.id = [\"slot\", idCounter++, Date.now(), Math.random().toString(36).slice(2)].join(\":\");\n }\n hasValue() {\n for (let context = currentContext; context; context = context.parent) {\n // We use the Slot object iself as a key to its value, which means the\n // value cannot be obtained without a reference to the Slot object.\n if (this.id in context.slots) {\n const value = context.slots[this.id];\n if (value === MISSING_VALUE) break;\n if (context !== currentContext) {\n // Cache the value in currentContext.slots so the next lookup will\n // be faster. This caching is safe because the tree of contexts and\n // the values of the slots are logically immutable.\n currentContext.slots[this.id] = value;\n }\n return true;\n }\n }\n if (currentContext) {\n // If a value was not found for this Slot, it's never going to be found\n // no matter how many times we look it up, so we might as well cache\n // the absence of the value, too.\n currentContext.slots[this.id] = MISSING_VALUE;\n }\n return false;\n }\n getValue() {\n if (this.hasValue()) {\n return currentContext.slots[this.id];\n }\n }\n withValue(value, callback,\n // Given the prevalence of arrow functions, specifying arguments is likely\n // to be much more common than specifying `this`, hence this ordering:\n args, thisArg) {\n const slots = {\n __proto__: null,\n [this.id]: value\n };\n const parent = currentContext;\n currentContext = {\n parent,\n slots\n };\n try {\n // Function.prototype.apply allows the arguments array argument to be\n // omitted or undefined, so args! is fine here.\n return callback.apply(thisArg, args);\n } finally {\n currentContext = parent;\n }\n }\n // Capture the current context and wrap a callback function so that it\n // reestablishes the captured context when called.\n static bind(callback) {\n const context = currentContext;\n return function () {\n const saved = currentContext;\n try {\n currentContext = context;\n return callback.apply(this, arguments);\n } finally {\n currentContext = saved;\n }\n };\n }\n // Immediately run a callback function without any captured context.\n static noContext(callback,\n // Given the prevalence of arrow functions, specifying arguments is likely\n // to be much more common than specifying `this`, hence this ordering:\n args, thisArg) {\n if (currentContext) {\n const saved = currentContext;\n try {\n currentContext = null;\n // Function.prototype.apply allows the arguments array argument to be\n // omitted or undefined, so args! is fine here.\n return callback.apply(thisArg, args);\n } finally {\n currentContext = saved;\n }\n } else {\n return callback.apply(thisArg, args);\n }\n }\n};\nfunction maybe(fn) {\n try {\n return fn();\n } catch (ignored) {}\n}\n// We store a single global implementation of the Slot class as a permanent\n// non-enumerable property of the globalThis object. This obfuscation does\n// nothing to prevent access to the Slot class, but at least it ensures the\n// implementation (i.e. currentContext) cannot be tampered with, and all copies\n// of the @wry/context package (hopefully just one) will share the same Slot\n// implementation. Since the first copy of the @wry/context package to be\n// imported wins, this technique imposes a steep cost for any future breaking\n// changes to the Slot class.\nconst globalKey = \"@wry/context:Slot\";\nconst host =\n// Prefer globalThis when available.\n// https://github.com/benjamn/wryware/issues/347\nmaybe(() => globalThis) ||\n// Fall back to global, which works in Node.js and may be converted by some\n// bundlers to the appropriate identifier (window, self, ...) depending on the\n// bundling target. https://github.com/endojs/endo/issues/576#issuecomment-1178515224\nmaybe(() => global) ||\n// Otherwise, use a dummy host that's local to this module. We used to fall\n// back to using the Array constructor as a namespace, but that was flagged in\n// https://github.com/benjamn/wryware/issues/347, and can be avoided.\nObject.create(null);\n// Whichever globalHost we're using, make TypeScript happy about the additional\n// globalKey property.\nconst globalHost = host;\nexport const Slot = globalHost[globalKey] ||\n// Earlier versions of this package stored the globalKey property on the Array\n// constructor, so we check there as well, to prevent Slot class duplication.\nArray[globalKey] || function (Slot) {\n try {\n Object.defineProperty(globalHost, globalKey, {\n value: Slot,\n enumerable: false,\n writable: false,\n // When it was possible for globalHost to be the Array constructor (a\n // legacy Slot dedup strategy), it was important for the property to be\n // configurable:true so it could be deleted. That does not seem to be as\n // important when globalHost is the global object, but I don't want to\n // cause similar problems again, and configurable:true seems safest.\n // https://github.com/endojs/endo/issues/576#issuecomment-1178274008\n configurable: true\n });\n } finally {\n return Slot;\n }\n}(makeSlotClass());","import { Slot } from \"./slot.js\";\nexport { Slot };\nexport const {\n bind,\n noContext\n} = Slot;\n// Like global.setTimeout, except the callback runs with captured context.\nexport { setTimeoutWithContext as setTimeout };\nfunction setTimeoutWithContext(callback, delay) {\n return setTimeout(bind(callback), delay);\n}\n// Turn any generator function into an async function (using yield instead\n// of await), with context automatically preserved across yields.\nexport function asyncFromGen(genFn) {\n return function () {\n const gen = genFn.apply(this, arguments);\n const boundNext = bind(gen.next);\n const boundThrow = bind(gen.throw);\n return new Promise((resolve, reject) => {\n function invoke(method, argument) {\n try {\n var result = method.call(gen, argument);\n } catch (error) {\n return reject(error);\n }\n const next = result.done ? resolve : invokeNext;\n if (isPromiseLike(result.value)) {\n result.value.then(next, result.done ? reject : invokeThrow);\n } else {\n next(result.value);\n }\n }\n const invokeNext = value => invoke(boundNext, value);\n const invokeThrow = error => invoke(boundThrow, error);\n invokeNext();\n });\n };\n}\nfunction isPromiseLike(value) {\n return value && typeof value.then === \"function\";\n}\n// If you use the fibers npm package to implement coroutines in Node.js,\n// you should call this function at least once to ensure context management\n// remains coherent across any yields.\nconst wrappedFibers = [];\nexport function wrapYieldingFiberMethods(Fiber) {\n // There can be only one implementation of Fiber per process, so this array\n // should never grow longer than one element.\n if (wrappedFibers.indexOf(Fiber) < 0) {\n const wrap = (obj, method) => {\n const fn = obj[method];\n obj[method] = function () {\n return noContext(fn, arguments, this);\n };\n };\n // These methods can yield, according to\n // https://github.com/laverdet/node-fibers/blob/ddebed9b8ae3883e57f822e2108e6943e5c8d2a8/fibers.js#L97-L100\n wrap(Fiber, \"yield\");\n wrap(Fiber.prototype, \"run\");\n wrap(Fiber.prototype, \"throwInto\");\n wrappedFibers.push(Fiber);\n }\n return Fiber;\n}","import { Slot } from \"@wry/context\";\nexport const parentEntrySlot = new Slot();\nexport function nonReactive(fn) {\n return parentEntrySlot.withValue(void 0, fn);\n}\nexport { Slot };\nexport { bind as bindContext, noContext, setTimeout, asyncFromGen } from \"@wry/context\";","export const {\n hasOwnProperty\n} = Object.prototype;\nexport const arrayFromSet = Array.from || function (set) {\n const array = [];\n set.forEach(item => array.push(item));\n return array;\n};\nexport function maybeUnsubscribe(entryOrDep) {\n const {\n unsubscribe\n } = entryOrDep;\n if (typeof unsubscribe === \"function\") {\n entryOrDep.unsubscribe = void 0;\n unsubscribe();\n }\n}","import { parentEntrySlot } from \"./context.js\";\nimport { maybeUnsubscribe, arrayFromSet } from \"./helpers.js\";\nconst emptySetPool = [];\nconst POOL_TARGET_SIZE = 100;\n// Since this package might be used browsers, we should avoid using the\n// Node built-in assert module.\nfunction assert(condition, optionalMessage) {\n if (!condition) {\n throw new Error(optionalMessage || \"assertion failure\");\n }\n}\nfunction valueIs(a, b) {\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}\nfunction valueGet(value) {\n switch (value.length) {\n case 0:\n throw new Error(\"unknown value\");\n case 1:\n return value[0];\n case 2:\n throw value[1];\n }\n}\nfunction valueCopy(value) {\n return value.slice(0);\n}\nexport class Entry {\n constructor(fn) {\n this.fn = fn;\n this.parents = new Set();\n this.childValues = new Map();\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 this.dirtyChildren = null;\n this.dirty = true;\n this.recomputing = false;\n this.value = [];\n this.deps = null;\n ++Entry.count;\n }\n peek() {\n if (this.value.length === 1 && !mightBeDirty(this)) {\n rememberParent(this);\n return this.value[0];\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 recompute(args) {\n assert(!this.recomputing, \"already recomputing\");\n rememberParent(this);\n return mightBeDirty(this) ? reallyRecompute(this, args) : valueGet(this.value);\n }\n setDirty() {\n if (this.dirty) return;\n this.dirty = true;\n reportDirty(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 dispose() {\n this.setDirty();\n // Sever any dependency relationships with our own children, so those\n // children don't retain this parent Entry in their child.parents sets,\n // thereby preventing it from being fully garbage collected.\n forgetChildren(this);\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 eachParent(this, (parent, child) => {\n parent.setDirty();\n forgetChild(parent, this);\n });\n }\n forget() {\n // The code that creates Entry objects in index.ts will replace this method\n // with one that actually removes the Entry from the cache, which will also\n // trigger the entry.dispose method.\n this.dispose();\n }\n dependOn(dep) {\n dep.add(this);\n if (!this.deps) {\n this.deps = emptySetPool.pop() || new Set();\n }\n this.deps.add(dep);\n }\n forgetDeps() {\n if (this.deps) {\n arrayFromSet(this.deps).forEach(dep => dep.delete(this));\n this.deps.clear();\n emptySetPool.push(this.deps);\n this.deps = null;\n }\n }\n}\nEntry.count = 0;\nfunction rememberParent(child) {\n const parent = parentEntrySlot.getValue();\n if (parent) {\n child.parents.add(parent);\n if (!parent.childValues.has(child)) {\n parent.childValues.set(child, []);\n }\n if (mightBeDirty(child)) {\n reportDirtyChild(parent, child);\n } else {\n reportCleanChild(parent, child);\n }\n return parent;\n }\n}\nfunction reallyRecompute(entry, args) {\n forgetChildren(entry);\n // Set entry as the parent entry while calling recomputeNewValue(entry).\n parentEntrySlot.withValue(entry, recomputeNewValue, [entry, args]);\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 return valueGet(entry.value);\n}\nfunction recomputeNewValue(entry, args) {\n entry.recomputing = true;\n const {\n normalizeResult\n } = entry;\n let oldValueCopy;\n if (normalizeResult && entry.value.length === 1) {\n oldValueCopy = valueCopy(entry.value);\n }\n // Make entry.value an empty array, representing an unknown value.\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 // If we have a viable oldValueCopy to compare with the (successfully\n // recomputed) new entry.value, and they are not already === identical, give\n // normalizeResult a chance to pick/choose/reuse parts of oldValueCopy[0]\n // and/or entry.value[0] to determine the final cached entry.value.\n if (normalizeResult && oldValueCopy && !valueIs(oldValueCopy, entry.value)) {\n try {\n entry.value[0] = normalizeResult(entry.value[0], oldValueCopy[0]);\n } catch (_a) {\n // If normalizeResult throws, just use the newer value, rather than\n // saving the exception as entry.value[1].\n }\n }\n } catch (e) {\n // If entry.fn throws, entry.value will hold that exception.\n entry.value[1] = e;\n }\n // Either way, this line is always reached.\n entry.recomputing = false;\n}\nfunction mightBeDirty(entry) {\n return entry.dirty || !!(entry.dirtyChildren && entry.dirtyChildren.size);\n}\nfunction setClean(entry) {\n entry.dirty = false;\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 reportClean(entry);\n}\nfunction reportDirty(child) {\n eachParent(child, reportDirtyChild);\n}\nfunction reportClean(child) {\n eachParent(child, reportCleanChild);\n}\nfunction eachParent(child, callback) {\n const parentCount = child.parents.size;\n if (parentCount) {\n const parents = arrayFromSet(child.parents);\n for (let i = 0; i < parentCount; ++i) {\n callback(parents[i], child);\n }\n }\n}\n// Let a parent Entry know that one of its children may be dirty.\nfunction reportDirtyChild(parent, child) {\n // Must have called rememberParent(child) before calling\n // reportDirtyChild(parent, child).\n assert(parent.childValues.has(child));\n assert(mightBeDirty(child));\n const parentWasClean = !mightBeDirty(parent);\n if (!parent.dirtyChildren) {\n parent.dirtyChildren = emptySetPool.pop() || new Set();\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 parent.dirtyChildren.add(child);\n // If parent was clean before, it just became (possibly) dirty (according to\n // mightBeDirty), since we just added child to parent.dirtyChildren.\n if (parentWasClean) {\n reportDirty(parent);\n }\n}\n// Let a parent Entry know that one of its children is no longer dirty.\nfunction reportCleanChild(parent, child) {\n // Must have called rememberChild(child) before calling\n // reportCleanChild(parent, child).\n assert(parent.childValues.has(child));\n assert(!mightBeDirty(child));\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 removeDirtyChild(parent, child);\n if (mightBeDirty(parent)) {\n return;\n }\n reportClean(parent);\n}\nfunction removeDirtyChild(parent, child) {\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// Removes all children from this entry and returns an array of the\n// removed children.\nfunction forgetChildren(parent) {\n if (parent.childValues.size > 0) {\n parent.childValues.forEach((_value, child) => {\n forgetChild(parent, child);\n });\n }\n // Remove this parent Entry from any sets to which it was added by the\n // addToSet method.\n parent.forgetDeps();\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}\nfunction forgetChild(parent, child) {\n child.parents.delete(parent);\n parent.childValues.delete(child);\n removeDirtyChild(parent, child);\n}\nfunction maybeSubscribe(entry, args) {\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 // Returning true indicates either that there was no entry.subscribe\n // function or that it succeeded.\n return true;\n}","import { parentEntrySlot } from \"./context.js\";\nimport { hasOwnProperty, maybeUnsubscribe, arrayFromSet } from \"./helpers.js\";\nconst EntryMethods = {\n setDirty: true,\n dispose: true,\n forget: true // Fully remove parent Entry from LRU cache and computation graph\n};\n\nexport function dep(options) {\n const depsByKey = new Map();\n const subscribe = options && options.subscribe;\n function depend(key) {\n const parent = parentEntrySlot.getValue();\n if (parent) {\n let dep = depsByKey.get(key);\n if (!dep) {\n depsByKey.set(key, dep = new Set());\n }\n parent.dependOn(dep);\n if (typeof subscribe === \"function\") {\n maybeUnsubscribe(dep);\n dep.unsubscribe = subscribe(key);\n }\n }\n }\n depend.dirty = function dirty(key, entryMethodName) {\n const dep = depsByKey.get(key);\n if (dep) {\n const m = entryMethodName && hasOwnProperty.call(EntryMethods, entryMethodName) ? entryMethodName : \"setDirty\";\n // We have to use arrayFromSet(dep).forEach instead of dep.forEach,\n // because modifying a Set while iterating over it can cause elements in\n // the Set to be removed from the Set before they've been iterated over.\n arrayFromSet(dep).forEach(entry => entry[m]());\n depsByKey.delete(key);\n maybeUnsubscribe(dep);\n }\n };\n return depend;\n}","import { Trie } from \"@wry/trie\";\nimport { StrongCache } from \"@wry/caches\";\nimport { Entry } from \"./entry.js\";\nimport { parentEntrySlot } from \"./context.js\";\n// These helper functions are important for making optimism work with\n// asynchronous code. In order to register parent-child dependencies,\n// optimism needs to know about any currently active parent computations.\n// In ordinary synchronous code, the parent context is implicit in the\n// execution stack, but asynchronous code requires some extra guidance in\n// order to propagate context from one async task segment to the next.\nexport { bindContext, noContext, nonReactive, setTimeout, asyncFromGen, Slot } from \"./context.js\";\n// A lighter-weight dependency, similar to OptimisticWrapperFunction, except\n// with only one argument, no makeCacheKey, no wrapped function to recompute,\n// and no result value. Useful for representing dependency leaves in the graph\n// of computation. Subscriptions are supported.\nexport { dep } from \"./dep.js\";\n// The defaultMakeCacheKey function is remarkably powerful, because it gives\n// a unique object for any shallow-identical list of arguments. If you need\n// to implement a custom makeCacheKey function, you may find it helpful to\n// delegate the final work to defaultMakeCacheKey, which is why we export it\n// here. However, you may want to avoid defaultMakeCacheKey if your runtime\n// does not support WeakMap, or you have the ability to return a string key.\n// In those cases, just write your own custom makeCacheKey functions.\nlet defaultKeyTrie;\nexport function defaultMakeCacheKey() {\n const trie = defaultKeyTrie || (defaultKeyTrie = new Trie(typeof WeakMap === \"function\"));\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return trie.lookupArray(args);\n}\n// If you're paranoid about memory leaks, or you want to avoid using WeakMap\n// under the hood, but you still need the behavior of defaultMakeCacheKey,\n// import this constructor to create your own tries.\nexport { Trie as KeyTrie };\n;\nconst caches = new Set();\nexport function wrap(originalFunction) {\n let {\n max = Math.pow(2, 16),\n keyArgs,\n makeCacheKey = defaultMakeCacheKey,\n normalizeResult,\n subscribe,\n cache: cacheOption = StrongCache\n } = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : Object.create(null);\n const cache = typeof cacheOption === \"function\" ? new cacheOption(max, entry => entry.dispose()) : cacheOption;\n const optimistic = function () {\n const key = makeCacheKey.apply(null, keyArgs ? keyArgs.apply(null, arguments) : arguments);\n if (key === void 0) {\n return originalFunction.apply(null, arguments);\n }\n let entry = cache.get(key);\n if (!entry) {\n cache.set(key, entry = new Entry(originalFunction));\n entry.normalizeResult = normalizeResult;\n entry.subscribe = subscribe;\n // Give the Entry the ability to trigger cache.delete(key), even though\n // the Entry itself does not know about key or cache.\n entry.forget = () => cache.delete(key);\n }\n const value = entry.recompute(Array.prototype.slice.call(arguments));\n // Move this entry to the front of the least-recently used queue,\n // since we just finished computing its value.\n cache.set(key, entry);\n caches.add(cache);\n // Clean up any excess entries in the cache, but only if there is no\n // active parent entry, meaning we're not in the middle of a larger\n // computation that might be flummoxed by the cleaning.\n if (!parentEntrySlot.hasValue()) {\n caches.forEach(cache => cache.clean());\n caches.clear();\n }\n return value;\n };\n Object.defineProperty(optimistic, \"size\", {\n get: () => cache.size,\n configurable: false,\n enumerable: false\n });\n Object.freeze(optimistic.options = {\n max,\n keyArgs,\n makeCacheKey,\n normalizeResult,\n subscribe,\n cache\n });\n function dirtyKey(key) {\n const entry = key && cache.get(key);\n if (entry) {\n entry.setDirty();\n }\n }\n optimistic.dirtyKey = dirtyKey;\n optimistic.dirty = function dirty() {\n dirtyKey(makeCacheKey.apply(null, arguments));\n };\n function peekKey(key) {\n const entry = key && cache.get(key);\n if (entry) {\n return entry.peek();\n }\n }\n optimistic.peekKey = peekKey;\n optimistic.peek = function peek() {\n return peekKey(makeCacheKey.apply(null, arguments));\n };\n function forgetKey(key) {\n return key ? cache.delete(key) : false;\n }\n optimistic.forgetKey = forgetKey;\n optimistic.forget = function forget() {\n return forgetKey(makeCacheKey.apply(null, arguments));\n };\n optimistic.makeCacheKey = makeCacheKey;\n optimistic.getKey = keyArgs ? function getKey() {\n return makeCacheKey.apply(null, keyArgs.apply(null, arguments));\n } : makeCacheKey;\n return Object.freeze(optimistic);\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',\n // 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 if (isLeaving) {\n key = ancestors.length === 0 ? undefined : path[path.length - 1];\n node = parent;\n parent = ancestors.pop();\n if (isEdited) {\n if (inArray) {\n node = node.slice();\n } else {\n var clone = {};\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 node = clone;\n }\n var editOffset = 0;\n for (var ii = 0; ii < edits.length; ii++) {\n var editKey = edits[ii][0];\n var editValue = edits[ii][1];\n if (inArray) {\n editKey -= editOffset;\n }\n if (inArray && editValue === null) {\n node.splice(editKey, 1);\n editOffset++;\n } else {\n node[editKey] = editValue;\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 if (node === null || node === undefined) {\n continue;\n }\n if (parent) {\n path.push(key);\n }\n }\n var result = void 0;\n if (!Array.isArray(node)) {\n if (!isNode(node)) {\n throw new Error(\"Invalid AST Node: \".concat(inspect(node), \".\"));\n }\n var visitFn = getVisitFn(visitor, node.kind, isLeaving);\n if (visitFn) {\n result = visitFn.call(visitor, node, key, parent, path, ancestors);\n if (result === BREAK) {\n break;\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 if (!isLeaving) {\n if (isNode(result)) {\n node = result;\n } else {\n path.pop();\n continue;\n }\n }\n }\n }\n }\n if (result === undefined && isEdited) {\n edits.push([key, node]);\n }\n if (isLeaving) {\n path.pop();\n } else {\n var _visitorKeys$node$kin;\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 if (parent) {\n ancestors.push(parent);\n }\n parent = node;\n }\n } while (stack !== undefined);\n if (edits.length !== 0) {\n newRoot = edits[edits.length - 1][1];\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, /* isLeaving */\n false);\n if (fn) {\n var result = fn.apply(visitors[i], arguments);\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, /* isLeaving */\n true);\n if (fn) {\n var result = fn.apply(visitors[i], arguments);\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 if (kindVisitor) {\n if (!isLeaving && typeof kindVisitor === 'function') {\n // { Kind() {} }\n return kindVisitor;\n }\n var kindSpecificVisitor = isLeaving ? kindVisitor.leave : kindVisitor.enter;\n if (typeof kindSpecificVisitor === 'function') {\n // { Kind: { enter() {}, leave() {} } }\n return kindSpecificVisitor;\n }\n } else {\n var specificVisitor = isLeaving ? visitor.leave : visitor.enter;\n if (specificVisitor) {\n if (typeof specificVisitor === 'function') {\n // { enter() {}, leave() {} }\n return specificVisitor;\n }\n var specificKindVisitor = specificVisitor[kind];\n if (typeof specificKindVisitor === 'function') {\n // { enter: { Kind() {} }, leave: { Kind() {} } }\n return specificKindVisitor;\n }\n }\n }\n}","import { __assign, __spreadArray } from \"tslib\";\nimport { invariant, newInvariantError } from \"../globals/index.js\";\nimport { BREAK, visit } from \"graphql\";\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(document, fragmentName) {\n var actualFragmentName = fragmentName;\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 var fragments = [];\n document.definitions.forEach(function (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 newInvariantError(85, definition.operation, definition.name ? \" named '\".concat(definition.name.value, \"'\") : \"\");\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 // 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(fragments.length === 1, 86, fragments.length);\n actualFragmentName = fragments[0].name.value;\n }\n // Generate a query document with an operation that simply spreads the\n // fragment inside of it.\n var query = __assign(__assign({}, document), {\n definitions: __spreadArray([{\n kind: \"OperationDefinition\",\n // OperationTypeNode is an enum\n operation: \"query\",\n selectionSet: {\n kind: \"SelectionSet\",\n selections: [{\n kind: \"FragmentSpread\",\n name: {\n kind: \"Name\",\n value: actualFragmentName\n }\n }]\n }\n }], document.definitions, true)\n });\n return query;\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(fragments) {\n if (fragments === void 0) {\n fragments = [];\n }\n var symTable = {};\n fragments.forEach(function (fragment) {\n symTable[fragment.name.value] = fragment;\n });\n return symTable;\n}\nexport function getFragmentFromSelection(selection, fragmentMap) {\n switch (selection.kind) {\n case \"InlineFragment\":\n return selection;\n case \"FragmentSpread\":\n {\n var fragmentName = selection.name.value;\n if (typeof fragmentMap === \"function\") {\n return fragmentMap(fragmentName);\n }\n var fragment = fragmentMap && fragmentMap[fragmentName];\n invariant(fragment, 87, fragmentName);\n return fragment || null;\n }\n default:\n return null;\n }\n}\nexport function isFullyUnmaskedOperation(document) {\n var isUnmasked = true;\n visit(document, {\n FragmentSpread: function (node) {\n isUnmasked = !!node.directives && node.directives.some(function (directive) {\n return directive.name.value === \"unmask\";\n });\n if (!isUnmasked) {\n return BREAK;\n }\n }\n });\n return isUnmasked;\n}","import { AutoCleanedStrongCache, cacheSizes } from \"../../utilities/caching/index.js\";\nimport { registerGlobalCache } from \"../caching/getMemoryInternals.js\";\n/**\n * Like JSON.stringify, but with object keys always sorted in the same order.\n *\n * To achieve performant sorting, this function uses a Map from JSON-serialized\n * arrays of keys (in any order) to sorted arrays of the same keys, with a\n * single sorted array reference shared by all permutations of the keys.\n *\n * As a drawback, this function will add a little bit more memory for every\n * object encountered that has different (more, less, a different order of) keys\n * than in the past.\n *\n * In a typical application, this extra memory usage should not play a\n * significant role, as `canonicalStringify` will be called for only a limited\n * number of object shapes, and the cache will not grow beyond a certain point.\n * But in some edge cases, this could be a problem, so we provide\n * canonicalStringify.reset() as a way of clearing the cache.\n * */\nexport var canonicalStringify = Object.assign(function canonicalStringify(value) {\n return JSON.stringify(value, stableObjectReplacer);\n}, {\n reset: function () {\n // Clearing the sortingMap will reclaim all cached memory, without\n // affecting the logical results of canonicalStringify, but potentially\n // sacrificing performance until the cache is refilled.\n sortingMap = new AutoCleanedStrongCache(cacheSizes.canonicalStringify || 1000 /* defaultCacheSizes.canonicalStringify */);\n }\n});\n\nif (globalThis.__DEV__ !== false) {\n registerGlobalCache(\"canonicalStringify\", function () {\n return sortingMap.size;\n });\n}\n// Values are JSON-serialized arrays of object keys (in any order), and values\n// are sorted arrays of the same keys.\nvar sortingMap;\ncanonicalStringify.reset();\n// The JSON.stringify function takes an optional second argument called a\n// replacer function. This function is called for each key-value pair in the\n// object being stringified, and its return value is used instead of the\n// original value. If the replacer function returns a new value, that value is\n// stringified as JSON instead of the original value of the property.\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify#the_replacer_parameter\nfunction stableObjectReplacer(key, value) {\n if (value && typeof value === \"object\") {\n var proto = Object.getPrototypeOf(value);\n // We don't want to mess with objects that are not \"plain\" objects, which\n // means their prototype is either Object.prototype or null. This check also\n // prevents needlessly rearranging the indices of arrays.\n if (proto === Object.prototype || proto === null) {\n var keys = Object.keys(value);\n // If keys is already sorted, let JSON.stringify serialize the original\n // value instead of creating a new object with keys in the same order.\n if (keys.every(everyKeyInOrder)) return value;\n var unsortedKey = JSON.stringify(keys);\n var sortedKeys = sortingMap.get(unsortedKey);\n if (!sortedKeys) {\n keys.sort();\n var sortedKey = JSON.stringify(keys);\n // Checking for sortedKey in the sortingMap allows us to share the same\n // sorted array reference for all permutations of the same set of keys.\n sortedKeys = sortingMap.get(sortedKey) || keys;\n sortingMap.set(unsortedKey, sortedKeys);\n sortingMap.set(sortedKey, sortedKeys);\n }\n var sortedObject_1 = Object.create(proto);\n // Reassigning the keys in sorted order will cause JSON.stringify to\n // serialize them in sorted order.\n sortedKeys.forEach(function (key) {\n sortedObject_1[key] = value[key];\n });\n return sortedObject_1;\n }\n }\n return value;\n}\n// Since everything that happens in stableObjectReplacer benefits from being as\n// efficient as possible, we use a static function as the callback for\n// keys.every in order to test if the provided keys are already sorted without\n// allocating extra memory for a callback.\nfunction everyKeyInOrder(key, i, keys) {\n return i === 0 || keys[i - 1] <= key;\n}","import { newInvariantError } from \"../globals/index.js\";\nimport { isNonNullObject } from \"../common/objects.js\";\nimport { getFragmentFromSelection } from \"./fragments.js\";\nimport { canonicalStringify } from \"../common/canonicalStringify.js\";\nexport function makeReference(id) {\n return {\n __ref: String(id)\n };\n}\nexport function isReference(obj) {\n return Boolean(obj && typeof obj === \"object\" && typeof obj.__ref === \"string\");\n}\nexport function isDocumentNode(value) {\n return isNonNullObject(value) && value.kind === \"Document\" && Array.isArray(value.definitions);\n}\nfunction isStringValue(value) {\n return value.kind === \"StringValue\";\n}\nfunction isBooleanValue(value) {\n return value.kind === \"BooleanValue\";\n}\nfunction isIntValue(value) {\n return value.kind === \"IntValue\";\n}\nfunction isFloatValue(value) {\n return value.kind === \"FloatValue\";\n}\nfunction isVariable(value) {\n return value.kind === \"Variable\";\n}\nfunction isObjectValue(value) {\n return value.kind === \"ObjectValue\";\n}\nfunction isListValue(value) {\n return value.kind === \"ListValue\";\n}\nfunction isEnumValue(value) {\n return value.kind === \"EnumValue\";\n}\nfunction isNullValue(value) {\n return value.kind === \"NullValue\";\n}\nexport function valueToObjectRepresentation(argObj, name, value, variables) {\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 var nestedArgObj_1 = {};\n value.fields.map(function (obj) {\n return valueToObjectRepresentation(nestedArgObj_1, obj.name, obj.value, variables);\n });\n argObj[name.value] = nestedArgObj_1;\n } else if (isVariable(value)) {\n var variableValue = (variables || {})[value.name.value];\n argObj[name.value] = variableValue;\n } else if (isListValue(value)) {\n argObj[name.value] = value.values.map(function (listValue) {\n var nestedArgArrayObj = {};\n valueToObjectRepresentation(nestedArgArrayObj, name, listValue, variables);\n return nestedArgArrayObj[name.value];\n });\n } else if (isEnumValue(value)) {\n argObj[name.value] = value.value;\n } else if (isNullValue(value)) {\n argObj[name.value] = null;\n } else {\n throw newInvariantError(96, name.value, value.kind);\n }\n}\nexport function storeKeyNameFromField(field, variables) {\n var directivesObj = null;\n if (field.directives) {\n directivesObj = {};\n field.directives.forEach(function (directive) {\n directivesObj[directive.name.value] = {};\n if (directive.arguments) {\n directive.arguments.forEach(function (_a) {\n var name = _a.name,\n value = _a.value;\n return valueToObjectRepresentation(directivesObj[directive.name.value], name, value, variables);\n });\n }\n });\n }\n var argObj = null;\n if (field.arguments && field.arguments.length) {\n argObj = {};\n field.arguments.forEach(function (_a) {\n var name = _a.name,\n value = _a.value;\n return valueToObjectRepresentation(argObj, name, value, variables);\n });\n }\n return getStoreKeyName(field.name.value, argObj, directivesObj);\n}\nvar KNOWN_DIRECTIVES = [\"connection\", \"include\", \"skip\", \"client\", \"rest\", \"export\", \"nonreactive\"];\n// Default stable JSON.stringify implementation used by getStoreKeyName. Can be\n// updated/replaced with something better by calling\n// getStoreKeyName.setStringify(newStringifyFunction).\nvar storeKeyNameStringify = canonicalStringify;\nexport var getStoreKeyName = Object.assign(function (fieldName, args, directives) {\n if (args && directives && directives[\"connection\"] && directives[\"connection\"][\"key\"]) {\n if (directives[\"connection\"][\"filter\"] && directives[\"connection\"][\"filter\"].length > 0) {\n var filterKeys = directives[\"connection\"][\"filter\"] ? directives[\"connection\"][\"filter\"] : [];\n filterKeys.sort();\n var filteredArgs_1 = {};\n filterKeys.forEach(function (key) {\n filteredArgs_1[key] = args[key];\n });\n return \"\".concat(directives[\"connection\"][\"key\"], \"(\").concat(storeKeyNameStringify(filteredArgs_1), \")\");\n } else {\n return directives[\"connection\"][\"key\"];\n }\n }\n var completeFieldName = fieldName;\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 var stringifiedArgs = storeKeyNameStringify(args);\n completeFieldName += \"(\".concat(stringifiedArgs, \")\");\n }\n if (directives) {\n Object.keys(directives).forEach(function (key) {\n if (KNOWN_DIRECTIVES.indexOf(key) !== -1) return;\n if (directives[key] && Object.keys(directives[key]).length) {\n completeFieldName += \"@\".concat(key, \"(\").concat(storeKeyNameStringify(directives[key]), \")\");\n } else {\n completeFieldName += \"@\".concat(key);\n }\n });\n }\n return completeFieldName;\n}, {\n setStringify: function (s) {\n var previous = storeKeyNameStringify;\n storeKeyNameStringify = s;\n return previous;\n }\n});\nexport function argumentsObjectFromField(field, variables) {\n if (field.arguments && field.arguments.length) {\n var argObj_1 = {};\n field.arguments.forEach(function (_a) {\n var name = _a.name,\n value = _a.value;\n return valueToObjectRepresentation(argObj_1, name, value, variables);\n });\n return argObj_1;\n }\n return null;\n}\nexport function resultKeyNameFromField(field) {\n return field.alias ? field.alias.value : field.name.value;\n}\nexport function getTypenameFromResult(result, selectionSet, fragmentMap) {\n var fragments;\n for (var _i = 0, _a = selectionSet.selections; _i < _a.length; _i++) {\n var selection = _a[_i];\n if (isField(selection)) {\n if (selection.name.value === \"__typename\") {\n return result[resultKeyNameFromField(selection)];\n }\n } else if (fragments) {\n fragments.push(selection);\n } else {\n fragments = [selection];\n }\n }\n if (typeof result.__typename === \"string\") {\n return result.__typename;\n }\n if (fragments) {\n for (var _b = 0, fragments_1 = fragments; _b < fragments_1.length; _b++) {\n var selection = fragments_1[_b];\n var typename = getTypenameFromResult(result, getFragmentFromSelection(selection, fragmentMap).selectionSet, fragmentMap);\n if (typeof typename === \"string\") {\n return typename;\n }\n }\n }\n}\nexport function isField(selection) {\n return selection.kind === \"Field\";\n}\nexport function isInlineFragment(selection) {\n return selection.kind === \"InlineFragment\";\n}","import { invariant, newInvariantError } from \"../globals/index.js\";\nimport { valueToObjectRepresentation } from \"./storeUtils.js\";\n// Checks the document for errors and throws an exception if there is an error.\nexport function checkDocument(doc) {\n invariant(doc && doc.kind === \"Document\", 88);\n var operations = doc.definitions.filter(function (d) {\n return d.kind !== \"FragmentDefinition\";\n }).map(function (definition) {\n if (definition.kind !== \"OperationDefinition\") {\n throw newInvariantError(89, definition.kind);\n }\n return definition;\n });\n invariant(operations.length <= 1, 90, operations.length);\n return doc;\n}\nexport function getOperationDefinition(doc) {\n checkDocument(doc);\n return doc.definitions.filter(function (definition) {\n return definition.kind === \"OperationDefinition\";\n })[0];\n}\nexport function getOperationName(doc) {\n return doc.definitions.filter(function (definition) {\n return definition.kind === \"OperationDefinition\" && !!definition.name;\n }).map(function (x) {\n return x.name.value;\n })[0] || null;\n}\n// Returns the FragmentDefinitions from a particular document as an array\nexport function getFragmentDefinitions(doc) {\n return doc.definitions.filter(function (definition) {\n return definition.kind === \"FragmentDefinition\";\n });\n}\nexport function getQueryDefinition(doc) {\n var queryDef = getOperationDefinition(doc);\n invariant(queryDef && queryDef.operation === \"query\", 91);\n return queryDef;\n}\nexport function getFragmentDefinition(doc) {\n invariant(doc.kind === \"Document\", 92);\n invariant(doc.definitions.length <= 1, 93);\n var fragmentDef = doc.definitions[0];\n invariant(fragmentDef.kind === \"FragmentDefinition\", 94);\n return fragmentDef;\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(queryDoc) {\n checkDocument(queryDoc);\n var fragmentDefinition;\n for (var _i = 0, _a = queryDoc.definitions; _i < _a.length; _i++) {\n var definition = _a[_i];\n if (definition.kind === \"OperationDefinition\") {\n var operation = definition.operation;\n if (operation === \"query\" || operation === \"mutation\" || operation === \"subscription\") {\n return definition;\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;\n }\n }\n if (fragmentDefinition) {\n return fragmentDefinition;\n }\n throw newInvariantError(95);\n}\nexport function getDefaultValues(definition) {\n var defaultValues = Object.create(null);\n var defs = definition && definition.variableDefinitions;\n if (defs && defs.length) {\n defs.forEach(function (def) {\n if (def.defaultValue) {\n valueToObjectRepresentation(defaultValues, def.variable.name, def.defaultValue);\n }\n });\n }\n return defaultValues;\n}","function _createForOfIteratorHelperLoose(o, allowArrayLike) {\n var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"];\n if (it) return (it = it.call(o)).next.bind(it);\n if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") {\n if (it) o = it;\n var i = 0;\n return function () {\n if (i >= o.length) return {\n done: true\n };\n return {\n done: false,\n value: o[i++]\n };\n };\n }\n throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);\n}\nfunction _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n return arr2;\n}\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\n\n// === Symbol Support ===\nvar hasSymbols = function () {\n return typeof Symbol === 'function';\n};\nvar hasSymbol = function (name) {\n return hasSymbols() && Boolean(Symbol[name]);\n};\nvar getSymbol = function (name) {\n return hasSymbol(name) ? Symbol[name] : '@@' + name;\n};\nif (hasSymbols() && !hasSymbol('observable')) {\n Symbol.observable = Symbol('observable');\n}\nvar SymbolIterator = getSymbol('iterator');\nvar SymbolObservable = getSymbol('observable');\nvar SymbolSpecies = getSymbol('species'); // === Abstract Operations ===\n\nfunction getMethod(obj, key) {\n var value = obj[key];\n if (value == null) return undefined;\n if (typeof value !== 'function') throw new TypeError(value + ' is not a function');\n return value;\n}\nfunction getSpecies(obj) {\n var ctor = obj.constructor;\n if (ctor !== undefined) {\n ctor = ctor[SymbolSpecies];\n if (ctor === null) {\n ctor = undefined;\n }\n }\n return ctor !== undefined ? ctor : Observable;\n}\nfunction isObservable(x) {\n return x instanceof Observable; // SPEC: Brand check\n}\n\nfunction hostReportError(e) {\n if (hostReportError.log) {\n hostReportError.log(e);\n } else {\n setTimeout(function () {\n throw e;\n });\n }\n}\nfunction enqueue(fn) {\n Promise.resolve().then(function () {\n try {\n fn();\n } catch (e) {\n hostReportError(e);\n }\n });\n}\nfunction cleanupSubscription(subscription) {\n var cleanup = subscription._cleanup;\n if (cleanup === undefined) return;\n subscription._cleanup = undefined;\n if (!cleanup) {\n return;\n }\n try {\n if (typeof cleanup === 'function') {\n cleanup();\n } else {\n var unsubscribe = getMethod(cleanup, 'unsubscribe');\n if (unsubscribe) {\n unsubscribe.call(cleanup);\n }\n }\n } catch (e) {\n hostReportError(e);\n }\n}\nfunction closeSubscription(subscription) {\n subscription._observer = undefined;\n subscription._queue = undefined;\n subscription._state = 'closed';\n}\nfunction flushSubscription(subscription) {\n var queue = subscription._queue;\n if (!queue) {\n return;\n }\n subscription._queue = undefined;\n subscription._state = 'ready';\n for (var i = 0; i < queue.length; ++i) {\n notifySubscription(subscription, queue[i].type, queue[i].value);\n if (subscription._state === 'closed') break;\n }\n}\nfunction notifySubscription(subscription, type, value) {\n subscription._state = 'running';\n var observer = subscription._observer;\n try {\n var m = getMethod(observer, type);\n switch (type) {\n case 'next':\n if (m) m.call(observer, value);\n break;\n case 'error':\n closeSubscription(subscription);\n if (m) m.call(observer, value);else throw value;\n break;\n case 'complete':\n closeSubscription(subscription);\n if (m) m.call(observer);\n break;\n }\n } catch (e) {\n hostReportError(e);\n }\n if (subscription._state === 'closed') cleanupSubscription(subscription);else if (subscription._state === 'running') subscription._state = 'ready';\n}\nfunction onNotify(subscription, type, value) {\n if (subscription._state === 'closed') return;\n if (subscription._state === 'buffering') {\n subscription._queue.push({\n type: type,\n value: value\n });\n return;\n }\n if (subscription._state !== 'ready') {\n subscription._state = 'buffering';\n subscription._queue = [{\n type: type,\n value: value\n }];\n enqueue(function () {\n return flushSubscription(subscription);\n });\n return;\n }\n notifySubscription(subscription, type, value);\n}\nvar Subscription = /*#__PURE__*/function () {\n function Subscription(observer, subscriber) {\n // ASSERT: observer is an object\n // ASSERT: subscriber is callable\n this._cleanup = undefined;\n this._observer = observer;\n this._queue = undefined;\n this._state = 'initializing';\n var subscriptionObserver = new SubscriptionObserver(this);\n try {\n this._cleanup = subscriber.call(undefined, subscriptionObserver);\n } catch (e) {\n subscriptionObserver.error(e);\n }\n if (this._state === 'initializing') this._state = 'ready';\n }\n var _proto = Subscription.prototype;\n _proto.unsubscribe = function unsubscribe() {\n if (this._state !== 'closed') {\n closeSubscription(this);\n cleanupSubscription(this);\n }\n };\n _createClass(Subscription, [{\n key: \"closed\",\n get: function () {\n return this._state === 'closed';\n }\n }]);\n return Subscription;\n}();\nvar SubscriptionObserver = /*#__PURE__*/function () {\n function SubscriptionObserver(subscription) {\n this._subscription = subscription;\n }\n var _proto2 = SubscriptionObserver.prototype;\n _proto2.next = function next(value) {\n onNotify(this._subscription, 'next', value);\n };\n _proto2.error = function error(value) {\n onNotify(this._subscription, 'error', value);\n };\n _proto2.complete = function complete() {\n onNotify(this._subscription, 'complete');\n };\n _createClass(SubscriptionObserver, [{\n key: \"closed\",\n get: function () {\n return this._subscription._state === 'closed';\n }\n }]);\n return SubscriptionObserver;\n}();\nvar Observable = /*#__PURE__*/function () {\n function Observable(subscriber) {\n if (!(this instanceof Observable)) throw new TypeError('Observable cannot be called as a function');\n if (typeof subscriber !== 'function') throw new TypeError('Observable initializer must be a function');\n this._subscriber = subscriber;\n }\n var _proto3 = Observable.prototype;\n _proto3.subscribe = function subscribe(observer) {\n if (typeof observer !== 'object' || observer === null) {\n observer = {\n next: observer,\n error: arguments[1],\n complete: arguments[2]\n };\n }\n return new Subscription(observer, this._subscriber);\n };\n _proto3.forEach = function forEach(fn) {\n var _this = this;\n return new Promise(function (resolve, reject) {\n if (typeof fn !== 'function') {\n reject(new TypeError(fn + ' is not a function'));\n return;\n }\n function done() {\n subscription.unsubscribe();\n resolve();\n }\n var subscription = _this.subscribe({\n next: function (value) {\n try {\n fn(value, done);\n } catch (e) {\n reject(e);\n subscription.unsubscribe();\n }\n },\n error: reject,\n complete: resolve\n });\n });\n };\n _proto3.map = function map(fn) {\n var _this2 = this;\n if (typeof fn !== 'function') throw new TypeError(fn + ' is not a function');\n var C = getSpecies(this);\n return new C(function (observer) {\n return _this2.subscribe({\n next: function (value) {\n try {\n value = fn(value);\n } catch (e) {\n return observer.error(e);\n }\n observer.next(value);\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n observer.complete();\n }\n });\n });\n };\n _proto3.filter = function filter(fn) {\n var _this3 = this;\n if (typeof fn !== 'function') throw new TypeError(fn + ' is not a function');\n var C = getSpecies(this);\n return new C(function (observer) {\n return _this3.subscribe({\n next: function (value) {\n try {\n if (!fn(value)) return;\n } catch (e) {\n return observer.error(e);\n }\n observer.next(value);\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n observer.complete();\n }\n });\n });\n };\n _proto3.reduce = function reduce(fn) {\n var _this4 = this;\n if (typeof fn !== 'function') throw new TypeError(fn + ' is not a function');\n var C = getSpecies(this);\n var hasSeed = arguments.length > 1;\n var hasValue = false;\n var seed = arguments[1];\n var acc = seed;\n return new C(function (observer) {\n return _this4.subscribe({\n next: function (value) {\n var first = !hasValue;\n hasValue = true;\n if (!first || hasSeed) {\n try {\n acc = fn(acc, value);\n } catch (e) {\n return observer.error(e);\n }\n } else {\n acc = value;\n }\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n if (!hasValue && !hasSeed) return observer.error(new TypeError('Cannot reduce an empty sequence'));\n observer.next(acc);\n observer.complete();\n }\n });\n });\n };\n _proto3.concat = function concat() {\n var _this5 = this;\n for (var _len = arguments.length, sources = new Array(_len), _key = 0; _key < _len; _key++) {\n sources[_key] = arguments[_key];\n }\n var C = getSpecies(this);\n return new C(function (observer) {\n var subscription;\n var index = 0;\n function startNext(next) {\n subscription = next.subscribe({\n next: function (v) {\n observer.next(v);\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n if (index === sources.length) {\n subscription = undefined;\n observer.complete();\n } else {\n startNext(C.from(sources[index++]));\n }\n }\n });\n }\n startNext(_this5);\n return function () {\n if (subscription) {\n subscription.unsubscribe();\n subscription = undefined;\n }\n };\n });\n };\n _proto3.flatMap = function flatMap(fn) {\n var _this6 = this;\n if (typeof fn !== 'function') throw new TypeError(fn + ' is not a function');\n var C = getSpecies(this);\n return new C(function (observer) {\n var subscriptions = [];\n var outer = _this6.subscribe({\n next: function (value) {\n if (fn) {\n try {\n value = fn(value);\n } catch (e) {\n return observer.error(e);\n }\n }\n var inner = C.from(value).subscribe({\n next: function (value) {\n observer.next(value);\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n var i = subscriptions.indexOf(inner);\n if (i >= 0) subscriptions.splice(i, 1);\n completeIfDone();\n }\n });\n subscriptions.push(inner);\n },\n error: function (e) {\n observer.error(e);\n },\n complete: function () {\n completeIfDone();\n }\n });\n function completeIfDone() {\n if (outer.closed && subscriptions.length === 0) observer.complete();\n }\n return function () {\n subscriptions.forEach(function (s) {\n return s.unsubscribe();\n });\n outer.unsubscribe();\n };\n });\n };\n _proto3[SymbolObservable] = function () {\n return this;\n };\n Observable.from = function from(x) {\n var C = typeof this === 'function' ? this : Observable;\n if (x == null) throw new TypeError(x + ' is not an object');\n var method = getMethod(x, SymbolObservable);\n if (method) {\n var observable = method.call(x);\n if (Object(observable) !== observable) throw new TypeError(observable + ' is not an object');\n if (isObservable(observable) && observable.constructor === C) return observable;\n return new C(function (observer) {\n return observable.subscribe(observer);\n });\n }\n if (hasSymbol('iterator')) {\n method = getMethod(x, SymbolIterator);\n if (method) {\n return new C(function (observer) {\n enqueue(function () {\n if (observer.closed) return;\n for (var _iterator = _createForOfIteratorHelperLoose(method.call(x)), _step; !(_step = _iterator()).done;) {\n var item = _step.value;\n observer.next(item);\n if (observer.closed) return;\n }\n observer.complete();\n });\n });\n }\n }\n if (Array.isArray(x)) {\n return new C(function (observer) {\n enqueue(function () {\n if (observer.closed) return;\n for (var i = 0; i < x.length; ++i) {\n observer.next(x[i]);\n if (observer.closed) return;\n }\n observer.complete();\n });\n });\n }\n throw new TypeError(x + ' is not observable');\n };\n Observable.of = function of() {\n for (var _len2 = arguments.length, items = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n items[_key2] = arguments[_key2];\n }\n var C = typeof this === 'function' ? this : Observable;\n return new C(function (observer) {\n enqueue(function () {\n if (observer.closed) return;\n for (var i = 0; i < items.length; ++i) {\n observer.next(items[i]);\n if (observer.closed) return;\n }\n observer.complete();\n });\n });\n };\n _createClass(Observable, null, [{\n key: SymbolSpecies,\n get: function () {\n return this;\n }\n }]);\n return Observable;\n}();\nif (hasSymbols()) {\n Object.defineProperty(Observable, Symbol('extensions'), {\n value: {\n symbol: SymbolObservable,\n hostReportError: hostReportError\n },\n configurable: true\n });\n}\nexport { Observable };","import { __assign, __spreadArray } from \"tslib\";\nimport { isNonNullObject } from \"./objects.js\";\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nexport function mergeDeep() {\n var sources = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n sources[_i] = arguments[_i];\n }\n return mergeDeepArray(sources);\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) {\n var target = sources[0] || {};\n var count = sources.length;\n if (count > 1) {\n var merger = new DeepMerger();\n for (var i = 1; i < count; ++i) {\n target = merger.merge(target, sources[i]);\n }\n }\n return target;\n}\nvar defaultReconciler = function (target, source, property) {\n return this.merge(target[property], source[property]);\n};\nvar DeepMerger = /** @class */function () {\n function DeepMerger(reconciler) {\n if (reconciler === void 0) {\n reconciler = defaultReconciler;\n }\n this.reconciler = reconciler;\n this.isObject = isNonNullObject;\n this.pastCopies = new Set();\n }\n DeepMerger.prototype.merge = function (target, source) {\n var _this = this;\n var context = [];\n for (var _i = 2; _i < arguments.length; _i++) {\n context[_i - 2] = arguments[_i];\n }\n if (isNonNullObject(source) && isNonNullObject(target)) {\n Object.keys(source).forEach(function (sourceKey) {\n if (hasOwnProperty.call(target, sourceKey)) {\n var targetValue = target[sourceKey];\n if (source[sourceKey] !== targetValue) {\n var result = _this.reconciler.apply(_this, __spreadArray([target, source, sourceKey], context, false));\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 return target;\n }\n // If source (or target) is not an object, let source replace target.\n return source;\n };\n DeepMerger.prototype.shallowCopyForMerge = function (value) {\n if (isNonNullObject(value)) {\n if (!this.pastCopies.has(value)) {\n if (Array.isArray(value)) {\n value = value.slice(0);\n } else {\n value = __assign({\n __proto__: Object.getPrototypeOf(value)\n }, value);\n }\n this.pastCopies.add(value);\n }\n }\n return value;\n };\n return DeepMerger;\n}();\nexport { DeepMerger };","import { invariant } from \"../globals/index.js\";\nimport { visit, BREAK, Kind } from \"graphql\";\nexport function shouldInclude(_a, variables) {\n var directives = _a.directives;\n if (!directives || !directives.length) {\n return true;\n }\n return getInclusionDirectives(directives).every(function (_a) {\n var directive = _a.directive,\n ifArgument = _a.ifArgument;\n var evaledValue = false;\n if (ifArgument.value.kind === \"Variable\") {\n evaledValue = variables && variables[ifArgument.value.name.value];\n invariant(evaledValue !== void 0, 78, directive.name.value);\n } else {\n evaledValue = ifArgument.value.value;\n }\n return directive.name.value === \"skip\" ? !evaledValue : evaledValue;\n });\n}\nexport function getDirectiveNames(root) {\n var names = [];\n visit(root, {\n Directive: function (node) {\n names.push(node.name.value);\n }\n });\n return names;\n}\nexport var hasAnyDirectives = function (names, root) {\n return hasDirectives(names, root, false);\n};\nexport var hasAllDirectives = function (names, root) {\n return hasDirectives(names, root, true);\n};\nexport function hasDirectives(names, root, all) {\n var nameSet = new Set(names);\n var uniqueCount = nameSet.size;\n visit(root, {\n Directive: function (node) {\n if (nameSet.delete(node.name.value) && (!all || !nameSet.size)) {\n return BREAK;\n }\n }\n });\n // If we found all the names, nameSet will be empty. If we only care about\n // finding some of them, the < condition is sufficient.\n return all ? !nameSet.size : nameSet.size < uniqueCount;\n}\nexport function hasClientExports(document) {\n return document && hasDirectives([\"client\", \"export\"], document, true);\n}\nfunction isInclusionDirective(_a) {\n var value = _a.name.value;\n return value === \"skip\" || value === \"include\";\n}\nexport function getInclusionDirectives(directives) {\n var result = [];\n if (directives && directives.length) {\n directives.forEach(function (directive) {\n if (!isInclusionDirective(directive)) return;\n var directiveArguments = directive.arguments;\n var directiveName = directive.name.value;\n invariant(directiveArguments && directiveArguments.length === 1, 79, directiveName);\n var ifArgument = directiveArguments[0];\n invariant(ifArgument.name && ifArgument.name.value === \"if\", 80, directiveName);\n var ifValue = ifArgument.value;\n // means it has to be a variable value if this is a valid @skip or @include directive\n invariant(ifValue && (ifValue.kind === \"Variable\" || ifValue.kind === \"BooleanValue\"), 81, directiveName);\n result.push({\n directive: directive,\n ifArgument: ifArgument\n });\n });\n }\n return result;\n}\n/** @internal */\nexport function getFragmentMaskMode(fragment) {\n var _a, _b;\n var directive = (_a = fragment.directives) === null || _a === void 0 ? void 0 : _a.find(function (_a) {\n var name = _a.name;\n return name.value === \"unmask\";\n });\n if (!directive) {\n return \"mask\";\n }\n var modeArg = (_b = directive.arguments) === null || _b === void 0 ? void 0 : _b.find(function (_a) {\n var name = _a.name;\n return name.value === \"mode\";\n });\n if (globalThis.__DEV__ !== false) {\n if (modeArg) {\n if (modeArg.value.kind === Kind.VARIABLE) {\n globalThis.__DEV__ !== false && invariant.warn(82);\n } else if (modeArg.value.kind !== Kind.STRING) {\n globalThis.__DEV__ !== false && invariant.warn(83);\n } else if (modeArg.value.value !== \"migrate\") {\n globalThis.__DEV__ !== false && invariant.warn(84, modeArg.value.value);\n }\n }\n }\n if (modeArg && \"value\" in modeArg.value && modeArg.value.value === \"migrate\") {\n return \"migrate\";\n }\n return \"unmask\";\n}","import { __rest } from \"tslib\";\nimport equal from \"@wry/equality\";\nimport { createFragmentMap, getFragmentDefinitions, getFragmentFromSelection, getMainDefinition, isField, resultKeyNameFromField, shouldInclude } from \"../utilities/index.js\";\n// Returns true if aResult and bResult are deeply equal according to the fields\n// selected by the given query, ignoring any fields marked as @nonreactive.\nexport function equalByQuery(query, _a, _b, variables) {\n var aData = _a.data,\n aRest = __rest(_a, [\"data\"]);\n var bData = _b.data,\n bRest = __rest(_b, [\"data\"]);\n return equal(aRest, bRest) && equalBySelectionSet(getMainDefinition(query).selectionSet, aData, bData, {\n fragmentMap: createFragmentMap(getFragmentDefinitions(query)),\n variables: variables\n });\n}\nfunction equalBySelectionSet(selectionSet, aResult, bResult, context) {\n if (aResult === bResult) {\n return true;\n }\n var seenSelections = new Set();\n // Returning true from this Array.prototype.every callback function skips the\n // current field/subtree. Returning false aborts the entire traversal\n // immediately, causing equalBySelectionSet to return false.\n return selectionSet.selections.every(function (selection) {\n // Avoid re-processing the same selection at the same level of recursion, in\n // case the same field gets included via multiple indirect fragment spreads.\n if (seenSelections.has(selection)) return true;\n seenSelections.add(selection);\n // Ignore @skip(if: true) and @include(if: false) fields.\n if (!shouldInclude(selection, context.variables)) return true;\n // If the field or (named) fragment spread has a @nonreactive directive on\n // it, we don't care if it's different, so we pretend it's the same.\n if (selectionHasNonreactiveDirective(selection)) return true;\n if (isField(selection)) {\n var resultKey = resultKeyNameFromField(selection);\n var aResultChild = aResult && aResult[resultKey];\n var bResultChild = bResult && bResult[resultKey];\n var childSelectionSet = selection.selectionSet;\n if (!childSelectionSet) {\n // These are scalar values, so we can compare them with deep equal\n // without redoing the main recursive work.\n return equal(aResultChild, bResultChild);\n }\n var aChildIsArray = Array.isArray(aResultChild);\n var bChildIsArray = Array.isArray(bResultChild);\n if (aChildIsArray !== bChildIsArray) return false;\n if (aChildIsArray && bChildIsArray) {\n var length_1 = aResultChild.length;\n if (bResultChild.length !== length_1) {\n return false;\n }\n for (var i = 0; i < length_1; ++i) {\n if (!equalBySelectionSet(childSelectionSet, aResultChild[i], bResultChild[i], context)) {\n return false;\n }\n }\n return true;\n }\n return equalBySelectionSet(childSelectionSet, aResultChild, bResultChild, context);\n } else {\n var fragment = getFragmentFromSelection(selection, context.fragmentMap);\n if (fragment) {\n // The fragment might === selection if it's an inline fragment, but\n // could be !== if it's a named fragment ...spread.\n if (selectionHasNonreactiveDirective(fragment)) return true;\n return equalBySelectionSet(fragment.selectionSet,\n // Notice that we reuse the same aResult and bResult values here,\n // since the fragment ...spread does not specify a field name, but\n // consists of multiple fields (within the fragment's selection set)\n // that should be applied to the current result value(s).\n aResult, bResult, context);\n }\n }\n });\n}\nfunction selectionHasNonreactiveDirective(selection) {\n return !!selection.directives && selection.directives.some(directiveIsNonreactive);\n}\nfunction directiveIsNonreactive(dir) {\n return dir.name.value === \"nonreactive\";\n}","import { Slot } from \"optimism\";\nimport { invariant } from \"../utilities/globals/index.js\";\nimport { canUseWeakMap, canUseWeakSet } from \"../utilities/index.js\";\nexport var MapImpl = canUseWeakMap ? WeakMap : Map;\nexport var SetImpl = canUseWeakSet ? WeakSet : Set;\n// Contextual slot that allows us to disable accessor warnings on fields when in\n// migrate mode.\n/** @internal */\nexport var disableWarningsSlot = new Slot();\nvar issuedWarning = false;\nexport function warnOnImproperCacheImplementation() {\n if (!issuedWarning) {\n issuedWarning = true;\n globalThis.__DEV__ !== false && invariant.warn(52);\n }\n}","import { isNonNullObject } from \"./objects.js\";\nexport function deepFreeze(value) {\n var workSet = new Set([value]);\n workSet.forEach(function (obj) {\n if (isNonNullObject(obj) && shallowFreeze(obj) === obj) {\n Object.getOwnPropertyNames(obj).forEach(function (name) {\n if (isNonNullObject(obj[name])) workSet.add(obj[name]);\n });\n }\n });\n return value;\n}\nfunction shallowFreeze(obj) {\n if (globalThis.__DEV__ !== false && !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}\nexport function maybeDeepFreeze(obj) {\n if (globalThis.__DEV__ !== false) {\n deepFreeze(obj);\n }\n return obj;\n}","import { Kind } from \"graphql\";\nimport { getFragmentMaskMode, maybeDeepFreeze, resultKeyNameFromField } from \"../utilities/index.js\";\nimport { disableWarningsSlot } from \"./utils.js\";\nimport { invariant } from \"../utilities/globals/index.js\";\nexport function maskDefinition(data, selectionSet, context) {\n return disableWarningsSlot.withValue(true, function () {\n var masked = maskSelectionSet(data, selectionSet, context, false);\n if (Object.isFrozen(data)) {\n maybeDeepFreeze(masked);\n }\n return masked;\n });\n}\nfunction getMutableTarget(data, mutableTargets) {\n if (mutableTargets.has(data)) {\n return mutableTargets.get(data);\n }\n var mutableTarget = Array.isArray(data) ? [] : Object.create(null);\n mutableTargets.set(data, mutableTarget);\n return mutableTarget;\n}\nfunction maskSelectionSet(data, selectionSet, context, migration, path) {\n var _a;\n var knownChanged = context.knownChanged;\n var memo = getMutableTarget(data, context.mutableTargets);\n if (Array.isArray(data)) {\n for (var _i = 0, _b = Array.from(data.entries()); _i < _b.length; _i++) {\n var _c = _b[_i],\n index = _c[0],\n item = _c[1];\n if (item === null) {\n memo[index] = null;\n continue;\n }\n var masked = maskSelectionSet(item, selectionSet, context, migration, globalThis.__DEV__ !== false ? \"\".concat(path || \"\", \"[\").concat(index, \"]\") : void 0);\n if (knownChanged.has(masked)) {\n knownChanged.add(memo);\n }\n memo[index] = masked;\n }\n return knownChanged.has(memo) ? memo : data;\n }\n for (var _d = 0, _e = selectionSet.selections; _d < _e.length; _d++) {\n var selection = _e[_d];\n var value = void 0;\n // we later want to add acessor warnings to the final result\n // so we need a new object to add the accessor warning to\n if (migration) {\n knownChanged.add(memo);\n }\n if (selection.kind === Kind.FIELD) {\n var keyName = resultKeyNameFromField(selection);\n var childSelectionSet = selection.selectionSet;\n value = memo[keyName] || data[keyName];\n if (value === void 0) {\n continue;\n }\n if (childSelectionSet && value !== null) {\n var masked = maskSelectionSet(data[keyName], childSelectionSet, context, migration, globalThis.__DEV__ !== false ? \"\".concat(path || \"\", \".\").concat(keyName) : void 0);\n if (knownChanged.has(masked)) {\n value = masked;\n }\n }\n if (!(globalThis.__DEV__ !== false)) {\n memo[keyName] = value;\n }\n if (globalThis.__DEV__ !== false) {\n if (migration && keyName !== \"__typename\" &&\n // either the field is not present in the memo object\n // or it has a `get` descriptor, not a `value` descriptor\n // => it is a warning accessor and we can overwrite it\n // with another accessor\n !((_a = Object.getOwnPropertyDescriptor(memo, keyName)) === null || _a === void 0 ? void 0 : _a.value)) {\n Object.defineProperty(memo, keyName, getAccessorWarningDescriptor(keyName, value, path || \"\", context.operationName, context.operationType));\n } else {\n delete memo[keyName];\n memo[keyName] = value;\n }\n }\n }\n if (selection.kind === Kind.INLINE_FRAGMENT && (!selection.typeCondition || context.cache.fragmentMatches(selection, data.__typename))) {\n value = maskSelectionSet(data, selection.selectionSet, context, migration, path);\n }\n if (selection.kind === Kind.FRAGMENT_SPREAD) {\n var fragmentName = selection.name.value;\n var fragment = context.fragmentMap[fragmentName] || (context.fragmentMap[fragmentName] = context.cache.lookupFragment(fragmentName));\n invariant(fragment, 47, fragmentName);\n var mode = getFragmentMaskMode(selection);\n if (mode !== \"mask\") {\n value = maskSelectionSet(data, fragment.selectionSet, context, mode === \"migrate\", path);\n }\n }\n if (knownChanged.has(value)) {\n knownChanged.add(memo);\n }\n }\n if (\"__typename\" in data && !(\"__typename\" in memo)) {\n memo.__typename = data.__typename;\n }\n // This check prevents cases where masked fields may accidentally be\n // returned as part of this object when the fragment also selects\n // additional fields from the same child selection.\n if (Object.keys(memo).length !== Object.keys(data).length) {\n knownChanged.add(memo);\n }\n return knownChanged.has(memo) ? memo : data;\n}\nfunction getAccessorWarningDescriptor(fieldName, value, path, operationName, operationType) {\n var getValue = function () {\n if (disableWarningsSlot.getValue()) {\n return value;\n }\n globalThis.__DEV__ !== false && invariant.warn(48, operationName ? \"\".concat(operationType, \" '\").concat(operationName, \"'\") : \"anonymous \".concat(operationType), \"\".concat(path, \".\").concat(fieldName).replace(/^\\./, \"\"));\n getValue = function () {\n return value;\n };\n return value;\n };\n return {\n get: function () {\n return getValue();\n },\n set: function (newValue) {\n getValue = function () {\n return newValue;\n };\n },\n enumerable: true,\n configurable: true\n };\n}","import { Kind } from \"graphql\";\nimport { MapImpl, SetImpl, warnOnImproperCacheImplementation } from \"./utils.js\";\nimport { invariant } from \"../utilities/globals/index.js\";\nimport equal from \"@wry/equality\";\nimport { maskDefinition } from \"./maskDefinition.js\";\nimport { createFragmentMap, getFragmentDefinitions } from \"../utilities/index.js\";\n/** @internal */\nexport function maskFragment(data, document, cache, fragmentName) {\n if (!cache.fragmentMatches) {\n if (globalThis.__DEV__ !== false) {\n warnOnImproperCacheImplementation();\n }\n return data;\n }\n var fragments = document.definitions.filter(function (node) {\n return node.kind === Kind.FRAGMENT_DEFINITION;\n });\n if (typeof fragmentName === \"undefined\") {\n invariant(fragments.length === 1, 49, fragments.length);\n fragmentName = fragments[0].name.value;\n }\n var fragment = fragments.find(function (fragment) {\n return fragment.name.value === fragmentName;\n });\n invariant(!!fragment, 50, fragmentName);\n if (data == null) {\n // Maintain the original `null` or `undefined` value\n return data;\n }\n if (equal(data, {})) {\n // Return early and skip the masking algorithm if we don't have any data\n // yet. This can happen when cache.diff returns an empty object which is\n // used from watchFragment.\n return data;\n }\n return maskDefinition(data, fragment.selectionSet, {\n operationType: \"fragment\",\n operationName: fragment.name.value,\n fragmentMap: createFragmentMap(getFragmentDefinitions(document)),\n cache: cache,\n mutableTargets: new MapImpl(),\n knownChanged: new SetImpl()\n });\n}","import { __assign, __rest } from \"tslib\";\nimport { wrap } from \"optimism\";\nimport { Observable, cacheSizes, getFragmentDefinition, getFragmentQueryDocument, mergeDeepArray } from \"../../utilities/index.js\";\nimport { WeakCache } from \"@wry/caches\";\nimport { getApolloCacheMemoryInternals } from \"../../utilities/caching/getMemoryInternals.js\";\nimport { equalByQuery } from \"../../core/equalByQuery.js\";\nimport { invariant } from \"../../utilities/globals/index.js\";\nimport { maskFragment } from \"../../masking/index.js\";\nvar ApolloCache = /** @class */function () {\n function ApolloCache() {\n this.assumeImmutableResults = false;\n // Make sure we compute the same (===) fragment query document every\n // time we receive the same fragment in readFragment.\n this.getFragmentDoc = wrap(getFragmentQueryDocument, {\n max: cacheSizes[\"cache.fragmentQueryDocuments\"] || 1000 /* defaultCacheSizes[\"cache.fragmentQueryDocuments\"] */,\n cache: WeakCache\n });\n }\n // Function used to lookup a fragment when a fragment definition is not part\n // of the GraphQL document. This is useful for caches, such as InMemoryCache,\n // that register fragments ahead of time so they can be referenced by name.\n ApolloCache.prototype.lookupFragment = function (fragmentName) {\n return null;\n };\n // Transactional API\n // The batch method is intended to replace/subsume both performTransaction\n // and recordOptimisticTransaction, but performTransaction came first, so we\n // provide a default batch implementation that's just another way of calling\n // performTransaction. Subclasses of ApolloCache (such as InMemoryCache) can\n // override the batch method to do more interesting things with its options.\n ApolloCache.prototype.batch = function (options) {\n var _this = this;\n var optimisticId = typeof options.optimistic === \"string\" ? options.optimistic : options.optimistic === false ? null : void 0;\n var updateResult;\n this.performTransaction(function () {\n return updateResult = options.update(_this);\n }, optimisticId);\n return updateResult;\n };\n ApolloCache.prototype.recordOptimisticTransaction = function (transaction, optimisticId) {\n this.performTransaction(transaction, optimisticId);\n };\n // Optional API\n // Called once per input document, allowing the cache to make static changes\n // to the query, such as adding __typename fields.\n ApolloCache.prototype.transformDocument = function (document) {\n return document;\n };\n // Called before each ApolloLink request, allowing the cache to make dynamic\n // changes to the query, such as filling in missing fragment definitions.\n ApolloCache.prototype.transformForLink = function (document) {\n return document;\n };\n ApolloCache.prototype.identify = function (object) {\n return;\n };\n ApolloCache.prototype.gc = function () {\n return [];\n };\n ApolloCache.prototype.modify = function (options) {\n return false;\n };\n // DataProxy API\n ApolloCache.prototype.readQuery = function (options, optimistic) {\n if (optimistic === void 0) {\n optimistic = !!options.optimistic;\n }\n return this.read(__assign(__assign({}, options), {\n rootId: options.id || \"ROOT_QUERY\",\n optimistic: optimistic\n }));\n };\n /** {@inheritDoc @apollo/client!ApolloClient#watchFragment:member(1)} */\n ApolloCache.prototype.watchFragment = function (options) {\n var _this = this;\n var fragment = options.fragment,\n fragmentName = options.fragmentName,\n from = options.from,\n _a = options.optimistic,\n optimistic = _a === void 0 ? true : _a,\n otherOptions = __rest(options, [\"fragment\", \"fragmentName\", \"from\", \"optimistic\"]);\n var query = this.getFragmentDoc(fragment, fragmentName);\n // While our TypeScript types do not allow for `undefined` as a valid\n // `from`, its possible `useFragment` gives us an `undefined` since it\n // calls` cache.identify` and provides that value to `from`. We are\n // adding this fix here however to ensure those using plain JavaScript\n // and using `cache.identify` themselves will avoid seeing the obscure\n // warning.\n var id = typeof from === \"undefined\" || typeof from === \"string\" ? from : this.identify(from);\n var dataMasking = !!options[Symbol.for(\"apollo.dataMasking\")];\n if (globalThis.__DEV__ !== false) {\n var actualFragmentName = fragmentName || getFragmentDefinition(fragment).name.value;\n if (!id) {\n globalThis.__DEV__ !== false && invariant.warn(1, actualFragmentName);\n }\n }\n var diffOptions = __assign(__assign({}, otherOptions), {\n returnPartialData: true,\n id: id,\n query: query,\n optimistic: optimistic\n });\n var latestDiff;\n return new Observable(function (observer) {\n return _this.watch(__assign(__assign({}, diffOptions), {\n immediate: true,\n callback: function (diff) {\n var data = dataMasking ? maskFragment(diff.result, fragment, _this, fragmentName) : diff.result;\n if (\n // Always ensure we deliver the first result\n latestDiff && equalByQuery(query, {\n data: latestDiff === null || latestDiff === void 0 ? void 0 : latestDiff.result\n }, {\n data: data\n })) {\n return;\n }\n var result = {\n data: data,\n complete: !!diff.complete\n };\n if (diff.missing) {\n result.missing = mergeDeepArray(diff.missing.map(function (error) {\n return error.missing;\n }));\n }\n latestDiff = __assign(__assign({}, diff), {\n result: data\n });\n observer.next(result);\n }\n }));\n });\n };\n ApolloCache.prototype.readFragment = function (options, optimistic) {\n if (optimistic === void 0) {\n optimistic = !!options.optimistic;\n }\n return this.read(__assign(__assign({}, options), {\n query: this.getFragmentDoc(options.fragment, options.fragmentName),\n rootId: options.id,\n optimistic: optimistic\n }));\n };\n ApolloCache.prototype.writeQuery = function (_a) {\n var id = _a.id,\n data = _a.data,\n options = __rest(_a, [\"id\", \"data\"]);\n return this.write(Object.assign(options, {\n dataId: id || \"ROOT_QUERY\",\n result: data\n }));\n };\n ApolloCache.prototype.writeFragment = function (_a) {\n var id = _a.id,\n data = _a.data,\n fragment = _a.fragment,\n fragmentName = _a.fragmentName,\n options = __rest(_a, [\"id\", \"data\", \"fragment\", \"fragmentName\"]);\n return this.write(Object.assign(options, {\n query: this.getFragmentDoc(fragment, fragmentName),\n dataId: id,\n result: data\n }));\n };\n ApolloCache.prototype.updateQuery = function (options, update) {\n return this.batch({\n update: function (cache) {\n var value = cache.readQuery(options);\n var data = update(value);\n if (data === void 0 || data === null) return value;\n cache.writeQuery(__assign(__assign({}, options), {\n data: data\n }));\n return data;\n }\n });\n };\n ApolloCache.prototype.updateFragment = function (options, update) {\n return this.batch({\n update: function (cache) {\n var value = cache.readFragment(options);\n var data = update(value);\n if (data === void 0 || data === null) return value;\n cache.writeFragment(__assign(__assign({}, options), {\n data: data\n }));\n return data;\n }\n });\n };\n return ApolloCache;\n}();\nexport { ApolloCache };\nif (globalThis.__DEV__ !== false) {\n ApolloCache.prototype.getMemoryInternals = getApolloCacheMemoryInternals;\n}","import { __extends } from \"tslib\";\nvar MissingFieldError = /** @class */function (_super) {\n __extends(MissingFieldError, _super);\n function MissingFieldError(message, path, query, variables) {\n var _a;\n // 'Error' breaks prototype chain here\n var _this = _super.call(this, message) || this;\n _this.message = message;\n _this.path = path;\n _this.query = query;\n _this.variables = variables;\n if (Array.isArray(_this.path)) {\n _this.missing = _this.message;\n for (var i = _this.path.length - 1; i >= 0; --i) {\n _this.missing = (_a = {}, _a[_this.path[i]] = _this.missing, _a);\n }\n } else {\n _this.missing = _this.path;\n }\n // We're not using `Object.setPrototypeOf` here as it isn't fully supported\n // on Android (see issue #3236).\n _this.__proto__ = MissingFieldError.prototype;\n return _this;\n }\n return MissingFieldError;\n}(Error);\nexport { MissingFieldError };","import { Trie } from \"@wry/trie\";\nimport { canUseWeakMap, canUseWeakSet } from \"../common/canUse.js\";\nimport { checkDocument } from \"./getFromAST.js\";\nimport { invariant } from \"../globals/index.js\";\nimport { WeakCache } from \"@wry/caches\";\nimport { wrap } from \"optimism\";\nimport { cacheSizes } from \"../caching/index.js\";\nfunction identity(document) {\n return document;\n}\nvar DocumentTransform = /** @class */function () {\n function DocumentTransform(transform, options) {\n if (options === void 0) {\n options = Object.create(null);\n }\n this.resultCache = canUseWeakSet ? new WeakSet() : new Set();\n this.transform = transform;\n if (options.getCacheKey) {\n // Override default `getCacheKey` function, which returns [document].\n this.getCacheKey = options.getCacheKey;\n }\n this.cached = options.cache !== false;\n this.resetCache();\n }\n // This default implementation of getCacheKey can be overridden by providing\n // options.getCacheKey to the DocumentTransform constructor. In general, a\n // getCacheKey function may either return an array of keys (often including\n // the document) to be used as a cache key, or undefined to indicate the\n // transform for this document should not be cached.\n DocumentTransform.prototype.getCacheKey = function (document) {\n return [document];\n };\n DocumentTransform.identity = function () {\n // No need to cache this transform since it just returns the document\n // unchanged. This should save a bit of memory that would otherwise be\n // needed to populate the `documentCache` of this transform.\n return new DocumentTransform(identity, {\n cache: false\n });\n };\n DocumentTransform.split = function (predicate, left, right) {\n if (right === void 0) {\n right = DocumentTransform.identity();\n }\n return Object.assign(new DocumentTransform(function (document) {\n var documentTransform = predicate(document) ? left : right;\n return documentTransform.transformDocument(document);\n },\n // Reasonably assume both `left` and `right` transforms handle their own caching\n {\n cache: false\n }), {\n left: left,\n right: right\n });\n };\n /**\n * Resets the internal cache of this transform, if it has one.\n */\n DocumentTransform.prototype.resetCache = function () {\n var _this = this;\n if (this.cached) {\n var stableCacheKeys_1 = new Trie(canUseWeakMap);\n this.performWork = wrap(DocumentTransform.prototype.performWork.bind(this), {\n makeCacheKey: function (document) {\n var cacheKeys = _this.getCacheKey(document);\n if (cacheKeys) {\n invariant(Array.isArray(cacheKeys), 77);\n return stableCacheKeys_1.lookupArray(cacheKeys);\n }\n },\n max: cacheSizes[\"documentTransform.cache\"],\n cache: WeakCache\n });\n }\n };\n DocumentTransform.prototype.performWork = function (document) {\n checkDocument(document);\n return this.transform(document);\n };\n DocumentTransform.prototype.transformDocument = function (document) {\n // If a user passes an already transformed result back to this function,\n // immediately return it.\n if (this.resultCache.has(document)) {\n return document;\n }\n var transformedDocument = this.performWork(document);\n this.resultCache.add(transformedDocument);\n return transformedDocument;\n };\n DocumentTransform.prototype.concat = function (otherTransform) {\n var _this = this;\n return Object.assign(new DocumentTransform(function (document) {\n return otherTransform.transformDocument(_this.transformDocument(document));\n },\n // Reasonably assume both transforms handle their own caching\n {\n cache: false\n }), {\n left: this,\n right: otherTransform\n });\n };\n return DocumentTransform;\n}();\nexport { DocumentTransform };","// A version of Array.isArray that works better with readonly arrays.\nexport var isArray = Array.isArray;\nexport function isNonEmptyArray(value) {\n return Array.isArray(value) && value.length > 0;\n}","import { __assign, __spreadArray } from \"tslib\";\nimport { invariant } from \"../globals/index.js\";\nimport { visit, Kind } from \"graphql\";\nimport { checkDocument, getOperationDefinition, getFragmentDefinition, getFragmentDefinitions, getMainDefinition } from \"./getFromAST.js\";\nimport { isField } from \"./storeUtils.js\";\nimport { createFragmentMap } from \"./fragments.js\";\nimport { isArray, isNonEmptyArray } from \"../common/arrays.js\";\nvar TYPENAME_FIELD = {\n kind: Kind.FIELD,\n name: {\n kind: Kind.NAME,\n value: \"__typename\"\n }\n};\nfunction isEmpty(op, fragmentMap) {\n return !op || op.selectionSet.selections.every(function (selection) {\n return selection.kind === Kind.FRAGMENT_SPREAD && isEmpty(fragmentMap[selection.name.value], fragmentMap);\n });\n}\nfunction nullIfDocIsEmpty(doc) {\n return isEmpty(getOperationDefinition(doc) || getFragmentDefinition(doc), createFragmentMap(getFragmentDefinitions(doc))) ? null : doc;\n}\nfunction getDirectiveMatcher(configs) {\n var names = new Map();\n var tests = new Map();\n configs.forEach(function (directive) {\n if (directive) {\n if (directive.name) {\n names.set(directive.name, directive);\n } else if (directive.test) {\n tests.set(directive.test, directive);\n }\n }\n });\n return function (directive) {\n var config = names.get(directive.name.value);\n if (!config && tests.size) {\n tests.forEach(function (testConfig, test) {\n if (test(directive)) {\n config = testConfig;\n }\n });\n }\n return config;\n };\n}\nfunction makeInUseGetterFunction(defaultKey) {\n var map = new Map();\n return function inUseGetterFunction(key) {\n if (key === void 0) {\n key = defaultKey;\n }\n var inUse = map.get(key);\n if (!inUse) {\n map.set(key, inUse = {\n // Variable and fragment spread names used directly within this\n // operation or fragment definition, as identified by key. These sets\n // will be populated during the first traversal of the document in\n // removeDirectivesFromDocument below.\n variables: new Set(),\n fragmentSpreads: new Set()\n });\n }\n return inUse;\n };\n}\nexport function removeDirectivesFromDocument(directives, doc) {\n checkDocument(doc);\n // Passing empty strings to makeInUseGetterFunction means we handle anonymous\n // operations as if their names were \"\". Anonymous fragment definitions are\n // not supposed to be possible, but the same default naming strategy seems\n // appropriate for that case as well.\n var getInUseByOperationName = makeInUseGetterFunction(\"\");\n var getInUseByFragmentName = makeInUseGetterFunction(\"\");\n var getInUse = function (ancestors) {\n for (var p = 0, ancestor = void 0; p < ancestors.length && (ancestor = ancestors[p]); ++p) {\n if (isArray(ancestor)) continue;\n if (ancestor.kind === Kind.OPERATION_DEFINITION) {\n // If an operation is anonymous, we use the empty string as its key.\n return getInUseByOperationName(ancestor.name && ancestor.name.value);\n }\n if (ancestor.kind === Kind.FRAGMENT_DEFINITION) {\n return getInUseByFragmentName(ancestor.name.value);\n }\n }\n globalThis.__DEV__ !== false && invariant.error(97);\n return null;\n };\n var operationCount = 0;\n for (var i = doc.definitions.length - 1; i >= 0; --i) {\n if (doc.definitions[i].kind === Kind.OPERATION_DEFINITION) {\n ++operationCount;\n }\n }\n var directiveMatcher = getDirectiveMatcher(directives);\n var shouldRemoveField = function (nodeDirectives) {\n return isNonEmptyArray(nodeDirectives) && nodeDirectives.map(directiveMatcher).some(function (config) {\n return config && config.remove;\n });\n };\n var originalFragmentDefsByPath = new Map();\n // Any time the first traversal of the document below makes a change like\n // removing a fragment (by returning null), this variable should be set to\n // true. Once it becomes true, it should never be set to false again. If this\n // variable remains false throughout the traversal, then we can return the\n // original doc immediately without any modifications.\n var firstVisitMadeChanges = false;\n var fieldOrInlineFragmentVisitor = {\n enter: function (node) {\n if (shouldRemoveField(node.directives)) {\n firstVisitMadeChanges = true;\n return null;\n }\n }\n };\n var docWithoutDirectiveSubtrees = visit(doc, {\n // These two AST node types share the same implementation, defined above.\n Field: fieldOrInlineFragmentVisitor,\n InlineFragment: fieldOrInlineFragmentVisitor,\n VariableDefinition: {\n enter: function () {\n // VariableDefinition nodes do not count as variables in use, though\n // they do contain Variable nodes that might be visited below. To avoid\n // counting variable declarations as usages, we skip visiting the\n // contents of this VariableDefinition node by returning false.\n return false;\n }\n },\n Variable: {\n enter: function (node, _key, _parent, _path, ancestors) {\n var inUse = getInUse(ancestors);\n if (inUse) {\n inUse.variables.add(node.name.value);\n }\n }\n },\n FragmentSpread: {\n enter: function (node, _key, _parent, _path, ancestors) {\n if (shouldRemoveField(node.directives)) {\n firstVisitMadeChanges = true;\n return null;\n }\n var inUse = getInUse(ancestors);\n if (inUse) {\n inUse.fragmentSpreads.add(node.name.value);\n }\n // We might like to remove this FragmentSpread by returning null here if\n // the corresponding FragmentDefinition node is also going to be removed\n // by the logic below, but we can't control the relative order of those\n // events, so we have to postpone the removal of dangling FragmentSpread\n // nodes until after the current visit of the document has finished.\n }\n },\n\n FragmentDefinition: {\n enter: function (node, _key, _parent, path) {\n originalFragmentDefsByPath.set(JSON.stringify(path), node);\n },\n leave: function (node, _key, _parent, path) {\n var originalNode = originalFragmentDefsByPath.get(JSON.stringify(path));\n if (node === originalNode) {\n // If the FragmentNode received by this leave function is identical to\n // the one received by the corresponding enter function (above), then\n // the visitor must not have made any changes within this\n // FragmentDefinition node. This fragment definition may still be\n // removed if there are no ...spread references to it, but it won't be\n // removed just because it has only a __typename field.\n return node;\n }\n if (\n // This logic applies only if the document contains one or more\n // operations, since removing all fragments from a document containing\n // only fragments makes the document useless.\n operationCount > 0 && node.selectionSet.selections.every(function (selection) {\n return selection.kind === Kind.FIELD && selection.name.value === \"__typename\";\n })) {\n // This is a somewhat opinionated choice: if a FragmentDefinition ends\n // up having no fields other than __typename, we remove the whole\n // fragment definition, and later prune ...spread references to it.\n getInUseByFragmentName(node.name.value).removed = true;\n firstVisitMadeChanges = true;\n return null;\n }\n }\n },\n Directive: {\n leave: function (node) {\n // If a matching directive is found, remove the directive itself. Note\n // that this does not remove the target (field, argument, etc) of the\n // directive, but only the directive itself.\n if (directiveMatcher(node)) {\n firstVisitMadeChanges = true;\n return null;\n }\n }\n }\n });\n if (!firstVisitMadeChanges) {\n // If our first pass did not change anything about the document, then there\n // is no cleanup we need to do, and we can return the original doc.\n return doc;\n }\n // Utility for making sure inUse.transitiveVars is recursively populated.\n // Because this logic assumes inUse.fragmentSpreads has been completely\n // populated and inUse.removed has been set if appropriate,\n // populateTransitiveVars must be called after that information has been\n // collected by the first traversal of the document.\n var populateTransitiveVars = function (inUse) {\n if (!inUse.transitiveVars) {\n inUse.transitiveVars = new Set(inUse.variables);\n if (!inUse.removed) {\n inUse.fragmentSpreads.forEach(function (childFragmentName) {\n populateTransitiveVars(getInUseByFragmentName(childFragmentName)).transitiveVars.forEach(function (varName) {\n inUse.transitiveVars.add(varName);\n });\n });\n }\n }\n return inUse;\n };\n // Since we've been keeping track of fragment spreads used by particular\n // operations and fragment definitions, we now need to compute the set of all\n // spreads used (transitively) by any operations in the document.\n var allFragmentNamesUsed = new Set();\n docWithoutDirectiveSubtrees.definitions.forEach(function (def) {\n if (def.kind === Kind.OPERATION_DEFINITION) {\n populateTransitiveVars(getInUseByOperationName(def.name && def.name.value)).fragmentSpreads.forEach(function (childFragmentName) {\n allFragmentNamesUsed.add(childFragmentName);\n });\n } else if (def.kind === Kind.FRAGMENT_DEFINITION &&\n // If there are no operations in the document, then all fragment\n // definitions count as usages of their own fragment names. This heuristic\n // prevents accidentally removing all fragment definitions from the\n // document just because it contains no operations that use the fragments.\n operationCount === 0 && !getInUseByFragmentName(def.name.value).removed) {\n allFragmentNamesUsed.add(def.name.value);\n }\n });\n // Now that we have added all fragment spreads used by operations to the\n // allFragmentNamesUsed set, we can complete the set by transitively adding\n // all fragment spreads used by those fragments, and so on.\n allFragmentNamesUsed.forEach(function (fragmentName) {\n // Once all the childFragmentName strings added here have been seen already,\n // the top-level allFragmentNamesUsed.forEach loop will terminate.\n populateTransitiveVars(getInUseByFragmentName(fragmentName)).fragmentSpreads.forEach(function (childFragmentName) {\n allFragmentNamesUsed.add(childFragmentName);\n });\n });\n var fragmentWillBeRemoved = function (fragmentName) {\n return !!(\n // A fragment definition will be removed if there are no spreads that refer\n // to it, or the fragment was explicitly removed because it had no fields\n // other than __typename.\n !allFragmentNamesUsed.has(fragmentName) || getInUseByFragmentName(fragmentName).removed);\n };\n var enterVisitor = {\n enter: function (node) {\n if (fragmentWillBeRemoved(node.name.value)) {\n return null;\n }\n }\n };\n return nullIfDocIsEmpty(visit(docWithoutDirectiveSubtrees, {\n // If the fragment is going to be removed, then leaving any dangling\n // FragmentSpread nodes with the same name would be a mistake.\n FragmentSpread: enterVisitor,\n // This is where the fragment definition is actually removed.\n FragmentDefinition: enterVisitor,\n OperationDefinition: {\n leave: function (node) {\n // Upon leaving each operation in the depth-first AST traversal, prune\n // any variables that are declared by the operation but unused within.\n if (node.variableDefinitions) {\n var usedVariableNames_1 = populateTransitiveVars(\n // If an operation is anonymous, we use the empty string as its key.\n getInUseByOperationName(node.name && node.name.value)).transitiveVars;\n // According to the GraphQL spec, all variables declared by an\n // operation must either be used by that operation or used by some\n // fragment included transitively into that operation:\n // https://spec.graphql.org/draft/#sec-All-Variables-Used\n //\n // To stay on the right side of this validation rule, if/when we\n // remove the last $var references from an operation or its fragments,\n // we must also remove the corresponding $var declaration from the\n // enclosing operation. This pruning applies only to operations and\n // not fragment definitions, at the moment. Fragments may be able to\n // declare variables eventually, but today they can only consume them.\n if (usedVariableNames_1.size < node.variableDefinitions.length) {\n return __assign(__assign({}, node), {\n variableDefinitions: node.variableDefinitions.filter(function (varDef) {\n return usedVariableNames_1.has(varDef.variable.name.value);\n })\n });\n }\n }\n }\n }\n }));\n}\nexport var addTypenameToDocument = Object.assign(function (doc) {\n return visit(doc, {\n SelectionSet: {\n enter: function (node, _key, parent) {\n // Don't add __typename to OperationDefinitions.\n if (parent && parent.kind === Kind.OPERATION_DEFINITION) {\n return;\n }\n // No changes if no selections.\n var selections = node.selections;\n if (!selections) {\n return;\n }\n // If selections already have a __typename, or are part of an\n // introspection query, do nothing.\n var skip = selections.some(function (selection) {\n return isField(selection) && (selection.name.value === \"__typename\" || selection.name.value.lastIndexOf(\"__\", 0) === 0);\n });\n if (skip) {\n return;\n }\n // If this SelectionSet is @export-ed as an input variable, it should\n // not have a __typename field (see issue #4691).\n var field = parent;\n if (isField(field) && field.directives && field.directives.some(function (d) {\n return d.name.value === \"export\";\n })) {\n return;\n }\n // Create and return a new SelectionSet with a __typename Field.\n return __assign(__assign({}, node), {\n selections: __spreadArray(__spreadArray([], selections, true), [TYPENAME_FIELD], false)\n });\n }\n }\n });\n}, {\n added: function (field) {\n return field === TYPENAME_FIELD;\n }\n});\nvar connectionRemoveConfig = {\n test: function (directive) {\n var willRemove = directive.name.value === \"connection\";\n if (willRemove) {\n if (!directive.arguments || !directive.arguments.some(function (arg) {\n return arg.name.value === \"key\";\n })) {\n globalThis.__DEV__ !== false && invariant.warn(98);\n }\n }\n return willRemove;\n }\n};\nexport function removeConnectionDirectiveFromDocument(doc) {\n return removeDirectivesFromDocument([connectionRemoveConfig], checkDocument(doc));\n}\nfunction hasDirectivesInSelectionSet(directives, selectionSet, nestedCheck) {\n if (nestedCheck === void 0) {\n nestedCheck = true;\n }\n return !!selectionSet && selectionSet.selections && selectionSet.selections.some(function (selection) {\n return hasDirectivesInSelection(directives, selection, nestedCheck);\n });\n}\nfunction hasDirectivesInSelection(directives, selection, nestedCheck) {\n if (nestedCheck === void 0) {\n nestedCheck = true;\n }\n if (!isField(selection)) {\n return true;\n }\n if (!selection.directives) {\n return false;\n }\n return selection.directives.some(getDirectiveMatcher(directives)) || nestedCheck && hasDirectivesInSelectionSet(directives, selection.selectionSet, nestedCheck);\n}\nfunction getArgumentMatcher(config) {\n return function argumentMatcher(argument) {\n return config.some(function (aConfig) {\n return argument.value && argument.value.kind === Kind.VARIABLE && argument.value.name && (aConfig.name === argument.value.name.value || aConfig.test && aConfig.test(argument));\n });\n };\n}\nexport function removeArgumentsFromDocument(config, doc) {\n var argMatcher = getArgumentMatcher(config);\n return nullIfDocIsEmpty(visit(doc, {\n OperationDefinition: {\n enter: function (node) {\n return __assign(__assign({}, node), {\n // Remove matching top level variables definitions.\n variableDefinitions: node.variableDefinitions ? node.variableDefinitions.filter(function (varDef) {\n return !config.some(function (arg) {\n return arg.name === varDef.variable.name.value;\n });\n }) : []\n });\n }\n },\n Field: {\n enter: function (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 var shouldRemoveField = config.some(function (argConfig) {\n return argConfig.remove;\n });\n if (shouldRemoveField) {\n var argMatchCount_1 = 0;\n if (node.arguments) {\n node.arguments.forEach(function (arg) {\n if (argMatcher(arg)) {\n argMatchCount_1 += 1;\n }\n });\n }\n if (argMatchCount_1 === 1) {\n return null;\n }\n }\n }\n },\n Argument: {\n enter: function (node) {\n // Remove all matching arguments.\n if (argMatcher(node)) {\n return null;\n }\n }\n }\n }));\n}\nexport function removeFragmentSpreadFromDocument(config, doc) {\n function enter(node) {\n if (config.some(function (def) {\n return def.name === node.name.value;\n })) {\n return null;\n }\n }\n return nullIfDocIsEmpty(visit(doc, {\n FragmentSpread: {\n enter: enter\n },\n FragmentDefinition: {\n enter: enter\n }\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(document) {\n var definition = getMainDefinition(document);\n var definitionOperation = definition.operation;\n if (definitionOperation === \"query\") {\n // Already a query, so return the existing document.\n return document;\n }\n // Build a new query using the selection set of the main operation.\n var modifiedDoc = visit(document, {\n OperationDefinition: {\n enter: function (node) {\n return __assign(__assign({}, node), {\n operation: \"query\"\n });\n }\n }\n });\n return modifiedDoc;\n}\n// Remove fields / selection sets that include an @client directive.\nexport function removeClientSetsFromDocument(document) {\n checkDocument(document);\n var modifiedDoc = removeDirectivesFromDocument([{\n test: function (directive) {\n return directive.name.value === \"client\";\n },\n remove: true\n }], document);\n return modifiedDoc;\n}\nexport function addNonReactiveToNamedFragments(document) {\n checkDocument(document);\n return visit(document, {\n FragmentSpread: function (node) {\n var _a;\n // Do not add `@nonreactive` if the fragment is marked with `@unmask`\n // since we want to react to changes in this fragment.\n if ((_a = node.directives) === null || _a === void 0 ? void 0 : _a.some(function (directive) {\n return directive.name.value === \"unmask\";\n })) {\n return;\n }\n return __assign(__assign({}, node), {\n directives: __spreadArray(__spreadArray([], node.directives || [], true), [{\n kind: Kind.DIRECTIVE,\n name: {\n kind: Kind.NAME,\n value: \"nonreactive\"\n }\n }], false)\n });\n }\n });\n}","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 if (argsLine.length > MAX_LINE_LENGTH) {\n argsLine = prefix + wrap('(\\n', indent(join(args, '\\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 (\n // 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};\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\nfunction join(maybeArray) {\n var _maybeArray$filter$jo;\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\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\nfunction wrap(start, maybeString) {\n var end = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';\n return maybeString != null && maybeString !== '' ? start + maybeString + end : '';\n}\nfunction indent(str) {\n return wrap(' ', str.replace(/\\n/g, '\\n '));\n}\nfunction isMultiline(str) {\n return str.indexOf('\\n') !== -1;\n}\nfunction hasMultilineItems(maybeArray) {\n return maybeArray != null && maybeArray.some(isMultiline);\n}","import { print as origPrint } from \"graphql\";\nimport { AutoCleanedWeakCache, cacheSizes } from \"../caching/index.js\";\nimport { registerGlobalCache } from \"../caching/getMemoryInternals.js\";\nvar printCache;\nexport var print = Object.assign(function (ast) {\n var result = printCache.get(ast);\n if (!result) {\n result = origPrint(ast);\n printCache.set(ast, result);\n }\n return result;\n}, {\n reset: function () {\n printCache = new AutoCleanedWeakCache(cacheSizes.print || 2000 /* defaultCacheSizes.print */);\n }\n});\n\nprint.reset();\nif (globalThis.__DEV__ !== false) {\n registerGlobalCache(\"print\", function () {\n return printCache ? printCache.size : 0;\n });\n}","import { isReference, isField, DeepMerger, resultKeyNameFromField, shouldInclude, isNonNullObject, compact, createFragmentMap, getFragmentDefinitions, isArray } from \"../../utilities/index.js\";\nexport var hasOwn = Object.prototype.hasOwnProperty;\nexport function isNullish(value) {\n return value === null || value === void 0;\n}\nexport { isArray };\nexport function defaultDataIdFromObject(_a, context) {\n var __typename = _a.__typename,\n id = _a.id,\n _id = _a._id;\n if (typeof __typename === \"string\") {\n if (context) {\n context.keyObject = !isNullish(id) ? {\n id: id\n } : !isNullish(_id) ? {\n _id: _id\n } : void 0;\n }\n // If there is no object.id, fall back to object._id.\n if (isNullish(id) && !isNullish(_id)) {\n id = _id;\n }\n if (!isNullish(id)) {\n return \"\".concat(__typename, \":\").concat(typeof id === \"number\" || typeof id === \"string\" ? id : JSON.stringify(id));\n }\n }\n}\nvar defaultConfig = {\n dataIdFromObject: defaultDataIdFromObject,\n addTypename: true,\n resultCaching: true,\n // Thanks to the shouldCanonizeResults helper, this should be the only line\n // you have to change to reenable canonization by default in the future.\n canonizeResults: false\n};\nexport function normalizeConfig(config) {\n return compact(defaultConfig, config);\n}\nexport function shouldCanonizeResults(config) {\n var value = config.canonizeResults;\n return value === void 0 ? defaultConfig.canonizeResults : value;\n}\nexport function getTypenameFromStoreObject(store, objectOrReference) {\n return isReference(objectOrReference) ? store.get(objectOrReference.__ref, \"__typename\") : objectOrReference && objectOrReference.__typename;\n}\nexport var TypeOrFieldNameRegExp = /^[_a-z][_0-9a-z]*/i;\nexport function fieldNameFromStoreName(storeFieldName) {\n var match = storeFieldName.match(TypeOrFieldNameRegExp);\n return match ? match[0] : storeFieldName;\n}\nexport function selectionSetMatchesResult(selectionSet, result, variables) {\n if (isNonNullObject(result)) {\n return isArray(result) ? result.every(function (item) {\n return selectionSetMatchesResult(selectionSet, item, variables);\n }) : selectionSet.selections.every(function (field) {\n if (isField(field) && shouldInclude(field, variables)) {\n var key = resultKeyNameFromField(field);\n return hasOwn.call(result, key) && (!field.selectionSet || 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}\nexport function storeValueIsStoreObject(value) {\n return isNonNullObject(value) && !isReference(value) && !isArray(value);\n}\nexport function makeProcessedFieldsMerger() {\n return new DeepMerger();\n}\nexport function extractFragmentContext(document, fragments) {\n // FragmentMap consisting only of fragments defined directly in document, not\n // including other fragments registered in the FragmentRegistry.\n var fragmentMap = createFragmentMap(getFragmentDefinitions(document));\n return {\n fragmentMap: fragmentMap,\n lookupFragment: function (name) {\n var def = fragmentMap[name];\n if (!def && fragments) {\n def = fragments.lookup(name);\n }\n return def || null;\n }\n };\n}","import { __assign, __extends, __rest } from \"tslib\";\nimport { invariant } from \"../../utilities/globals/index.js\";\nimport { dep } from \"optimism\";\nimport { equal } from \"@wry/equality\";\nimport { Trie } from \"@wry/trie\";\nimport { isReference, makeReference, DeepMerger, maybeDeepFreeze, canUseWeakMap, isNonNullObject } from \"../../utilities/index.js\";\nimport { hasOwn, fieldNameFromStoreName } from \"./helpers.js\";\nvar DELETE = Object.create(null);\nvar delModifier = function () {\n return DELETE;\n};\nvar INVALIDATE = Object.create(null);\nvar EntityStore = /** @class */function () {\n function EntityStore(policies, group) {\n var _this = this;\n this.policies = policies;\n this.group = group;\n this.data = Object.create(null);\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 this.rootIds = Object.create(null);\n // Lazily tracks { __ref: } strings contained by this.data[dataId].\n this.refs = Object.create(null);\n // Bound function that can be passed around to provide easy access to fields\n // of Reference objects as well as ordinary objects.\n this.getFieldValue = function (objectOrReference, storeFieldName) {\n return maybeDeepFreeze(isReference(objectOrReference) ? _this.get(objectOrReference.__ref, storeFieldName) : objectOrReference && objectOrReference[storeFieldName]);\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 this.canRead = function (objOrRef) {\n return isReference(objOrRef) ? _this.has(objOrRef.__ref) : typeof objOrRef === \"object\";\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 this.toReference = function (objOrIdOrRef, mergeIntoStore) {\n if (typeof objOrIdOrRef === \"string\") {\n return makeReference(objOrIdOrRef);\n }\n if (isReference(objOrIdOrRef)) {\n return objOrIdOrRef;\n }\n var id = _this.policies.identify(objOrIdOrRef)[0];\n if (id) {\n var ref = makeReference(id);\n if (mergeIntoStore) {\n _this.merge(id, objOrIdOrRef);\n }\n return ref;\n }\n };\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 EntityStore.prototype.toObject = function () {\n return __assign({}, this.data);\n };\n EntityStore.prototype.has = function (dataId) {\n return this.lookup(dataId, true) !== void 0;\n };\n EntityStore.prototype.get = function (dataId, fieldName) {\n this.group.depend(dataId, fieldName);\n if (hasOwn.call(this.data, dataId)) {\n var storeObject = this.data[dataId];\n if (storeObject && hasOwn.call(storeObject, fieldName)) {\n return storeObject[fieldName];\n }\n }\n if (fieldName === \"__typename\" && 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 EntityStore.prototype.lookup = function (dataId, dependOnExistence) {\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 if (hasOwn.call(this.data, dataId)) {\n return this.data[dataId];\n }\n if (this instanceof Layer) {\n return this.parent.lookup(dataId, dependOnExistence);\n }\n if (this.policies.rootTypenamesById[dataId]) {\n return Object.create(null);\n }\n };\n EntityStore.prototype.merge = function (older, newer) {\n var _this = this;\n var dataId;\n // Convert unexpected references to ID strings.\n if (isReference(older)) older = older.__ref;\n if (isReference(newer)) newer = newer.__ref;\n var existing = typeof older === \"string\" ? this.lookup(dataId = older) : older;\n var incoming = typeof newer === \"string\" ? this.lookup(dataId = newer) : newer;\n // If newer was a string ID, but that ID was not defined in this store,\n // then there are no fields to be merged, so we're done.\n if (!incoming) return;\n invariant(typeof dataId === \"string\", 2);\n var merged = 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 var fieldsToDirty_1 = Object.create(null);\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_1.__exists = 1;\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(function (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_1[storeFieldName] = 1;\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 var fieldName = fieldNameFromStoreName(storeFieldName);\n if (fieldName !== storeFieldName && !_this.policies.hasKeyArgs(merged.__typename, fieldName)) {\n fieldsToDirty_1[fieldName] = 1;\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 if (fieldsToDirty_1.__typename && !(existing && existing.__typename) &&\n // Since we return default root __typename strings\n // automatically from store.get, we don't need to dirty the\n // ROOT_QUERY.__typename field if merged.__typename is equal\n // to the default string (usually \"Query\").\n this.policies.rootTypenamesById[dataId] === merged.__typename) {\n delete fieldsToDirty_1.__typename;\n }\n Object.keys(fieldsToDirty_1).forEach(function (fieldName) {\n return _this.group.dirty(dataId, fieldName);\n });\n }\n }\n };\n EntityStore.prototype.modify = function (dataId, fields) {\n var _this = this;\n var storeObject = this.lookup(dataId);\n if (storeObject) {\n var changedFields_1 = Object.create(null);\n var needToMerge_1 = false;\n var allDeleted_1 = true;\n var sharedDetails_1 = {\n DELETE: DELETE,\n INVALIDATE: INVALIDATE,\n isReference: isReference,\n toReference: this.toReference,\n canRead: this.canRead,\n readField: function (fieldNameOrOptions, from) {\n return _this.policies.readField(typeof fieldNameOrOptions === \"string\" ? {\n fieldName: fieldNameOrOptions,\n from: from || makeReference(dataId)\n } : fieldNameOrOptions, {\n store: _this\n });\n }\n };\n Object.keys(storeObject).forEach(function (storeFieldName) {\n var fieldName = fieldNameFromStoreName(storeFieldName);\n var fieldValue = storeObject[storeFieldName];\n if (fieldValue === void 0) return;\n var modify = typeof fields === \"function\" ? fields : fields[storeFieldName] || fields[fieldName];\n if (modify) {\n var newValue = modify === delModifier ? DELETE : modify(maybeDeepFreeze(fieldValue), __assign(__assign({}, sharedDetails_1), {\n fieldName: fieldName,\n storeFieldName: 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_1[storeFieldName] = newValue;\n needToMerge_1 = true;\n fieldValue = newValue;\n if (globalThis.__DEV__ !== false) {\n var checkReference = function (ref) {\n if (_this.lookup(ref.__ref) === undefined) {\n globalThis.__DEV__ !== false && invariant.warn(3, ref);\n return true;\n }\n };\n if (isReference(newValue)) {\n checkReference(newValue);\n } else if (Array.isArray(newValue)) {\n // Warn about writing \"mixed\" arrays of Reference and non-Reference objects\n var seenReference = false;\n var someNonReference = void 0;\n for (var _i = 0, newValue_1 = newValue; _i < newValue_1.length; _i++) {\n var value = newValue_1[_i];\n if (isReference(value)) {\n seenReference = true;\n if (checkReference(value)) break;\n } else {\n // Do not warn on primitive values, since those could never be represented\n // by a reference. This is a valid (albeit uncommon) use case.\n if (typeof value === \"object\" && !!value) {\n var id = _this.policies.identify(value)[0];\n // check if object could even be referenced, otherwise we are not interested in it for this warning\n if (id) {\n someNonReference = value;\n }\n }\n }\n if (seenReference && someNonReference !== undefined) {\n globalThis.__DEV__ !== false && invariant.warn(4, someNonReference);\n break;\n }\n }\n }\n }\n }\n }\n }\n if (fieldValue !== void 0) {\n allDeleted_1 = false;\n }\n });\n if (needToMerge_1) {\n this.merge(dataId, changedFields_1);\n if (allDeleted_1) {\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 return true;\n }\n }\n return false;\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 EntityStore.prototype.delete = function (dataId, fieldName, args) {\n var _a;\n var storeObject = this.lookup(dataId);\n if (storeObject) {\n var typename = this.getFieldValue(storeObject, \"__typename\");\n var storeFieldName = fieldName && args ? this.policies.getStoreFieldName({\n typename: typename,\n fieldName: fieldName,\n args: args\n }) : fieldName;\n return this.modify(dataId, storeFieldName ? (_a = {}, _a[storeFieldName] = delModifier, _a) : delModifier);\n }\n return false;\n };\n EntityStore.prototype.evict = function (options, limit) {\n var 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 && this !== limit) {\n evicted = this.parent.evict(options, limit) || 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 EntityStore.prototype.clear = function () {\n this.replace(null);\n };\n EntityStore.prototype.extract = function () {\n var _this = this;\n var obj = this.toObject();\n var extraRootIds = [];\n this.getRootIdSet().forEach(function (id) {\n if (!hasOwn.call(_this.policies.rootTypenamesById, id)) {\n extraRootIds.push(id);\n }\n });\n if (extraRootIds.length) {\n obj.__META = {\n extraRootIds: extraRootIds.sort()\n };\n }\n return obj;\n };\n EntityStore.prototype.replace = function (newData) {\n var _this = this;\n Object.keys(this.data).forEach(function (dataId) {\n if (!(newData && hasOwn.call(newData, dataId))) {\n _this.delete(dataId);\n }\n });\n if (newData) {\n var __META = newData.__META,\n rest_1 = __rest(newData, [\"__META\"]);\n Object.keys(rest_1).forEach(function (dataId) {\n _this.merge(dataId, rest_1[dataId]);\n });\n if (__META) {\n __META.extraRootIds.forEach(this.retain, this);\n }\n }\n };\n EntityStore.prototype.retain = function (rootId) {\n return this.rootIds[rootId] = (this.rootIds[rootId] || 0) + 1;\n };\n EntityStore.prototype.release = function (rootId) {\n if (this.rootIds[rootId] > 0) {\n var count = --this.rootIds[rootId];\n if (!count) delete this.rootIds[rootId];\n return count;\n }\n return 0;\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 EntityStore.prototype.getRootIdSet = function (ids) {\n if (ids === void 0) {\n ids = new Set();\n }\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 // 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 EntityStore.prototype.gc = function () {\n var _this = this;\n var ids = this.getRootIdSet();\n var snapshot = this.toObject();\n ids.forEach(function (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 var idsToRemove = Object.keys(snapshot);\n if (idsToRemove.length) {\n var root_1 = this;\n while (root_1 instanceof Layer) root_1 = root_1.parent;\n idsToRemove.forEach(function (id) {\n return root_1.delete(id);\n });\n }\n return idsToRemove;\n };\n EntityStore.prototype.findChildRefIds = function (dataId) {\n if (!hasOwn.call(this.refs, dataId)) {\n var found_1 = this.refs[dataId] = Object.create(null);\n var root = this.data[dataId];\n if (!root) return found_1;\n var workSet_1 = new Set([root]);\n // Within the store, only arrays and objects can contain child entity\n // references, so we can prune the traversal using this predicate:\n workSet_1.forEach(function (obj) {\n if (isReference(obj)) {\n found_1[obj.__ref] = true;\n // In rare cases, a { __ref } Reference object may have other fields.\n // This often indicates a mismerging of References with StoreObjects,\n // but garbage collection should not be fooled by a stray __ref\n // property in a StoreObject (ignoring all the other fields just\n // because the StoreObject looks like a Reference). To avoid this\n // premature termination of findChildRefIds recursion, we fall through\n // to the code below, which will handle any other properties of obj.\n }\n\n if (isNonNullObject(obj)) {\n Object.keys(obj).forEach(function (key) {\n var child = obj[key];\n // No need to add primitive values to the workSet, since they cannot\n // contain reference objects.\n if (isNonNullObject(child)) {\n workSet_1.add(child);\n }\n });\n }\n });\n }\n return this.refs[dataId];\n };\n EntityStore.prototype.makeCacheKey = function () {\n return this.group.keyMaker.lookupArray(arguments);\n };\n return EntityStore;\n}();\nexport { EntityStore };\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.\nvar CacheGroup = /** @class */function () {\n function CacheGroup(caching, parent) {\n if (parent === void 0) {\n parent = null;\n }\n this.caching = caching;\n this.parent = parent;\n this.d = null;\n this.resetCaching();\n }\n CacheGroup.prototype.resetCaching = function () {\n this.d = this.caching ? dep() : null;\n this.keyMaker = new Trie(canUseWeakMap);\n };\n CacheGroup.prototype.depend = function (dataId, storeFieldName) {\n if (this.d) {\n this.d(makeDepKey(dataId, storeFieldName));\n var 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 if (this.parent) {\n this.parent.depend(dataId, storeFieldName);\n }\n }\n };\n CacheGroup.prototype.dirty = function (dataId, storeFieldName) {\n if (this.d) {\n this.d.dirty(makeDepKey(dataId, storeFieldName),\n // When storeFieldName === \"__exists\", that means the entity identified\n // by dataId has either disappeared from the cache or was newly added,\n // so the result caching system would do well to \"forget everything it\n // knows\" about that object. To achieve that kind of invalidation, we\n // not only dirty the associated result cache entry, but also remove it\n // completely from the dependency graph. For the optimism implementation\n // details, see https://github.com/benjamn/optimism/pull/195.\n storeFieldName === \"__exists\" ? \"forget\" : \"setDirty\");\n }\n };\n return CacheGroup;\n}();\nfunction makeDepKey(dataId, storeFieldName) {\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}\nexport function maybeDependOnExistenceOfEntity(store, entityId) {\n if (supportsResultCaching(store)) {\n // We use this pseudo-field __exists elsewhere in the EntityStore code to\n // represent changes in the existence of the entity object identified by\n // entityId. This dependency gets reliably dirtied whenever an object with\n // this ID is deleted (or newly created) within this group, so any result\n // cache entries (for example, StoreReader#executeSelectionSet results) that\n // depend on __exists for this entityId will get dirtied as well, leading to\n // the eventual recomputation (instead of reuse) of those result objects the\n // next time someone reads them from the cache.\n store.group.depend(entityId, \"__exists\");\n }\n}\n(function (EntityStore) {\n // Refer to this class as EntityStore.Root outside this namespace.\n var Root = /** @class */function (_super) {\n __extends(Root, _super);\n function Root(_a) {\n var policies = _a.policies,\n _b = _a.resultCaching,\n resultCaching = _b === void 0 ? true : _b,\n seed = _a.seed;\n var _this = _super.call(this, policies, new CacheGroup(resultCaching)) || this;\n _this.stump = new Stump(_this);\n _this.storageTrie = new Trie(canUseWeakMap);\n if (seed) _this.replace(seed);\n return _this;\n }\n Root.prototype.addLayer = function (layerId, replay) {\n // Adding an optimistic Layer on top of the Root actually adds the Layer\n // on top of the Stump, so the Stump always comes between the Root and\n // any Layer objects that we've added.\n return this.stump.addLayer(layerId, replay);\n };\n Root.prototype.removeLayer = function () {\n // Never remove the root layer.\n return this;\n };\n Root.prototype.getStorage = function () {\n return this.storageTrie.lookupArray(arguments);\n };\n return Root;\n }(EntityStore);\n EntityStore.Root = Root;\n})(EntityStore || (EntityStore = {}));\n// Not exported, since all Layer instances are created by the addLayer method\n// of the EntityStore.Root class.\nvar Layer = /** @class */function (_super) {\n __extends(Layer, _super);\n function Layer(id, parent, replay, group) {\n var _this = _super.call(this, parent.policies, group) || this;\n _this.id = id;\n _this.parent = parent;\n _this.replay = replay;\n _this.group = group;\n replay(_this);\n return _this;\n }\n Layer.prototype.addLayer = function (layerId, replay) {\n return new Layer(layerId, this, replay, this.group);\n };\n Layer.prototype.removeLayer = function (layerId) {\n var _this = this;\n // Remove all instances of the given id, not just the first one.\n var parent = this.parent.removeLayer(layerId);\n if (layerId === this.id) {\n if (this.group.caching) {\n // Dirty every ID we're removing. Technically we might be able to avoid\n // dirtying fields that have values in higher layers, but we don't have\n // easy access to higher layers here, and we're about to recreate those\n // layers anyway (see parent.addLayer below).\n Object.keys(this.data).forEach(function (dataId) {\n var ownStoreObject = _this.data[dataId];\n var parentStoreObject = parent[\"lookup\"](dataId);\n if (!parentStoreObject) {\n // The StoreObject identified by dataId was defined in this layer\n // but will be undefined in the parent layer, so we can delete the\n // whole entity using this.delete(dataId). Since we're about to\n // throw this layer away, the only goal of this deletion is to dirty\n // the removed fields.\n _this.delete(dataId);\n } else if (!ownStoreObject) {\n // This layer had an entry for dataId but it was undefined, which\n // means the entity was deleted in this layer, and it's about to\n // become undeleted when we remove this layer, so we need to dirty\n // all fields that are about to be reexposed.\n _this.group.dirty(dataId, \"__exists\");\n Object.keys(parentStoreObject).forEach(function (storeFieldName) {\n _this.group.dirty(dataId, storeFieldName);\n });\n } else if (ownStoreObject !== parentStoreObject) {\n // If ownStoreObject is not exactly the same as parentStoreObject,\n // dirty any fields whose values will change as a result of this\n // removal.\n Object.keys(ownStoreObject).forEach(function (storeFieldName) {\n if (!equal(ownStoreObject[storeFieldName], parentStoreObject[storeFieldName])) {\n _this.group.dirty(dataId, storeFieldName);\n }\n });\n }\n });\n }\n return parent;\n }\n // No changes are necessary if the parent chain remains identical.\n if (parent === this.parent) return this;\n // Recreate this layer on top of the new parent.\n return parent.addLayer(this.id, this.replay);\n };\n Layer.prototype.toObject = function () {\n return __assign(__assign({}, this.parent.toObject()), this.data);\n };\n Layer.prototype.findChildRefIds = function (dataId) {\n var fromParent = this.parent.findChildRefIds(dataId);\n return hasOwn.call(this.data, dataId) ? __assign(__assign({}, fromParent), _super.prototype.findChildRefIds.call(this, dataId)) : fromParent;\n };\n Layer.prototype.getStorage = function () {\n var p = this.parent;\n while (p.parent) p = p.parent;\n return p.getStorage.apply(p,\n // @ts-expect-error\n arguments);\n };\n return Layer;\n}(EntityStore);\n// Represents a Layer permanently installed just above the Root, which allows\n// reading optimistically (and registering optimistic dependencies) even when\n// no optimistic layers are currently active. The stump.group CacheGroup object\n// is shared by any/all Layer objects added on top of the Stump.\nvar Stump = /** @class */function (_super) {\n __extends(Stump, _super);\n function Stump(root) {\n return _super.call(this, \"EntityStore.Stump\", root, function () {}, new CacheGroup(root.group.caching, root.group)) || this;\n }\n Stump.prototype.removeLayer = function () {\n // Never remove the Stump layer.\n return this;\n };\n Stump.prototype.merge = function (older, newer) {\n // We never want to write any data into the Stump, so we forward any merge\n // calls to the Root instead. Another option here would be to throw an\n // exception, but the toReference(object, true) function can sometimes\n // trigger Stump writes (which used to be Root writes, before the Stump\n // concept was introduced).\n return this.parent.merge(older, newer);\n };\n return Stump;\n}(Layer);\nfunction storeObjectReconciler(existingObject, incomingObject, property) {\n var existingValue = existingObject[property];\n var 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}\nexport function supportsResultCaching(store) {\n // When result caching is disabled, store.depend will be null.\n return !!(store instanceof EntityStore && store.group.caching);\n}","import { __assign } from \"tslib\";\nimport { Trie } from \"@wry/trie\";\nimport { canUseWeakMap, canUseWeakSet, isNonNullObject as isObjectOrArray } from \"../../utilities/index.js\";\nimport { isArray } from \"./helpers.js\";\nfunction shallowCopy(value) {\n if (isObjectOrArray(value)) {\n return isArray(value) ? value.slice(0) : __assign({\n __proto__: Object.getPrototypeOf(value)\n }, value);\n }\n return value;\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.\nvar ObjectCanon = /** @class */function () {\n function ObjectCanon() {\n // Set of all canonical objects this ObjectCanon has admitted, allowing\n // canon.admit to return previously-canonicalized objects immediately.\n this.known = new (canUseWeakSet ? WeakSet : Set)();\n // Efficient storage/lookup structure for canonical objects.\n this.pool = new Trie(canUseWeakMap);\n // Make the ObjectCanon assume this value has already been\n // canonicalized.\n this.passes = new WeakMap();\n // Arrays that contain the same elements in a different order can share\n // the same SortedKeysInfo object, to save memory.\n this.keysByJSON = new Map();\n // This has to come last because it depends on keysByJSON.\n this.empty = this.admit({});\n }\n ObjectCanon.prototype.isKnown = function (value) {\n return isObjectOrArray(value) && this.known.has(value);\n };\n ObjectCanon.prototype.pass = function (value) {\n if (isObjectOrArray(value)) {\n var copy = shallowCopy(value);\n this.passes.set(copy, value);\n return copy;\n }\n return value;\n };\n ObjectCanon.prototype.admit = function (value) {\n var _this = this;\n if (isObjectOrArray(value)) {\n var original = this.passes.get(value);\n if (original) return original;\n var proto = Object.getPrototypeOf(value);\n switch (proto) {\n case Array.prototype:\n {\n if (this.known.has(value)) return value;\n var array = value.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 var 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 (globalThis.__DEV__ !== false) {\n Object.freeze(array);\n }\n }\n return node.array;\n }\n case null:\n case Object.prototype:\n {\n if (this.known.has(value)) return value;\n var proto_1 = Object.getPrototypeOf(value);\n var array_1 = [proto_1];\n var keys = this.sortedKeys(value);\n array_1.push(keys.json);\n var firstValueIndex_1 = array_1.length;\n keys.sorted.forEach(function (key) {\n array_1.push(_this.admit(value[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 var node = this.pool.lookupArray(array_1);\n if (!node.object) {\n var obj_1 = node.object = Object.create(proto_1);\n this.known.add(obj_1);\n keys.sorted.forEach(function (key, i) {\n obj_1[key] = array_1[firstValueIndex_1 + 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 (globalThis.__DEV__ !== false) {\n Object.freeze(obj_1);\n }\n }\n return node.object;\n }\n }\n }\n return value;\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 ObjectCanon.prototype.sortedKeys = function (obj) {\n var keys = Object.keys(obj);\n var node = this.pool.lookupArray(keys);\n if (!node.keys) {\n keys.sort();\n var json = JSON.stringify(keys);\n if (!(node.keys = this.keysByJSON.get(json))) {\n this.keysByJSON.set(json, node.keys = {\n sorted: keys,\n json: json\n });\n }\n }\n return node.keys;\n };\n return ObjectCanon;\n}();\nexport { ObjectCanon };","import { __assign } from \"tslib\";\nimport { invariant, newInvariantError } from \"../../utilities/globals/index.js\";\nimport { Kind } from \"graphql\";\nimport { wrap } from \"optimism\";\nimport { isField, resultKeyNameFromField, isReference, makeReference, shouldInclude, addTypenameToDocument, getDefaultValues, getMainDefinition, getQueryDefinition, getFragmentFromSelection, maybeDeepFreeze, mergeDeepArray, DeepMerger, isNonNullObject, canUseWeakMap, compact, canonicalStringify, cacheSizes } from \"../../utilities/index.js\";\nimport { maybeDependOnExistenceOfEntity, supportsResultCaching } from \"./entityStore.js\";\nimport { isArray, extractFragmentContext, getTypenameFromStoreObject, shouldCanonizeResults } from \"./helpers.js\";\nimport { MissingFieldError } from \"../core/types/common.js\";\nimport { ObjectCanon } from \"./object-canon.js\";\nfunction execSelectionSetKeyArgs(options) {\n return [options.selectionSet, options.objectOrReference, options.context,\n // We split out this property so we can pass different values\n // independently without modifying options.context itself.\n options.context.canonizeResults];\n}\nvar StoreReader = /** @class */function () {\n function StoreReader(config) {\n var _this = this;\n this.knownResults = new (canUseWeakMap ? WeakMap : Map)();\n this.config = compact(config, {\n addTypename: config.addTypename !== false,\n canonizeResults: shouldCanonizeResults(config)\n });\n this.canon = config.canon || new ObjectCanon();\n // memoized functions in this class will be \"garbage-collected\"\n // by recreating the whole `StoreReader` in\n // `InMemoryCache.resetResultsCache`\n // (triggered from `InMemoryCache.gc` with `resetResultCache: true`)\n this.executeSelectionSet = wrap(function (options) {\n var _a;\n var canonizeResults = options.context.canonizeResults;\n var peekArgs = execSelectionSetKeyArgs(options);\n // Negate this boolean option so we can find out if we've already read\n // this result using the other boolean value.\n peekArgs[3] = !canonizeResults;\n var other = (_a = _this.executeSelectionSet).peek.apply(_a, peekArgs);\n if (other) {\n if (canonizeResults) {\n return __assign(__assign({}, other), {\n // If we previously read this result without canonizing it, we can\n // reuse that result simply by canonizing it now.\n result: _this.canon.admit(other.result)\n });\n }\n // If we previously read this result with canonization enabled, we can\n // return that canonized result as-is.\n return other;\n }\n maybeDependOnExistenceOfEntity(options.context.store, options.enclosingRef.__ref);\n // Finally, if we didn't find any useful previous results, run the real\n // execSelectionSetImpl method with the given options.\n return _this.execSelectionSetImpl(options);\n }, {\n max: this.config.resultCacheMaxSize || cacheSizes[\"inMemoryCache.executeSelectionSet\"] || 50000 /* defaultCacheSizes[\"inMemoryCache.executeSelectionSet\"] */,\n keyArgs: execSelectionSetKeyArgs,\n // Note that the parameters of makeCacheKey are determined by the\n // array returned by keyArgs.\n makeCacheKey: function (selectionSet, parent, context, canonizeResults) {\n if (supportsResultCaching(context.store)) {\n return context.store.makeCacheKey(selectionSet, isReference(parent) ? parent.__ref : parent, context.varString, canonizeResults);\n }\n }\n });\n this.executeSubSelectedArray = wrap(function (options) {\n maybeDependOnExistenceOfEntity(options.context.store, options.enclosingRef.__ref);\n return _this.execSubSelectedArrayImpl(options);\n }, {\n max: this.config.resultCacheMaxSize || cacheSizes[\"inMemoryCache.executeSubSelectedArray\"] || 10000 /* defaultCacheSizes[\"inMemoryCache.executeSubSelectedArray\"] */,\n makeCacheKey: function (_a) {\n var field = _a.field,\n array = _a.array,\n context = _a.context;\n if (supportsResultCaching(context.store)) {\n return context.store.makeCacheKey(field, array, context.varString);\n }\n }\n });\n }\n StoreReader.prototype.resetCanon = function () {\n this.canon = new ObjectCanon();\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 */\n StoreReader.prototype.diffQueryAgainstStore = function (_a) {\n var store = _a.store,\n query = _a.query,\n _b = _a.rootId,\n rootId = _b === void 0 ? \"ROOT_QUERY\" : _b,\n variables = _a.variables,\n _c = _a.returnPartialData,\n returnPartialData = _c === void 0 ? true : _c,\n _d = _a.canonizeResults,\n canonizeResults = _d === void 0 ? this.config.canonizeResults : _d;\n var policies = this.config.cache.policies;\n variables = __assign(__assign({}, getDefaultValues(getQueryDefinition(query))), variables);\n var rootRef = makeReference(rootId);\n var execResult = this.executeSelectionSet({\n selectionSet: getMainDefinition(query).selectionSet,\n objectOrReference: rootRef,\n enclosingRef: rootRef,\n context: __assign({\n store: store,\n query: query,\n policies: policies,\n variables: variables,\n varString: canonicalStringify(variables),\n canonizeResults: canonizeResults\n }, extractFragmentContext(query, this.config.fragments))\n });\n var missing;\n if (execResult.missing) {\n // For backwards compatibility we still report an array of\n // MissingFieldError objects, even though there will only ever be at most\n // one of them, now that all missing field error messages are grouped\n // together in the execResult.missing tree.\n missing = [new MissingFieldError(firstMissing(execResult.missing), execResult.missing, query, variables)];\n if (!returnPartialData) {\n throw missing[0];\n }\n }\n return {\n result: execResult.result,\n complete: !missing,\n missing: missing\n };\n };\n StoreReader.prototype.isFresh = function (result, parent, selectionSet, context) {\n if (supportsResultCaching(context.store) && this.knownResults.get(result) === selectionSet) {\n var latest = this.executeSelectionSet.peek(selectionSet, parent, context,\n // If result is canonical, then it could only have been previously\n // cached by the canonizing version of executeSelectionSet, so we can\n // avoid checking both possibilities here.\n this.canon.isKnown(result));\n if (latest && result === latest.result) {\n return true;\n }\n }\n return false;\n };\n // Uncached version of executeSelectionSet.\n StoreReader.prototype.execSelectionSetImpl = function (_a) {\n var _this = this;\n var selectionSet = _a.selectionSet,\n objectOrReference = _a.objectOrReference,\n enclosingRef = _a.enclosingRef,\n context = _a.context;\n if (isReference(objectOrReference) && !context.policies.rootTypenamesById[objectOrReference.__ref] && !context.store.has(objectOrReference.__ref)) {\n return {\n result: this.canon.empty,\n missing: \"Dangling reference to missing \".concat(objectOrReference.__ref, \" object\")\n };\n }\n var variables = context.variables,\n policies = context.policies,\n store = context.store;\n var typename = store.getFieldValue(objectOrReference, \"__typename\");\n var objectsToMerge = [];\n var missing;\n var missingMerger = new DeepMerger();\n if (this.config.addTypename && typeof typename === \"string\" && !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({\n __typename: typename\n });\n }\n function handleMissing(result, resultName) {\n var _a;\n if (result.missing) {\n missing = missingMerger.merge(missing, (_a = {}, _a[resultName] = result.missing, _a));\n }\n return result.result;\n }\n var workSet = new Set(selectionSet.selections);\n workSet.forEach(function (selection) {\n var _a, _b;\n // Omit fields with directives @skip(if: ) or\n // @include(if: ).\n if (!shouldInclude(selection, variables)) return;\n if (isField(selection)) {\n var fieldValue = policies.readField({\n fieldName: selection.name.value,\n field: selection,\n variables: context.variables,\n from: objectOrReference\n }, context);\n var resultName = resultKeyNameFromField(selection);\n if (fieldValue === void 0) {\n if (!addTypenameToDocument.added(selection)) {\n missing = missingMerger.merge(missing, (_a = {}, _a[resultName] = \"Can't find field '\".concat(selection.name.value, \"' on \").concat(isReference(objectOrReference) ? objectOrReference.__ref + \" object\" : \"object \" + JSON.stringify(objectOrReference, null, 2)), _a));\n }\n } else if (isArray(fieldValue)) {\n if (fieldValue.length > 0) {\n fieldValue = handleMissing(_this.executeSubSelectedArray({\n field: selection,\n array: fieldValue,\n enclosingRef: enclosingRef,\n context: context\n }), resultName);\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. To keep this.canon from canonicalizing\n // this value, we use this.canon.pass to wrap fieldValue in a\n // Pass object that this.canon.admit will later unwrap as-is.\n if (context.canonizeResults) {\n fieldValue = _this.canon.pass(fieldValue);\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,\n enclosingRef: isReference(fieldValue) ? fieldValue : enclosingRef,\n context: context\n }), resultName);\n }\n if (fieldValue !== void 0) {\n objectsToMerge.push((_b = {}, _b[resultName] = fieldValue, _b));\n }\n } else {\n var fragment = getFragmentFromSelection(selection, context.lookupFragment);\n if (!fragment && selection.kind === Kind.FRAGMENT_SPREAD) {\n throw newInvariantError(10, selection.name.value);\n }\n if (fragment && policies.fragmentMatches(fragment, typename)) {\n fragment.selectionSet.selections.forEach(workSet.add, workSet);\n }\n }\n });\n var result = mergeDeepArray(objectsToMerge);\n var finalResult = {\n result: result,\n missing: missing\n };\n var frozen = context.canonizeResults ? this.canon.admit(finalResult)\n // Since this.canon is normally responsible for freezing results (only in\n // development), freeze them manually if canonization is disabled.\n : maybeDeepFreeze(finalResult);\n // Store this result with its selection set so that we can quickly\n // recognize it again in the StoreReader#isFresh method.\n if (frozen.result) {\n this.knownResults.set(frozen.result, selectionSet);\n }\n return frozen;\n };\n // Uncached version of executeSubSelectedArray.\n StoreReader.prototype.execSubSelectedArrayImpl = function (_a) {\n var _this = this;\n var field = _a.field,\n array = _a.array,\n enclosingRef = _a.enclosingRef,\n context = _a.context;\n var missing;\n var missingMerger = new DeepMerger();\n function handleMissing(childResult, i) {\n var _a;\n if (childResult.missing) {\n missing = missingMerger.merge(missing, (_a = {}, _a[i] = childResult.missing, _a));\n }\n return childResult.result;\n }\n if (field.selectionSet) {\n array = array.filter(context.store.canRead);\n }\n array = array.map(function (item, i) {\n // null value in array\n if (item === null) {\n return null;\n }\n // This is a nested array, recurse\n if (isArray(item)) {\n return handleMissing(_this.executeSubSelectedArray({\n field: field,\n array: item,\n enclosingRef: enclosingRef,\n context: context\n }), i);\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 enclosingRef: isReference(item) ? item : enclosingRef,\n context: context\n }), i);\n }\n if (globalThis.__DEV__ !== false) {\n assertSelectionSetForIdValue(context.store, field, item);\n }\n return item;\n });\n return {\n result: context.canonizeResults ? this.canon.admit(array) : array,\n missing: missing\n };\n };\n return StoreReader;\n}();\nexport { StoreReader };\nfunction firstMissing(tree) {\n try {\n JSON.stringify(tree, function (_, value) {\n if (typeof value === \"string\") throw value;\n return value;\n });\n } catch (result) {\n return result;\n }\n}\nfunction assertSelectionSetForIdValue(store, field, fieldValue) {\n if (!field.selectionSet) {\n var workSet_1 = new Set([fieldValue]);\n workSet_1.forEach(function (value) {\n if (isNonNullObject(value)) {\n invariant(!isReference(value), 11, getTypenameFromStoreObject(store, value), field.name.value);\n Object.values(value).forEach(workSet_1.add, workSet_1);\n }\n });\n }\n}","var toString = Object.prototype.toString;\n/**\n * Deeply clones a value to create a new instance.\n */\nexport function cloneDeep(value) {\n return cloneDeepHelper(value);\n}\nfunction cloneDeepHelper(val, seen) {\n switch (toString.call(val)) {\n case \"[object Array]\":\n {\n seen = seen || new Map();\n if (seen.has(val)) return seen.get(val);\n var copy_1 = val.slice(0);\n seen.set(val, copy_1);\n copy_1.forEach(function (child, i) {\n copy_1[i] = cloneDeepHelper(child, seen);\n });\n return copy_1;\n }\n case \"[object Object]\":\n {\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 var copy_2 = Object.create(Object.getPrototypeOf(val));\n seen.set(val, copy_2);\n Object.keys(val).forEach(function (key) {\n copy_2[key] = cloneDeepHelper(val[key], seen);\n });\n return copy_2;\n }\n default:\n return val;\n }\n}","import { dep, Slot } from \"optimism\";\n// Contextual Slot that acquires its value when custom read functions are\n// called in Policies#readField.\nexport var cacheSlot = new Slot();\nvar cacheInfoMap = new WeakMap();\nfunction getCacheInfo(cache) {\n var 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}\nexport function forgetCache(cache) {\n getCacheInfo(cache).vars.forEach(function (rv) {\n return 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) {\n getCacheInfo(cache).vars.forEach(function (rv) {\n return rv.attachCache(cache);\n });\n}\nexport function makeVar(value) {\n var caches = new Set();\n var listeners = new Set();\n var rv = function (newValue) {\n if (arguments.length > 0) {\n if (value !== newValue) {\n value = newValue;\n caches.forEach(function (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 var oldListeners = Array.from(listeners);\n listeners.clear();\n oldListeners.forEach(function (listener) {\n return listener(value);\n });\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 var cache = cacheSlot.getValue();\n if (cache) {\n attach(cache);\n getCacheInfo(cache).dep(rv);\n }\n }\n return value;\n };\n rv.onNextChange = function (listener) {\n listeners.add(listener);\n return function () {\n listeners.delete(listener);\n };\n };\n var attach = rv.attachCache = function (cache) {\n caches.add(cache);\n getCacheInfo(cache).vars.add(rv);\n return rv;\n };\n rv.forgetCache = function (cache) {\n return caches.delete(cache);\n };\n return rv;\n}\nfunction broadcast(cache) {\n if (cache.broadcastWatches) {\n cache.broadcastWatches();\n }\n}","import { invariant } from \"../../utilities/globals/index.js\";\nimport { argumentsObjectFromField, DeepMerger, isNonEmptyArray, isNonNullObject } from \"../../utilities/index.js\";\nimport { hasOwn, isArray } from \"./helpers.js\";\n// Mapping from JSON-encoded KeySpecifier strings to associated information.\nvar specifierInfoCache = Object.create(null);\nfunction lookupSpecifierInfo(spec) {\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 var cacheKey = JSON.stringify(spec);\n return specifierInfoCache[cacheKey] || (specifierInfoCache[cacheKey] = Object.create(null));\n}\nexport function keyFieldsFnFromSpecifier(specifier) {\n var info = lookupSpecifierInfo(specifier);\n return info.keyFieldsFn || (info.keyFieldsFn = function (object, context) {\n var extract = function (from, key) {\n return context.readField(key, from);\n };\n var keyObject = context.keyObject = collectSpecifierPaths(specifier, function (schemaKeyPath) {\n var extracted = extractKeyPath(context.storeObject, 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 if (extracted === void 0 && object !== context.storeObject && hasOwn.call(object, schemaKeyPath[0])) {\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 invariant(extracted !== void 0, 5, schemaKeyPath.join(\".\"), object);\n return extracted;\n });\n return \"\".concat(context.typename, \":\").concat(JSON.stringify(keyObject));\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) {\n var info = lookupSpecifierInfo(specifier);\n return info.keyArgsFn || (info.keyArgsFn = function (args, _a) {\n var field = _a.field,\n variables = _a.variables,\n fieldName = _a.fieldName;\n var collected = collectSpecifierPaths(specifier, function (keyPath) {\n var firstKey = keyPath[0];\n var firstChar = firstKey.charAt(0);\n if (firstChar === \"@\") {\n if (field && isNonEmptyArray(field.directives)) {\n var directiveName_1 = 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 var d = field.directives.find(function (d) {\n return d.name.value === directiveName_1;\n });\n // Fortunately argumentsObjectFromField works for DirectiveNode!\n var 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(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 // 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 if (firstChar === \"$\") {\n var variableName = firstKey.slice(1);\n if (variables && hasOwn.call(variables, variableName)) {\n var 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 if (args) {\n return extractKeyPath(args, keyPath);\n }\n });\n var suffix = JSON.stringify(collected);\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 return fieldName;\n });\n}\nexport function collectSpecifierPaths(specifier, extractor) {\n // For each path specified by specifier, invoke the extractor, and repeatedly\n // merge the results together, with appropriate ancestor context.\n var merger = new DeepMerger();\n return getSpecifierPaths(specifier).reduce(function (collected, path) {\n var _a;\n var 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 (var i = path.length - 1; i >= 0; --i) {\n toMerge = (_a = {}, _a[path[i]] = toMerge, _a);\n }\n collected = merger.merge(collected, toMerge);\n }\n return collected;\n }, Object.create(null));\n}\nexport function getSpecifierPaths(spec) {\n var info = lookupSpecifierInfo(spec);\n if (!info.paths) {\n var paths_1 = info.paths = [];\n var currentPath_1 = [];\n spec.forEach(function (s, i) {\n if (isArray(s)) {\n getSpecifierPaths(s).forEach(function (p) {\n return paths_1.push(currentPath_1.concat(p));\n });\n currentPath_1.length = 0;\n } else {\n currentPath_1.push(s);\n if (!isArray(spec[i + 1])) {\n paths_1.push(currentPath_1.slice(0));\n currentPath_1.length = 0;\n }\n }\n });\n }\n return info.paths;\n}\nfunction extractKey(object, key) {\n return object[key];\n}\nexport function extractKeyPath(object, path, extract) {\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) {\n return isArray(obj) ? obj.map(function (child) {\n return reducer(child, key);\n }) : obj && extract(obj, key);\n }, object));\n}\nfunction normalize(value) {\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);\n }\n return collectSpecifierPaths(Object.keys(value).sort(), function (path) {\n return extractKeyPath(value, path);\n });\n }\n return value;\n}","import { __assign, __rest } from \"tslib\";\nimport { invariant, newInvariantError } from \"../../utilities/globals/index.js\";\nimport { storeKeyNameFromField, argumentsObjectFromField, isReference, getStoreKeyName, isNonNullObject, stringifyForDisplay } from \"../../utilities/index.js\";\nimport { hasOwn, fieldNameFromStoreName, storeValueIsStoreObject, selectionSetMatchesResult, TypeOrFieldNameRegExp, defaultDataIdFromObject, isArray } from \"./helpers.js\";\nimport { cacheSlot } from \"./reactiveVars.js\";\nimport { keyArgsFnFromSpecifier, keyFieldsFnFromSpecifier } from \"./key-extractor.js\";\nimport { disableWarningsSlot } from \"../../masking/index.js\";\nfunction argsFromFieldSpecifier(spec) {\n return spec.args !== void 0 ? spec.args : spec.field ? argumentsObjectFromField(spec.field, spec.variables) : null;\n}\nvar nullKeyFieldsFn = function () {\n return void 0;\n};\nvar simpleKeyArgsFn = function (_args, context) {\n return context.fieldName;\n};\n// These merge functions can be selected by specifying merge:true or\n// merge:false in a field policy.\nvar mergeTrueFn = function (existing, incoming, _a) {\n var mergeObjects = _a.mergeObjects;\n return mergeObjects(existing, incoming);\n};\nvar mergeFalseFn = function (_, incoming) {\n return incoming;\n};\nvar Policies = /** @class */function () {\n function Policies(config) {\n this.config = config;\n this.typePolicies = Object.create(null);\n this.toBeAdded = Object.create(null);\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 this.supertypeMap = new Map();\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 this.fuzzySubtypes = new Map();\n this.rootIdsByTypename = Object.create(null);\n this.rootTypenamesById = Object.create(null);\n this.usingPossibleTypes = false;\n this.config = __assign({\n dataIdFromObject: defaultDataIdFromObject\n }, config);\n this.cache = this.config.cache;\n this.setRootTypename(\"Query\");\n this.setRootTypename(\"Mutation\");\n this.setRootTypename(\"Subscription\");\n if (config.possibleTypes) {\n this.addPossibleTypes(config.possibleTypes);\n }\n if (config.typePolicies) {\n this.addTypePolicies(config.typePolicies);\n }\n }\n Policies.prototype.identify = function (object, partialContext) {\n var _a;\n var policies = this;\n var typename = partialContext && (partialContext.typename || ((_a = partialContext.storeObject) === null || _a === void 0 ? void 0 : _a.__typename)) || object.__typename;\n // It should be possible to write root Query fields with writeFragment,\n // using { __typename: \"Query\", ... } as the data, but it does not make\n // sense to allow the same identification behavior for the Mutation and\n // Subscription types, since application code should never be writing\n // directly to (or reading directly from) those root objects.\n if (typename === this.rootTypenamesById.ROOT_QUERY) {\n return [\"ROOT_QUERY\"];\n }\n // Default context.storeObject to object if not otherwise provided.\n var storeObject = partialContext && partialContext.storeObject || object;\n var context = __assign(__assign({}, partialContext), {\n typename: typename,\n storeObject: storeObject,\n readField: partialContext && partialContext.readField || function () {\n var options = normalizeReadFieldOptions(arguments, storeObject);\n return policies.readField(options, {\n store: policies.cache[\"data\"],\n variables: options.variables\n });\n }\n });\n var id;\n var policy = typename && this.getTypePolicy(typename);\n var keyFn = policy && policy.keyFn || this.config.dataIdFromObject;\n disableWarningsSlot.withValue(true, function () {\n while (keyFn) {\n var specifierOrId = keyFn(__assign(__assign({}, object), storeObject), context);\n if (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 Policies.prototype.addTypePolicies = function (typePolicies) {\n var _this = this;\n Object.keys(typePolicies).forEach(function (typename) {\n var _a = typePolicies[typename],\n queryType = _a.queryType,\n mutationType = _a.mutationType,\n subscriptionType = _a.subscriptionType,\n incoming = __rest(_a, [\"queryType\", \"mutationType\", \"subscriptionType\"]);\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 if (hasOwn.call(_this.toBeAdded, typename)) {\n _this.toBeAdded[typename].push(incoming);\n } else {\n _this.toBeAdded[typename] = [incoming];\n }\n });\n };\n Policies.prototype.updateTypePolicy = function (typename, incoming) {\n var _this = this;\n var existing = this.getTypePolicy(typename);\n var keyFields = incoming.keyFields,\n fields = incoming.fields;\n function setMerge(existing, merge) {\n existing.merge = 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 : existing.merge;\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 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 : 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 if (fields) {\n Object.keys(fields).forEach(function (fieldName) {\n var existing = _this.getFieldPolicy(typename, fieldName, true);\n var incoming = fields[fieldName];\n if (typeof incoming === \"function\") {\n existing.read = incoming;\n } else {\n var keyArgs = incoming.keyArgs,\n read = incoming.read,\n merge = incoming.merge;\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 : 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 if (typeof read === \"function\") {\n existing.read = read;\n }\n setMerge(existing, merge);\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 Policies.prototype.setRootTypename = function (which, typename) {\n if (typename === void 0) {\n typename = which;\n }\n var rootId = \"ROOT_\" + which.toUpperCase();\n var old = this.rootTypenamesById[rootId];\n if (typename !== old) {\n invariant(!old || old === which, 6, which);\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 Policies.prototype.addPossibleTypes = function (possibleTypes) {\n var _this = this;\n this.usingPossibleTypes = true;\n Object.keys(possibleTypes).forEach(function (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 possibleTypes[supertype].forEach(function (subtype) {\n _this.getSupertypeSet(subtype, true).add(supertype);\n var 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 Policies.prototype.getTypePolicy = function (typename) {\n var _this = this;\n if (!hasOwn.call(this.typePolicies, typename)) {\n var policy_1 = this.typePolicies[typename] = Object.create(null);\n policy_1.fields = Object.create(null);\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 properties can\n // still be updated directly using addTypePolicies, but future changes to\n // inherited supertype policies will not be reflected in this subtype\n // policy, because this code runs at most once per typename.\n var supertypes_1 = this.supertypeMap.get(typename);\n if (!supertypes_1 && this.fuzzySubtypes.size) {\n // To make the inheritance logic work for unknown typename strings that\n // may have fuzzy supertypes, we give this typename an empty supertype\n // set and then populate it with any fuzzy supertypes that match.\n supertypes_1 = this.getSupertypeSet(typename, true);\n // This only works for typenames that are directly matched by a fuzzy\n // supertype. What if there is an intermediate chain of supertypes?\n // While possible, that situation can only be solved effectively by\n // specifying the intermediate relationships via possibleTypes, manually\n // and in a non-fuzzy way.\n this.fuzzySubtypes.forEach(function (regExp, fuzzy) {\n if (regExp.test(typename)) {\n // The fuzzy parameter is just the original string version of regExp\n // (not a valid __typename string), but we can look up the\n // associated supertype(s) in this.supertypeMap.\n var fuzzySupertypes = _this.supertypeMap.get(fuzzy);\n if (fuzzySupertypes) {\n fuzzySupertypes.forEach(function (supertype) {\n return supertypes_1.add(supertype);\n });\n }\n }\n });\n }\n if (supertypes_1 && supertypes_1.size) {\n supertypes_1.forEach(function (supertype) {\n var _a = _this.getTypePolicy(supertype),\n fields = _a.fields,\n rest = __rest(_a, [\"fields\"]);\n Object.assign(policy_1, rest);\n Object.assign(policy_1.fields, fields);\n });\n }\n }\n var inbox = this.toBeAdded[typename];\n if (inbox && inbox.length) {\n // Merge the pending policies into this.typePolicies, in the order they\n // were originally passed to addTypePolicy.\n inbox.splice(0).forEach(function (policy) {\n _this.updateTypePolicy(typename, policy);\n });\n }\n return this.typePolicies[typename];\n };\n Policies.prototype.getFieldPolicy = function (typename, fieldName, createIfMissing) {\n if (typename) {\n var fieldPolicies = this.getTypePolicy(typename).fields;\n return fieldPolicies[fieldName] || createIfMissing && (fieldPolicies[fieldName] = Object.create(null));\n }\n };\n Policies.prototype.getSupertypeSet = function (subtype, createIfMissing) {\n var supertypeSet = this.supertypeMap.get(subtype);\n if (!supertypeSet && createIfMissing) {\n this.supertypeMap.set(subtype, supertypeSet = new Set());\n }\n return supertypeSet;\n };\n Policies.prototype.fragmentMatches = function (fragment, typename, result, variables) {\n var _this = this;\n if (!fragment.typeCondition) return true;\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 var supertype = fragment.typeCondition.name.value;\n // Common case: fragment type condition and __typename are the same.\n if (typename === supertype) return true;\n if (this.usingPossibleTypes && this.supertypeMap.has(supertype)) {\n var typenameSupertypeSet = this.getSupertypeSet(typename, true);\n var workQueue_1 = [typenameSupertypeSet];\n var maybeEnqueue_1 = function (subtype) {\n var supertypeSet = _this.getSupertypeSet(subtype, false);\n if (supertypeSet && supertypeSet.size && workQueue_1.indexOf(supertypeSet) < 0) {\n workQueue_1.push(supertypeSet);\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 var needToCheckFuzzySubtypes = !!(result && this.fuzzySubtypes.size);\n var checkingFuzzySubtypes = false;\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 (var i = 0; i < workQueue_1.length; ++i) {\n var supertypeSet = workQueue_1[i];\n if (supertypeSet.has(supertype)) {\n if (!typenameSupertypeSet.has(supertype)) {\n if (checkingFuzzySubtypes) {\n globalThis.__DEV__ !== false && invariant.warn(7, typename, 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 supertypeSet.forEach(maybeEnqueue_1);\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_1.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 // 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(function (regExp, fuzzyString) {\n var match = typename.match(regExp);\n if (match && match[0] === typename) {\n maybeEnqueue_1(fuzzyString);\n }\n });\n }\n }\n }\n return false;\n };\n Policies.prototype.hasKeyArgs = function (typename, fieldName) {\n var policy = this.getFieldPolicy(typename, fieldName, false);\n return !!(policy && policy.keyFn);\n };\n Policies.prototype.getStoreFieldName = function (fieldSpec) {\n var typename = fieldSpec.typename,\n fieldName = fieldSpec.fieldName;\n var policy = this.getFieldPolicy(typename, fieldName, false);\n var storeFieldName;\n var keyFn = policy && policy.keyFn;\n if (keyFn && typename) {\n var context = {\n typename: typename,\n fieldName: fieldName,\n field: fieldSpec.field || null,\n variables: fieldSpec.variables\n };\n var args = argsFromFieldSpecifier(fieldSpec);\n while (keyFn) {\n var specifierOrString = keyFn(args, context);\n if (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 if (storeFieldName === void 0) {\n storeFieldName = fieldSpec.field ? storeKeyNameFromField(fieldSpec.field, fieldSpec.variables) : getStoreKeyName(fieldName, argsFromFieldSpecifier(fieldSpec));\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 // 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) ? storeFieldName : fieldName + \":\" + storeFieldName;\n };\n Policies.prototype.readField = function (options, context) {\n var objectOrReference = options.from;\n if (!objectOrReference) return;\n var nameOrField = options.field || options.fieldName;\n if (!nameOrField) return;\n if (options.typename === void 0) {\n var typename = context.store.getFieldValue(objectOrReference, \"__typename\");\n if (typename) options.typename = typename;\n }\n var storeFieldName = this.getStoreFieldName(options);\n var fieldName = fieldNameFromStoreName(storeFieldName);\n var existing = context.store.getFieldValue(objectOrReference, storeFieldName);\n var policy = this.getFieldPolicy(options.typename, fieldName, false);\n var read = policy && policy.read;\n if (read) {\n var readOptions = makeFieldFunctionOptions(this, objectOrReference, options, context, context.store.getStorage(isReference(objectOrReference) ? objectOrReference.__ref : objectOrReference, storeFieldName));\n // Call read(existing, readOptions) with cacheSlot holding this.cache.\n return cacheSlot.withValue(this.cache, read, [existing, readOptions]);\n }\n return existing;\n };\n Policies.prototype.getReadFunction = function (typename, fieldName) {\n var policy = this.getFieldPolicy(typename, fieldName, false);\n return policy && policy.read;\n };\n Policies.prototype.getMergeFunction = function (parentTypename, fieldName, childTypename) {\n var policy = this.getFieldPolicy(parentTypename, fieldName, false);\n var merge = policy && policy.merge;\n if (!merge && childTypename) {\n policy = this.getTypePolicy(childTypename);\n merge = policy && policy.merge;\n }\n return merge;\n };\n Policies.prototype.runMergeFunction = function (existing, incoming, _a, context, storage) {\n var field = _a.field,\n typename = _a.typename,\n merge = _a.merge;\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(context.store)(existing, incoming);\n }\n if (merge === mergeFalseFn) {\n // Likewise for mergeFalseFn, whose implementation is even simpler.\n return incoming;\n }\n // If cache.writeQuery or cache.writeFragment was called with\n // options.overwrite set to true, we still call merge functions, but\n // the existing data is always undefined, so the merge function will\n // not attempt to combine the incoming data with the existing data.\n if (context.overwrite) {\n existing = void 0;\n }\n return merge(existing, incoming, makeFieldFunctionOptions(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: typename,\n fieldName: field.name.value,\n field: field,\n variables: context.variables\n }, context, storage || Object.create(null)));\n };\n return Policies;\n}();\nexport { Policies };\nfunction makeFieldFunctionOptions(policies, objectOrReference, fieldSpec, context, storage) {\n var storeFieldName = policies.getStoreFieldName(fieldSpec);\n var fieldName = fieldNameFromStoreName(storeFieldName);\n var variables = fieldSpec.variables || context.variables;\n var _a = context.store,\n toReference = _a.toReference,\n canRead = _a.canRead;\n return {\n args: argsFromFieldSpecifier(fieldSpec),\n field: fieldSpec.field || null,\n fieldName: fieldName,\n storeFieldName: storeFieldName,\n variables: variables,\n isReference: isReference,\n toReference: toReference,\n storage: storage,\n cache: policies.cache,\n canRead: canRead,\n readField: function () {\n return policies.readField(normalizeReadFieldOptions(arguments, objectOrReference, variables), context);\n },\n mergeObjects: makeMergeObjectsFunction(context.store)\n };\n}\nexport function normalizeReadFieldOptions(readFieldArgs, objectOrReference, variables) {\n var fieldNameOrOptions = readFieldArgs[0],\n from = readFieldArgs[1],\n argc = readFieldArgs.length;\n var options;\n if (typeof fieldNameOrOptions === \"string\") {\n options = {\n fieldName: fieldNameOrOptions,\n // Default to objectOrReference only when no second argument was\n // passed for the from parameter, not when undefined is explicitly\n // passed as the second argument.\n from: argc > 1 ? from : objectOrReference\n };\n } else {\n options = __assign({}, fieldNameOrOptions);\n // Default to objectOrReference only when fieldNameOrOptions.from is\n // actually omitted, rather than just undefined.\n if (!hasOwn.call(options, \"from\")) {\n options.from = objectOrReference;\n }\n }\n if (globalThis.__DEV__ !== false && options.from === void 0) {\n globalThis.__DEV__ !== false && invariant.warn(8, stringifyForDisplay(Array.from(readFieldArgs)));\n }\n if (void 0 === options.variables) {\n options.variables = variables;\n }\n return options;\n}\nfunction makeMergeObjectsFunction(store) {\n return function mergeObjects(existing, incoming) {\n if (isArray(existing) || isArray(incoming)) {\n throw newInvariantError(9);\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 (isNonNullObject(existing) && isNonNullObject(incoming)) {\n var eType = store.getFieldValue(existing, \"__typename\");\n var iType = store.getFieldValue(incoming, \"__typename\");\n var typesDiffer = eType && iType && eType !== iType;\n if (typesDiffer) {\n return incoming;\n }\n if (isReference(existing) && storeValueIsStoreObject(incoming)) {\n // Update the normalized EntityStore for the entity identified by\n // existing.__ref, preferring/overwriting any fields contributed by the\n // newer incoming StoreObject.\n store.merge(existing.__ref, incoming);\n return existing;\n }\n if (storeValueIsStoreObject(existing) && isReference(incoming)) {\n // Update the normalized EntityStore for the entity identified by\n // incoming.__ref, taking fields from the older existing object only if\n // those fields are not already present in the newer StoreObject\n // identified by incoming.__ref.\n store.merge(existing, incoming.__ref);\n return incoming;\n }\n if (storeValueIsStoreObject(existing) && storeValueIsStoreObject(incoming)) {\n return __assign(__assign({}, existing), incoming);\n }\n }\n return incoming;\n };\n}","import { __assign } from \"tslib\";\nimport { invariant, newInvariantError } from \"../../utilities/globals/index.js\";\nimport { equal } from \"@wry/equality\";\nimport { Trie } from \"@wry/trie\";\nimport { Kind } from \"graphql\";\nimport { getFragmentFromSelection, getDefaultValues, getOperationDefinition, getTypenameFromResult, makeReference, isField, resultKeyNameFromField, isReference, shouldInclude, cloneDeep, addTypenameToDocument, isNonEmptyArray, argumentsObjectFromField, canonicalStringify } from \"../../utilities/index.js\";\nimport { isArray, makeProcessedFieldsMerger, fieldNameFromStoreName, storeValueIsStoreObject, extractFragmentContext } from \"./helpers.js\";\nimport { normalizeReadFieldOptions } from \"./policies.js\";\n// Since there are only four possible combinations of context.clientOnly and\n// context.deferred values, we should need at most four \"flavors\" of any given\n// WriteContext. To avoid creating multiple copies of the same context, we cache\n// the contexts in the context.flavors Map (shared by all flavors) according to\n// their clientOnly and deferred values (always in that order).\nfunction getContextFlavor(context, clientOnly, deferred) {\n var key = \"\".concat(clientOnly).concat(deferred);\n var flavored = context.flavors.get(key);\n if (!flavored) {\n context.flavors.set(key, flavored = context.clientOnly === clientOnly && context.deferred === deferred ? context : __assign(__assign({}, context), {\n clientOnly: clientOnly,\n deferred: deferred\n }));\n }\n return flavored;\n}\nvar StoreWriter = /** @class */function () {\n function StoreWriter(cache, reader, fragments) {\n this.cache = cache;\n this.reader = reader;\n this.fragments = fragments;\n }\n StoreWriter.prototype.writeToStore = function (store, _a) {\n var _this = this;\n var query = _a.query,\n result = _a.result,\n dataId = _a.dataId,\n variables = _a.variables,\n overwrite = _a.overwrite;\n var operationDefinition = getOperationDefinition(query);\n var merger = makeProcessedFieldsMerger();\n variables = __assign(__assign({}, getDefaultValues(operationDefinition)), variables);\n var context = __assign(__assign({\n store: store,\n written: Object.create(null),\n merge: function (existing, incoming) {\n return merger.merge(existing, incoming);\n },\n variables: variables,\n varString: canonicalStringify(variables)\n }, extractFragmentContext(query, this.fragments)), {\n overwrite: !!overwrite,\n incomingById: new Map(),\n clientOnly: false,\n deferred: false,\n flavors: new Map()\n });\n var ref = this.processSelectionSet({\n result: result || Object.create(null),\n dataId: dataId,\n selectionSet: operationDefinition.selectionSet,\n mergeTree: {\n map: new Map()\n },\n context: context\n });\n if (!isReference(ref)) {\n throw newInvariantError(12, result);\n }\n // So far, the store has not been modified, so now it's time to process\n // context.incomingById and merge those incoming fields into context.store.\n context.incomingById.forEach(function (_a, dataId) {\n var storeObject = _a.storeObject,\n mergeTree = _a.mergeTree,\n fieldNodeSet = _a.fieldNodeSet;\n var entityRef = makeReference(dataId);\n if (mergeTree && mergeTree.map.size) {\n var applied = _this.applyMerges(mergeTree, entityRef, storeObject, context);\n if (isReference(applied)) {\n // Assume References returned by applyMerges have already been merged\n // into the store. See makeMergeObjectsFunction in policies.ts for an\n // example of how this can happen.\n return;\n }\n // Otherwise, applyMerges returned a StoreObject, whose fields we should\n // merge into the store (see store.merge statement below).\n storeObject = applied;\n }\n if (globalThis.__DEV__ !== false && !context.overwrite) {\n var fieldsWithSelectionSets_1 = Object.create(null);\n fieldNodeSet.forEach(function (field) {\n if (field.selectionSet) {\n fieldsWithSelectionSets_1[field.name.value] = true;\n }\n });\n var hasSelectionSet_1 = function (storeFieldName) {\n return fieldsWithSelectionSets_1[fieldNameFromStoreName(storeFieldName)] === true;\n };\n var hasMergeFunction_1 = function (storeFieldName) {\n var childTree = mergeTree && mergeTree.map.get(storeFieldName);\n return Boolean(childTree && childTree.info && childTree.info.merge);\n };\n Object.keys(storeObject).forEach(function (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_1(storeFieldName) && !hasMergeFunction_1(storeFieldName)) {\n warnAboutDataLoss(entityRef, storeObject, storeFieldName, context.store);\n }\n });\n }\n store.merge(dataId, storeObject);\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 return ref;\n };\n StoreWriter.prototype.processSelectionSet = function (_a) {\n var _this = this;\n var dataId = _a.dataId,\n result = _a.result,\n selectionSet = _a.selectionSet,\n context = _a.context,\n // This object allows processSelectionSet to report useful information\n // to its callers without explicitly returning that information.\n mergeTree = _a.mergeTree;\n var policies = this.cache.policies;\n // This variable will be repeatedly updated using context.merge to\n // accumulate all fields that need to be written into the store.\n var incoming = Object.create(null);\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 var typename = dataId && policies.rootTypenamesById[dataId] || getTypenameFromResult(result, selectionSet, context.fragmentMap) || dataId && context.store.get(dataId, \"__typename\");\n if (\"string\" === typeof typename) {\n incoming.__typename = typename;\n }\n // This readField function will be passed as context.readField in the\n // KeyFieldsContext object created within policies.identify (called below).\n // In addition to reading from the existing context.store (thanks to the\n // policies.readField(options, context) line at the very bottom), this\n // version of readField can read from Reference objects that are currently\n // pending in context.incomingById, which is important whenever keyFields\n // need to be extracted from a child object that processSelectionSet has\n // turned into a Reference.\n var readField = function () {\n var options = normalizeReadFieldOptions(arguments, incoming, context.variables);\n if (isReference(options.from)) {\n var info = context.incomingById.get(options.from.__ref);\n if (info) {\n var result_1 = policies.readField(__assign(__assign({}, options), {\n from: info.storeObject\n }), context);\n if (result_1 !== void 0) {\n return result_1;\n }\n }\n }\n return policies.readField(options, context);\n };\n var fieldNodeSet = new Set();\n this.flattenFields(selectionSet, result,\n // This WriteContext will be the default context value for fields returned\n // by the flattenFields method, but some fields may be assigned a modified\n // context, depending on the presence of @client and other directives.\n context, typename).forEach(function (context, field) {\n var _a;\n var resultFieldKey = resultKeyNameFromField(field);\n var value = result[resultFieldKey];\n fieldNodeSet.add(field);\n if (value !== void 0) {\n var storeFieldName = policies.getStoreFieldName({\n typename: typename,\n fieldName: field.name.value,\n field: field,\n variables: context.variables\n });\n var childTree = getChildMergeTree(mergeTree, storeFieldName);\n var incomingValue = _this.processFieldValue(value, field,\n // Reset context.clientOnly and context.deferred to their default\n // values before processing nested selection sets.\n field.selectionSet ? getContextFlavor(context, false, false) : context, childTree);\n // To determine if this field holds a child object with a merge function\n // defined in its type policy (see PR #7070), we need to figure out the\n // child object's __typename.\n var childTypename = void 0;\n // The field's value can be an object that has a __typename only if the\n // field has a selection set. Otherwise incomingValue is scalar.\n if (field.selectionSet && (isReference(incomingValue) || storeValueIsStoreObject(incomingValue))) {\n childTypename = readField(\"__typename\", incomingValue);\n }\n var merge = policies.getMergeFunction(typename, field.name.value, childTypename);\n if (merge) {\n childTree.info = {\n // TODO Check compatibility against any existing childTree.field?\n field: field,\n typename: typename,\n merge: merge\n };\n } else {\n maybeRecycleChildMergeTree(mergeTree, storeFieldName);\n }\n incoming = context.merge(incoming, (_a = {}, _a[storeFieldName] = incomingValue, _a));\n } else if (globalThis.__DEV__ !== false && !context.clientOnly && !context.deferred && !addTypenameToDocument.added(field) &&\n // If the field has a read function, it may be a synthetic field or\n // provide a default value, so its absence from the written data should\n // not be cause for alarm.\n !policies.getReadFunction(typename, field.name.value)) {\n globalThis.__DEV__ !== false && invariant.error(13, resultKeyNameFromField(field), result);\n }\n });\n // Identify the result object, even if dataId was already provided,\n // since we always need keyObject below.\n try {\n var _b = policies.identify(result, {\n typename: typename,\n selectionSet: selectionSet,\n fragmentMap: context.fragmentMap,\n storeObject: incoming,\n readField: readField\n }),\n id = _b[0],\n keyObject = _b[1];\n // If dataId was not provided, fall back to the id just generated by\n // policies.identify.\n dataId = dataId || id;\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 // TODO Reverse the order of the arguments?\n incoming = context.merge(incoming, keyObject);\n }\n } catch (e) {\n // If dataId was provided, tolerate failure of policies.identify.\n if (!dataId) throw e;\n }\n if (\"string\" === typeof dataId) {\n var dataRef = makeReference(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 var sets = context.written[dataId] || (context.written[dataId] = []);\n if (sets.indexOf(selectionSet) >= 0) return dataRef;\n sets.push(selectionSet);\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(result, dataRef, selectionSet, context)) {\n return dataRef;\n }\n var previous_1 = context.incomingById.get(dataId);\n if (previous_1) {\n previous_1.storeObject = context.merge(previous_1.storeObject, incoming);\n previous_1.mergeTree = mergeMergeTrees(previous_1.mergeTree, mergeTree);\n fieldNodeSet.forEach(function (field) {\n return previous_1.fieldNodeSet.add(field);\n });\n } else {\n context.incomingById.set(dataId, {\n storeObject: incoming,\n // Save a reference to mergeTree only if it is not empty, because\n // empty MergeTrees may be recycled by maybeRecycleChildMergeTree and\n // reused for entirely different parts of the result tree.\n mergeTree: mergeTreeIsEmpty(mergeTree) ? void 0 : mergeTree,\n fieldNodeSet: fieldNodeSet\n });\n }\n return dataRef;\n }\n return incoming;\n };\n StoreWriter.prototype.processFieldValue = function (value, field, context, mergeTree) {\n var _this = this;\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 globalThis.__DEV__ !== false ? cloneDeep(value) : value;\n }\n if (isArray(value)) {\n return value.map(function (item, i) {\n var value = _this.processFieldValue(item, field, context, getChildMergeTree(mergeTree, i));\n maybeRecycleChildMergeTree(mergeTree, i);\n return value;\n });\n }\n return this.processSelectionSet({\n result: value,\n selectionSet: field.selectionSet,\n context: context,\n mergeTree: mergeTree\n });\n };\n // Implements https://spec.graphql.org/draft/#sec-Field-Collection, but with\n // some additions for tracking @client and @defer directives.\n StoreWriter.prototype.flattenFields = function (selectionSet, result, context, typename) {\n if (typename === void 0) {\n typename = getTypenameFromResult(result, selectionSet, context.fragmentMap);\n }\n var fieldMap = new Map();\n var policies = this.cache.policies;\n var limitingTrie = new Trie(false); // No need for WeakMap, since limitingTrie does not escape.\n (function flatten(selectionSet, inheritedContext) {\n var visitedNode = limitingTrie.lookup(selectionSet,\n // Because we take inheritedClientOnly and inheritedDeferred into\n // consideration here (in addition to selectionSet), it's possible for\n // the same selection set to be flattened more than once, if it appears\n // in the query with different @client and/or @directive configurations.\n inheritedContext.clientOnly, inheritedContext.deferred);\n if (visitedNode.visited) return;\n visitedNode.visited = true;\n selectionSet.selections.forEach(function (selection) {\n if (!shouldInclude(selection, context.variables)) return;\n var clientOnly = inheritedContext.clientOnly,\n deferred = inheritedContext.deferred;\n if (\n // Since the presence of @client or @defer on this field can only\n // cause clientOnly or deferred to become true, we can skip the\n // forEach loop if both clientOnly and deferred are already true.\n !(clientOnly && deferred) && isNonEmptyArray(selection.directives)) {\n selection.directives.forEach(function (dir) {\n var name = dir.name.value;\n if (name === \"client\") clientOnly = true;\n if (name === \"defer\") {\n var args = argumentsObjectFromField(dir, context.variables);\n // The @defer directive takes an optional args.if boolean\n // argument, similar to @include(if: boolean). Note that\n // @defer(if: false) does not make context.deferred false, but\n // instead behaves as if there was no @defer directive.\n if (!args || args.if !== false) {\n deferred = true;\n }\n // TODO In the future, we may want to record args.label using\n // context.deferred, if a label is specified.\n }\n });\n }\n\n if (isField(selection)) {\n var existing = fieldMap.get(selection);\n if (existing) {\n // If this field has been visited along another recursive path\n // before, the final context should have clientOnly or deferred set\n // to true only if *all* paths have the directive (hence the &&).\n clientOnly = clientOnly && existing.clientOnly;\n deferred = deferred && existing.deferred;\n }\n fieldMap.set(selection, getContextFlavor(context, clientOnly, deferred));\n } else {\n var fragment = getFragmentFromSelection(selection, context.lookupFragment);\n if (!fragment && selection.kind === Kind.FRAGMENT_SPREAD) {\n throw newInvariantError(14, selection.name.value);\n }\n if (fragment && policies.fragmentMatches(fragment, typename, result, context.variables)) {\n flatten(fragment.selectionSet, getContextFlavor(context, clientOnly, deferred));\n }\n }\n });\n })(selectionSet, context);\n return fieldMap;\n };\n StoreWriter.prototype.applyMerges = function (mergeTree, existing, incoming, context, getStorageArgs) {\n var _a;\n var _this = this;\n if (mergeTree.map.size && !isReference(incoming)) {\n var e_1 =\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 !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)) ? existing : void 0;\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 var i_1 = incoming;\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_1 && !getStorageArgs) {\n getStorageArgs = [isReference(e_1) ? e_1.__ref : e_1];\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 var changedFields_1;\n var getValue_1 = function (from, name) {\n return isArray(from) ? typeof name === \"number\" ? from[name] : void 0 : context.store.getFieldValue(from, String(name));\n };\n mergeTree.map.forEach(function (childTree, storeFieldName) {\n var eVal = getValue_1(e_1, storeFieldName);\n var iVal = getValue_1(i_1, storeFieldName);\n // If we have no incoming data, leave any existing data untouched.\n if (void 0 === iVal) return;\n if (getStorageArgs) {\n getStorageArgs.push(storeFieldName);\n }\n var aVal = _this.applyMerges(childTree, eVal, iVal, context, getStorageArgs);\n if (aVal !== iVal) {\n changedFields_1 = changedFields_1 || new Map();\n changedFields_1.set(storeFieldName, aVal);\n }\n if (getStorageArgs) {\n invariant(getStorageArgs.pop() === storeFieldName);\n }\n });\n if (changedFields_1) {\n // Shallow clone i so we can add changed fields to it.\n incoming = isArray(i_1) ? i_1.slice(0) : __assign({}, i_1);\n changedFields_1.forEach(function (value, name) {\n incoming[name] = value;\n });\n }\n }\n if (mergeTree.info) {\n return this.cache.policies.runMergeFunction(existing, incoming, mergeTree.info, context, getStorageArgs && (_a = context.store).getStorage.apply(_a, getStorageArgs));\n }\n return incoming;\n };\n return StoreWriter;\n}();\nexport { StoreWriter };\nvar emptyMergeTreePool = [];\nfunction getChildMergeTree(_a, name) {\n var map = _a.map;\n if (!map.has(name)) {\n map.set(name, emptyMergeTreePool.pop() || {\n map: new Map()\n });\n }\n return map.get(name);\n}\nfunction mergeMergeTrees(left, right) {\n if (left === right || !right || mergeTreeIsEmpty(right)) return left;\n if (!left || mergeTreeIsEmpty(left)) return right;\n var info = left.info && right.info ? __assign(__assign({}, left.info), right.info) : left.info || right.info;\n var needToMergeMaps = left.map.size && right.map.size;\n var map = needToMergeMaps ? new Map() : left.map.size ? left.map : right.map;\n var merged = {\n info: info,\n map: map\n };\n if (needToMergeMaps) {\n var remainingRightKeys_1 = new Set(right.map.keys());\n left.map.forEach(function (leftTree, key) {\n merged.map.set(key, mergeMergeTrees(leftTree, right.map.get(key)));\n remainingRightKeys_1.delete(key);\n });\n remainingRightKeys_1.forEach(function (key) {\n merged.map.set(key, mergeMergeTrees(right.map.get(key), left.map.get(key)));\n });\n }\n return merged;\n}\nfunction mergeTreeIsEmpty(tree) {\n return !tree || !(tree.info || tree.map.size);\n}\nfunction maybeRecycleChildMergeTree(_a, name) {\n var map = _a.map;\n var childTree = map.get(name);\n if (childTree && mergeTreeIsEmpty(childTree)) {\n emptyMergeTreePool.push(childTree);\n map.delete(name);\n }\n}\nvar warnings = new Set();\n// Note that this function is unused in production, and thus should be\n// pruned by any well-configured minifier.\nfunction warnAboutDataLoss(existingRef, incomingObj, storeFieldName, store) {\n var getChild = function (objOrRef) {\n var child = store.getFieldValue(objOrRef, storeFieldName);\n return typeof child === \"object\" && child;\n };\n var existing = getChild(existingRef);\n if (!existing) return;\n var incoming = getChild(incomingObj);\n if (!incoming) return;\n // It's always safe to replace a reference, since it refers to data\n // safely stored elsewhere.\n if (isReference(existing)) return;\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 // 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(function (key) {\n return store.getFieldValue(incoming, key) !== void 0;\n })) {\n return;\n }\n var parentType = store.getFieldValue(existingRef, \"__typename\") || store.getFieldValue(incomingObj, \"__typename\");\n var fieldName = fieldNameFromStoreName(storeFieldName);\n var typeDotName = \"\".concat(parentType, \".\").concat(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 var childTypenames = [];\n // Arrays do not have __typename fields, and always need a custom merge\n // function, even if their elements are normalized entities.\n if (!isArray(existing) && !isArray(incoming)) {\n [existing, incoming].forEach(function (child) {\n var typename = store.getFieldValue(child, \"__typename\");\n if (typeof typename === \"string\" && !childTypenames.includes(typename)) {\n childTypenames.push(typename);\n }\n });\n }\n globalThis.__DEV__ !== false && invariant.warn(15, fieldName, parentType, childTypenames.length ? \"either ensure all objects of type \" + childTypenames.join(\" and \") + \" have an ID or a custom merge function, or \" : \"\", typeDotName, __assign({}, existing), __assign({}, incoming));\n}","import { __assign, __extends } from \"tslib\";\nimport { invariant } from \"../../utilities/globals/index.js\";\n// Make builtins like Map and Set safe to use with non-extensible objects.\nimport \"./fixPolyfills.js\";\nimport { wrap } from \"optimism\";\nimport { equal } from \"@wry/equality\";\nimport { ApolloCache } from \"../core/cache.js\";\nimport { MissingFieldError } from \"../core/types/common.js\";\nimport { addTypenameToDocument, isReference, DocumentTransform, canonicalStringify, print, cacheSizes } from \"../../utilities/index.js\";\nimport { StoreReader } from \"./readFromStore.js\";\nimport { StoreWriter } from \"./writeToStore.js\";\nimport { EntityStore, supportsResultCaching } from \"./entityStore.js\";\nimport { makeVar, forgetCache, recallCache } from \"./reactiveVars.js\";\nimport { Policies } from \"./policies.js\";\nimport { hasOwn, normalizeConfig, shouldCanonizeResults } from \"./helpers.js\";\nimport { getInMemoryCacheMemoryInternals } from \"../../utilities/caching/getMemoryInternals.js\";\nvar InMemoryCache = /** @class */function (_super) {\n __extends(InMemoryCache, _super);\n function InMemoryCache(config) {\n if (config === void 0) {\n config = {};\n }\n var _this = _super.call(this) || this;\n _this.watches = new Set();\n _this.addTypenameTransform = new DocumentTransform(addTypenameToDocument);\n // Override the default value, since InMemoryCache result objects are frozen\n // in development and expected to remain logically immutable in production.\n _this.assumeImmutableResults = true;\n _this.makeVar = makeVar;\n _this.txCount = 0;\n _this.config = normalizeConfig(config);\n _this.addTypename = !!_this.config.addTypename;\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 _this.init();\n return _this;\n }\n InMemoryCache.prototype.init = function () {\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 var rootStore = this.data = new EntityStore.Root({\n policies: this.policies,\n resultCaching: this.config.resultCaching\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 EntityStore Layer objects that terminates with the\n // original this.data cache object.\n this.optimisticData = rootStore.stump;\n this.resetResultCache();\n };\n InMemoryCache.prototype.resetResultCache = function (resetResultIdentities) {\n var _this = this;\n var previousReader = this.storeReader;\n var fragments = this.config.fragments;\n // The StoreWriter is mostly stateless and so doesn't really need to be\n // reset, but it does need to have its writer.storeReader reference updated,\n // so it's simpler to update this.storeWriter as well.\n this.storeWriter = new StoreWriter(this, this.storeReader = new StoreReader({\n cache: this,\n addTypename: this.addTypename,\n resultCacheMaxSize: this.config.resultCacheMaxSize,\n canonizeResults: shouldCanonizeResults(this.config),\n canon: resetResultIdentities ? void 0 : previousReader && previousReader.canon,\n fragments: fragments\n }), fragments);\n this.maybeBroadcastWatch = wrap(function (c, options) {\n return _this.broadcastWatch(c, options);\n }, {\n max: this.config.resultCacheMaxSize || cacheSizes[\"inMemoryCache.maybeBroadcastWatch\"] || 5000 /* defaultCacheSizes[\"inMemoryCache.maybeBroadcastWatch\"] */,\n makeCacheKey: function (c) {\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 var store = c.optimistic ? _this.optimisticData : _this.data;\n if (supportsResultCaching(store)) {\n var optimistic = c.optimistic,\n id = c.id,\n variables = c.variables;\n return store.makeCacheKey(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, canonicalStringify({\n optimistic: optimistic,\n id: id,\n variables: variables\n }));\n }\n }\n });\n // Since we have thrown away all the cached functions that depend on the\n // CacheGroup dependencies maintained by EntityStore, we should also reset\n // all CacheGroup dependency information.\n new Set([this.data.group, this.optimisticData.group]).forEach(function (group) {\n return group.resetCaching();\n });\n };\n InMemoryCache.prototype.restore = function (data) {\n this.init();\n // Since calling this.init() discards/replaces the entire StoreReader, along\n // with the result caches it maintains, this.data.replace(data) won't have\n // to bother deleting the old data.\n if (data) this.data.replace(data);\n return this;\n };\n InMemoryCache.prototype.extract = function (optimistic) {\n if (optimistic === void 0) {\n optimistic = false;\n }\n return (optimistic ? this.optimisticData : this.data).extract();\n };\n InMemoryCache.prototype.read = function (options) {\n var\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 _a = options.returnPartialData,\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 = _a === void 0 ? false : _a;\n try {\n return this.storeReader.diffQueryAgainstStore(__assign(__assign({}, options), {\n store: options.optimistic ? this.optimisticData : this.data,\n config: this.config,\n returnPartialData: returnPartialData\n })).result || null;\n } catch (e) {\n if (e instanceof MissingFieldError) {\n // Swallow MissingFieldError and return null, so callers do not need to\n // worry about catching \"normal\" exceptions resulting from incomplete\n // cache data. Unexpected errors will be re-thrown. If you need more\n // information about which fields were missing, use cache.diff instead,\n // and examine diffResult.missing.\n return null;\n }\n throw e;\n }\n };\n InMemoryCache.prototype.write = function (options) {\n try {\n ++this.txCount;\n return this.storeWriter.writeToStore(this.data, options);\n } finally {\n if (! --this.txCount && options.broadcast !== false) {\n this.broadcastWatches();\n }\n }\n };\n InMemoryCache.prototype.modify = function (options) {\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 var store = options.optimistic // Defaults to false.\n ? this.optimisticData : 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 InMemoryCache.prototype.diff = function (options) {\n return this.storeReader.diffQueryAgainstStore(__assign(__assign({}, options), {\n store: options.optimistic ? this.optimisticData : this.data,\n rootId: options.id || \"ROOT_QUERY\",\n config: this.config\n }));\n };\n InMemoryCache.prototype.watch = function (watch) {\n var _this = this;\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 function () {\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 // 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 InMemoryCache.prototype.gc = function (options) {\n var _a;\n canonicalStringify.reset();\n print.reset();\n this.addTypenameTransform.resetCache();\n (_a = this.config.fragments) === null || _a === void 0 ? void 0 : _a.resetCaches();\n var ids = this.optimisticData.gc();\n if (options && !this.txCount) {\n if (options.resetResultCache) {\n this.resetResultCache(options.resetResultIdentities);\n } else if (options.resetResultIdentities) {\n this.storeReader.resetCanon();\n }\n }\n return ids;\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 InMemoryCache.prototype.retain = function (rootId, optimistic) {\n return (optimistic ? this.optimisticData : this.data).retain(rootId);\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 InMemoryCache.prototype.release = function (rootId, optimistic) {\n return (optimistic ? this.optimisticData : this.data).release(rootId);\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 InMemoryCache.prototype.identify = function (object) {\n if (isReference(object)) return object.__ref;\n try {\n return this.policies.identify(object)[0];\n } catch (e) {\n globalThis.__DEV__ !== false && invariant.warn(e);\n }\n };\n InMemoryCache.prototype.evict = function (options) {\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 = __assign(__assign({}, options), {\n id: \"ROOT_QUERY\"\n });\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 // Pass this.data as a limit on the depth of the eviction, so evictions\n // during optimistic updates (when this.data is temporarily set equal to\n // this.optimisticData) do not escape their optimistic Layer.\n return this.optimisticData.evict(options, this.data);\n } finally {\n if (! --this.txCount && options.broadcast !== false) {\n this.broadcastWatches();\n }\n }\n };\n InMemoryCache.prototype.reset = function (options) {\n var _this = this;\n this.init();\n canonicalStringify.reset();\n if (options && options.discardWatches) {\n // Similar to what happens in the unsubscribe function returned by\n // cache.watch, applied to all current watches.\n this.watches.forEach(function (watch) {\n return _this.maybeBroadcastWatch.forget(watch);\n });\n this.watches.clear();\n forgetCache(this);\n } else {\n // Calling this.init() above unblocks all maybeBroadcastWatch caching, so\n // this.broadcastWatches() triggers a broadcast to every current watcher\n // (letting them know their data is now missing). This default behavior is\n // convenient because it means the watches do not have to be manually\n // reestablished after resetting the cache. To prevent this broadcast and\n // cancel all watches, pass true for options.discardWatches.\n this.broadcastWatches();\n }\n return Promise.resolve();\n };\n InMemoryCache.prototype.removeOptimistic = function (idToRemove) {\n var newOptimisticData = this.optimisticData.removeLayer(idToRemove);\n if (newOptimisticData !== this.optimisticData) {\n this.optimisticData = newOptimisticData;\n this.broadcastWatches();\n }\n };\n InMemoryCache.prototype.batch = function (options) {\n var _this = this;\n var update = options.update,\n _a = options.optimistic,\n optimistic = _a === void 0 ? true : _a,\n removeOptimistic = options.removeOptimistic,\n onWatchUpdated = options.onWatchUpdated;\n var updateResult;\n var perform = function (layer) {\n var _a = _this,\n data = _a.data,\n optimisticData = _a.optimisticData;\n ++_this.txCount;\n if (layer) {\n _this.data = _this.optimisticData = layer;\n }\n try {\n return updateResult = update(_this);\n } finally {\n --_this.txCount;\n _this.data = data;\n _this.optimisticData = optimisticData;\n }\n };\n var alreadyDirty = new Set();\n if (onWatchUpdated && !this.txCount) {\n // If an options.onWatchUpdated callback is provided, we want to call it\n // with only the Cache.WatchOptions objects affected by options.update,\n // but there might be dirty watchers already waiting to be broadcast that\n // have nothing to do with the update. To prevent including those watchers\n // in the post-update broadcast, we perform this initial broadcast to\n // collect the dirty watchers, so we can re-dirty them later, after the\n // post-update broadcast, allowing them to receive their pending\n // broadcasts the next time broadcastWatches is called, just as they would\n // if we never called cache.batch.\n this.broadcastWatches(__assign(__assign({}, options), {\n onWatchUpdated: function (watch) {\n alreadyDirty.add(watch);\n return false;\n }\n }));\n }\n if (typeof optimistic === \"string\") {\n // Note that there can be multiple layers with the same optimistic ID.\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(optimistic, perform);\n } else if (optimistic === false) {\n // Ensure both this.data and this.optimisticData refer to the root\n // (non-optimistic) layer of the cache during the update. Note that\n // this.data could be a Layer if we are currently executing an optimistic\n // update function, but otherwise will always be an EntityStore.Root\n // instance.\n perform(this.data);\n } else {\n // Otherwise, leave this.data and this.optimisticData unchanged and run\n // the update with broadcast batching.\n perform();\n }\n if (typeof removeOptimistic === \"string\") {\n this.optimisticData = this.optimisticData.removeLayer(removeOptimistic);\n }\n // Note: if this.txCount > 0, then alreadyDirty.size === 0, so this code\n // takes the else branch and calls this.broadcastWatches(options), which\n // does nothing when this.txCount > 0.\n if (onWatchUpdated && alreadyDirty.size) {\n this.broadcastWatches(__assign(__assign({}, options), {\n onWatchUpdated: function (watch, diff) {\n var result = onWatchUpdated.call(this, watch, diff);\n if (result !== false) {\n // Since onWatchUpdated did not return false, this diff is\n // about to be broadcast to watch.callback, so we don't need\n // to re-dirty it with the other alreadyDirty watches below.\n alreadyDirty.delete(watch);\n }\n return result;\n }\n }));\n // Silently re-dirty any watches that were already dirty before the update\n // was performed, and were not broadcast just now.\n if (alreadyDirty.size) {\n alreadyDirty.forEach(function (watch) {\n return _this.maybeBroadcastWatch.dirty(watch);\n });\n }\n } else {\n // If alreadyDirty is empty or we don't have an onWatchUpdated\n // function, we don't need to go to the trouble of wrapping\n // options.onWatchUpdated.\n this.broadcastWatches(options);\n }\n return updateResult;\n };\n InMemoryCache.prototype.performTransaction = function (update, optimisticId) {\n return this.batch({\n update: update,\n optimistic: optimisticId || optimisticId !== null\n });\n };\n InMemoryCache.prototype.transformDocument = function (document) {\n return this.addTypenameToDocument(this.addFragmentsToDocument(document));\n };\n InMemoryCache.prototype.fragmentMatches = function (fragment, typename) {\n return this.policies.fragmentMatches(fragment, typename);\n };\n InMemoryCache.prototype.lookupFragment = function (fragmentName) {\n var _a;\n return ((_a = this.config.fragments) === null || _a === void 0 ? void 0 : _a.lookup(fragmentName)) || null;\n };\n InMemoryCache.prototype.broadcastWatches = function (options) {\n var _this = this;\n if (!this.txCount) {\n this.watches.forEach(function (c) {\n return _this.maybeBroadcastWatch(c, options);\n });\n }\n };\n InMemoryCache.prototype.addFragmentsToDocument = function (document) {\n var fragments = this.config.fragments;\n return fragments ? fragments.transform(document) : document;\n };\n InMemoryCache.prototype.addTypenameToDocument = function (document) {\n if (this.addTypename) {\n return this.addTypenameTransform.transformDocument(document);\n }\n return document;\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 InMemoryCache.prototype.broadcastWatch = function (c, options) {\n var lastDiff = c.lastDiff;\n // Both WatchOptions and DiffOptions extend ReadOptions, and DiffOptions\n // currently requires no additional properties, so we can use c (a\n // WatchOptions object) as DiffOptions, without having to allocate a new\n // object, and without having to enumerate the relevant properties (query,\n // variables, etc.) explicitly. There will be some additional properties\n // (lastDiff, callback, etc.), but cache.diff ignores them.\n var diff = this.diff(c);\n if (options) {\n if (c.optimistic && typeof options.optimistic === \"string\") {\n diff.fromOptimisticTransaction = true;\n }\n if (options.onWatchUpdated && options.onWatchUpdated.call(this, c, diff, lastDiff) === false) {\n // Returning false from the onWatchUpdated callback will prevent\n // calling c.callback(diff) for this watcher.\n return;\n }\n }\n if (!lastDiff || !equal(lastDiff.result, diff.result)) {\n c.callback(c.lastDiff = diff, lastDiff);\n }\n };\n return InMemoryCache;\n}(ApolloCache);\nexport { InMemoryCache };\nif (globalThis.__DEV__ !== false) {\n InMemoryCache.prototype.getMemoryInternals = getInMemoryCacheMemoryInternals;\n}","import { newInvariantError, invariant } from \"../../utilities/globals/index.js\";\nimport { Observable } from \"../../utilities/index.js\";\nimport { validateOperation, createOperation, transformOperation } from \"../utils/index.js\";\nfunction passthrough(op, forward) {\n return forward ? forward(op) : Observable.of();\n}\nfunction toLink(handler) {\n return typeof handler === \"function\" ? new ApolloLink(handler) : handler;\n}\nfunction isTerminating(link) {\n return link.request.length <= 1;\n}\nvar ApolloLink = /** @class */function () {\n function ApolloLink(request) {\n if (request) this.request = request;\n }\n ApolloLink.empty = function () {\n return new ApolloLink(function () {\n return Observable.of();\n });\n };\n ApolloLink.from = function (links) {\n if (links.length === 0) return ApolloLink.empty();\n return links.map(toLink).reduce(function (x, y) {\n return x.concat(y);\n });\n };\n ApolloLink.split = function (test, left, right) {\n var leftLink = toLink(left);\n var rightLink = toLink(right || new ApolloLink(passthrough));\n var ret;\n if (isTerminating(leftLink) && isTerminating(rightLink)) {\n ret = new ApolloLink(function (operation) {\n return test(operation) ? leftLink.request(operation) || Observable.of() : rightLink.request(operation) || Observable.of();\n });\n } else {\n ret = new ApolloLink(function (operation, forward) {\n return test(operation) ? leftLink.request(operation, forward) || Observable.of() : rightLink.request(operation, forward) || Observable.of();\n });\n }\n return Object.assign(ret, {\n left: leftLink,\n right: rightLink\n });\n };\n ApolloLink.execute = function (link, operation) {\n return link.request(createOperation(operation.context, transformOperation(validateOperation(operation)))) || Observable.of();\n };\n ApolloLink.concat = function (first, second) {\n var firstLink = toLink(first);\n if (isTerminating(firstLink)) {\n globalThis.__DEV__ !== false && invariant.warn(38, firstLink);\n return firstLink;\n }\n var nextLink = toLink(second);\n var ret;\n if (isTerminating(nextLink)) {\n ret = new ApolloLink(function (operation) {\n return firstLink.request(operation, function (op) {\n return nextLink.request(op) || Observable.of();\n }) || Observable.of();\n });\n } else {\n ret = new ApolloLink(function (operation, forward) {\n return firstLink.request(operation, function (op) {\n return nextLink.request(op, forward) || Observable.of();\n }) || Observable.of();\n });\n }\n return Object.assign(ret, {\n left: firstLink,\n right: nextLink\n });\n };\n ApolloLink.prototype.split = function (test, left, right) {\n return this.concat(ApolloLink.split(test, left, right || new ApolloLink(passthrough)));\n };\n ApolloLink.prototype.concat = function (next) {\n return ApolloLink.concat(this, next);\n };\n ApolloLink.prototype.request = function (operation, forward) {\n throw newInvariantError(39);\n };\n ApolloLink.prototype.onError = function (error, observer) {\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 ApolloLink.prototype.setOnError = function (fn) {\n this.onError = fn;\n return this;\n };\n return ApolloLink;\n}();\nexport { ApolloLink };","import { __assign } from \"tslib\";\nexport function createOperation(starting, operation) {\n var context = __assign({}, starting);\n var setContext = function (next) {\n if (typeof next === \"function\") {\n context = __assign(__assign({}, context), next(context));\n } else {\n context = __assign(__assign({}, context), next);\n }\n };\n var getContext = function () {\n return __assign({}, context);\n };\n Object.defineProperty(operation, \"setContext\", {\n enumerable: false,\n value: setContext\n });\n Object.defineProperty(operation, \"getContext\", {\n enumerable: false,\n value: getContext\n });\n return operation;\n}","import { getOperationName } from \"../../utilities/index.js\";\nexport function transformOperation(operation) {\n var transformedOperation = {\n variables: operation.variables || {},\n extensions: operation.extensions || {},\n operationName: operation.operationName,\n query: operation.query\n };\n // Best guess at an operation name\n if (!transformedOperation.operationName) {\n transformedOperation.operationName = typeof transformedOperation.query !== \"string\" ? getOperationName(transformedOperation.query) || undefined : \"\";\n }\n return transformedOperation;\n}","import { newInvariantError } from \"../../utilities/globals/index.js\";\nexport function validateOperation(operation) {\n var OPERATION_FIELDS = [\"query\", \"operationName\", \"variables\", \"extensions\", \"context\"];\n for (var _i = 0, _a = Object.keys(operation); _i < _a.length; _i++) {\n var key = _a[_i];\n if (OPERATION_FIELDS.indexOf(key) < 0) {\n throw newInvariantError(46, key);\n }\n }\n return operation;\n}","import { ApolloLink } from \"./ApolloLink.js\";\nexport var execute = ApolloLink.execute;","import { newInvariantError } from \"../../utilities/globals/index.js\";\nexport var serializeFetchParameter = function (p, label) {\n var serialized;\n try {\n serialized = JSON.stringify(p);\n } catch (e) {\n var parseError = newInvariantError(42, label, e.message);\n parseError.parseError = e;\n throw parseError;\n }\n return serialized;\n};","/**\n * Original source:\n * https://github.com/kmalakoff/response-iterator/blob/master/src/iterators/nodeStream.ts\n */\nimport { canUseAsyncIteratorSymbol } from \"../../../utilities/index.js\";\nexport default function nodeStreamIterator(stream) {\n var cleanup = null;\n var error = null;\n var done = false;\n var data = [];\n var waiting = [];\n function onData(chunk) {\n if (error) return;\n if (waiting.length) {\n var shiftedArr = waiting.shift();\n if (Array.isArray(shiftedArr) && shiftedArr[0]) {\n return shiftedArr[0]({\n value: chunk,\n done: false\n });\n }\n }\n data.push(chunk);\n }\n function onError(err) {\n error = err;\n var all = waiting.slice();\n all.forEach(function (pair) {\n pair[1](err);\n });\n !cleanup || cleanup();\n }\n function onEnd() {\n done = true;\n var all = waiting.slice();\n all.forEach(function (pair) {\n pair[0]({\n value: undefined,\n done: true\n });\n });\n !cleanup || cleanup();\n }\n cleanup = function () {\n cleanup = null;\n stream.removeListener(\"data\", onData);\n stream.removeListener(\"error\", onError);\n stream.removeListener(\"end\", onEnd);\n stream.removeListener(\"finish\", onEnd);\n stream.removeListener(\"close\", onEnd);\n };\n stream.on(\"data\", onData);\n stream.on(\"error\", onError);\n stream.on(\"end\", onEnd);\n stream.on(\"finish\", onEnd);\n stream.on(\"close\", onEnd);\n function getNext() {\n return new Promise(function (resolve, reject) {\n if (error) return reject(error);\n if (data.length) return resolve({\n value: data.shift(),\n done: false\n });\n if (done) return resolve({\n value: undefined,\n done: true\n });\n waiting.push([resolve, reject]);\n });\n }\n var iterator = {\n next: function () {\n return getNext();\n }\n };\n if (canUseAsyncIteratorSymbol) {\n iterator[Symbol.asyncIterator] = function () {\n return this;\n };\n }\n return iterator;\n}","/**\n * Original source:\n * https://github.com/kmalakoff/response-iterator/blob/master/src/iterators/reader.ts\n */\nimport { canUseAsyncIteratorSymbol } from \"../../../utilities/index.js\";\nexport default function readerIterator(reader) {\n var iterator = {\n next: function () {\n return reader.read();\n }\n };\n if (canUseAsyncIteratorSymbol) {\n iterator[Symbol.asyncIterator] = function () {\n return this;\n };\n }\n return iterator;\n}","/**\n * Original source:\n * https://github.com/kmalakoff/response-iterator/blob/master/src/index.ts\n */\nimport { canUseAsyncIteratorSymbol } from \"../../utilities/index.js\";\nimport asyncIterator from \"./iterators/async.js\";\nimport nodeStreamIterator from \"./iterators/nodeStream.js\";\nimport promiseIterator from \"./iterators/promise.js\";\nimport readerIterator from \"./iterators/reader.js\";\nfunction isNodeResponse(value) {\n return !!value.body;\n}\nfunction isReadableStream(value) {\n return !!value.getReader;\n}\nfunction isAsyncIterableIterator(value) {\n return !!(canUseAsyncIteratorSymbol && value[Symbol.asyncIterator]);\n}\nfunction isStreamableBlob(value) {\n return !!value.stream;\n}\nfunction isBlob(value) {\n return !!value.arrayBuffer;\n}\nfunction isNodeReadableStream(value) {\n return !!value.pipe;\n}\nexport function responseIterator(response) {\n var body = response;\n if (isNodeResponse(response)) body = response.body;\n if (isAsyncIterableIterator(body)) return asyncIterator(body);\n if (isReadableStream(body)) return readerIterator(body.getReader());\n // this errors without casting to ReadableStream\n // because Blob.stream() returns a NodeJS ReadableStream\n if (isStreamableBlob(body)) {\n return readerIterator(body.stream().getReader());\n }\n if (isBlob(body)) return promiseIterator(body.arrayBuffer());\n if (isNodeReadableStream(body)) return nodeStreamIterator(body);\n throw new Error(\"Unknown body type for responseIterator. Please pass a streamable response.\");\n}","/**\n * Original source:\n * https://github.com/kmalakoff/response-iterator/blob/master/src/iterators/async.ts\n */\nexport default function asyncIterator(source) {\n var _a;\n var iterator = source[Symbol.asyncIterator]();\n return _a = {\n next: function () {\n return iterator.next();\n }\n }, _a[Symbol.asyncIterator] = function () {\n return this;\n }, _a;\n}","/**\n * Original source:\n * https://github.com/kmalakoff/response-iterator/blob/master/src/iterators/promise.ts\n */\nimport { canUseAsyncIteratorSymbol } from \"../../../utilities/index.js\";\nexport default function promiseIterator(promise) {\n var resolved = false;\n var iterator = {\n next: function () {\n if (resolved) return Promise.resolve({\n value: undefined,\n done: true\n });\n resolved = true;\n return new Promise(function (resolve, reject) {\n promise.then(function (value) {\n resolve({\n value: value,\n done: false\n });\n }).catch(reject);\n });\n }\n };\n if (canUseAsyncIteratorSymbol) {\n iterator[Symbol.asyncIterator] = function () {\n return this;\n };\n }\n return iterator;\n}","export var throwServerError = function (response, result, message) {\n var error = new Error(message);\n error.name = \"ServerError\";\n error.response = response;\n error.statusCode = response.status;\n error.result = result;\n throw error;\n};","import { isNonNullObject } from \"./objects.js\";\nimport { isNonEmptyArray } from \"./arrays.js\";\nimport { DeepMerger } from \"./mergeDeep.js\";\nexport function isExecutionPatchIncrementalResult(value) {\n return \"incremental\" in value;\n}\nexport function isExecutionPatchInitialResult(value) {\n return \"hasNext\" in value && \"data\" in value;\n}\nexport function isExecutionPatchResult(value) {\n return isExecutionPatchIncrementalResult(value) || isExecutionPatchInitialResult(value);\n}\n// This function detects an Apollo payload result before it is transformed\n// into a FetchResult via HttpLink; it cannot detect an ApolloPayloadResult\n// once it leaves the link chain.\nexport function isApolloPayloadResult(value) {\n return isNonNullObject(value) && \"payload\" in value;\n}\nexport function mergeIncrementalData(prevResult, result) {\n var mergedData = prevResult;\n var merger = new DeepMerger();\n if (isExecutionPatchIncrementalResult(result) && isNonEmptyArray(result.incremental)) {\n result.incremental.forEach(function (_a) {\n var data = _a.data,\n path = _a.path;\n for (var i = path.length - 1; i >= 0; --i) {\n var key = path[i];\n var isNumericKey = !isNaN(+key);\n var parent_1 = isNumericKey ? [] : {};\n parent_1[key] = data;\n data = parent_1;\n }\n mergedData = merger.merge(mergedData, data);\n });\n }\n return mergedData;\n}","import { __assign, __awaiter, __generator } from \"tslib\";\nimport { responseIterator } from \"./responseIterator.js\";\nimport { throwServerError } from \"../utils/index.js\";\nimport { PROTOCOL_ERRORS_SYMBOL } from \"../../errors/index.js\";\nimport { isApolloPayloadResult } from \"../../utilities/common/incrementalResult.js\";\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nexport function readMultipartBody(response, nextValue) {\n return __awaiter(this, void 0, void 0, function () {\n var decoder, contentType, delimiter, boundaryVal, boundary, buffer, iterator, running, _a, value, done, chunk, searchFrom, bi, message, i, headers, contentType_1, body, result, next;\n var _b, _c;\n var _d;\n return __generator(this, function (_e) {\n switch (_e.label) {\n case 0:\n if (TextDecoder === undefined) {\n throw new Error(\"TextDecoder must be defined in the environment: please import a polyfill.\");\n }\n decoder = new TextDecoder(\"utf-8\");\n contentType = (_d = response.headers) === null || _d === void 0 ? void 0 : _d.get(\"content-type\");\n delimiter = \"boundary=\";\n boundaryVal = (contentType === null || contentType === void 0 ? void 0 : contentType.includes(delimiter)) ? contentType === null || contentType === void 0 ? void 0 : contentType.substring((contentType === null || contentType === void 0 ? void 0 : contentType.indexOf(delimiter)) + delimiter.length).replace(/['\"]/g, \"\").replace(/\\;(.*)/gm, \"\").trim() : \"-\";\n boundary = \"\\r\\n--\".concat(boundaryVal);\n buffer = \"\";\n iterator = responseIterator(response);\n running = true;\n _e.label = 1;\n case 1:\n if (!running) return [3 /*break*/, 3];\n return [4 /*yield*/, iterator.next()];\n case 2:\n _a = _e.sent(), value = _a.value, done = _a.done;\n chunk = typeof value === \"string\" ? value : decoder.decode(value);\n searchFrom = buffer.length - boundary.length + 1;\n running = !done;\n buffer += chunk;\n bi = buffer.indexOf(boundary, searchFrom);\n while (bi > -1) {\n message = void 0;\n _b = [buffer.slice(0, bi), buffer.slice(bi + boundary.length)], message = _b[0], buffer = _b[1];\n i = message.indexOf(\"\\r\\n\\r\\n\");\n headers = parseHeaders(message.slice(0, i));\n contentType_1 = headers[\"content-type\"];\n if (contentType_1 && contentType_1.toLowerCase().indexOf(\"application/json\") === -1) {\n throw new Error(\"Unsupported patch content type: application/json is required.\");\n }\n body = message.slice(i);\n if (body) {\n result = parseJsonBody(response, body);\n if (Object.keys(result).length > 1 || \"data\" in result || \"incremental\" in result || \"errors\" in result || \"payload\" in result) {\n if (isApolloPayloadResult(result)) {\n next = {};\n if (\"payload\" in result) {\n if (Object.keys(result).length === 1 && result.payload === null) {\n return [2 /*return*/];\n }\n\n next = __assign({}, result.payload);\n }\n if (\"errors\" in result) {\n next = __assign(__assign({}, next), {\n extensions: __assign(__assign({}, \"extensions\" in next ? next.extensions : null), (_c = {}, _c[PROTOCOL_ERRORS_SYMBOL] = result.errors, _c))\n });\n }\n nextValue(next);\n } else {\n // for the last chunk with only `hasNext: false`\n // we don't need to call observer.next as there is no data/errors\n nextValue(result);\n }\n } else if (\n // If the chunk contains only a \"hasNext: false\", we can call\n // observer.complete() immediately.\n Object.keys(result).length === 1 && \"hasNext\" in result && !result.hasNext) {\n return [2 /*return*/];\n }\n }\n\n bi = buffer.indexOf(boundary);\n }\n return [3 /*break*/, 1];\n case 3:\n return [2 /*return*/];\n }\n });\n });\n}\n\nexport function parseHeaders(headerText) {\n var headersInit = {};\n headerText.split(\"\\n\").forEach(function (line) {\n var i = line.indexOf(\":\");\n if (i > -1) {\n // normalize headers to lowercase\n var name_1 = line.slice(0, i).trim().toLowerCase();\n var value = line.slice(i + 1).trim();\n headersInit[name_1] = value;\n }\n });\n return headersInit;\n}\nexport function parseJsonBody(response, bodyText) {\n if (response.status >= 300) {\n // Network error\n var getResult = function () {\n try {\n return JSON.parse(bodyText);\n } catch (err) {\n return bodyText;\n }\n };\n throwServerError(response, getResult(), \"Response not successful: Received status code \".concat(response.status));\n }\n try {\n return JSON.parse(bodyText);\n } catch (err) {\n var parseError = err;\n parseError.name = \"ServerParseError\";\n parseError.response = response;\n parseError.statusCode = response.status;\n parseError.bodyText = bodyText;\n throw parseError;\n }\n}\nexport function handleError(err, observer) {\n // if it is a network error, BUT there is graphql result info fire\n // the next observer before calling error this gives apollo-client\n // (and react-apollo) the `graphqlErrors` and `networkErrors` to\n // pass to UI this should only happen if we *also* have data as\n // part of the response key per 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\n // because AC didn't get any graphqlErrors this is graphql\n // execution result info (i.e errors and possibly data) this is\n // 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\n // 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}\nexport function parseAndCheckHttpResponse(operations) {\n return function (response) {\n return response.text().then(function (bodyText) {\n return parseJsonBody(response, bodyText);\n }).then(function (result) {\n if (!Array.isArray(result) && !hasOwnProperty.call(result, \"data\") && !hasOwnProperty.call(result, \"errors\")) {\n // Data error\n throwServerError(response, result, \"Server response was missing for query '\".concat(Array.isArray(operations) ? operations.map(function (op) {\n return op.operationName;\n }) : operations.operationName, \"'.\"));\n }\n return result;\n });\n };\n}","import { newInvariantError } from \"../../utilities/globals/index.js\";\nexport var checkFetcher = function (fetcher) {\n if (!fetcher && typeof fetch === \"undefined\") {\n throw newInvariantError(40);\n }\n};","import { __assign, __spreadArray } from \"tslib\";\nimport { print } from \"../../utilities/index.js\";\nvar defaultHttpOptions = {\n includeQuery: true,\n includeExtensions: false,\n preserveHeaderCase: false\n};\nvar defaultHeaders = {\n // headers are case insensitive (https://stackoverflow.com/a/5259004)\n accept: \"*/*\",\n // The content-type header describes the type of the body of the request, and\n // so it typically only is sent with requests that actually have bodies. One\n // could imagine that Apollo Client would remove this header when constructing\n // a GET request (which has no body), but we historically have not done that.\n // This means that browsers will preflight all Apollo Client requests (even\n // GET requests). Apollo Server's CSRF prevention feature (introduced in\n // AS3.7) takes advantage of this fact and does not block requests with this\n // header. If you want to drop this header from GET requests, then you should\n // probably replace it with a `apollo-require-preflight` header, or servers\n // with CSRF prevention enabled might block your GET request. See\n // https://www.apollographql.com/docs/apollo-server/security/cors/#preventing-cross-site-request-forgery-csrf\n // for more details.\n \"content-type\": \"application/json\"\n};\nvar defaultOptions = {\n method: \"POST\"\n};\nexport var fallbackHttpConfig = {\n http: defaultHttpOptions,\n headers: defaultHeaders,\n options: defaultOptions\n};\nexport var defaultPrinter = function (ast, printer) {\n return printer(ast);\n};\nexport function selectHttpOptionsAndBody(operation, fallbackConfig) {\n var configs = [];\n for (var _i = 2; _i < arguments.length; _i++) {\n configs[_i - 2] = arguments[_i];\n }\n configs.unshift(fallbackConfig);\n return selectHttpOptionsAndBodyInternal.apply(void 0, __spreadArray([operation, defaultPrinter], configs, false));\n}\nexport function selectHttpOptionsAndBodyInternal(operation, printer) {\n var configs = [];\n for (var _i = 2; _i < arguments.length; _i++) {\n configs[_i - 2] = arguments[_i];\n }\n var options = {};\n var http = {};\n configs.forEach(function (config) {\n options = __assign(__assign(__assign({}, options), config.options), {\n headers: __assign(__assign({}, options.headers), config.headers)\n });\n if (config.credentials) {\n options.credentials = config.credentials;\n }\n http = __assign(__assign({}, http), config.http);\n });\n if (options.headers) {\n options.headers = removeDuplicateHeaders(options.headers, http.preserveHeaderCase);\n }\n //The body depends on the http options\n var operationName = operation.operationName,\n extensions = operation.extensions,\n variables = operation.variables,\n query = operation.query;\n var body = {\n operationName: operationName,\n variables: variables\n };\n if (http.includeExtensions) body.extensions = extensions;\n // not sending the query (i.e persisted queries)\n if (http.includeQuery) body.query = printer(query, print);\n return {\n options: options,\n body: body\n };\n}\n// Remove potential duplicate header names, preserving last (by insertion order).\n// This is done to prevent unintentionally duplicating a header instead of\n// overwriting it (See #8447 and #8449).\nfunction removeDuplicateHeaders(headers, preserveHeaderCase) {\n // If we're not preserving the case, just remove duplicates w/ normalization.\n if (!preserveHeaderCase) {\n var normalizedHeaders_1 = {};\n Object.keys(Object(headers)).forEach(function (name) {\n normalizedHeaders_1[name.toLowerCase()] = headers[name];\n });\n return normalizedHeaders_1;\n }\n // If we are preserving the case, remove duplicates w/ normalization,\n // preserving the original name.\n // This allows for non-http-spec-compliant servers that expect intentionally\n // capitalized header names (See #6741).\n var headerData = {};\n Object.keys(Object(headers)).forEach(function (name) {\n headerData[name.toLowerCase()] = {\n originalName: name,\n value: headers[name]\n };\n });\n var normalizedHeaders = {};\n Object.keys(headerData).forEach(function (name) {\n normalizedHeaders[headerData[name].originalName] = headerData[name].value;\n });\n return normalizedHeaders;\n}","import { Observable } from \"../../utilities/index.js\";\nexport function fromError(errorValue) {\n return new Observable(function (observer) {\n observer.error(errorValue);\n });\n}","import { __assign, __rest } from \"tslib\";\nimport { invariant } from \"../../utilities/globals/index.js\";\nimport { ApolloLink } from \"../core/index.js\";\nimport { Observable, hasDirectives } from \"../../utilities/index.js\";\nimport { serializeFetchParameter } from \"./serializeFetchParameter.js\";\nimport { selectURI } from \"./selectURI.js\";\nimport { handleError, readMultipartBody, parseAndCheckHttpResponse } from \"./parseAndCheckHttpResponse.js\";\nimport { checkFetcher } from \"./checkFetcher.js\";\nimport { selectHttpOptionsAndBodyInternal, defaultPrinter, fallbackHttpConfig } from \"./selectHttpOptionsAndBody.js\";\nimport { rewriteURIForGET } from \"./rewriteURIForGET.js\";\nimport { fromError, filterOperationVariables } from \"../utils/index.js\";\nimport { maybe, getMainDefinition, removeClientSetsFromDocument } from \"../../utilities/index.js\";\nvar backupFetch = maybe(function () {\n return fetch;\n});\nexport var createHttpLink = function (linkOptions) {\n if (linkOptions === void 0) {\n linkOptions = {};\n }\n var _a = linkOptions.uri,\n uri = _a === void 0 ? \"/graphql\" : _a,\n // use default global fetch if nothing passed in\n preferredFetch = linkOptions.fetch,\n _b = linkOptions.print,\n print = _b === void 0 ? defaultPrinter : _b,\n includeExtensions = linkOptions.includeExtensions,\n preserveHeaderCase = linkOptions.preserveHeaderCase,\n useGETForQueries = linkOptions.useGETForQueries,\n _c = linkOptions.includeUnusedVariables,\n includeUnusedVariables = _c === void 0 ? false : _c,\n requestOptions = __rest(linkOptions, [\"uri\", \"fetch\", \"print\", \"includeExtensions\", \"preserveHeaderCase\", \"useGETForQueries\", \"includeUnusedVariables\"]);\n if (globalThis.__DEV__ !== false) {\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 var linkConfig = {\n http: {\n includeExtensions: includeExtensions,\n preserveHeaderCase: preserveHeaderCase\n },\n options: requestOptions.fetchOptions,\n credentials: requestOptions.credentials,\n headers: requestOptions.headers\n };\n return new ApolloLink(function (operation) {\n var chosenURI = selectURI(operation, uri);\n var context = operation.getContext();\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 var clientAwarenessHeaders = {};\n if (context.clientAwareness) {\n var _a = context.clientAwareness,\n name_1 = _a.name,\n version = _a.version;\n if (name_1) {\n clientAwarenessHeaders[\"apollographql-client-name\"] = name_1;\n }\n if (version) {\n clientAwarenessHeaders[\"apollographql-client-version\"] = version;\n }\n }\n var contextHeaders = __assign(__assign({}, clientAwarenessHeaders), context.headers);\n var contextConfig = {\n http: context.http,\n options: context.fetchOptions,\n credentials: context.credentials,\n headers: contextHeaders\n };\n if (hasDirectives([\"client\"], operation.query)) {\n var transformedQuery = removeClientSetsFromDocument(operation.query);\n if (!transformedQuery) {\n return fromError(new Error(\"HttpLink: Trying to send a client-only query to the server. To send to the server, ensure a non-client field is added to the query or set the `transformOptions.removeClientFields` option to `true`.\"));\n }\n operation.query = transformedQuery;\n }\n //uses fallback, link, and then context to build options\n var _b = selectHttpOptionsAndBodyInternal(operation, print, fallbackHttpConfig, linkConfig, contextConfig),\n options = _b.options,\n body = _b.body;\n if (body.variables && !includeUnusedVariables) {\n body.variables = filterOperationVariables(body.variables, operation.query);\n }\n var controller;\n if (!options.signal && typeof AbortController !== \"undefined\") {\n controller = new AbortController();\n options.signal = controller.signal;\n }\n // If requested, set method to GET if there are no mutations.\n var definitionIsMutation = function (d) {\n return d.kind === \"OperationDefinition\" && d.operation === \"mutation\";\n };\n var definitionIsSubscription = function (d) {\n return d.kind === \"OperationDefinition\" && d.operation === \"subscription\";\n };\n var isSubscription = definitionIsSubscription(getMainDefinition(operation.query));\n // does not match custom directives beginning with @defer\n var hasDefer = hasDirectives([\"defer\"], operation.query);\n if (useGETForQueries && !operation.query.definitions.some(definitionIsMutation)) {\n options.method = \"GET\";\n }\n if (hasDefer || isSubscription) {\n options.headers = options.headers || {};\n var acceptHeader = \"multipart/mixed;\";\n // Omit defer-specific headers if the user attempts to defer a selection\n // set on a subscription and log a warning.\n if (isSubscription && hasDefer) {\n globalThis.__DEV__ !== false && invariant.warn(41);\n }\n if (isSubscription) {\n acceptHeader += \"boundary=graphql;subscriptionSpec=1.0,application/json\";\n } else if (hasDefer) {\n acceptHeader += \"deferSpec=20220824,application/json\";\n }\n options.headers.accept = acceptHeader;\n }\n if (options.method === \"GET\") {\n var _c = rewriteURIForGET(chosenURI, body),\n newURI = _c.newURI,\n parseError = _c.parseError;\n if (parseError) {\n return fromError(parseError);\n }\n chosenURI = newURI;\n } else {\n try {\n options.body = serializeFetchParameter(body, \"Payload\");\n } catch (parseError) {\n return fromError(parseError);\n }\n }\n return new Observable(function (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 var currentFetch = preferredFetch || maybe(function () {\n return fetch;\n }) || backupFetch;\n var observerNext = observer.next.bind(observer);\n currentFetch(chosenURI, options).then(function (response) {\n var _a;\n operation.setContext({\n response: response\n });\n var ctype = (_a = response.headers) === null || _a === void 0 ? void 0 : _a.get(\"content-type\");\n if (ctype !== null && /^multipart\\/mixed/i.test(ctype)) {\n return readMultipartBody(response, observerNext);\n } else {\n return parseAndCheckHttpResponse(operation)(response).then(observerNext);\n }\n }).then(function () {\n controller = undefined;\n observer.complete();\n }).catch(function (err) {\n controller = undefined;\n handleError(err, observer);\n });\n return function () {\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};","export var selectURI = function (operation, fallbackURI) {\n var context = operation.getContext();\n var contextURI = context.uri;\n if (contextURI) {\n return contextURI;\n } else if (typeof fallbackURI === \"function\") {\n return fallbackURI(operation);\n } else {\n return fallbackURI || \"/graphql\";\n }\n};","import { __assign } from \"tslib\";\nimport { visit } from \"graphql\";\nexport function filterOperationVariables(variables, query) {\n var result = __assign({}, variables);\n var unusedNames = new Set(Object.keys(variables));\n visit(query, {\n Variable: function (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.kind !== \"VariableDefinition\") {\n unusedNames.delete(node.name.value);\n }\n }\n });\n unusedNames.forEach(function (name) {\n delete result[name];\n });\n return result;\n}","import { serializeFetchParameter } from \"./serializeFetchParameter.js\";\n// For GET operations, returns the given URI rewritten with parameters, or a\n// parse error.\nexport function rewriteURIForGET(chosenURI, body) {\n // Implement the standard HTTP GET serialization, plus 'extensions'. Note\n // the extra level of JSON serialization!\n var queryParams = [];\n var addQueryParam = function (key, value) {\n queryParams.push(\"\".concat(key, \"=\").concat(encodeURIComponent(value)));\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 var serializedVariables = void 0;\n try {\n serializedVariables = serializeFetchParameter(body.variables, \"Variables map\");\n } catch (parseError) {\n return {\n parseError: parseError\n };\n }\n addQueryParam(\"variables\", serializedVariables);\n }\n if (body.extensions) {\n var serializedExtensions = void 0;\n try {\n serializedExtensions = serializeFetchParameter(body.extensions, \"Extensions map\");\n } catch (parseError) {\n return {\n parseError: parseError\n };\n }\n addQueryParam(\"extensions\", serializedExtensions);\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 var fragment = \"\",\n preFragment = chosenURI;\n var fragmentStart = chosenURI.indexOf(\"#\");\n if (fragmentStart !== -1) {\n fragment = chosenURI.substr(fragmentStart);\n preFragment = chosenURI.substr(0, fragmentStart);\n }\n var queryParamsPrefix = preFragment.indexOf(\"?\") === -1 ? \"?\" : \"&\";\n var newURI = preFragment + queryParamsPrefix + queryParams.join(\"&\") + fragment;\n return {\n newURI: newURI\n };\n}","import { __extends } from \"tslib\";\nimport { ApolloLink } from \"../core/index.js\";\nimport { createHttpLink } from \"./createHttpLink.js\";\nvar HttpLink = /** @class */function (_super) {\n __extends(HttpLink, _super);\n function HttpLink(options) {\n if (options === void 0) {\n options = {};\n }\n var _this = _super.call(this, createHttpLink(options).request) || this;\n _this.options = options;\n return _this;\n }\n return HttpLink;\n}(ApolloLink);\nexport { HttpLink };","import { Observable } from \"./Observable.js\";\n// Like Observable.prototype.map, except that the mapping function can\n// optionally return a Promise (or be async).\nexport function asyncMap(observable, mapFn, catchFn) {\n return new Observable(function (observer) {\n var 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: function (callback) {\n return new Promise(function (resolve) {\n return resolve(callback());\n });\n }\n };\n function makeCallback(examiner, key) {\n return function (arg) {\n if (examiner) {\n var both = function () {\n // If the observer is closed, we don't want to continue calling the\n // mapping function - it's result will be swallowed anyways.\n return observer.closed ? /* will be swallowed */0 : examiner(arg);\n };\n promiseQueue = promiseQueue.then(both, both).then(function (result) {\n return observer.next(result);\n }, function (error) {\n return observer.error(error);\n });\n } else {\n observer[key](arg);\n }\n };\n }\n var handler = {\n next: makeCallback(mapFn, \"next\"),\n error: makeCallback(catchFn, \"error\"),\n complete: function () {\n // no need to reassign `promiseQueue`, after `observer.complete`,\n // the observer will be closed and short-circuit everything anyways\n /*promiseQueue = */\n promiseQueue.then(function () {\n return observer.complete();\n });\n }\n };\n var sub = observable.subscribe(handler);\n return function () {\n return sub.unsubscribe();\n };\n });\n}","import { isNonEmptyArray } from \"./arrays.js\";\nimport { isExecutionPatchIncrementalResult } from \"./incrementalResult.js\";\nexport function graphQLResultHasError(result) {\n var errors = getGraphQLErrorsFromResult(result);\n return isNonEmptyArray(errors);\n}\nexport function getGraphQLErrorsFromResult(result) {\n var graphQLErrors = isNonEmptyArray(result.errors) ? result.errors.slice(0) : [];\n if (isExecutionPatchIncrementalResult(result) && isNonEmptyArray(result.incremental)) {\n result.incremental.forEach(function (incrementalResult) {\n if (incrementalResult.errors) {\n graphQLErrors.push.apply(graphQLErrors, incrementalResult.errors);\n }\n });\n }\n return graphQLErrors;\n}","export function iterateObserversSafely(observers, method, argument) {\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 var observersWithMethod = [];\n observers.forEach(function (obs) {\n return obs[method] && observersWithMethod.push(obs);\n });\n observersWithMethod.forEach(function (obs) {\n return obs[method](argument);\n });\n}","import { Observable } from \"./Observable.js\";\nimport { canUseSymbol } from \"../common/canUse.js\";\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(subclass) {\n function set(key) {\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, {\n value: Observable\n });\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}","import { __extends } from \"tslib\";\nimport { Observable } from \"./Observable.js\";\nimport { iterateObserversSafely } from \"./iteration.js\";\nimport { fixObservableSubclass } from \"./subclassing.js\";\nfunction isPromiseLike(value) {\n return value && typeof value.then === \"function\";\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.\nvar Concast = /** @class */function (_super) {\n __extends(Concast, _super);\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 function Concast(sources) {\n var _this = _super.call(this, function (observer) {\n _this.addObserver(observer);\n return function () {\n return _this.removeObserver(observer);\n };\n }) || this;\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 _this.observers = new Set();\n _this.promise = new Promise(function (resolve, reject) {\n _this.resolve = resolve;\n _this.reject = reject;\n });\n // Bound handler functions that can be reused for every internal\n // subscription.\n _this.handlers = {\n next: function (result) {\n if (_this.sub !== null) {\n _this.latest = [\"next\", result];\n _this.notify(\"next\", result);\n iterateObserversSafely(_this.observers, \"next\", result);\n }\n },\n error: function (error) {\n var sub = _this.sub;\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(function () {\n return sub.unsubscribe();\n });\n _this.sub = null;\n _this.latest = [\"error\", error];\n _this.reject(error);\n _this.notify(\"error\", error);\n iterateObserversSafely(_this.observers, \"error\", error);\n }\n },\n complete: function () {\n var _a = _this,\n sub = _a.sub,\n _b = _a.sources,\n sources = _b === void 0 ? [] : _b;\n if (sub !== null) {\n // If complete is called before concast.start, this.sources may be\n // undefined, so we use a default value of [] for sources. That works\n // here because it falls into the if (!value) {...} block, which\n // appropriately terminates the Concast, even if this.sources might\n // eventually have been initialized to a non-empty array.\n var value = sources.shift();\n if (!value) {\n if (sub) setTimeout(function () {\n return sub.unsubscribe();\n });\n _this.sub = null;\n if (_this.latest && _this.latest[0] === \"next\") {\n _this.resolve(_this.latest[1]);\n } else {\n _this.resolve();\n }\n _this.notify(\"complete\");\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(function (obs) {\n return _this.sub = obs.subscribe(_this.handlers);\n }, _this.handlers.error);\n } else {\n _this.sub = value.subscribe(_this.handlers);\n }\n }\n }\n };\n _this.nextResultListeners = new Set();\n // A public way to abort observation and broadcast.\n _this.cancel = function (reason) {\n _this.reject(reason);\n _this.sources = [];\n _this.handlers.error(reason);\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(function (_) {});\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 if (isPromiseLike(sources)) {\n sources.then(function (iterable) {\n return _this.start(iterable);\n }, _this.handlers.error);\n } else {\n _this.start(sources);\n }\n return _this;\n }\n Concast.prototype.start = function (sources) {\n if (this.sub !== void 0) return;\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 // 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 Concast.prototype.deliverLastMessage = function (observer) {\n if (this.latest) {\n var nextOrError = this.latest[0];\n var 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 && nextOrError === \"next\" && observer.complete) {\n observer.complete();\n }\n }\n };\n Concast.prototype.addObserver = function (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 }\n };\n Concast.prototype.removeObserver = function (observer) {\n if (this.observers.delete(observer) && this.observers.size < 1) {\n // In case there are still any listeners in this.nextResultListeners, and\n // no error or completion has been broadcast yet, make sure those\n // observers have a chance to run and then remove themselves from\n // this.observers.\n this.handlers.complete();\n }\n };\n Concast.prototype.notify = function (method, arg) {\n var nextResultListeners = this.nextResultListeners;\n if (nextResultListeners.size) {\n // Replacing this.nextResultListeners first ensures it does not grow while\n // we are iterating over it, potentially leading to infinite loops.\n this.nextResultListeners = new Set();\n nextResultListeners.forEach(function (listener) {\n return listener(method, arg);\n });\n }\n };\n // We need a way to run callbacks just *before* the next result (or error or\n // completion) is delivered by this Concast, so we can be sure any code that\n // runs as a result of delivering that result/error observes the effects of\n // running the callback(s). It was tempting to reuse the Observer type instead\n // of introducing NextResultListener, but that messes with the sizing and\n // maintenance of this.observers, and ends up being more code overall.\n Concast.prototype.beforeNext = function (callback) {\n var called = false;\n this.nextResultListeners.add(function (method, arg) {\n if (!called) {\n called = true;\n callback(method, arg);\n }\n });\n };\n return Concast;\n}(Observable);\nexport { Concast };\n// Necessary because the Concast constructor has a different signature\n// than the Observable constructor.\nfixObservableSubclass(Concast);","/**\n * The current status of a query’s execution in our system.\n */\nexport var NetworkStatus;\n(function (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 NetworkStatus[NetworkStatus[\"loading\"] = 1] = \"loading\";\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 NetworkStatus[NetworkStatus[\"setVariables\"] = 2] = \"setVariables\";\n /**\n * Indicates that `fetchMore` was called on this query and that the query created is currently in\n * flight.\n */\n NetworkStatus[NetworkStatus[\"fetchMore\"] = 3] = \"fetchMore\";\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 NetworkStatus[NetworkStatus[\"refetch\"] = 4] = \"refetch\";\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 NetworkStatus[NetworkStatus[\"poll\"] = 6] = \"poll\";\n /**\n * No request is in flight for this query, and no errors happened. Everything is OK.\n */\n NetworkStatus[NetworkStatus[\"ready\"] = 7] = \"ready\";\n /**\n * No request is in flight for this query, but one or more errors were detected.\n */\n NetworkStatus[NetworkStatus[\"error\"] = 8] = \"error\";\n})(NetworkStatus || (NetworkStatus = {}));\n/**\n * Returns true if there is currently a network request in flight according to a given network\n * status.\n */\nexport function isNetworkRequestInFlight(networkStatus) {\n return networkStatus ? networkStatus < 7 : false;\n}\n/**\n * Returns true if the network request is in ready or error state according to a given network\n * status.\n */\nexport function isNetworkRequestSettled(networkStatus) {\n return networkStatus === 7 || networkStatus === 8;\n}","import { __assign, __extends } from \"tslib\";\nimport { invariant } from \"../utilities/globals/index.js\";\nimport { equal } from \"@wry/equality\";\nimport { NetworkStatus, isNetworkRequestInFlight } from \"./networkStatus.js\";\nimport { cloneDeep, compact, getOperationDefinition, Observable, iterateObserversSafely, fixObservableSubclass, getQueryDefinition, preventUnhandledRejection } from \"../utilities/index.js\";\nimport { ApolloError, isApolloError } from \"../errors/index.js\";\nimport { equalByQuery } from \"./equalByQuery.js\";\nvar assign = Object.assign,\n hasOwnProperty = Object.hasOwnProperty;\nvar ObservableQuery = /** @class */function (_super) {\n __extends(ObservableQuery, _super);\n function ObservableQuery(_a) {\n var queryManager = _a.queryManager,\n queryInfo = _a.queryInfo,\n options = _a.options;\n var _this = _super.call(this, function (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._subscription._observer;\n if (subObserver && !subObserver.error) {\n subObserver.error = defaultSubscriptionObserverErrorCallback;\n }\n } catch (_a) {}\n var first = !_this.observers.size;\n _this.observers.add(observer);\n // Deliver most recent error or result.\n var 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(_this.maskResult(last.result));\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(function () {});\n }\n return function () {\n if (_this.observers.delete(observer) && !_this.observers.size) {\n _this.tearDownQuery();\n }\n };\n }) || this;\n _this.observers = new Set();\n _this.subscriptions = new Set();\n // related classes\n _this.queryInfo = queryInfo;\n _this.queryManager = queryManager;\n // active state\n _this.waitForOwnResult = skipCacheDataFor(options.fetchPolicy);\n _this.isTornDown = false;\n _this.subscribeToMore = _this.subscribeToMore.bind(_this);\n _this.maskResult = _this.maskResult.bind(_this);\n var _b = queryManager.defaultOptions.watchQuery,\n _c = _b === void 0 ? {} : _b,\n _d = _c.fetchPolicy,\n defaultFetchPolicy = _d === void 0 ? \"cache-first\" : _d;\n var _e = options.fetchPolicy,\n fetchPolicy = _e === void 0 ? defaultFetchPolicy : _e,\n // Make sure we don't store \"standby\" as the initialFetchPolicy.\n _f = options.initialFetchPolicy,\n // Make sure we don't store \"standby\" as the initialFetchPolicy.\n initialFetchPolicy = _f === void 0 ? fetchPolicy === \"standby\" ? defaultFetchPolicy : fetchPolicy : _f;\n _this.options = __assign(__assign({}, options), {\n // Remember the initial options.fetchPolicy so we can revert back to this\n // policy when variables change. This information can also be specified\n // (or overridden) by providing options.initialFetchPolicy explicitly.\n initialFetchPolicy: initialFetchPolicy,\n // This ensures this.options.fetchPolicy always has a string value, in\n // case options.fetchPolicy was not provided.\n fetchPolicy: fetchPolicy\n });\n _this.queryId = queryInfo.queryId || queryManager.generateQueryId();\n var opDef = getOperationDefinition(_this.query);\n _this.queryName = opDef && opDef.name && opDef.name.value;\n return _this;\n }\n Object.defineProperty(ObservableQuery.prototype, \"query\", {\n // The `query` computed property will always reflect the document transformed\n // by the last run query. `this.options.query` will always reflect the raw\n // untransformed query to ensure document transforms with runtime conditionals\n // are run on the original document.\n get: function () {\n return this.lastQuery || this.options.query;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(ObservableQuery.prototype, \"variables\", {\n // Computed shorthand for this.options.variables, preserved for\n // backwards compatibility.\n /**\n * An object containing the variables that were provided for the query.\n */\n get: function () {\n return this.options.variables;\n },\n enumerable: false,\n configurable: true\n });\n ObservableQuery.prototype.result = function () {\n var _this = this;\n return new Promise(function (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 var observer = {\n next: function (result) {\n resolve(result);\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 setTimeout(function () {\n subscription.unsubscribe();\n }, 0);\n },\n error: reject\n };\n var subscription = _this.subscribe(observer);\n });\n };\n /** @internal */\n ObservableQuery.prototype.resetDiff = function () {\n this.queryInfo.resetDiff();\n };\n ObservableQuery.prototype.getCurrentFullResult = function (saveAsLastResult) {\n if (saveAsLastResult === void 0) {\n saveAsLastResult = true;\n }\n // Use the last result as long as the variables match this.variables.\n var lastResult = this.getLastResult(true);\n var networkStatus = this.queryInfo.networkStatus || lastResult && lastResult.networkStatus || NetworkStatus.ready;\n var result = __assign(__assign({}, lastResult), {\n loading: isNetworkRequestInFlight(networkStatus),\n networkStatus: networkStatus\n });\n var _a = this.options.fetchPolicy,\n fetchPolicy = _a === void 0 ? \"cache-first\" : _a;\n if (\n // These fetch policies should never deliver data from the cache, unless\n // redelivering a previously delivered result.\n skipCacheDataFor(fetchPolicy) ||\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.getDocumentInfo(this.query).hasForcedResolvers) {\n // Fall through.\n } else if (this.waitForOwnResult) {\n // This would usually be a part of `QueryInfo.getDiff()`.\n // which we skip in the waitForOwnResult case since we are not\n // interested in the diff.\n this.queryInfo[\"updateWatch\"]();\n } else {\n var diff = this.queryInfo.getDiff();\n if (diff.complete || this.options.returnPartialData) {\n result.data = diff.result;\n }\n if (equal(result.data, {})) {\n result.data = void 0;\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 // 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 (diff.complete && result.networkStatus === NetworkStatus.loading && (fetchPolicy === \"cache-first\" || fetchPolicy === \"cache-only\")) {\n result.networkStatus = NetworkStatus.ready;\n result.loading = false;\n }\n } else {\n result.partial = true;\n }\n if (globalThis.__DEV__ !== false && !diff.complete && !this.options.partialRefetch && !result.loading && !result.data && !result.error) {\n logMissingFieldErrors(diff.missing);\n }\n }\n if (saveAsLastResult) {\n this.updateLastResult(result);\n }\n return result;\n };\n ObservableQuery.prototype.getCurrentResult = function (saveAsLastResult) {\n if (saveAsLastResult === void 0) {\n saveAsLastResult = true;\n }\n return this.maskResult(this.getCurrentFullResult(saveAsLastResult));\n };\n // Compares newResult to the snapshot we took of this.lastResult when it was\n // first received.\n ObservableQuery.prototype.isDifferentFromLastResult = function (newResult, variables) {\n if (!this.last) {\n return true;\n }\n var documentInfo = this.queryManager.getDocumentInfo(this.query);\n var dataMasking = this.queryManager.dataMasking;\n var query = dataMasking ? documentInfo.nonReactiveQuery : this.query;\n var resultIsDifferent = dataMasking || documentInfo.hasNonreactiveDirective ? !equalByQuery(query, this.last.result, newResult, this.variables) : !equal(this.last.result, newResult);\n return resultIsDifferent || variables && !equal(this.last.variables, variables);\n };\n ObservableQuery.prototype.getLast = function (key, variablesMustMatch) {\n var last = this.last;\n if (last && last[key] && (!variablesMustMatch || equal(last.variables, this.variables))) {\n return last[key];\n }\n };\n ObservableQuery.prototype.getLastResult = function (variablesMustMatch) {\n return this.getLast(\"result\", variablesMustMatch);\n };\n ObservableQuery.prototype.getLastError = function (variablesMustMatch) {\n return this.getLast(\"error\", variablesMustMatch);\n };\n ObservableQuery.prototype.resetLastResults = function () {\n delete this.last;\n this.isTornDown = false;\n };\n ObservableQuery.prototype.resetQueryStoreErrors = function () {\n this.queryManager.resetErrors(this.queryId);\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 ObservableQuery.prototype.refetch = function (variables) {\n var _a;\n var reobserveOptions = {\n // Always disable polling for refetches.\n pollInterval: 0\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 var fetchPolicy = this.options.fetchPolicy;\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 if (globalThis.__DEV__ !== false && variables && hasOwnProperty.call(variables, \"variables\")) {\n var queryDef = getQueryDefinition(this.query);\n var vars = queryDef.variableDefinitions;\n if (!vars || !vars.some(function (v) {\n return v.variable.name.value === \"variables\";\n })) {\n globalThis.__DEV__ !== false && invariant.warn(21, variables, ((_a = queryDef.name) === null || _a === void 0 ? void 0 : _a.value) || queryDef);\n }\n }\n if (variables && !equal(this.options.variables, variables)) {\n // Update the existing options with new variables\n reobserveOptions.variables = this.options.variables = __assign(__assign({}, this.options.variables), variables);\n }\n this.queryInfo.resetLastWrite();\n return this.reobserve(reobserveOptions, NetworkStatus.refetch);\n };\n /**\n * A function that helps you fetch the next set of results for a [paginated list field](https://www.apollographql.com/docs/react/pagination/core-api/).\n */\n ObservableQuery.prototype.fetchMore = function (fetchMoreOptions) {\n var _this = this;\n var combinedOptions = __assign(__assign({}, fetchMoreOptions.query ? fetchMoreOptions : __assign(__assign(__assign(__assign({}, this.options), {\n query: this.options.query\n }), fetchMoreOptions), {\n variables: __assign(__assign({}, this.options.variables), fetchMoreOptions.variables)\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 });\n combinedOptions.query = this.transformDocument(combinedOptions.query);\n var qid = this.queryManager.generateQueryId();\n // If a temporary query is passed to `fetchMore`, we don't want to store\n // it as the last query result since it may be an optimized query for\n // pagination. We will however run the transforms on the original document\n // as well as the document passed in `fetchMoreOptions` to ensure the cache\n // uses the most up-to-date document which may rely on runtime conditionals.\n this.lastQuery = fetchMoreOptions.query ? this.transformDocument(this.options.query) : combinedOptions.query;\n // Simulate a loading result for the original query with\n // result.networkStatus === NetworkStatus.fetchMore.\n var queryInfo = this.queryInfo;\n var originalNetworkStatus = queryInfo.networkStatus;\n queryInfo.networkStatus = NetworkStatus.fetchMore;\n if (combinedOptions.notifyOnNetworkStatusChange) {\n this.observe();\n }\n var updatedQuerySet = new Set();\n var updateQuery = fetchMoreOptions === null || fetchMoreOptions === void 0 ? void 0 : fetchMoreOptions.updateQuery;\n var isCached = this.options.fetchPolicy !== \"no-cache\";\n if (!isCached) {\n invariant(updateQuery, 22);\n }\n return this.queryManager.fetchQuery(qid, combinedOptions, NetworkStatus.fetchMore).then(function (fetchMoreResult) {\n _this.queryManager.removeQuery(qid);\n if (queryInfo.networkStatus === NetworkStatus.fetchMore) {\n queryInfo.networkStatus = originalNetworkStatus;\n }\n if (isCached) {\n // Performing this cache update inside a cache.batch transaction ensures\n // any affected cache.watch watchers are notified at most once about any\n // updates. Most watchers will be using the QueryInfo class, which\n // responds to notifications by calling reobserveCacheFirst to deliver\n // fetchMore cache results back to this ObservableQuery.\n _this.queryManager.cache.batch({\n update: function (cache) {\n var updateQuery = fetchMoreOptions.updateQuery;\n if (updateQuery) {\n cache.updateQuery({\n query: _this.query,\n variables: _this.variables,\n returnPartialData: true,\n optimistic: false\n }, function (previous) {\n return updateQuery(previous, {\n fetchMoreResult: fetchMoreResult.data,\n variables: combinedOptions.variables\n });\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 cache.writeQuery({\n query: combinedOptions.query,\n variables: combinedOptions.variables,\n data: fetchMoreResult.data\n });\n }\n },\n onWatchUpdated: function (watch) {\n // Record the DocumentNode associated with any watched query whose\n // data were updated by the cache writes above.\n updatedQuerySet.add(watch.query);\n }\n });\n } else {\n // There is a possibility `lastResult` may not be set when\n // `fetchMore` is called which would cause this to crash. This should\n // only happen if we haven't previously reported a result. We don't\n // quite know what the right behavior should be here since this block\n // of code runs after the fetch result has executed on the network.\n // We plan to let it crash in the meantime.\n //\n // If we get bug reports due to the `data` property access on\n // undefined, this should give us a real-world scenario that we can\n // use to test against and determine the right behavior. If we do end\n // up changing this behavior, this may require, for example, an\n // adjustment to the types on `updateQuery` since that function\n // expects that the first argument always contains previous result\n // data, but not `undefined`.\n var lastResult = _this.getLast(\"result\");\n var data = updateQuery(lastResult.data, {\n fetchMoreResult: fetchMoreResult.data,\n variables: combinedOptions.variables\n });\n _this.reportResult(__assign(__assign({}, lastResult), {\n data: data\n }), _this.variables);\n }\n return _this.maskResult(fetchMoreResult);\n }).finally(function () {\n // In case the cache writes above did not generate a broadcast\n // notification (which would have been intercepted by onWatchUpdated),\n // likely because the written data were the same as what was already in\n // the cache, we still want fetchMore to deliver its final loading:false\n // result with the unchanged data.\n if (isCached && !updatedQuerySet.has(_this.query)) {\n reobserveCacheFirst(_this);\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 /**\n * A function that enables you to execute a [subscription](https://www.apollographql.com/docs/react/data/subscriptions/), usually to subscribe to specific fields that were included in the query.\n *\n * This function returns _another_ function that you can call to terminate the subscription.\n */\n ObservableQuery.prototype.subscribeToMore = function (options) {\n var _this = this;\n var subscription = this.queryManager.startGraphQLSubscription({\n query: options.document,\n variables: options.variables,\n context: options.context\n }).subscribe({\n next: function (subscriptionData) {\n var updateQuery = options.updateQuery;\n if (updateQuery) {\n _this.updateQuery(function (previous, _a) {\n var variables = _a.variables;\n return updateQuery(previous, {\n subscriptionData: subscriptionData,\n variables: variables\n });\n });\n }\n },\n error: function (err) {\n if (options.onError) {\n options.onError(err);\n return;\n }\n globalThis.__DEV__ !== false && invariant.error(23, err);\n }\n });\n this.subscriptions.add(subscription);\n return function () {\n if (_this.subscriptions.delete(subscription)) {\n subscription.unsubscribe();\n }\n };\n };\n ObservableQuery.prototype.setOptions = function (newOptions) {\n return this.reobserve(newOptions);\n };\n ObservableQuery.prototype.silentSetOptions = function (newOptions) {\n var mergedOptions = compact(this.options, newOptions || {});\n assign(this.options, mergedOptions);\n };\n /**\n * Update the variables of this observable query, and fetch the new results\n * if they've changed. Most users should prefer `refetch` instead of\n * `setVariables` in order to to be properly notified of results even when\n * they come from the cache.\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 * @param variables - The new set of variables. If there are missing variables,\n * the previous values of those variables will be used.\n */\n ObservableQuery.prototype.setVariables = function (variables) {\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 ? this.result() : Promise.resolve();\n }\n this.options.variables = variables;\n // See comment above\n if (!this.observers.size) {\n return Promise.resolve();\n }\n return this.reobserve({\n // Reset options.fetchPolicy to its original value.\n fetchPolicy: this.options.initialFetchPolicy,\n variables: variables\n }, NetworkStatus.setVariables);\n };\n /**\n * A function that enables you to update the query's cached result without executing a followup GraphQL operation.\n *\n * See [using updateQuery and updateFragment](https://www.apollographql.com/docs/react/caching/cache-interaction/#using-updatequery-and-updatefragment) for additional information.\n */\n ObservableQuery.prototype.updateQuery = function (mapFn) {\n var queryManager = this.queryManager;\n var result = queryManager.cache.diff({\n query: this.options.query,\n variables: this.variables,\n returnPartialData: true,\n optimistic: false\n }).result;\n var newResult = mapFn(result, {\n variables: this.variables\n });\n if (newResult) {\n queryManager.cache.writeQuery({\n query: this.options.query,\n data: newResult,\n variables: this.variables\n });\n queryManager.broadcastQueries();\n }\n };\n /**\n * A function that instructs the query to begin re-executing at a specified interval (in milliseconds).\n */\n ObservableQuery.prototype.startPolling = function (pollInterval) {\n this.options.pollInterval = pollInterval;\n this.updatePolling();\n };\n /**\n * A function that instructs the query to stop polling after a previous call to `startPolling`.\n */\n ObservableQuery.prototype.stopPolling = function () {\n this.options.pollInterval = 0;\n this.updatePolling();\n };\n // Update options.fetchPolicy according to options.nextFetchPolicy.\n ObservableQuery.prototype.applyNextFetchPolicy = function (reason,\n // It's possible to use this method to apply options.nextFetchPolicy to\n // options.fetchPolicy even if options !== this.options, though that happens\n // most often when the options are temporary, used for only one request and\n // then thrown away, so nextFetchPolicy may not end up mattering.\n options) {\n if (options.nextFetchPolicy) {\n var _a = options.fetchPolicy,\n fetchPolicy = _a === void 0 ? \"cache-first\" : _a,\n _b = options.initialFetchPolicy,\n initialFetchPolicy = _b === void 0 ? fetchPolicy : _b;\n if (fetchPolicy === \"standby\") {\n // Do nothing, leaving options.fetchPolicy unchanged.\n } else if (typeof options.nextFetchPolicy === \"function\") {\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\n // seem to imply. Instead, when the cache reports an update after the\n // initial network request, it may be desirable for subsequent network\n // requests to be triggered only if the cache result is incomplete. To\n // that end, the options.nextFetchPolicy option provides an easy way to\n // update options.fetchPolicy after the initial network request, without\n // having to call observableQuery.setOptions.\n options.fetchPolicy = options.nextFetchPolicy(fetchPolicy, {\n reason: reason,\n options: options,\n observable: this,\n initialFetchPolicy: initialFetchPolicy\n });\n } else if (reason === \"variables-changed\") {\n options.fetchPolicy = initialFetchPolicy;\n } else {\n options.fetchPolicy = options.nextFetchPolicy;\n }\n }\n return options.fetchPolicy;\n };\n ObservableQuery.prototype.fetch = function (options, newNetworkStatus, query) {\n // TODO Make sure we update the networkStatus (and infer fetchVariables)\n // before actually committing to the fetch.\n this.queryManager.setObservableQuery(this);\n return this.queryManager[\"fetchConcastWithInfo\"](this.queryId, options, newNetworkStatus, query);\n };\n // Turns polling on or off based on this.options.pollInterval.\n ObservableQuery.prototype.updatePolling = function () {\n var _this = this;\n // Avoid polling in SSR mode\n if (this.queryManager.ssrMode) {\n return;\n }\n var _a = this,\n pollingInfo = _a.pollingInfo,\n pollInterval = _a.options.pollInterval;\n if (!pollInterval || !this.hasObservers()) {\n if (pollingInfo) {\n clearTimeout(pollingInfo.timeout);\n delete this.pollingInfo;\n }\n return;\n }\n if (pollingInfo && pollingInfo.interval === pollInterval) {\n return;\n }\n invariant(pollInterval, 24);\n var info = pollingInfo || (this.pollingInfo = {});\n info.interval = pollInterval;\n var maybeFetch = function () {\n var _a, _b;\n if (_this.pollingInfo) {\n if (!isNetworkRequestInFlight(_this.queryInfo.networkStatus) && !((_b = (_a = _this.options).skipPollAttempt) === null || _b === void 0 ? void 0 : _b.call(_a))) {\n _this.reobserve({\n // Most fetchPolicy options don't make sense to use in a polling context, as\n // users wouldn't want to be polling the cache directly. However, network-only and\n // no-cache are both useful for when the user wants to control whether or not the\n // polled results are written to the cache.\n fetchPolicy: _this.options.initialFetchPolicy === \"no-cache\" ? \"no-cache\" : \"network-only\"\n }, NetworkStatus.poll).then(poll, poll);\n } else {\n poll();\n }\n }\n };\n var poll = function () {\n var info = _this.pollingInfo;\n if (info) {\n clearTimeout(info.timeout);\n info.timeout = setTimeout(maybeFetch, info.interval);\n }\n };\n poll();\n };\n ObservableQuery.prototype.updateLastResult = function (newResult, variables) {\n if (variables === void 0) {\n variables = this.variables;\n }\n var error = this.getLastError();\n // Preserve this.last.error unless the variables have changed.\n if (error && this.last && !equal(variables, this.last.variables)) {\n error = void 0;\n }\n return this.last = __assign({\n result: this.queryManager.assumeImmutableResults ? newResult : cloneDeep(newResult),\n variables: variables\n }, error ? {\n error: error\n } : null);\n };\n ObservableQuery.prototype.reobserveAsConcast = function (newOptions, newNetworkStatus) {\n var _this = this;\n this.isTornDown = false;\n var 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\" or \"no-cache\") won't override the original options.\n newNetworkStatus === NetworkStatus.poll;\n // Save the old variables, since Object.assign may modify them below.\n var oldVariables = this.options.variables;\n var oldFetchPolicy = this.options.fetchPolicy;\n var mergedOptions = compact(this.options, newOptions || {});\n var options = useDisposableConcast ?\n // Disposable Concast fetches receive a shallow copy of this.options\n // (merged with newOptions), leaving this.options unmodified.\n mergedOptions : assign(this.options, mergedOptions);\n // Don't update options.query with the transformed query to avoid\n // overwriting this.options.query when we aren't using a disposable concast.\n // We want to ensure we can re-run the custom document transforms the next\n // time a request is made against the original query.\n var query = this.transformDocument(options.query);\n this.lastQuery = query;\n if (!useDisposableConcast) {\n // We can skip calling updatePolling if we're not changing this.options.\n this.updatePolling();\n // Reset options.fetchPolicy to its original value when variables change,\n // unless a new fetchPolicy was provided by newOptions.\n if (newOptions && newOptions.variables && !equal(newOptions.variables, oldVariables) &&\n // Don't mess with the fetchPolicy if it's currently \"standby\".\n options.fetchPolicy !== \"standby\" && (\n // If we're changing the fetchPolicy anyway, don't try to change it here\n // using applyNextFetchPolicy. The explicit options.fetchPolicy wins.\n options.fetchPolicy === oldFetchPolicy ||\n // A `nextFetchPolicy` function has even higher priority, though,\n // so in that case `applyNextFetchPolicy` must be called.\n typeof options.nextFetchPolicy === \"function\")) {\n this.applyNextFetchPolicy(\"variables-changed\", options);\n if (newNetworkStatus === void 0) {\n newNetworkStatus = NetworkStatus.setVariables;\n }\n }\n }\n this.waitForOwnResult && (this.waitForOwnResult = skipCacheDataFor(options.fetchPolicy));\n var finishWaitingForOwnResult = function () {\n if (_this.concast === concast) {\n _this.waitForOwnResult = false;\n }\n };\n var variables = options.variables && __assign({}, options.variables);\n var _a = this.fetch(options, newNetworkStatus, query),\n concast = _a.concast,\n fromLink = _a.fromLink;\n var observer = {\n next: function (result) {\n if (equal(_this.variables, variables)) {\n finishWaitingForOwnResult();\n _this.reportResult(result, variables);\n }\n },\n error: function (error) {\n if (equal(_this.variables, variables)) {\n // Coming from `getResultsFromLink`, `error` here should always be an `ApolloError`.\n // However, calling `concast.cancel` can inject another type of error, so we have to\n // wrap it again here.\n if (!isApolloError(error)) {\n error = new ApolloError({\n networkError: error\n });\n }\n finishWaitingForOwnResult();\n _this.reportError(error, variables);\n }\n }\n };\n if (!useDisposableConcast && (fromLink || !this.concast)) {\n // We use the {add,remove}Observer methods directly to avoid wrapping\n // observer with an unnecessary SubscriptionObserver object.\n if (this.concast && this.observer) {\n this.concast.removeObserver(this.observer);\n }\n this.concast = concast;\n this.observer = observer;\n }\n concast.addObserver(observer);\n return concast;\n };\n ObservableQuery.prototype.reobserve = function (newOptions, newNetworkStatus) {\n return preventUnhandledRejection(this.reobserveAsConcast(newOptions, newNetworkStatus).promise.then(this.maskResult));\n };\n ObservableQuery.prototype.resubscribeAfterError = function () {\n var args = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n args[_i] = arguments[_i];\n }\n // If `lastError` is set in the current 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 the last value afterwards so that the\n // subscription has a chance to stay open.\n var last = this.last;\n this.resetLastResults();\n var subscription = this.subscribe.apply(this, args);\n this.last = last;\n return subscription;\n };\n // (Re)deliver the current result to this.observers without applying fetch\n // policies or making network requests.\n ObservableQuery.prototype.observe = function () {\n this.reportResult(\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.reportResult.\n this.getCurrentFullResult(false), this.variables);\n };\n ObservableQuery.prototype.reportResult = function (result, variables) {\n var lastError = this.getLastError();\n var isDifferent = this.isDifferentFromLastResult(result, variables);\n // Update the last result even when isDifferentFromLastResult returns false,\n // because the query may be using the @nonreactive directive, and we want to\n // save the the latest version of any nonreactive subtrees (in case\n // getCurrentResult is called), even though we skip broadcasting changes.\n if (lastError || !result.partial || this.options.returnPartialData) {\n this.updateLastResult(result, variables);\n }\n if (lastError || isDifferent) {\n iterateObserversSafely(this.observers, \"next\", this.maskResult(result));\n }\n };\n ObservableQuery.prototype.reportError = function (error, variables) {\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 var errorResult = __assign(__assign({}, this.getLastResult()), {\n error: error,\n errors: error.graphQLErrors,\n networkStatus: NetworkStatus.error,\n loading: false\n });\n this.updateLastResult(errorResult, variables);\n iterateObserversSafely(this.observers, \"error\", this.last.error = error);\n };\n ObservableQuery.prototype.hasObservers = function () {\n return this.observers.size > 0;\n };\n ObservableQuery.prototype.tearDownQuery = function () {\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 this.stopPolling();\n // stop all active GraphQL subscriptions\n this.subscriptions.forEach(function (sub) {\n return sub.unsubscribe();\n });\n this.subscriptions.clear();\n this.queryManager.stopQuery(this.queryId);\n this.observers.clear();\n this.isTornDown = true;\n };\n ObservableQuery.prototype.transformDocument = function (document) {\n return this.queryManager.transform(document);\n };\n ObservableQuery.prototype.maskResult = function (result) {\n return result && \"data\" in result ? __assign(__assign({}, result), {\n data: this.queryManager.maskOperation({\n document: this.query,\n data: result.data,\n fetchPolicy: this.options.fetchPolicy,\n id: this.queryId\n })\n }) : result;\n };\n return ObservableQuery;\n}(Observable);\nexport { ObservableQuery };\n// Necessary because the ObservableQuery constructor has a different\n// signature than the Observable constructor.\nfixObservableSubclass(ObservableQuery);\n// Reobserve with fetchPolicy effectively set to \"cache-first\", triggering\n// delivery of any new data from the cache, possibly falling back to the network\n// if any cache data are missing. This allows _complete_ cache results to be\n// delivered without also kicking off unnecessary network requests when\n// this.options.fetchPolicy is \"cache-and-network\" or \"network-only\". When\n// this.options.fetchPolicy is any other policy (\"cache-first\", \"cache-only\",\n// \"standby\", or \"no-cache\"), we call this.reobserve() as usual.\nexport function reobserveCacheFirst(obsQuery) {\n var _a = obsQuery.options,\n fetchPolicy = _a.fetchPolicy,\n nextFetchPolicy = _a.nextFetchPolicy;\n if (fetchPolicy === \"cache-and-network\" || fetchPolicy === \"network-only\") {\n return obsQuery.reobserve({\n fetchPolicy: \"cache-first\",\n // Use a temporary nextFetchPolicy function that replaces itself with the\n // previous nextFetchPolicy value and returns the original fetchPolicy.\n nextFetchPolicy: function (currentFetchPolicy, context) {\n // Replace this nextFetchPolicy function in the options object with the\n // original this.options.nextFetchPolicy value.\n this.nextFetchPolicy = nextFetchPolicy;\n // If the original nextFetchPolicy value was a function, give it a\n // chance to decide what happens here.\n if (typeof this.nextFetchPolicy === \"function\") {\n return this.nextFetchPolicy(currentFetchPolicy, context);\n }\n // Otherwise go back to the original this.options.fetchPolicy.\n return fetchPolicy;\n }\n });\n }\n return obsQuery.reobserve();\n}\nfunction defaultSubscriptionObserverErrorCallback(error) {\n globalThis.__DEV__ !== false && invariant.error(25, error.message, error.stack);\n}\nexport function logMissingFieldErrors(missing) {\n if (globalThis.__DEV__ !== false && missing) {\n globalThis.__DEV__ !== false && invariant.debug(26, missing);\n }\n}\nfunction skipCacheDataFor(fetchPolicy /* `undefined` would mean `\"cache-first\"` */) {\n return fetchPolicy === \"network-only\" || fetchPolicy === \"no-cache\" || fetchPolicy === \"standby\";\n}","export function preventUnhandledRejection(promise) {\n promise.catch(function () {});\n return promise;\n}","import { __assign } from \"tslib\";\nimport { equal } from \"@wry/equality\";\nimport { DeepMerger } from \"../utilities/index.js\";\nimport { mergeIncrementalData } from \"../utilities/index.js\";\nimport { reobserveCacheFirst } from \"./ObservableQuery.js\";\nimport { isNonEmptyArray, graphQLResultHasError, canUseWeakMap } from \"../utilities/index.js\";\nimport { NetworkStatus, isNetworkRequestInFlight } from \"./networkStatus.js\";\nvar destructiveMethodCounts = new (canUseWeakMap ? WeakMap : Map)();\nfunction wrapDestructiveCacheMethod(cache, methodName) {\n var original = cache[methodName];\n if (typeof original === \"function\") {\n // @ts-expect-error this is just too generic to be typed correctly\n cache[methodName] = function () {\n destructiveMethodCounts.set(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 // @ts-expect-error this is just too generic to be typed correctly\n return original.apply(this, arguments);\n };\n }\n}\nfunction cancelNotifyTimeout(info) {\n if (info[\"notifyTimeout\"]) {\n clearTimeout(info[\"notifyTimeout\"]);\n info[\"notifyTimeout\"] = void 0;\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.\nvar QueryInfo = /** @class */function () {\n function QueryInfo(queryManager, queryId) {\n if (queryId === void 0) {\n queryId = queryManager.generateQueryId();\n }\n this.queryId = queryId;\n this.listeners = new Set();\n this.document = null;\n this.lastRequestId = 1;\n this.stopped = false;\n this.dirty = false;\n this.observableQuery = null;\n var cache = this.cache = queryManager.cache;\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 QueryInfo.prototype.init = function (query) {\n var networkStatus = query.networkStatus || NetworkStatus.loading;\n if (this.variables && this.networkStatus !== NetworkStatus.loading && !equal(this.variables, query.variables)) {\n networkStatus = NetworkStatus.setVariables;\n }\n if (!equal(query.variables, this.variables)) {\n this.lastDiff = void 0;\n }\n Object.assign(this, {\n document: query.document,\n variables: query.variables,\n networkError: null,\n graphQLErrors: this.graphQLErrors || [],\n networkStatus: networkStatus\n });\n if (query.observableQuery) {\n this.setObservableQuery(query.observableQuery);\n }\n if (query.lastRequestId) {\n this.lastRequestId = query.lastRequestId;\n }\n return this;\n };\n QueryInfo.prototype.reset = function () {\n cancelNotifyTimeout(this);\n this.dirty = false;\n };\n QueryInfo.prototype.resetDiff = function () {\n this.lastDiff = void 0;\n };\n QueryInfo.prototype.getDiff = function () {\n var options = this.getDiffOptions();\n if (this.lastDiff && equal(options, this.lastDiff.options)) {\n return this.lastDiff.diff;\n }\n this.updateWatch(this.variables);\n var oq = this.observableQuery;\n if (oq && oq.options.fetchPolicy === \"no-cache\") {\n return {\n complete: false\n };\n }\n var diff = this.cache.diff(options);\n this.updateLastDiff(diff, options);\n return diff;\n };\n QueryInfo.prototype.updateLastDiff = function (diff, options) {\n this.lastDiff = diff ? {\n diff: diff,\n options: options || this.getDiffOptions()\n } : void 0;\n };\n QueryInfo.prototype.getDiffOptions = function (variables) {\n var _a;\n if (variables === void 0) {\n variables = this.variables;\n }\n return {\n query: this.document,\n variables: variables,\n returnPartialData: true,\n optimistic: true,\n canonizeResults: (_a = this.observableQuery) === null || _a === void 0 ? void 0 : _a.options.canonizeResults\n };\n };\n QueryInfo.prototype.setDiff = function (diff) {\n var _this = this;\n var _a;\n var oldDiff = this.lastDiff && this.lastDiff.diff;\n // If we are trying to deliver an incomplete cache result, we avoid\n // reporting it if the query has errored, otherwise we let the broadcast try\n // and repair the partial result by refetching the query. This check avoids\n // a situation where a query that errors and another succeeds with\n // overlapping data does not report the partial data result to the errored\n // query.\n //\n // See https://github.com/apollographql/apollo-client/issues/11400 for more\n // information on this issue.\n if (diff && !diff.complete && ((_a = this.observableQuery) === null || _a === void 0 ? void 0 : _a.getLastError())) {\n return;\n }\n this.updateLastDiff(diff);\n if (!this.dirty && !equal(oldDiff && oldDiff.result, diff && diff.result)) {\n this.dirty = true;\n if (!this.notifyTimeout) {\n this.notifyTimeout = setTimeout(function () {\n return _this.notify();\n }, 0);\n }\n }\n };\n QueryInfo.prototype.setObservableQuery = function (oq) {\n var _this = this;\n if (oq === this.observableQuery) return;\n if (this.oqListener) {\n this.listeners.delete(this.oqListener);\n }\n this.observableQuery = oq;\n if (oq) {\n oq[\"queryInfo\"] = this;\n this.listeners.add(this.oqListener = function () {\n var diff = _this.getDiff();\n if (diff.fromOptimisticTransaction) {\n // If this diff came from an optimistic transaction, deliver the\n // current cache data to the ObservableQuery, but don't perform a\n // reobservation, since oq.reobserveCacheFirst might make a network\n // request, and we never want to trigger network requests in the\n // middle of optimistic updates.\n oq[\"observe\"]();\n } else {\n // Otherwise, make the ObservableQuery \"reobserve\" the latest data\n // using a temporary fetch policy of \"cache-first\", so complete cache\n // results have a chance to be delivered without triggering additional\n // network requests, even when options.fetchPolicy is \"network-only\"\n // or \"cache-and-network\". All other fetch policies are preserved by\n // this method, and are handled by calling oq.reobserve(). If this\n // reobservation is spurious, isDifferentFromLastResult still has a\n // chance to catch it before delivery to ObservableQuery subscribers.\n reobserveCacheFirst(oq);\n }\n });\n } else {\n delete this.oqListener;\n }\n };\n QueryInfo.prototype.notify = function () {\n var _this = this;\n cancelNotifyTimeout(this);\n if (this.shouldNotify()) {\n this.listeners.forEach(function (listener) {\n return listener(_this);\n });\n }\n this.dirty = false;\n };\n QueryInfo.prototype.shouldNotify = function () {\n if (!this.dirty || !this.listeners.size) {\n return false;\n }\n if (isNetworkRequestInFlight(this.networkStatus) && this.observableQuery) {\n var fetchPolicy = this.observableQuery.options.fetchPolicy;\n if (fetchPolicy !== \"cache-only\" && fetchPolicy !== \"cache-and-network\") {\n return false;\n }\n }\n return true;\n };\n QueryInfo.prototype.stop = function () {\n if (!this.stopped) {\n this.stopped = true;\n // Cancel the pending notify timeout\n this.reset();\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 var oq = this.observableQuery;\n if (oq) oq.stopPolling();\n }\n };\n // This method is a no-op by default, until/unless overridden by the\n // updateWatch method.\n QueryInfo.prototype.cancel = function () {};\n QueryInfo.prototype.updateWatch = function (variables) {\n var _this = this;\n if (variables === void 0) {\n variables = this.variables;\n }\n var oq = this.observableQuery;\n if (oq && oq.options.fetchPolicy === \"no-cache\") {\n return;\n }\n var watchOptions = __assign(__assign({}, this.getDiffOptions(variables)), {\n watcher: this,\n callback: function (diff) {\n return _this.setDiff(diff);\n }\n });\n if (!this.lastWatch || !equal(watchOptions, this.lastWatch)) {\n this.cancel();\n this.cancel = this.cache.watch(this.lastWatch = watchOptions);\n }\n };\n QueryInfo.prototype.resetLastWrite = function () {\n this.lastWrite = void 0;\n };\n QueryInfo.prototype.shouldWrite = function (result, variables) {\n var lastWrite = this.lastWrite;\n return !(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) && equal(variables, lastWrite.variables) && equal(result.data, lastWrite.result.data));\n };\n QueryInfo.prototype.markResult = function (result, document, options, cacheWriteBehavior) {\n var _this = this;\n var merger = new DeepMerger();\n var graphQLErrors = isNonEmptyArray(result.errors) ? result.errors.slice(0) : [];\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 if (\"incremental\" in result && isNonEmptyArray(result.incremental)) {\n var mergedData = mergeIncrementalData(this.getDiff().result, result);\n result.data = mergedData;\n // Detect the first chunk of a deferred query and merge it with existing\n // cache data. This ensures a `cache-first` fetch policy that returns\n // partial cache data or a `cache-and-network` fetch policy that already\n // has full data in the cache does not complain when trying to merge the\n // initial deferred server data with existing cache data.\n } else if (\"hasNext\" in result && result.hasNext) {\n var diff = this.getDiff();\n result.data = merger.merge(diff.result, result.data);\n }\n this.graphQLErrors = graphQLErrors;\n if (options.fetchPolicy === \"no-cache\") {\n this.updateLastDiff({\n result: result.data,\n complete: true\n }, this.getDiffOptions(options.variables));\n } else if (cacheWriteBehavior !== 0 /* 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(function (cache) {\n if (_this.shouldWrite(result, options.variables)) {\n cache.writeQuery({\n query: document,\n data: result.data,\n variables: options.variables,\n overwrite: cacheWriteBehavior === 1 /* CacheWriteBehavior.OVERWRITE */\n });\n\n _this.lastWrite = {\n result: 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 && _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 var diffOptions = _this.getDiffOptions(options.variables);\n var diff = cache.diff(diffOptions);\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. We also avoid updating\n // the watch if we are writing a result that doesn't match the current\n // variables to avoid race conditions from broadcasting the wrong\n // result.\n if (!_this.stopped && equal(_this.variables, options.variables)) {\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 // 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 QueryInfo.prototype.markReady = function () {\n this.networkError = null;\n return this.networkStatus = NetworkStatus.ready;\n };\n QueryInfo.prototype.markError = function (error) {\n this.networkStatus = NetworkStatus.error;\n this.lastWrite = void 0;\n this.reset();\n if (error.graphQLErrors) {\n this.graphQLErrors = error.graphQLErrors;\n }\n if (error.networkError) {\n this.networkError = error.networkError;\n }\n return error;\n };\n return QueryInfo;\n}();\nexport { QueryInfo };\nexport function shouldWriteResult(result, errorPolicy) {\n if (errorPolicy === void 0) {\n errorPolicy = \"none\";\n }\n var ignoreErrors = errorPolicy === \"ignore\" || errorPolicy === \"all\";\n var writeWithErrors = !graphQLResultHasError(result);\n if (!writeWithErrors && ignoreErrors && result.data) {\n writeWithErrors = true;\n }\n return writeWithErrors;\n}","import { __assign, __awaiter, __generator } from \"tslib\";\nimport { invariant, newInvariantError } from \"../utilities/globals/index.js\";\nimport { equal } from \"@wry/equality\";\nimport { execute } from \"../link/core/index.js\";\nimport { addNonReactiveToNamedFragments, hasDirectives, isExecutionPatchIncrementalResult, isExecutionPatchResult, isFullyUnmaskedOperation, removeDirectivesFromDocument } from \"../utilities/index.js\";\nimport { canonicalStringify } from \"../cache/index.js\";\nimport { getDefaultValues, getOperationDefinition, getOperationName, hasClientExports, graphQLResultHasError, getGraphQLErrorsFromResult, Observable, asyncMap, isNonEmptyArray, Concast, makeUniqueId, isDocumentNode, isNonNullObject, DocumentTransform } from \"../utilities/index.js\";\nimport { mergeIncrementalData } from \"../utilities/common/incrementalResult.js\";\nimport { ApolloError, isApolloError, graphQLResultHasProtocolErrors } from \"../errors/index.js\";\nimport { ObservableQuery, logMissingFieldErrors } from \"./ObservableQuery.js\";\nimport { NetworkStatus, isNetworkRequestInFlight } from \"./networkStatus.js\";\nimport { QueryInfo, shouldWriteResult } from \"./QueryInfo.js\";\nimport { PROTOCOL_ERRORS_SYMBOL } from \"../errors/index.js\";\nimport { print } from \"../utilities/index.js\";\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar IGNORE = Object.create(null);\nimport { Trie } from \"@wry/trie\";\nimport { AutoCleanedWeakCache, cacheSizes } from \"../utilities/index.js\";\nimport { maskFragment, maskOperation } from \"../masking/index.js\";\nvar QueryManager = /** @class */function () {\n function QueryManager(options) {\n var _this = this;\n this.clientAwareness = {};\n // All the queries that the QueryManager is currently managing (not\n // including mutations and subscriptions).\n this.queries = new Map();\n // Maps from queryId strings to Promise rejection functions for\n // currently active queries and fetches.\n // Use protected instead of private field so\n // @apollo/experimental-nextjs-app-support can access type info.\n this.fetchCancelFns = new Map();\n this.transformCache = new AutoCleanedWeakCache(cacheSizes[\"queryManager.getDocumentInfo\"] || 2000 /* defaultCacheSizes[\"queryManager.getDocumentInfo\"] */);\n this.queryIdCounter = 1;\n this.requestIdCounter = 1;\n this.mutationIdCounter = 1;\n // Use protected instead of private field so\n // @apollo/experimental-nextjs-app-support can access type info.\n this.inFlightLinkObservables = new Trie(false);\n this.noCacheWarningsByQueryId = new Set();\n var defaultDocumentTransform = new DocumentTransform(function (document) {\n return _this.cache.transformDocument(document);\n },\n // Allow the apollo cache to manage its own transform caches\n {\n cache: false\n });\n this.cache = options.cache;\n this.link = options.link;\n this.defaultOptions = options.defaultOptions;\n this.queryDeduplication = options.queryDeduplication;\n this.clientAwareness = options.clientAwareness;\n this.localState = options.localState;\n this.ssrMode = options.ssrMode;\n this.assumeImmutableResults = options.assumeImmutableResults;\n this.dataMasking = options.dataMasking;\n var documentTransform = options.documentTransform;\n this.documentTransform = documentTransform ? defaultDocumentTransform.concat(documentTransform)\n // The custom document transform may add new fragment spreads or new\n // field selections, so we want to give the cache a chance to run\n // again. For example, the InMemoryCache adds __typename to field\n // selections and fragments from the fragment registry.\n .concat(defaultDocumentTransform) : defaultDocumentTransform;\n this.defaultContext = options.defaultContext || Object.create(null);\n if (this.onBroadcast = options.onBroadcast) {\n this.mutationStore = Object.create(null);\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 QueryManager.prototype.stop = function () {\n var _this = this;\n this.queries.forEach(function (_info, queryId) {\n _this.stopQueryNoBroadcast(queryId);\n });\n this.cancelPendingFetches(newInvariantError(27));\n };\n QueryManager.prototype.cancelPendingFetches = function (error) {\n this.fetchCancelFns.forEach(function (cancel) {\n return cancel(error);\n });\n this.fetchCancelFns.clear();\n };\n QueryManager.prototype.mutate = function (_a) {\n return __awaiter(this, arguments, void 0, function (_b) {\n var mutationId, hasClientExports, mutationStoreValue, isOptimistic, self;\n var _c, _d;\n var mutation = _b.mutation,\n variables = _b.variables,\n optimisticResponse = _b.optimisticResponse,\n updateQueries = _b.updateQueries,\n _e = _b.refetchQueries,\n refetchQueries = _e === void 0 ? [] : _e,\n _f = _b.awaitRefetchQueries,\n awaitRefetchQueries = _f === void 0 ? false : _f,\n updateWithProxyFn = _b.update,\n onQueryUpdated = _b.onQueryUpdated,\n _g = _b.fetchPolicy,\n fetchPolicy = _g === void 0 ? ((_c = this.defaultOptions.mutate) === null || _c === void 0 ? void 0 : _c.fetchPolicy) || \"network-only\" : _g,\n _h = _b.errorPolicy,\n errorPolicy = _h === void 0 ? ((_d = this.defaultOptions.mutate) === null || _d === void 0 ? void 0 : _d.errorPolicy) || \"none\" : _h,\n keepRootFields = _b.keepRootFields,\n context = _b.context;\n return __generator(this, function (_j) {\n switch (_j.label) {\n case 0:\n invariant(mutation, 28);\n invariant(fetchPolicy === \"network-only\" || fetchPolicy === \"no-cache\", 29);\n mutationId = this.generateMutationId();\n mutation = this.cache.transformForLink(this.transform(mutation));\n hasClientExports = this.getDocumentInfo(mutation).hasClientExports;\n variables = this.getVariables(mutation, variables);\n if (!hasClientExports) return [3 /*break*/, 2];\n return [4 /*yield*/, this.localState.addExportedVariables(mutation, variables, context)];\n case 1:\n variables = _j.sent();\n _j.label = 2;\n case 2:\n mutationStoreValue = this.mutationStore && (this.mutationStore[mutationId] = {\n mutation: mutation,\n variables: variables,\n loading: true,\n error: null\n });\n isOptimistic = optimisticResponse && this.markMutationOptimistic(optimisticResponse, {\n mutationId: mutationId,\n document: mutation,\n variables: variables,\n fetchPolicy: fetchPolicy,\n errorPolicy: errorPolicy,\n context: context,\n updateQueries: updateQueries,\n update: updateWithProxyFn,\n keepRootFields: keepRootFields\n });\n this.broadcastQueries();\n self = this;\n return [2 /*return*/, new Promise(function (resolve, reject) {\n return asyncMap(self.getObservableFromLink(mutation, __assign(__assign({}, context), {\n optimisticResponse: isOptimistic ? optimisticResponse : void 0\n }), variables, {}, false), function (result) {\n if (graphQLResultHasError(result) && errorPolicy === \"none\") {\n throw new ApolloError({\n graphQLErrors: getGraphQLErrorsFromResult(result)\n });\n }\n if (mutationStoreValue) {\n mutationStoreValue.loading = false;\n mutationStoreValue.error = null;\n }\n var storeResult = __assign({}, result);\n if (typeof refetchQueries === \"function\") {\n refetchQueries = refetchQueries(storeResult);\n }\n if (errorPolicy === \"ignore\" && graphQLResultHasError(storeResult)) {\n delete storeResult.errors;\n }\n return self.markMutationResult({\n mutationId: mutationId,\n result: storeResult,\n document: mutation,\n variables: variables,\n fetchPolicy: fetchPolicy,\n errorPolicy: errorPolicy,\n context: context,\n update: updateWithProxyFn,\n updateQueries: updateQueries,\n awaitRefetchQueries: awaitRefetchQueries,\n refetchQueries: refetchQueries,\n removeOptimistic: isOptimistic ? mutationId : void 0,\n onQueryUpdated: onQueryUpdated,\n keepRootFields: keepRootFields\n });\n }).subscribe({\n next: function (storeResult) {\n self.broadcastQueries();\n // Since mutations might receive multiple payloads from the\n // ApolloLink chain (e.g. when used with @defer),\n // we resolve with a SingleExecutionResult or after the final\n // ExecutionPatchResult has arrived and we have assembled the\n // multipart response into a single result.\n if (!(\"hasNext\" in storeResult) || storeResult.hasNext === false) {\n resolve(__assign(__assign({}, storeResult), {\n data: self.maskOperation({\n document: mutation,\n data: storeResult.data,\n fetchPolicy: fetchPolicy,\n id: mutationId\n })\n }));\n }\n },\n error: function (err) {\n if (mutationStoreValue) {\n mutationStoreValue.loading = false;\n mutationStoreValue.error = err;\n }\n if (isOptimistic) {\n self.cache.removeOptimistic(mutationId);\n }\n self.broadcastQueries();\n reject(err instanceof ApolloError ? err : new ApolloError({\n networkError: err\n }));\n }\n });\n })];\n }\n });\n });\n };\n QueryManager.prototype.markMutationResult = function (mutation, cache) {\n var _this = this;\n if (cache === void 0) {\n cache = this.cache;\n }\n var result = mutation.result;\n var cacheWrites = [];\n var skipCache = mutation.fetchPolicy === \"no-cache\";\n if (!skipCache && shouldWriteResult(result, mutation.errorPolicy)) {\n if (!isExecutionPatchIncrementalResult(result)) {\n cacheWrites.push({\n result: result.data,\n dataId: \"ROOT_MUTATION\",\n query: mutation.document,\n variables: mutation.variables\n });\n }\n if (isExecutionPatchIncrementalResult(result) && isNonEmptyArray(result.incremental)) {\n var 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.getDocumentInfo(mutation.document).asQuery,\n variables: mutation.variables,\n optimistic: false,\n returnPartialData: true\n });\n var mergedData = void 0;\n if (diff.result) {\n mergedData = mergeIncrementalData(diff.result, result);\n }\n if (typeof mergedData !== \"undefined\") {\n // cast the ExecutionPatchResult to FetchResult here since\n // ExecutionPatchResult never has `data` when returned from the server\n result.data = mergedData;\n cacheWrites.push({\n result: mergedData,\n dataId: \"ROOT_MUTATION\",\n query: mutation.document,\n variables: mutation.variables\n });\n }\n }\n var updateQueries_1 = mutation.updateQueries;\n if (updateQueries_1) {\n this.queries.forEach(function (_a, queryId) {\n var observableQuery = _a.observableQuery;\n var queryName = observableQuery && observableQuery.queryName;\n if (!queryName || !hasOwnProperty.call(updateQueries_1, queryName)) {\n return;\n }\n var updater = updateQueries_1[queryName];\n var _b = _this.queries.get(queryId),\n document = _b.document,\n variables = _b.variables;\n // Read the current query result from the store.\n var _c = cache.diff({\n query: document,\n variables: variables,\n returnPartialData: true,\n optimistic: false\n }),\n currentQueryResult = _c.result,\n complete = _c.complete;\n if (complete && currentQueryResult) {\n // Run our reducer using the current query result and the mutation result.\n var nextQueryResult = updater(currentQueryResult, {\n mutationResult: result,\n queryName: document && getOperationName(document) || void 0,\n queryVariables: variables\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: variables\n });\n }\n }\n });\n }\n }\n if (cacheWrites.length > 0 || (mutation.refetchQueries || \"\").length > 0 || mutation.update || mutation.onQueryUpdated || mutation.removeOptimistic) {\n var results_1 = [];\n this.refetchQueries({\n updateCache: function (cache) {\n if (!skipCache) {\n cacheWrites.forEach(function (write) {\n return 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 var update = mutation.update;\n // Determine whether result is a SingleExecutionResult,\n // or the final ExecutionPatchResult.\n var isFinalResult = !isExecutionPatchResult(result) || isExecutionPatchIncrementalResult(result) && !result.hasNext;\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 var 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.getDocumentInfo(mutation.document).asQuery,\n variables: mutation.variables,\n optimistic: false,\n returnPartialData: true\n });\n if (diff.complete) {\n result = __assign(__assign({}, result), {\n data: diff.result\n });\n if (\"incremental\" in result) {\n delete result.incremental;\n }\n if (\"hasNext\" in result) {\n delete result.hasNext;\n }\n }\n }\n // If we've received the whole response,\n // either a SingleExecutionResult or the final ExecutionPatchResult,\n // call the update function.\n if (isFinalResult) {\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 && isFinalResult) {\n cache.modify({\n id: \"ROOT_MUTATION\",\n fields: function (value, _a) {\n var fieldName = _a.fieldName,\n DELETE = _a.DELETE;\n return fieldName === \"__typename\" ? value : DELETE;\n }\n });\n }\n },\n include: mutation.refetchQueries,\n // Write the final mutation.result to the root layer of the cache.\n optimistic: false,\n // Remove the corresponding optimistic layer at the same time as we\n // write the final non-optimistic result.\n removeOptimistic: mutation.removeOptimistic,\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 }).forEach(function (result) {\n return results_1.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_1).then(function () {\n return result;\n });\n }\n }\n return Promise.resolve(result);\n };\n QueryManager.prototype.markMutationOptimistic = function (optimisticResponse, mutation) {\n var _this = this;\n var data = typeof optimisticResponse === \"function\" ? optimisticResponse(mutation.variables, {\n IGNORE: IGNORE\n }) : optimisticResponse;\n if (data === IGNORE) {\n return false;\n }\n this.cache.recordOptimisticTransaction(function (cache) {\n try {\n _this.markMutationResult(__assign(__assign({}, mutation), {\n result: {\n data: data\n }\n }), cache);\n } catch (error) {\n globalThis.__DEV__ !== false && invariant.error(error);\n }\n }, mutation.mutationId);\n return true;\n };\n QueryManager.prototype.fetchQuery = function (queryId, options, networkStatus) {\n return this.fetchConcastWithInfo(queryId, options, networkStatus).concast.promise;\n };\n QueryManager.prototype.getQueryStore = function () {\n var store = Object.create(null);\n this.queries.forEach(function (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 QueryManager.prototype.resetErrors = function (queryId) {\n var queryInfo = this.queries.get(queryId);\n if (queryInfo) {\n queryInfo.networkError = undefined;\n queryInfo.graphQLErrors = [];\n }\n };\n QueryManager.prototype.transform = function (document) {\n return this.documentTransform.transformDocument(document);\n };\n QueryManager.prototype.getDocumentInfo = function (document) {\n var transformCache = this.transformCache;\n if (!transformCache.has(document)) {\n var cacheEntry = {\n // TODO These three calls (hasClientExports, shouldForceResolvers, and\n // usesNonreactiveDirective) are performing independent full traversals\n // of the transformed document. We should consider merging these\n // traversals into a single pass in the future, though the work is\n // cached after the first time.\n hasClientExports: hasClientExports(document),\n hasForcedResolvers: this.localState.shouldForceResolvers(document),\n hasNonreactiveDirective: hasDirectives([\"nonreactive\"], document),\n nonReactiveQuery: addNonReactiveToNamedFragments(document),\n clientQuery: this.localState.clientQuery(document),\n serverQuery: removeDirectivesFromDocument([{\n name: \"client\",\n remove: true\n }, {\n name: \"connection\"\n }, {\n name: \"nonreactive\"\n }, {\n name: \"unmask\"\n }], document),\n defaultVars: getDefaultValues(getOperationDefinition(document)),\n // Transform any mutation or subscription operations to query operations\n // so we can read/write them from/to the cache.\n asQuery: __assign(__assign({}, document), {\n definitions: document.definitions.map(function (def) {\n if (def.kind === \"OperationDefinition\" && def.operation !== \"query\") {\n return __assign(__assign({}, def), {\n operation: \"query\"\n });\n }\n return def;\n })\n })\n };\n transformCache.set(document, cacheEntry);\n }\n return transformCache.get(document);\n };\n QueryManager.prototype.getVariables = function (document, variables) {\n return __assign(__assign({}, this.getDocumentInfo(document).defaultVars), variables);\n };\n QueryManager.prototype.watchQuery = function (options) {\n var query = this.transform(options.query);\n // assign variable default values if supplied\n // NOTE: We don't modify options.query here with the transformed query to\n // ensure observable.options.query is set to the raw untransformed query.\n options = __assign(__assign({}, options), {\n variables: this.getVariables(query, options.variables)\n });\n if (typeof options.notifyOnNetworkStatusChange === \"undefined\") {\n options.notifyOnNetworkStatusChange = false;\n }\n var queryInfo = new QueryInfo(this);\n var observable = new ObservableQuery({\n queryManager: this,\n queryInfo: queryInfo,\n options: options\n });\n observable[\"lastQuery\"] = query;\n this.queries.set(observable.queryId, queryInfo);\n // We give queryInfo the transformed query to ensure the first cache diff\n // uses the transformed query instead of the raw query\n queryInfo.init({\n document: query,\n observableQuery: observable,\n variables: observable.variables\n });\n return observable;\n };\n QueryManager.prototype.query = function (options, queryId) {\n var _this = this;\n if (queryId === void 0) {\n queryId = this.generateQueryId();\n }\n invariant(options.query, 30);\n invariant(options.query.kind === \"Document\", 31);\n invariant(!options.returnPartialData, 32);\n invariant(!options.pollInterval, 33);\n var query = this.transform(options.query);\n return this.fetchQuery(queryId, __assign(__assign({}, options), {\n query: query\n })).then(function (result) {\n return result && __assign(__assign({}, result), {\n data: _this.maskOperation({\n document: query,\n data: result.data,\n fetchPolicy: options.fetchPolicy,\n id: queryId\n })\n });\n }).finally(function () {\n return _this.stopQuery(queryId);\n });\n };\n QueryManager.prototype.generateQueryId = function () {\n return String(this.queryIdCounter++);\n };\n QueryManager.prototype.generateRequestId = function () {\n return this.requestIdCounter++;\n };\n QueryManager.prototype.generateMutationId = function () {\n return String(this.mutationIdCounter++);\n };\n QueryManager.prototype.stopQueryInStore = function (queryId) {\n this.stopQueryInStoreNoBroadcast(queryId);\n this.broadcastQueries();\n };\n QueryManager.prototype.stopQueryInStoreNoBroadcast = function (queryId) {\n var queryInfo = this.queries.get(queryId);\n if (queryInfo) queryInfo.stop();\n };\n QueryManager.prototype.clearStore = function (options) {\n if (options === void 0) {\n options = {\n discardWatches: true\n };\n }\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(newInvariantError(34));\n this.queries.forEach(function (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 if (this.mutationStore) {\n this.mutationStore = Object.create(null);\n }\n // begin removing data from the store\n return this.cache.reset(options);\n };\n QueryManager.prototype.getObservableQueries = function (include) {\n var _this = this;\n if (include === void 0) {\n include = \"active\";\n }\n var queries = new Map();\n var queryNames = new Map();\n var queryNamesAndQueryStrings = new Map();\n var legacyQueryOptions = new Set();\n if (Array.isArray(include)) {\n include.forEach(function (desc) {\n if (typeof desc === \"string\") {\n queryNames.set(desc, desc);\n queryNamesAndQueryStrings.set(desc, false);\n } else if (isDocumentNode(desc)) {\n var queryString = print(_this.transform(desc));\n queryNames.set(queryString, getOperationName(desc));\n queryNamesAndQueryStrings.set(queryString, false);\n } else if (isNonNullObject(desc) && desc.query) {\n legacyQueryOptions.add(desc);\n }\n });\n }\n this.queries.forEach(function (_a, queryId) {\n var oq = _a.observableQuery,\n document = _a.document;\n if (oq) {\n if (include === \"all\") {\n queries.set(queryId, oq);\n return;\n }\n var queryName = oq.queryName,\n fetchPolicy = oq.options.fetchPolicy;\n if (fetchPolicy === \"standby\" || include === \"active\" && !oq.hasObservers()) {\n return;\n }\n if (include === \"active\" || queryName && queryNamesAndQueryStrings.has(queryName) || document && queryNamesAndQueryStrings.has(print(document))) {\n queries.set(queryId, oq);\n if (queryName) queryNamesAndQueryStrings.set(queryName, true);\n if (document) queryNamesAndQueryStrings.set(print(document), true);\n }\n }\n });\n if (legacyQueryOptions.size) {\n legacyQueryOptions.forEach(function (options) {\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 var queryId = makeUniqueId(\"legacyOneTimeQuery\");\n var queryInfo = _this.getQuery(queryId).init({\n document: options.query,\n variables: options.variables\n });\n var oq = new ObservableQuery({\n queryManager: _this,\n queryInfo: queryInfo,\n options: __assign(__assign({}, options), {\n fetchPolicy: \"network-only\"\n })\n });\n invariant(oq.queryId === queryId);\n queryInfo.setObservableQuery(oq);\n queries.set(queryId, oq);\n });\n }\n if (globalThis.__DEV__ !== false && queryNamesAndQueryStrings.size) {\n queryNamesAndQueryStrings.forEach(function (included, nameOrQueryString) {\n if (!included) {\n var queryName = queryNames.get(nameOrQueryString);\n if (queryName) {\n globalThis.__DEV__ !== false && invariant.warn(35, queryName);\n } else {\n globalThis.__DEV__ !== false && invariant.warn(36);\n }\n }\n });\n }\n return queries;\n };\n QueryManager.prototype.reFetchObservableQueries = function (includeStandby) {\n var _this = this;\n if (includeStandby === void 0) {\n includeStandby = false;\n }\n var observableQueryPromises = [];\n this.getObservableQueries(includeStandby ? \"all\" : \"active\").forEach(function (observableQuery, queryId) {\n var fetchPolicy = observableQuery.options.fetchPolicy;\n observableQuery.resetLastResults();\n if (includeStandby || fetchPolicy !== \"standby\" && fetchPolicy !== \"cache-only\") {\n observableQueryPromises.push(observableQuery.refetch());\n }\n _this.getQuery(queryId).setDiff(null);\n });\n this.broadcastQueries();\n return Promise.all(observableQueryPromises);\n };\n QueryManager.prototype.setObservableQuery = function (observableQuery) {\n this.getQuery(observableQuery.queryId).setObservableQuery(observableQuery);\n };\n QueryManager.prototype.startGraphQLSubscription = function (options) {\n var _this = this;\n var query = options.query,\n variables = options.variables;\n var fetchPolicy = options.fetchPolicy,\n _a = options.errorPolicy,\n errorPolicy = _a === void 0 ? \"none\" : _a,\n _b = options.context,\n context = _b === void 0 ? {} : _b,\n _c = options.extensions,\n extensions = _c === void 0 ? {} : _c;\n query = this.transform(query);\n variables = this.getVariables(query, variables);\n var makeObservable = function (variables) {\n return _this.getObservableFromLink(query, context, variables, extensions).map(function (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: query,\n result: result.data,\n dataId: \"ROOT_SUBSCRIPTION\",\n variables: variables\n });\n }\n _this.broadcastQueries();\n }\n var hasErrors = graphQLResultHasError(result);\n var hasProtocolErrors = graphQLResultHasProtocolErrors(result);\n if (hasErrors || hasProtocolErrors) {\n var errors = {};\n if (hasErrors) {\n errors.graphQLErrors = result.errors;\n }\n if (hasProtocolErrors) {\n errors.protocolErrors = result.extensions[PROTOCOL_ERRORS_SYMBOL];\n }\n // `errorPolicy` is a mechanism for handling GraphQL errors, according\n // to our documentation, so we throw protocol errors regardless of the\n // set error policy.\n if (errorPolicy === \"none\" || hasProtocolErrors) {\n throw new ApolloError(errors);\n }\n }\n if (errorPolicy === \"ignore\") {\n delete result.errors;\n }\n return result;\n });\n };\n if (this.getDocumentInfo(query).hasClientExports) {\n var observablePromise_1 = this.localState.addExportedVariables(query, variables, context).then(makeObservable);\n return new Observable(function (observer) {\n var sub = null;\n observablePromise_1.then(function (observable) {\n return sub = observable.subscribe(observer);\n }, observer.error);\n return function () {\n return sub && sub.unsubscribe();\n };\n });\n }\n return makeObservable(variables);\n };\n QueryManager.prototype.stopQuery = function (queryId) {\n this.stopQueryNoBroadcast(queryId);\n this.broadcastQueries();\n };\n QueryManager.prototype.stopQueryNoBroadcast = function (queryId) {\n this.stopQueryInStoreNoBroadcast(queryId);\n this.removeQuery(queryId);\n };\n QueryManager.prototype.removeQuery = function (queryId) {\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 if (this.queries.has(queryId)) {\n this.getQuery(queryId).stop();\n this.queries.delete(queryId);\n }\n };\n QueryManager.prototype.broadcastQueries = function () {\n if (this.onBroadcast) this.onBroadcast();\n this.queries.forEach(function (info) {\n return info.notify();\n });\n };\n QueryManager.prototype.getLocalState = function () {\n return this.localState;\n };\n QueryManager.prototype.getObservableFromLink = function (query, context, variables, extensions,\n // Prefer context.queryDeduplication if specified.\n deduplication) {\n var _this = this;\n var _a;\n if (deduplication === void 0) {\n deduplication = (_a = context === null || context === void 0 ? void 0 : context.queryDeduplication) !== null && _a !== void 0 ? _a : this.queryDeduplication;\n }\n var observable;\n var _b = this.getDocumentInfo(query),\n serverQuery = _b.serverQuery,\n clientQuery = _b.clientQuery;\n if (serverQuery) {\n var _c = this,\n inFlightLinkObservables_1 = _c.inFlightLinkObservables,\n link = _c.link;\n var operation = {\n query: serverQuery,\n variables: variables,\n operationName: getOperationName(serverQuery) || void 0,\n context: this.prepareContext(__assign(__assign({}, context), {\n forceFetch: !deduplication\n })),\n extensions: extensions\n };\n context = operation.context;\n if (deduplication) {\n var printedServerQuery_1 = print(serverQuery);\n var varJson_1 = canonicalStringify(variables);\n var entry = inFlightLinkObservables_1.lookup(printedServerQuery_1, varJson_1);\n observable = entry.observable;\n if (!observable) {\n var concast = new Concast([execute(link, operation)]);\n observable = entry.observable = concast;\n concast.beforeNext(function () {\n inFlightLinkObservables_1.remove(printedServerQuery_1, varJson_1);\n });\n }\n } else {\n observable = new Concast([execute(link, operation)]);\n }\n } else {\n observable = new Concast([Observable.of({\n data: {}\n })]);\n context = this.prepareContext(context);\n }\n if (clientQuery) {\n observable = asyncMap(observable, function (result) {\n return _this.localState.runResolvers({\n document: clientQuery,\n remoteResult: result,\n context: context,\n variables: variables\n });\n });\n }\n return observable;\n };\n QueryManager.prototype.getResultsFromLink = function (queryInfo, cacheWriteBehavior, options) {\n var requestId = queryInfo.lastRequestId = this.generateRequestId();\n // Performing transformForLink here gives this.cache a chance to fill in\n // missing fragment definitions (for example) before sending this document\n // through the link chain.\n var linkDocument = this.cache.transformForLink(options.query);\n return asyncMap(this.getObservableFromLink(linkDocument, options.context, options.variables), function (result) {\n var graphQLErrors = getGraphQLErrorsFromResult(result);\n var hasErrors = graphQLErrors.length > 0;\n var errorPolicy = options.errorPolicy;\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 && errorPolicy === \"none\") {\n // Throwing here effectively calls observer.error.\n throw queryInfo.markError(new ApolloError({\n graphQLErrors: graphQLErrors\n }));\n }\n // Use linkDocument rather than queryInfo.document so the\n // operation/fragments used to write the result are the same as the\n // ones used to obtain it from the link.\n queryInfo.markResult(result, linkDocument, options, cacheWriteBehavior);\n queryInfo.markReady();\n }\n var aqr = {\n data: result.data,\n loading: false,\n networkStatus: NetworkStatus.ready\n };\n // In the case we start multiple network requests simulatenously, we\n // want to ensure we properly set `data` if we're reporting on an old\n // result which will not be caught by the conditional above that ends up\n // throwing the markError result.\n if (hasErrors && errorPolicy === \"none\") {\n aqr.data = void 0;\n }\n if (hasErrors && errorPolicy !== \"ignore\") {\n aqr.errors = graphQLErrors;\n aqr.networkStatus = NetworkStatus.error;\n }\n return aqr;\n }, function (networkError) {\n var error = isApolloError(networkError) ? networkError : new ApolloError({\n networkError: networkError\n });\n // Avoid storing errors from older interrupted queries.\n if (requestId >= queryInfo.lastRequestId) {\n queryInfo.markError(error);\n }\n throw error;\n });\n };\n QueryManager.prototype.fetchConcastWithInfo = function (queryId, options,\n // The initial networkStatus for this fetch, most often\n // NetworkStatus.loading, but also possibly fetchMore, poll, refetch,\n // or setVariables.\n networkStatus, query) {\n var _this = this;\n if (networkStatus === void 0) {\n networkStatus = NetworkStatus.loading;\n }\n if (query === void 0) {\n query = options.query;\n }\n var variables = this.getVariables(query, options.variables);\n var queryInfo = this.getQuery(queryId);\n var defaults = this.defaultOptions.watchQuery;\n var _a = options.fetchPolicy,\n fetchPolicy = _a === void 0 ? defaults && defaults.fetchPolicy || \"cache-first\" : _a,\n _b = options.errorPolicy,\n errorPolicy = _b === void 0 ? defaults && defaults.errorPolicy || \"none\" : _b,\n _c = options.returnPartialData,\n returnPartialData = _c === void 0 ? false : _c,\n _d = options.notifyOnNetworkStatusChange,\n notifyOnNetworkStatusChange = _d === void 0 ? false : _d,\n _e = options.context,\n context = _e === void 0 ? {} : _e;\n var normalized = Object.assign({}, options, {\n query: query,\n variables: variables,\n fetchPolicy: fetchPolicy,\n errorPolicy: errorPolicy,\n returnPartialData: returnPartialData,\n notifyOnNetworkStatusChange: notifyOnNetworkStatusChange,\n context: context\n });\n var fromVariables = function (variables) {\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 var sourcesWithInfo = _this.fetchQueryByPolicy(queryInfo, normalized, networkStatus);\n if (\n // If we're in standby, postpone advancing options.fetchPolicy using\n // applyNextFetchPolicy.\n normalized.fetchPolicy !== \"standby\" &&\n // The \"standby\" policy currently returns [] from fetchQueryByPolicy, so\n // this is another way to detect when nothing was done/fetched.\n sourcesWithInfo.sources.length > 0 && queryInfo.observableQuery) {\n queryInfo.observableQuery[\"applyNextFetchPolicy\"](\"after-fetch\", options);\n }\n return sourcesWithInfo;\n };\n // This cancel function needs to be set before the concast is created,\n // in case concast creation synchronously cancels the request.\n var cleanupCancelFn = function () {\n return _this.fetchCancelFns.delete(queryId);\n };\n this.fetchCancelFns.set(queryId, function (reason) {\n cleanupCancelFn();\n // This delay ensures the concast variable has been initialized.\n setTimeout(function () {\n return concast.cancel(reason);\n });\n });\n var concast, containsDataFromLink;\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 if (this.getDocumentInfo(normalized.query).hasClientExports) {\n concast = new Concast(this.localState.addExportedVariables(normalized.query, normalized.variables, normalized.context).then(fromVariables).then(function (sourcesWithInfo) {\n return sourcesWithInfo.sources;\n }));\n // there is just no way we can synchronously get the *right* value here,\n // so we will assume `true`, which is the behaviour before the bug fix in\n // #10597. This means that bug is not fixed in that case, and is probably\n // un-fixable with reasonable effort for the edge case of @export as\n // directives.\n containsDataFromLink = true;\n } else {\n var sourcesWithInfo = fromVariables(normalized.variables);\n containsDataFromLink = sourcesWithInfo.fromLink;\n concast = new Concast(sourcesWithInfo.sources);\n }\n concast.promise.then(cleanupCancelFn, cleanupCancelFn);\n return {\n concast: concast,\n fromLink: containsDataFromLink\n };\n };\n QueryManager.prototype.refetchQueries = function (_a) {\n var _this = this;\n var updateCache = _a.updateCache,\n include = _a.include,\n _b = _a.optimistic,\n optimistic = _b === void 0 ? false : _b,\n _c = _a.removeOptimistic,\n removeOptimistic = _c === void 0 ? optimistic ? makeUniqueId(\"refetchQueries\") : void 0 : _c,\n onQueryUpdated = _a.onQueryUpdated;\n var includedQueriesById = new Map();\n if (include) {\n this.getObservableQueries(include).forEach(function (oq, queryId) {\n includedQueriesById.set(queryId, {\n oq: oq,\n lastDiff: _this.getQuery(queryId).getDiff()\n });\n });\n }\n var results = new Map();\n if (updateCache) {\n this.cache.batch({\n update: updateCache,\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 // 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: removeOptimistic,\n onWatchUpdated: function (watch, diff, lastDiff) {\n var oq = watch.watcher instanceof QueryInfo && watch.watcher.observableQuery;\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 var result = onQueryUpdated(oq, diff, lastDiff);\n if (result === true) {\n // The onQueryUpdated function requested the default refetching\n // behavior by returning true.\n result = oq.refetch();\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);\n }\n // Allow the default cache broadcast to happen, except when\n // onQueryUpdated returns false.\n return result;\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, {\n oq: oq,\n lastDiff: lastDiff,\n diff: diff\n });\n }\n }\n }\n });\n }\n if (includedQueriesById.size) {\n includedQueriesById.forEach(function (_a, queryId) {\n var oq = _a.oq,\n lastDiff = _a.lastDiff,\n diff = _a.diff;\n var result;\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 var 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 // Otherwise, we fall back to refetching.\n if (!onQueryUpdated || result === true) {\n result = oq.refetch();\n }\n if (result !== false) {\n results.set(oq, result);\n }\n if (queryId.indexOf(\"legacyOneTimeQuery\") >= 0) {\n _this.stopQueryNoBroadcast(queryId);\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 return results;\n };\n QueryManager.prototype.maskOperation = function (options) {\n var _a, _b, _c;\n var document = options.document,\n data = options.data;\n if (globalThis.__DEV__ !== false) {\n var fetchPolicy = options.fetchPolicy,\n id = options.id;\n var operationType = (_a = getOperationDefinition(document)) === null || _a === void 0 ? void 0 : _a.operation;\n var operationId = ((_b = operationType === null || operationType === void 0 ? void 0 : operationType[0]) !== null && _b !== void 0 ? _b : \"o\") + id;\n if (this.dataMasking && fetchPolicy === \"no-cache\" && !isFullyUnmaskedOperation(document) && !this.noCacheWarningsByQueryId.has(operationId)) {\n this.noCacheWarningsByQueryId.add(operationId);\n globalThis.__DEV__ !== false && invariant.warn(37, (_c = getOperationName(document)) !== null && _c !== void 0 ? _c : \"Unnamed \".concat(operationType !== null && operationType !== void 0 ? operationType : \"operation\"));\n }\n }\n return this.dataMasking ? maskOperation(data, document, this.cache) : data;\n };\n QueryManager.prototype.maskFragment = function (options) {\n var data = options.data,\n fragment = options.fragment,\n fragmentName = options.fragmentName;\n return this.dataMasking ? maskFragment(data, fragment, this.cache, fragmentName) : data;\n };\n QueryManager.prototype.fetchQueryByPolicy = function (queryInfo, _a,\n // The initial networkStatus for this fetch, most often\n // NetworkStatus.loading, but also possibly fetchMore, poll, refetch,\n // or setVariables.\n networkStatus) {\n var _this = this;\n var query = _a.query,\n variables = _a.variables,\n fetchPolicy = _a.fetchPolicy,\n refetchWritePolicy = _a.refetchWritePolicy,\n errorPolicy = _a.errorPolicy,\n returnPartialData = _a.returnPartialData,\n context = _a.context,\n notifyOnNetworkStatusChange = _a.notifyOnNetworkStatusChange;\n var oldNetworkStatus = queryInfo.networkStatus;\n queryInfo.init({\n document: query,\n variables: variables,\n networkStatus: networkStatus\n });\n var readCache = function () {\n return queryInfo.getDiff();\n };\n var resultsFromCache = function (diff, networkStatus) {\n if (networkStatus === void 0) {\n networkStatus = queryInfo.networkStatus || NetworkStatus.loading;\n }\n var data = diff.result;\n if (globalThis.__DEV__ !== false && !returnPartialData && !equal(data, {})) {\n logMissingFieldErrors(diff.missing);\n }\n var fromData = function (data) {\n return Observable.of(__assign({\n data: data,\n loading: isNetworkRequestInFlight(networkStatus),\n networkStatus: networkStatus\n }, diff.complete ? null : {\n partial: true\n }));\n };\n if (data && _this.getDocumentInfo(query).hasForcedResolvers) {\n return _this.localState.runResolvers({\n document: query,\n remoteResult: {\n data: data\n },\n context: context,\n variables: variables,\n onlyRunForcedResolvers: true\n }).then(function (resolved) {\n return fromData(resolved.data || void 0);\n });\n }\n // Resolves https://github.com/apollographql/apollo-client/issues/10317.\n // If errorPolicy is 'none' and notifyOnNetworkStatusChange is true,\n // data was incorrectly returned from the cache on refetch:\n // if diff.missing exists, we should not return cache data.\n if (errorPolicy === \"none\" && networkStatus === NetworkStatus.refetch && Array.isArray(diff.missing)) {\n return fromData(void 0);\n }\n return fromData(data);\n };\n var cacheWriteBehavior = fetchPolicy === \"no-cache\" ? 0 /* 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 && refetchWritePolicy !== \"merge\" ? 1 /* CacheWriteBehavior.OVERWRITE */ : 2 /* CacheWriteBehavior.MERGE */;\n var resultsFromLink = function () {\n return _this.getResultsFromLink(queryInfo, cacheWriteBehavior, {\n query: query,\n variables: variables,\n context: context,\n fetchPolicy: fetchPolicy,\n errorPolicy: errorPolicy\n });\n };\n var shouldNotify = notifyOnNetworkStatusChange && typeof oldNetworkStatus === \"number\" && oldNetworkStatus !== networkStatus && isNetworkRequestInFlight(networkStatus);\n switch (fetchPolicy) {\n default:\n case \"cache-first\":\n {\n var diff = readCache();\n if (diff.complete) {\n return {\n fromLink: false,\n sources: [resultsFromCache(diff, queryInfo.markReady())]\n };\n }\n if (returnPartialData || shouldNotify) {\n return {\n fromLink: true,\n sources: [resultsFromCache(diff), resultsFromLink()]\n };\n }\n return {\n fromLink: true,\n sources: [resultsFromLink()]\n };\n }\n case \"cache-and-network\":\n {\n var diff = readCache();\n if (diff.complete || returnPartialData || shouldNotify) {\n return {\n fromLink: true,\n sources: [resultsFromCache(diff), resultsFromLink()]\n };\n }\n return {\n fromLink: true,\n sources: [resultsFromLink()]\n };\n }\n case \"cache-only\":\n return {\n fromLink: false,\n sources: [resultsFromCache(readCache(), queryInfo.markReady())]\n };\n case \"network-only\":\n if (shouldNotify) {\n return {\n fromLink: true,\n sources: [resultsFromCache(readCache()), resultsFromLink()]\n };\n }\n return {\n fromLink: true,\n sources: [resultsFromLink()]\n };\n case \"no-cache\":\n if (shouldNotify) {\n return {\n fromLink: true,\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 sources: [resultsFromCache(queryInfo.getDiff()), resultsFromLink()]\n };\n }\n return {\n fromLink: true,\n sources: [resultsFromLink()]\n };\n case \"standby\":\n return {\n fromLink: false,\n sources: []\n };\n }\n };\n QueryManager.prototype.getQuery = function (queryId) {\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 QueryManager.prototype.prepareContext = function (context) {\n if (context === void 0) {\n context = {};\n }\n var newContext = this.localState.prepareContext(context);\n return __assign(__assign(__assign({}, this.defaultContext), newContext), {\n clientAwareness: this.clientAwareness\n });\n };\n return QueryManager;\n}();\nexport { QueryManager };","import { invariant } from \"../utilities/globals/index.js\";\nimport { createFragmentMap, getFragmentDefinitions, getOperationDefinition } from \"../utilities/index.js\";\nimport { maskDefinition } from \"./maskDefinition.js\";\nimport { MapImpl, SetImpl, warnOnImproperCacheImplementation } from \"./utils.js\";\n/** @internal */\nexport function maskOperation(data, document, cache) {\n var _a;\n if (!cache.fragmentMatches) {\n if (globalThis.__DEV__ !== false) {\n warnOnImproperCacheImplementation();\n }\n return data;\n }\n var definition = getOperationDefinition(document);\n invariant(definition, 51);\n if (data == null) {\n // Maintain the original `null` or `undefined` value\n return data;\n }\n return maskDefinition(data, definition.selectionSet, {\n operationType: definition.operation,\n operationName: (_a = definition.name) === null || _a === void 0 ? void 0 : _a.value,\n fragmentMap: createFragmentMap(getFragmentDefinitions(document)),\n cache: cache,\n mutableTargets: new MapImpl(),\n knownChanged: new SetImpl()\n });\n}","import { Kind } from \"./kinds.mjs\";\nexport function isDefinitionNode(node) {\n return isExecutableDefinitionNode(node) || isTypeSystemDefinitionNode(node) || isTypeSystemExtensionNode(node);\n}\nexport function isExecutableDefinitionNode(node) {\n return node.kind === Kind.OPERATION_DEFINITION || node.kind === Kind.FRAGMENT_DEFINITION;\n}\nexport function isSelectionNode(node) {\n return node.kind === Kind.FIELD || node.kind === Kind.FRAGMENT_SPREAD || node.kind === Kind.INLINE_FRAGMENT;\n}\nexport function isValueNode(node) {\n return node.kind === Kind.VARIABLE || node.kind === Kind.INT || node.kind === Kind.FLOAT || node.kind === Kind.STRING || node.kind === Kind.BOOLEAN || node.kind === Kind.NULL || node.kind === Kind.ENUM || node.kind === Kind.LIST || node.kind === Kind.OBJECT;\n}\nexport function isTypeNode(node) {\n return node.kind === Kind.NAMED_TYPE || node.kind === Kind.LIST_TYPE || node.kind === Kind.NON_NULL_TYPE;\n}\nexport function isTypeSystemDefinitionNode(node) {\n return node.kind === Kind.SCHEMA_DEFINITION || isTypeDefinitionNode(node) || node.kind === Kind.DIRECTIVE_DEFINITION;\n}\nexport function isTypeDefinitionNode(node) {\n return node.kind === Kind.SCALAR_TYPE_DEFINITION || node.kind === Kind.OBJECT_TYPE_DEFINITION || node.kind === Kind.INTERFACE_TYPE_DEFINITION || node.kind === Kind.UNION_TYPE_DEFINITION || node.kind === Kind.ENUM_TYPE_DEFINITION || node.kind === Kind.INPUT_OBJECT_TYPE_DEFINITION;\n}\nexport function isTypeSystemExtensionNode(node) {\n return node.kind === Kind.SCHEMA_EXTENSION || isTypeExtensionNode(node);\n}\nexport function isTypeExtensionNode(node) {\n return node.kind === Kind.SCALAR_TYPE_EXTENSION || node.kind === Kind.OBJECT_TYPE_EXTENSION || node.kind === Kind.INTERFACE_TYPE_EXTENSION || node.kind === Kind.UNION_TYPE_EXTENSION || node.kind === Kind.ENUM_TYPE_EXTENSION || node.kind === Kind.INPUT_OBJECT_TYPE_EXTENSION;\n}","import { __assign, __awaiter, __generator } from \"tslib\";\nimport { invariant } from \"../utilities/globals/index.js\";\nimport { visit, BREAK, isSelectionNode } from \"graphql\";\nimport { argumentsObjectFromField, buildQueryFromSelectionSet, createFragmentMap, getFragmentDefinitions, getMainDefinition, hasDirectives, isField, isInlineFragment, mergeDeep, mergeDeepArray, removeClientSetsFromDocument, resultKeyNameFromField, shouldInclude } from \"../utilities/index.js\";\nimport { cacheSlot } from \"../cache/index.js\";\nvar LocalState = /** @class */function () {\n function LocalState(_a) {\n var cache = _a.cache,\n client = _a.client,\n resolvers = _a.resolvers,\n fragmentMatcher = _a.fragmentMatcher;\n this.selectionsToResolveCache = new WeakMap();\n this.cache = cache;\n if (client) {\n this.client = client;\n }\n if (resolvers) {\n this.addResolvers(resolvers);\n }\n if (fragmentMatcher) {\n this.setFragmentMatcher(fragmentMatcher);\n }\n }\n LocalState.prototype.addResolvers = function (resolvers) {\n var _this = this;\n this.resolvers = this.resolvers || {};\n if (Array.isArray(resolvers)) {\n resolvers.forEach(function (resolverGroup) {\n _this.resolvers = mergeDeep(_this.resolvers, resolverGroup);\n });\n } else {\n this.resolvers = mergeDeep(this.resolvers, resolvers);\n }\n };\n LocalState.prototype.setResolvers = function (resolvers) {\n this.resolvers = {};\n this.addResolvers(resolvers);\n };\n LocalState.prototype.getResolvers = function () {\n return this.resolvers || {};\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 LocalState.prototype.runResolvers = function (_a) {\n return __awaiter(this, arguments, void 0, function (_b) {\n var document = _b.document,\n remoteResult = _b.remoteResult,\n context = _b.context,\n variables = _b.variables,\n _c = _b.onlyRunForcedResolvers,\n onlyRunForcedResolvers = _c === void 0 ? false : _c;\n return __generator(this, function (_d) {\n if (document) {\n return [2 /*return*/, this.resolveDocument(document, remoteResult.data, context, variables, this.fragmentMatcher, onlyRunForcedResolvers).then(function (localResult) {\n return __assign(__assign({}, remoteResult), {\n data: localResult.result\n });\n })];\n }\n return [2 /*return*/, remoteResult];\n });\n });\n };\n LocalState.prototype.setFragmentMatcher = function (fragmentMatcher) {\n this.fragmentMatcher = fragmentMatcher;\n };\n LocalState.prototype.getFragmentMatcher = function () {\n return this.fragmentMatcher;\n };\n // Client queries contain everything in the incoming document (if a @client\n // directive is found).\n LocalState.prototype.clientQuery = function (document) {\n if (hasDirectives([\"client\"], document)) {\n if (this.resolvers) {\n return document;\n }\n }\n return null;\n };\n // Server queries are stripped of all @client based selection sets.\n LocalState.prototype.serverQuery = function (document) {\n return removeClientSetsFromDocument(document);\n };\n LocalState.prototype.prepareContext = function (context) {\n var cache = this.cache;\n return __assign(__assign({}, context), {\n cache: cache,\n // Getting an entry's cache key is useful for local state resolvers.\n getCacheKey: function (obj) {\n return cache.identify(obj);\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 LocalState.prototype.addExportedVariables = function (document_1) {\n return __awaiter(this, arguments, void 0, function (document, variables, context) {\n if (variables === void 0) {\n variables = {};\n }\n if (context === void 0) {\n context = {};\n }\n return __generator(this, function (_a) {\n if (document) {\n return [2 /*return*/, this.resolveDocument(document, this.buildRootValueFromCache(document, variables) || {}, this.prepareContext(context), variables).then(function (data) {\n return __assign(__assign({}, variables), data.exportedVariables);\n })];\n }\n return [2 /*return*/, __assign({}, variables)];\n });\n });\n };\n LocalState.prototype.shouldForceResolvers = function (document) {\n var forceResolvers = false;\n visit(document, {\n Directive: {\n enter: function (node) {\n if (node.name.value === \"client\" && node.arguments) {\n forceResolvers = node.arguments.some(function (arg) {\n return arg.name.value === \"always\" && arg.value.kind === \"BooleanValue\" && arg.value.value === true;\n });\n if (forceResolvers) {\n return BREAK;\n }\n }\n }\n }\n });\n return forceResolvers;\n };\n // Query the cache and return matching data.\n LocalState.prototype.buildRootValueFromCache = function (document, variables) {\n return this.cache.diff({\n query: buildQueryFromSelectionSet(document),\n variables: variables,\n returnPartialData: true,\n optimistic: false\n }).result;\n };\n LocalState.prototype.resolveDocument = function (document_1, rootValue_1) {\n return __awaiter(this, arguments, void 0, function (document, rootValue, context, variables, fragmentMatcher, onlyRunForcedResolvers) {\n var mainDefinition, fragments, fragmentMap, selectionsToResolve, definitionOperation, defaultOperationType, _a, cache, client, execContext, isClientFieldDescendant;\n if (context === void 0) {\n context = {};\n }\n if (variables === void 0) {\n variables = {};\n }\n if (fragmentMatcher === void 0) {\n fragmentMatcher = function () {\n return true;\n };\n }\n if (onlyRunForcedResolvers === void 0) {\n onlyRunForcedResolvers = false;\n }\n return __generator(this, function (_b) {\n mainDefinition = getMainDefinition(document);\n fragments = getFragmentDefinitions(document);\n fragmentMap = createFragmentMap(fragments);\n selectionsToResolve = this.collectSelectionsToResolve(mainDefinition, fragmentMap);\n definitionOperation = mainDefinition.operation;\n defaultOperationType = definitionOperation ? definitionOperation.charAt(0).toUpperCase() + definitionOperation.slice(1) : \"Query\";\n _a = this, cache = _a.cache, client = _a.client;\n execContext = {\n fragmentMap: fragmentMap,\n context: __assign(__assign({}, context), {\n cache: cache,\n client: client\n }),\n variables: variables,\n fragmentMatcher: fragmentMatcher,\n defaultOperationType: defaultOperationType,\n exportedVariables: {},\n selectionsToResolve: selectionsToResolve,\n onlyRunForcedResolvers: onlyRunForcedResolvers\n };\n isClientFieldDescendant = false;\n return [2 /*return*/, this.resolveSelectionSet(mainDefinition.selectionSet, isClientFieldDescendant, rootValue, execContext).then(function (result) {\n return {\n result: result,\n exportedVariables: execContext.exportedVariables\n };\n })];\n });\n });\n };\n LocalState.prototype.resolveSelectionSet = function (selectionSet, isClientFieldDescendant, rootValue, execContext) {\n return __awaiter(this, void 0, void 0, function () {\n var fragmentMap, context, variables, resultsToMerge, execute;\n var _this = this;\n return __generator(this, function (_a) {\n fragmentMap = execContext.fragmentMap, context = execContext.context, variables = execContext.variables;\n resultsToMerge = [rootValue];\n execute = function (selection) {\n return __awaiter(_this, void 0, void 0, function () {\n var fragment, typeCondition;\n return __generator(this, function (_a) {\n if (!isClientFieldDescendant && !execContext.selectionsToResolve.has(selection)) {\n // Skip selections without @client directives\n // (still processing if one of the ancestors or one of the child fields has @client directive)\n return [2 /*return*/];\n }\n\n if (!shouldInclude(selection, variables)) {\n // Skip this entirely.\n return [2 /*return*/];\n }\n\n if (isField(selection)) {\n return [2 /*return*/, this.resolveField(selection, isClientFieldDescendant, rootValue, execContext).then(function (fieldResult) {\n var _a;\n if (typeof fieldResult !== \"undefined\") {\n resultsToMerge.push((_a = {}, _a[resultKeyNameFromField(selection)] = fieldResult, _a));\n }\n })];\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, 19, selection.name.value);\n }\n if (fragment && fragment.typeCondition) {\n typeCondition = fragment.typeCondition.name.value;\n if (execContext.fragmentMatcher(rootValue, typeCondition, context)) {\n return [2 /*return*/, this.resolveSelectionSet(fragment.selectionSet, isClientFieldDescendant, rootValue, execContext).then(function (fragmentResult) {\n resultsToMerge.push(fragmentResult);\n })];\n }\n }\n return [2 /*return*/];\n });\n });\n };\n\n return [2 /*return*/, Promise.all(selectionSet.selections.map(execute)).then(function () {\n return mergeDeepArray(resultsToMerge);\n })];\n });\n });\n };\n LocalState.prototype.resolveField = function (field, isClientFieldDescendant, rootValue, execContext) {\n return __awaiter(this, void 0, void 0, function () {\n var variables, fieldName, aliasedFieldName, aliasUsed, defaultResult, resultPromise, resolverType, resolverMap, resolve;\n var _this = this;\n return __generator(this, function (_a) {\n if (!rootValue) {\n return [2 /*return*/, null];\n }\n variables = execContext.variables;\n fieldName = field.name.value;\n aliasedFieldName = resultKeyNameFromField(field);\n aliasUsed = fieldName !== aliasedFieldName;\n defaultResult = rootValue[aliasedFieldName] || rootValue[fieldName];\n resultPromise = Promise.resolve(defaultResult);\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 (!execContext.onlyRunForcedResolvers || this.shouldForceResolvers(field)) {\n resolverType = rootValue.__typename || execContext.defaultOperationType;\n resolverMap = this.resolvers && this.resolvers[resolverType];\n if (resolverMap) {\n 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, [rootValue, argumentsObjectFromField(field, variables), execContext.context, {\n field: field,\n fragmentMap: execContext.fragmentMap\n }]));\n }\n }\n }\n return [2 /*return*/, resultPromise.then(function (result) {\n var _a, _b;\n if (result === void 0) {\n result = defaultResult;\n }\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(function (directive) {\n if (directive.name.value === \"export\" && directive.arguments) {\n directive.arguments.forEach(function (arg) {\n if (arg.name.value === \"as\" && arg.value.kind === \"StringValue\") {\n execContext.exportedVariables[arg.value.value] = result;\n }\n });\n }\n });\n }\n // Handle all scalar types here.\n if (!field.selectionSet) {\n return result;\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 var isClientField = (_b = (_a = field.directives) === null || _a === void 0 ? void 0 : _a.some(function (d) {\n return d.name.value === \"client\";\n })) !== null && _b !== void 0 ? _b : false;\n if (Array.isArray(result)) {\n return _this.resolveSubSelectedArray(field, isClientFieldDescendant || isClientField, result, execContext);\n }\n // Returned value is an object, and the query has a sub-selection. Recurse.\n if (field.selectionSet) {\n return _this.resolveSelectionSet(field.selectionSet, isClientFieldDescendant || isClientField, result, execContext);\n }\n })];\n });\n });\n };\n LocalState.prototype.resolveSubSelectedArray = function (field, isClientFieldDescendant, result, execContext) {\n var _this = this;\n return Promise.all(result.map(function (item) {\n if (item === null) {\n return null;\n }\n // This is a nested array, recurse.\n if (Array.isArray(item)) {\n return _this.resolveSubSelectedArray(field, isClientFieldDescendant, item, execContext);\n }\n // This is an object, run the selection set on it.\n if (field.selectionSet) {\n return _this.resolveSelectionSet(field.selectionSet, isClientFieldDescendant, item, execContext);\n }\n }));\n };\n // Collect selection nodes on paths from document root down to all @client directives.\n // This function takes into account transitive fragment spreads.\n // Complexity equals to a single `visit` over the full document.\n LocalState.prototype.collectSelectionsToResolve = function (mainDefinition, fragmentMap) {\n var isSingleASTNode = function (node) {\n return !Array.isArray(node);\n };\n var selectionsToResolveCache = this.selectionsToResolveCache;\n function collectByDefinition(definitionNode) {\n if (!selectionsToResolveCache.has(definitionNode)) {\n var matches_1 = new Set();\n selectionsToResolveCache.set(definitionNode, matches_1);\n visit(definitionNode, {\n Directive: function (node, _, __, ___, ancestors) {\n if (node.name.value === \"client\") {\n ancestors.forEach(function (node) {\n if (isSingleASTNode(node) && isSelectionNode(node)) {\n matches_1.add(node);\n }\n });\n }\n },\n FragmentSpread: function (spread, _, __, ___, ancestors) {\n var fragment = fragmentMap[spread.name.value];\n invariant(fragment, 20, spread.name.value);\n var fragmentSelections = collectByDefinition(fragment);\n if (fragmentSelections.size > 0) {\n // Fragment for this spread contains @client directive (either directly or transitively)\n // Collect selection nodes on paths from the root down to fields with the @client directive\n ancestors.forEach(function (node) {\n if (isSingleASTNode(node) && isSelectionNode(node)) {\n matches_1.add(node);\n }\n });\n matches_1.add(spread);\n fragmentSelections.forEach(function (selection) {\n matches_1.add(selection);\n });\n }\n }\n });\n }\n return selectionsToResolveCache.get(definitionNode);\n }\n return collectByDefinition(mainDefinition);\n };\n return LocalState;\n}();\nexport { LocalState };","import { __assign } from \"tslib\";\nimport { invariant, newInvariantError } from \"../utilities/globals/index.js\";\nimport { ApolloLink, execute } from \"../link/core/index.js\";\nimport { version } from \"../version.js\";\nimport { HttpLink } from \"../link/http/index.js\";\nimport { QueryManager } from \"./QueryManager.js\";\nimport { LocalState } from \"./LocalState.js\";\nvar hasSuggestedDevtools = false;\n// Though mergeOptions now resides in @apollo/client/utilities, it was\n// previously declared and exported from this module, and then reexported from\n// @apollo/client/core. Since we need to preserve that API anyway, the easiest\n// solution is to reexport mergeOptions where it was previously declared (here).\nimport { mergeOptions } from \"../utilities/index.js\";\nimport { getApolloClientMemoryInternals } from \"../utilities/caching/getMemoryInternals.js\";\nexport { mergeOptions };\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 an `ApolloLink` instance,\n * receive results from the server and cache the results in a store. It also delivers updates\n * to GraphQL queries through `Observable` instances.\n */\nvar ApolloClient = /** @class */function () {\n /**\n * Constructs an instance of `ApolloClient`.\n *\n * @example\n * ```js\n * import { ApolloClient, InMemoryCache } from '@apollo/client';\n *\n * const cache = new InMemoryCache();\n *\n * const client = new ApolloClient({\n * // Provide required constructor fields\n * cache: cache,\n * uri: 'http://localhost:4000/',\n *\n * // Provide some optional constructor fields\n * name: 'react-web-client',\n * version: '1.3',\n * queryDeduplication: false,\n * defaultOptions: {\n * watchQuery: {\n * fetchPolicy: 'cache-and-network',\n * },\n * },\n * });\n * ```\n */\n function ApolloClient(options) {\n var _this = this;\n var _a;\n this.resetStoreCallbacks = [];\n this.clearStoreCallbacks = [];\n if (!options.cache) {\n throw newInvariantError(16);\n }\n var uri = options.uri,\n credentials = options.credentials,\n headers = options.headers,\n cache = options.cache,\n documentTransform = options.documentTransform,\n _b = options.ssrMode,\n ssrMode = _b === void 0 ? false : _b,\n _c = options.ssrForceFetchDelay,\n ssrForceFetchDelay = _c === void 0 ? 0 : _c,\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 connectToDevTools = options.connectToDevTools,\n _d = options.queryDeduplication,\n queryDeduplication = _d === void 0 ? true : _d,\n defaultOptions = options.defaultOptions,\n defaultContext = options.defaultContext,\n _e = options.assumeImmutableResults,\n assumeImmutableResults = _e === void 0 ? cache.assumeImmutableResults : _e,\n resolvers = options.resolvers,\n typeDefs = options.typeDefs,\n fragmentMatcher = options.fragmentMatcher,\n clientAwarenessName = options.name,\n clientAwarenessVersion = options.version,\n devtools = options.devtools,\n dataMasking = options.dataMasking;\n var link = options.link;\n if (!link) {\n link = uri ? new HttpLink({\n uri: uri,\n credentials: credentials,\n headers: headers\n }) : ApolloLink.empty();\n }\n this.link = link;\n this.cache = cache;\n this.disableNetworkFetches = ssrMode || ssrForceFetchDelay > 0;\n this.queryDeduplication = queryDeduplication;\n this.defaultOptions = defaultOptions || Object.create(null);\n this.typeDefs = typeDefs;\n this.devtoolsConfig = __assign(__assign({}, devtools), {\n enabled: (_a = devtools === null || devtools === void 0 ? void 0 : devtools.enabled) !== null && _a !== void 0 ? _a : connectToDevTools\n });\n if (this.devtoolsConfig.enabled === undefined) {\n this.devtoolsConfig.enabled = globalThis.__DEV__ !== false;\n }\n if (ssrForceFetchDelay) {\n setTimeout(function () {\n return _this.disableNetworkFetches = false;\n }, ssrForceFetchDelay);\n }\n this.watchQuery = this.watchQuery.bind(this);\n this.query = this.query.bind(this);\n this.mutate = this.mutate.bind(this);\n this.watchFragment = this.watchFragment.bind(this);\n this.resetStore = this.resetStore.bind(this);\n this.reFetchObservableQueries = this.reFetchObservableQueries.bind(this);\n this.version = version;\n this.localState = new LocalState({\n cache: cache,\n client: this,\n resolvers: resolvers,\n fragmentMatcher: fragmentMatcher\n });\n this.queryManager = new QueryManager({\n cache: this.cache,\n link: this.link,\n defaultOptions: this.defaultOptions,\n defaultContext: defaultContext,\n documentTransform: documentTransform,\n queryDeduplication: queryDeduplication,\n ssrMode: ssrMode,\n dataMasking: !!dataMasking,\n clientAwareness: {\n name: clientAwarenessName,\n version: clientAwarenessVersion\n },\n localState: this.localState,\n assumeImmutableResults: assumeImmutableResults,\n onBroadcast: this.devtoolsConfig.enabled ? function () {\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 if (this.devtoolsConfig.enabled) this.connectToDevTools();\n }\n ApolloClient.prototype.connectToDevTools = function () {\n if (typeof window === \"undefined\") {\n return;\n }\n var windowWithDevTools = window;\n var devtoolsSymbol = Symbol.for(\"apollo.devtools\");\n (windowWithDevTools[devtoolsSymbol] = windowWithDevTools[devtoolsSymbol] || []).push(this);\n windowWithDevTools.__APOLLO_CLIENT__ = this;\n /**\n * Suggest installing the devtools for developers who don't have them\n */\n if (!hasSuggestedDevtools && globalThis.__DEV__ !== false) {\n hasSuggestedDevtools = true;\n if (window.document && window.top === window.self && /^(https?|file):$/.test(window.location.protocol)) {\n setTimeout(function () {\n if (!window.__APOLLO_DEVTOOLS_GLOBAL_HOOK__) {\n var nav = window.navigator;\n var ua = nav && nav.userAgent;\n var url = void 0;\n if (typeof ua === \"string\") {\n if (ua.indexOf(\"Chrome/\") > -1) {\n url = \"https://chrome.google.com/webstore/detail/\" + \"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 globalThis.__DEV__ !== false && invariant.log(\"Download the Apollo DevTools for a better development \" + \"experience: %s\", url);\n }\n }\n }, 10000);\n }\n }\n };\n Object.defineProperty(ApolloClient.prototype, \"documentTransform\", {\n /**\n * The `DocumentTransform` used to modify GraphQL documents before a request\n * is made. If a custom `DocumentTransform` is not provided, this will be the\n * default document transform.\n */\n get: function () {\n return this.queryManager.documentTransform;\n },\n enumerable: false,\n configurable: true\n });\n /**\n * Call this method to terminate any active client processes, making it safe\n * to dispose of this `ApolloClient` instance.\n */\n ApolloClient.prototype.stop = function () {\n this.queryManager.stop();\n };\n /**\n * This watches the cache store of the query according to the options specified and\n * returns an `ObservableQuery`. We can subscribe to this `ObservableQuery` and\n * receive updated results through an 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 ApolloClient.prototype.watchQuery = function (options) {\n if (this.defaultOptions.watchQuery) {\n options = mergeOptions(this.defaultOptions.watchQuery, options);\n }\n // XXX Overwriting options is probably not the best way to do this long term...\n if (this.disableNetworkFetches && (options.fetchPolicy === \"network-only\" || options.fetchPolicy === \"cache-and-network\")) {\n options = __assign(__assign({}, options), {\n fetchPolicy: \"cache-first\"\n });\n }\n return this.queryManager.watchQuery(options);\n };\n /**\n * This resolves a single query according to the options specified and\n * returns a `Promise` which is either resolved with the resulting data\n * or rejected with an error.\n *\n * @param options - An object of type `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 ApolloClient.prototype.query = function (options) {\n if (this.defaultOptions.query) {\n options = mergeOptions(this.defaultOptions.query, options);\n }\n invariant(options.fetchPolicy !== \"cache-and-network\", 17);\n if (this.disableNetworkFetches && options.fetchPolicy === \"network-only\") {\n options = __assign(__assign({}, options), {\n fetchPolicy: \"cache-first\"\n });\n }\n return this.queryManager.query(options);\n };\n /**\n * This resolves a single mutation according to the options specified and returns a\n * Promise which is either resolved with the resulting data or rejected with an\n * error. In some cases both `data` and `errors` might be undefined, for example\n * when `errorPolicy` is set to `'ignore'`.\n *\n * It takes options as an object with the following keys and values:\n */\n ApolloClient.prototype.mutate = function (options) {\n if (this.defaultOptions.mutate) {\n options = mergeOptions(this.defaultOptions.mutate, options);\n }\n return this.queryManager.mutate(options);\n };\n /**\n * This subscribes to a graphql subscription according to the options specified and returns an\n * `Observable` which either emits received data or an error.\n */\n ApolloClient.prototype.subscribe = function (options) {\n var _this = this;\n var id = this.queryManager.generateQueryId();\n return this.queryManager.startGraphQLSubscription(options).map(function (result) {\n return __assign(__assign({}, result), {\n data: _this.queryManager.maskOperation({\n document: options.query,\n data: result.data,\n fetchPolicy: options.fetchPolicy,\n id: id\n })\n });\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 ApolloClient.prototype.readQuery = function (options, optimistic) {\n if (optimistic === void 0) {\n optimistic = false;\n }\n return this.cache.readQuery(options, optimistic);\n };\n /**\n * Watches the cache store of the fragment according to the options specified\n * and returns an `Observable`. We can subscribe to this\n * `Observable` and receive updated results through an\n * observer when the cache store changes.\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 * @since 3.10.0\n * @param options - An object of type `WatchFragmentOptions` that allows\n * the cache to identify the fragment and optionally specify whether to react\n * to optimistic updates.\n */\n ApolloClient.prototype.watchFragment = function (options) {\n var _a;\n return this.cache.watchFragment(__assign(__assign({}, options), (_a = {}, _a[Symbol.for(\"apollo.dataMasking\")] = this.queryManager.dataMasking, _a)));\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 ApolloClient.prototype.readFragment = function (options, optimistic) {\n if (optimistic === void 0) {\n optimistic = false;\n }\n return this.cache.readFragment(options, optimistic);\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 ApolloClient.prototype.writeQuery = function (options) {\n var ref = this.cache.writeQuery(options);\n if (options.broadcast !== false) {\n this.queryManager.broadcastQueries();\n }\n return ref;\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 ApolloClient.prototype.writeFragment = function (options) {\n var ref = this.cache.writeFragment(options);\n if (options.broadcast !== false) {\n this.queryManager.broadcastQueries();\n }\n return ref;\n };\n ApolloClient.prototype.__actionHookForDevTools = function (cb) {\n this.devToolsHookCb = cb;\n };\n ApolloClient.prototype.__requestRaw = function (payload) {\n return execute(this.link, payload);\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 ApolloClient.prototype.resetStore = function () {\n var _this = this;\n return Promise.resolve().then(function () {\n return _this.queryManager.clearStore({\n discardWatches: false\n });\n }).then(function () {\n return Promise.all(_this.resetStoreCallbacks.map(function (fn) {\n return fn();\n }));\n }).then(function () {\n return _this.reFetchObservableQueries();\n });\n };\n /**\n * Remove all data from the store. Unlike `resetStore`, `clearStore` will\n * not refetch any active queries.\n */\n ApolloClient.prototype.clearStore = function () {\n var _this = this;\n return Promise.resolve().then(function () {\n return _this.queryManager.clearStore({\n discardWatches: true\n });\n }).then(function () {\n return Promise.all(_this.clearStoreCallbacks.map(function (fn) {\n return fn();\n }));\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 ApolloClient.prototype.onResetStore = function (cb) {\n var _this = this;\n this.resetStoreCallbacks.push(cb);\n return function () {\n _this.resetStoreCallbacks = _this.resetStoreCallbacks.filter(function (c) {\n return 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 ApolloClient.prototype.onClearStore = function (cb) {\n var _this = this;\n this.clearStoreCallbacks.push(cb);\n return function () {\n _this.clearStoreCallbacks = _this.clearStoreCallbacks.filter(function (c) {\n return 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 ApolloClient.prototype.reFetchObservableQueries = function (includeStandby) {\n return this.queryManager.reFetchObservableQueries(includeStandby);\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 ApolloClient.prototype.refetchQueries = function (options) {\n var map = this.queryManager.refetchQueries(options);\n var queries = [];\n var results = [];\n map.forEach(function (result, obsQuery) {\n queries.push(obsQuery);\n results.push(result);\n });\n var result = Promise.all(results);\n // In case you need the raw results immediately, without awaiting\n // Promise.all(results):\n result.queries = queries;\n result.results = results;\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(function (error) {\n globalThis.__DEV__ !== false && invariant.debug(18, error);\n });\n return result;\n };\n /**\n * Get all currently active `ObservableQuery` objects, in a `Map` keyed by\n * query ID strings.\n *\n * An \"active\" query is one that has observers and a `fetchPolicy` other than\n * \"standby\" or \"cache-only\".\n *\n * You can include all `ObservableQuery` objects (including the inactive ones)\n * by passing \"all\" instead of \"active\", or you can include just a subset of\n * active queries by passing an array of query names or DocumentNode objects.\n */\n ApolloClient.prototype.getObservableQueries = function (include) {\n if (include === void 0) {\n include = \"active\";\n }\n return this.queryManager.getObservableQueries(include);\n };\n /**\n * Exposes the cache's complete state, in a serializable format for later restoration.\n */\n ApolloClient.prototype.extract = function (optimistic) {\n return this.cache.extract(optimistic);\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 ApolloClient.prototype.restore = function (serializedState) {\n return this.cache.restore(serializedState);\n };\n /**\n * Add additional local resolvers.\n */\n ApolloClient.prototype.addResolvers = function (resolvers) {\n this.localState.addResolvers(resolvers);\n };\n /**\n * Set (override existing) local resolvers.\n */\n ApolloClient.prototype.setResolvers = function (resolvers) {\n this.localState.setResolvers(resolvers);\n };\n /**\n * Get all registered local resolvers.\n */\n ApolloClient.prototype.getResolvers = function () {\n return this.localState.getResolvers();\n };\n /**\n * Set a custom local state fragment matcher.\n */\n ApolloClient.prototype.setLocalStateFragmentMatcher = function (fragmentMatcher) {\n this.localState.setFragmentMatcher(fragmentMatcher);\n };\n /**\n * Define a new ApolloLink (or link chain) that Apollo Client will use.\n */\n ApolloClient.prototype.setLink = function (newLink) {\n this.link = this.queryManager.link = newLink;\n };\n Object.defineProperty(ApolloClient.prototype, \"defaultContext\", {\n get: function () {\n return this.queryManager.defaultContext;\n },\n enumerable: false,\n configurable: true\n });\n return ApolloClient;\n}();\nexport { ApolloClient };\nif (globalThis.__DEV__ !== false) {\n ApolloClient.prototype.getMemoryInternals = getApolloClientMemoryInternals;\n}","import { __assign } from \"tslib\";\nimport { invariant } from \"../../utilities/globals/index.js\";\nimport * as React from \"rehackt\";\nimport { getApolloContext } from \"./ApolloContext.js\";\nexport var ApolloProvider = function (_a) {\n var client = _a.client,\n children = _a.children;\n var ApolloContext = getApolloContext();\n var parentContext = React.useContext(ApolloContext);\n var context = React.useMemo(function () {\n return __assign(__assign({}, parentContext), {\n client: client || parentContext.client\n });\n }, [parentContext, client]);\n invariant(context.client, 55);\n return React.createElement(ApolloContext.Provider, {\n value: context\n }, children);\n};","import React from 'react';\nimport fetch from 'isomorphic-fetch';\nimport {ApolloClient, ApolloProvider, InMemoryCache} from '@apollo/client';\n\nconst cache = new InMemoryCache();\n\n// eslint-disable-next-line react/prop-types\nexport const wrapRootElement = ({element}, {uri, headers, credentials}) => {\n const client = new ApolloClient({\n fetch,\n uri,\n headers,\n credentials,\n cache\n });\n return {element};\n};\n","/* eslint-disable no-unused-expressions */\nimport { stripIndent } from \"common-tags\"\nimport camelCase from \"camelcase\"\nimport { IGatsbyImageData } from \".\"\n\nconst DEFAULT_PIXEL_DENSITIES = [0.25, 0.5, 1, 2]\nexport const DEFAULT_BREAKPOINTS = [750, 1080, 1366, 1920]\nexport const EVERY_BREAKPOINT = [\n 320, 654, 768, 1024, 1366, 1600, 1920, 2048, 2560, 3440, 3840, 4096,\n]\nconst DEFAULT_FLUID_WIDTH = 800\nconst DEFAULT_FIXED_WIDTH = 800\nconst DEFAULT_ASPECT_RATIO = 4 / 3\n\nexport type Fit = \"cover\" | \"fill\" | \"inside\" | \"outside\" | \"contain\"\n\nexport type Layout = \"fixed\" | \"fullWidth\" | \"constrained\"\nexport type ImageFormat = \"jpg\" | \"png\" | \"webp\" | \"avif\" | \"auto\" | \"\"\n\n/**\n * The minimal required reporter, as we don't want to import it from gatsby-cli\n */\nexport interface IReporter {\n warn(message: string): void\n}\n\nexport interface ISharpGatsbyImageArgs {\n layout?: Layout\n formats?: Array\n placeholder?: \"tracedSVG\" | \"dominantColor\" | \"blurred\" | \"none\"\n tracedSVGOptions?: Record\n width?: number\n height?: number\n aspectRatio?: number\n sizes?: string\n quality?: number\n transformOptions?: {\n fit?: Fit\n cropFocus?: number | string\n duotone?: {\n highlight: string\n shadow: string\n opacity?: number\n }\n grayscale?: boolean\n rotate?: number\n trim?: number\n }\n jpgOptions?: Record\n pngOptions?: Record\n webpOptions?: Record\n avifOptions?: Record\n blurredOptions?: { width?: number; toFormat?: ImageFormat }\n breakpoints?: Array\n backgroundColor?: string\n}\n\nexport interface IImageSizeArgs {\n width?: number\n height?: number\n layout?: Layout\n filename: string\n outputPixelDensities?: Array\n breakpoints?: Array\n fit?: Fit\n reporter?: IReporter\n sourceMetadata: { width: number; height: number }\n}\n\nexport interface IImageSizes {\n sizes: Array\n presentationWidth: number\n presentationHeight: number\n aspectRatio: number\n unscaledWidth: number\n}\n\nexport interface IImage {\n src: string\n width: number\n height: number\n format: ImageFormat\n}\n\nexport interface IGatsbyImageHelperArgs {\n pluginName: string\n generateImageSource: (\n filename: string,\n width: number,\n height: number,\n format: ImageFormat,\n fit?: Fit,\n options?: Record\n ) => IImage\n layout?: Layout\n formats?: Array\n filename: string\n placeholderURL?: string\n width?: number\n height?: number\n sizes?: string\n reporter?: IReporter\n sourceMetadata?: { width: number; height: number; format: ImageFormat }\n fit?: Fit\n options?: Record\n breakpoints?: Array\n backgroundColor?: string\n aspectRatio?: number\n}\n\nconst warn = (message: string): void => console.warn(message)\n\nconst sortNumeric = (a: number, b: number): number => a - b\n\nexport const getSizes = (width: number, layout: Layout): string | undefined => {\n switch (layout) {\n // If screen is wider than the max size, image width is the max size,\n // otherwise it's the width of the screen\n case `constrained`:\n return `(min-width: ${width}px) ${width}px, 100vw`\n\n // Image is always the same width, whatever the size of the screen\n case `fixed`:\n return `${width}px`\n\n // Image is always the width of the screen\n case `fullWidth`:\n return `100vw`\n\n default:\n return undefined\n }\n}\n\nexport const getSrcSet = (images: Array): string =>\n images.map(image => `${image.src} ${image.width}w`).join(`,\\n`)\n\nexport function formatFromFilename(filename: string): ImageFormat | undefined {\n const dot = filename.lastIndexOf(`.`)\n if (dot !== -1) {\n const ext = filename.substr(dot + 1)\n if (ext === `jpeg`) {\n return `jpg`\n }\n if (ext.length === 3 || ext.length === 4) {\n return ext as ImageFormat\n }\n }\n return undefined\n}\n\nexport function setDefaultDimensions(\n args: IGatsbyImageHelperArgs\n): IGatsbyImageHelperArgs {\n let {\n layout = `constrained`,\n width,\n height,\n sourceMetadata,\n breakpoints,\n aspectRatio,\n formats = [`auto`, `webp`],\n } = args\n formats = formats.map(format => format.toLowerCase() as ImageFormat)\n layout = camelCase(layout) as Layout\n\n if (width && height) {\n return { ...args, formats, layout, aspectRatio: width / height }\n }\n if (sourceMetadata.width && sourceMetadata.height && !aspectRatio) {\n aspectRatio = sourceMetadata.width / sourceMetadata.height\n }\n\n if (layout === `fullWidth`) {\n width = width || sourceMetadata.width || breakpoints[breakpoints.length - 1]\n height = height || Math.round(width / (aspectRatio || DEFAULT_ASPECT_RATIO))\n } else {\n if (!width) {\n if (height && aspectRatio) {\n width = height * aspectRatio\n } else if (sourceMetadata.width) {\n width = sourceMetadata.width\n } else if (height) {\n width = Math.round(height / DEFAULT_ASPECT_RATIO)\n } else {\n width = DEFAULT_FIXED_WIDTH\n }\n }\n\n if (aspectRatio && !height) {\n height = Math.round(width / aspectRatio)\n } else if (!aspectRatio) {\n aspectRatio = width / height\n }\n }\n return { ...args, width, height, aspectRatio, layout, formats }\n}\n\n/**\n * Use this for getting an image for the blurred placeholder. This ensures the\n * aspect ratio and crop match the main image\n */\nexport function getLowResolutionImageURL(\n args: IGatsbyImageHelperArgs,\n width = 20\n): string {\n args = setDefaultDimensions(args)\n const { generateImageSource, filename, aspectRatio } = args\n return generateImageSource(\n filename,\n width,\n Math.round(width / aspectRatio),\n args.sourceMetadata.format || `jpg`,\n args.fit,\n args.options\n )?.src\n}\n\nexport function generateImageData(\n args: IGatsbyImageHelperArgs\n): IGatsbyImageData {\n args = setDefaultDimensions(args)\n\n let {\n pluginName,\n sourceMetadata,\n generateImageSource,\n layout,\n fit,\n options,\n width,\n height,\n filename,\n reporter = { warn },\n backgroundColor,\n placeholderURL,\n } = args\n\n if (!pluginName) {\n reporter.warn(\n `[gatsby-plugin-image] \"generateImageData\" was not passed a plugin name`\n )\n }\n\n if (typeof generateImageSource !== `function`) {\n throw new Error(`generateImageSource must be a function`)\n }\n\n if (!sourceMetadata || (!sourceMetadata.width && !sourceMetadata.height)) {\n // No metadata means we let the CDN handle max size etc, aspect ratio etc\n sourceMetadata = {\n width,\n height,\n format: sourceMetadata?.format || formatFromFilename(filename) || `auto`,\n }\n } else if (!sourceMetadata.format) {\n sourceMetadata.format = formatFromFilename(filename)\n }\n\n const formats = new Set(args.formats)\n\n if (formats.size === 0 || formats.has(`auto`) || formats.has(``)) {\n formats.delete(`auto`)\n formats.delete(``)\n formats.add(sourceMetadata.format)\n }\n\n if (formats.has(`jpg`) && formats.has(`png`)) {\n reporter.warn(\n `[${pluginName}] Specifying both 'jpg' and 'png' formats is not supported. Using 'auto' instead`\n )\n if (sourceMetadata.format === `jpg`) {\n formats.delete(`png`)\n } else {\n formats.delete(`jpg`)\n }\n }\n\n const imageSizes = calculateImageSizes({ ...args, sourceMetadata })\n\n const result: IGatsbyImageData[\"images\"] = {\n sources: [],\n }\n\n let sizes = args.sizes\n if (!sizes) {\n sizes = getSizes(imageSizes.presentationWidth, layout)\n }\n\n formats.forEach(format => {\n const images = imageSizes.sizes\n .map(size => {\n const imageSrc = generateImageSource(\n filename,\n size,\n Math.round(size / imageSizes.aspectRatio),\n format,\n fit,\n options\n )\n if (\n !imageSrc?.width ||\n !imageSrc.height ||\n !imageSrc.src ||\n !imageSrc.format\n ) {\n reporter.warn(\n `[${pluginName}] The resolver for image ${filename} returned an invalid value.`\n )\n return undefined\n }\n return imageSrc\n })\n .filter(Boolean)\n\n if (format === `jpg` || format === `png` || format === `auto`) {\n const unscaled =\n images.find(img => img.width === imageSizes.unscaledWidth) || images[0]\n\n if (unscaled) {\n result.fallback = {\n src: unscaled.src,\n srcSet: getSrcSet(images),\n sizes,\n }\n }\n } else {\n result.sources?.push({\n srcSet: getSrcSet(images),\n sizes,\n type: `image/${format}`,\n })\n }\n })\n\n const imageProps: Partial = {\n images: result,\n layout,\n backgroundColor,\n }\n\n if (placeholderURL) {\n imageProps.placeholder = { fallback: placeholderURL }\n }\n\n switch (layout) {\n case `fixed`:\n imageProps.width = imageSizes.presentationWidth\n imageProps.height = imageSizes.presentationHeight\n break\n\n case `fullWidth`:\n imageProps.width = 1\n imageProps.height = 1 / imageSizes.aspectRatio\n break\n\n case `constrained`:\n imageProps.width = args.width || imageSizes.presentationWidth || 1\n imageProps.height = (imageProps.width || 1) / imageSizes.aspectRatio\n }\n\n return imageProps as IGatsbyImageData\n}\n\nconst dedupeAndSortDensities = (values: Array): Array =>\n Array.from(new Set([1, ...values])).sort(sortNumeric)\n\nexport function calculateImageSizes(args: IImageSizeArgs): IImageSizes {\n const {\n width,\n height,\n filename,\n layout = `constrained`,\n sourceMetadata: imgDimensions,\n reporter = { warn },\n breakpoints = DEFAULT_BREAKPOINTS,\n } = args\n\n // check that all dimensions provided are positive\n const userDimensions = { width, height }\n const erroneousUserDimensions = Object.entries(userDimensions).filter(\n ([_, size]) => typeof size === `number` && size < 1\n )\n if (erroneousUserDimensions.length) {\n throw new Error(\n `Specified dimensions for images must be positive numbers (> 0). Problem dimensions you have are ${erroneousUserDimensions\n .map(dim => dim.join(`: `))\n .join(`, `)}`\n )\n }\n\n if (layout === `fixed`) {\n return fixedImageSizes(args)\n } else if (layout === `constrained`) {\n return responsiveImageSizes(args)\n } else if (layout === `fullWidth`) {\n return responsiveImageSizes({ breakpoints, ...args })\n } else {\n reporter.warn(\n `No valid layout was provided for the image at ${filename}. Valid image layouts are fixed, fullWidth, and constrained. Found ${layout}`\n )\n return {\n sizes: [imgDimensions.width],\n presentationWidth: imgDimensions.width,\n presentationHeight: imgDimensions.height,\n aspectRatio: imgDimensions.width / imgDimensions.height,\n unscaledWidth: imgDimensions.width,\n }\n }\n}\nexport function fixedImageSizes({\n filename,\n sourceMetadata: imgDimensions,\n width,\n height,\n fit = `cover`,\n outputPixelDensities = DEFAULT_PIXEL_DENSITIES,\n reporter = { warn },\n}: IImageSizeArgs): IImageSizes {\n let aspectRatio = imgDimensions.width / imgDimensions.height\n // Sort, dedupe and ensure there's a 1\n const densities = dedupeAndSortDensities(outputPixelDensities)\n\n // If both are provided then we need to check the fit\n if (width && height) {\n const calculated = getDimensionsAndAspectRatio(imgDimensions, {\n width,\n height,\n fit,\n })\n width = calculated.width\n height = calculated.height\n aspectRatio = calculated.aspectRatio\n }\n\n if (!width) {\n if (!height) {\n width = DEFAULT_FIXED_WIDTH\n } else {\n width = Math.round(height * aspectRatio)\n }\n } else if (!height) {\n height = Math.round(width / aspectRatio)\n }\n\n const originalWidth = width // will use this for presentationWidth, don't want to lose it\n const isTopSizeOverriden =\n imgDimensions.width < width || imgDimensions.height < (height as number)\n\n // If the image is smaller than requested, warn the user that it's being processed as such\n // print out this message with the necessary information before we overwrite it for sizing\n if (isTopSizeOverriden) {\n const fixedDimension = imgDimensions.width < width ? `width` : `height`\n reporter.warn(stripIndent`\n The requested ${fixedDimension} \"${\n fixedDimension === `width` ? width : height\n }px\" for the image ${filename} was larger than the actual image ${fixedDimension} of ${\n imgDimensions[fixedDimension]\n }px. If possible, replace the current image with a larger one.`)\n\n if (fixedDimension === `width`) {\n width = imgDimensions.width\n height = Math.round(width / aspectRatio)\n } else {\n height = imgDimensions.height\n width = height * aspectRatio\n }\n }\n\n const sizes = densities\n .filter(size => size >= 1) // remove smaller densities because fixed images don't need them\n .map(density => Math.round(density * (width as number)))\n .filter(size => size <= imgDimensions.width)\n\n return {\n sizes,\n aspectRatio,\n presentationWidth: originalWidth,\n presentationHeight: Math.round(originalWidth / aspectRatio),\n unscaledWidth: width,\n }\n}\n\nexport function responsiveImageSizes({\n sourceMetadata: imgDimensions,\n width,\n height,\n fit = `cover`,\n outputPixelDensities = DEFAULT_PIXEL_DENSITIES,\n breakpoints,\n layout,\n}: IImageSizeArgs): IImageSizes {\n let sizes\n let aspectRatio = imgDimensions.width / imgDimensions.height\n // Sort, dedupe and ensure there's a 1\n const densities = dedupeAndSortDensities(outputPixelDensities)\n\n // If both are provided then we need to check the fit\n if (width && height) {\n const calculated = getDimensionsAndAspectRatio(imgDimensions, {\n width,\n height,\n fit,\n })\n width = calculated.width\n height = calculated.height\n aspectRatio = calculated.aspectRatio\n }\n\n // Case 1: width of height were passed in, make sure it isn't larger than the actual image\n width = width && Math.min(width, imgDimensions.width)\n height = height && Math.min(height, imgDimensions.height)\n\n // Case 2: neither width or height were passed in, use default size\n if (!width && !height) {\n width = Math.min(DEFAULT_FLUID_WIDTH, imgDimensions.width)\n height = width / aspectRatio\n }\n\n // if it still hasn't been found, calculate width from the derived height.\n // TS isn't smart enough to realise the type for height has been narrowed here\n if (!width) {\n width = (height as number) * aspectRatio\n }\n\n const originalWidth = width\n const isTopSizeOverriden =\n imgDimensions.width < width || imgDimensions.height < (height as number)\n if (isTopSizeOverriden) {\n width = imgDimensions.width\n height = imgDimensions.height\n }\n\n width = Math.round(width)\n\n if (breakpoints?.length > 0) {\n sizes = breakpoints.filter(size => size <= imgDimensions.width)\n\n // If a larger breakpoint has been filtered-out, add the actual image width instead\n if (\n sizes.length < breakpoints.length &&\n !sizes.includes(imgDimensions.width)\n ) {\n sizes.push(imgDimensions.width)\n }\n } else {\n sizes = densities.map(density => Math.round(density * (width as number)))\n sizes = sizes.filter(size => size <= imgDimensions.width)\n }\n\n // ensure that the size passed in is included in the final output\n if (layout === `constrained` && !sizes.includes(width)) {\n sizes.push(width)\n }\n sizes = sizes.sort(sortNumeric)\n return {\n sizes,\n aspectRatio,\n presentationWidth: originalWidth,\n presentationHeight: Math.round(originalWidth / aspectRatio),\n unscaledWidth: width,\n }\n}\n\nexport function getDimensionsAndAspectRatio(\n dimensions,\n options\n): { width: number; height: number; aspectRatio: number } {\n // Calculate the eventual width/height of the image.\n const imageAspectRatio = dimensions.width / dimensions.height\n\n let width = options.width\n let height = options.height\n\n switch (options.fit) {\n case `fill`: {\n width = options.width ? options.width : dimensions.width\n height = options.height ? options.height : dimensions.height\n break\n }\n case `inside`: {\n const widthOption = options.width\n ? options.width\n : Number.MAX_SAFE_INTEGER\n const heightOption = options.height\n ? options.height\n : Number.MAX_SAFE_INTEGER\n\n width = Math.min(widthOption, Math.round(heightOption * imageAspectRatio))\n height = Math.min(\n heightOption,\n Math.round(widthOption / imageAspectRatio)\n )\n break\n }\n case `outside`: {\n const widthOption = options.width ? options.width : 0\n const heightOption = options.height ? options.height : 0\n\n width = Math.max(widthOption, Math.round(heightOption * imageAspectRatio))\n height = Math.max(\n heightOption,\n Math.round(widthOption / imageAspectRatio)\n )\n break\n }\n\n default: {\n if (options.width && !options.height) {\n width = options.width\n height = Math.round(options.width / imageAspectRatio)\n }\n\n if (options.height && !options.width) {\n width = Math.round(options.height * imageAspectRatio)\n height = options.height\n }\n }\n }\n\n return {\n width,\n height,\n aspectRatio: width / height,\n }\n}\n","/* eslint-disable no-unused-expressions */\nimport {\n useState,\n CSSProperties,\n useEffect,\n HTMLAttributes,\n ImgHTMLAttributes,\n ReactEventHandler,\n SetStateAction,\n Dispatch,\n RefObject,\n} from \"react\"\nimport { Node } from \"gatsby\"\nimport { PlaceholderProps } from \"./placeholder\"\nimport { MainImageProps } from \"./main-image\"\nimport type { IGatsbyImageData } from \"./gatsby-image.browser\"\nimport {\n IGatsbyImageHelperArgs,\n generateImageData,\n Layout,\n EVERY_BREAKPOINT,\n IImage,\n ImageFormat,\n} from \"../image-utils\"\nconst imageCache = new Set()\n\n// Native lazy-loading support: https://addyosmani.com/blog/lazy-loading/\nexport const hasNativeLazyLoadSupport = (): boolean =>\n typeof HTMLImageElement !== `undefined` &&\n `loading` in HTMLImageElement.prototype\n\nexport function gatsbyImageIsInstalled(): boolean {\n return typeof GATSBY___IMAGE !== `undefined` && GATSBY___IMAGE\n}\n\nexport function storeImageloaded(cacheKey?: string): void {\n if (cacheKey) {\n imageCache.add(cacheKey)\n }\n}\n\nexport function hasImageLoaded(cacheKey: string): boolean {\n return imageCache.has(cacheKey)\n}\nexport type IGatsbyImageDataParent = T & {\n gatsbyImageData: IGatsbyImageData\n}\nexport type FileNode = Node & {\n childImageSharp?: IGatsbyImageDataParent\n}\n\nconst isGatsbyImageData = (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n node: IGatsbyImageData | any\n): node is IGatsbyImageData =>\n // 🦆 check for a deep prop to be sure this is a valid gatsbyImageData object\n Boolean(node?.images?.fallback?.src)\n\nconst isGatsbyImageDataParent = (\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n node: IGatsbyImageDataParent | any\n): node is IGatsbyImageDataParent => Boolean(node?.gatsbyImageData)\n\nexport type ImageDataLike = FileNode | IGatsbyImageDataParent | IGatsbyImageData\nexport const getImage = (node: ImageDataLike): IGatsbyImageData | undefined => {\n if (isGatsbyImageData(node)) {\n return node\n }\n if (isGatsbyImageDataParent(node)) {\n return node.gatsbyImageData\n }\n return node?.childImageSharp?.gatsbyImageData\n}\n\nexport const getSrc = (node: ImageDataLike): string | undefined =>\n getImage(node)?.images?.fallback?.src\n\nexport const getSrcSet = (node: ImageDataLike): string | undefined =>\n getImage(node)?.images?.fallback?.srcSet\n\nexport function getWrapperProps(\n width: number,\n height: number,\n layout: Layout\n): Pick, \"className\" | \"style\"> & {\n \"data-gatsby-image-wrapper\": string\n} {\n const wrapperStyle: CSSProperties = {}\n\n let className = `gatsby-image-wrapper`\n\n // If the plugin isn't installed we need to apply the styles inline\n if (!gatsbyImageIsInstalled()) {\n wrapperStyle.position = `relative`\n wrapperStyle.overflow = `hidden`\n }\n\n if (layout === `fixed`) {\n wrapperStyle.width = width\n wrapperStyle.height = height\n } else if (layout === `constrained`) {\n if (!gatsbyImageIsInstalled()) {\n wrapperStyle.display = `inline-block`\n wrapperStyle.verticalAlign = `top`\n }\n className = `gatsby-image-wrapper gatsby-image-wrapper-constrained`\n }\n\n return {\n className,\n \"data-gatsby-image-wrapper\": ``,\n style: wrapperStyle,\n }\n}\n\nexport async function applyPolyfill(\n ref: RefObject\n): Promise {\n if (!(`objectFitPolyfill` in window)) {\n await import(\n // @ts-ignore typescript can't find the module for some reason ¯\\_(ツ)_/¯\n /* webpackChunkName: \"gatsby-plugin-image-objectfit-polyfill\" */ `objectFitPolyfill`\n )\n }\n ;(window as any).objectFitPolyfill(ref.current)\n}\n\nexport interface IUrlBuilderArgs {\n width: number\n height: number\n baseUrl: string\n format: ImageFormat\n options: OptionsType\n}\nexport interface IGetImageDataArgs> {\n baseUrl: string\n /**\n * For constrained and fixed images, the size of the image element\n */\n width?: number\n height?: number\n /**\n * If available, pass the source image width and height\n */\n sourceWidth?: number\n sourceHeight?: number\n /**\n * If only one dimension is passed, then this will be used to calculate the other.\n */\n aspectRatio?: number\n layout?: Layout\n /**\n * Returns a URL based on the passed arguments. Should be a pure function\n */\n urlBuilder: (args: IUrlBuilderArgs) => string\n\n /**\n * Should be a data URI\n */\n placeholderURL?: string\n backgroundColor?: string\n /**\n * Used in error messages etc\n */\n pluginName?: string\n\n /**\n * If you do not support auto-format, pass an array of image types here\n */\n formats?: Array\n\n breakpoints?: Array\n\n /**\n * Passed to the urlBuilder function\n */\n options?: OptionsType\n}\n\n/**\n * Use this hook to generate gatsby-plugin-image data in the browser.\n */\nexport function getImageData({\n baseUrl,\n urlBuilder,\n sourceWidth,\n sourceHeight,\n pluginName = `getImageData`,\n formats = [`auto`],\n breakpoints,\n options,\n ...props\n}: IGetImageDataArgs): IGatsbyImageData {\n if (\n !breakpoints?.length &&\n (props.layout === `fullWidth` || (props.layout as string) === `FULL_WIDTH`)\n ) {\n breakpoints = EVERY_BREAKPOINT\n }\n const generateImageSource = (\n baseUrl: string,\n width: number,\n height?: number,\n format?: ImageFormat\n ): IImage => {\n return {\n width,\n height,\n format,\n src: urlBuilder({ baseUrl, width, height, options, format }),\n }\n }\n\n const sourceMetadata: IGatsbyImageHelperArgs[\"sourceMetadata\"] = {\n width: sourceWidth,\n height: sourceHeight,\n format: `auto`,\n }\n\n const args: IGatsbyImageHelperArgs = {\n ...props,\n pluginName,\n generateImageSource,\n filename: baseUrl,\n formats,\n breakpoints,\n sourceMetadata,\n }\n return generateImageData(args)\n}\n\nexport function getMainProps(\n isLoading: boolean,\n isLoaded: boolean,\n images: IGatsbyImageData[\"images\"],\n loading?: \"eager\" | \"lazy\",\n toggleLoaded?: (loaded: boolean) => void,\n cacheKey?: string,\n ref?: RefObject,\n style: CSSProperties = {}\n): Partial {\n const onLoad: ReactEventHandler = function (e) {\n if (isLoaded) {\n return\n }\n\n storeImageloaded(cacheKey)\n\n const target = e.currentTarget\n const img = new Image()\n img.src = target.currentSrc\n\n if (img.decode) {\n // Decode the image through javascript to support our transition\n img\n .decode()\n .catch(() => {\n // ignore error, we just go forward\n })\n .then(() => {\n toggleLoaded(true)\n })\n } else {\n toggleLoaded(true)\n }\n }\n\n // Polyfill \"object-fit\" if unsupported (mostly IE)\n if (ref?.current && !(`objectFit` in document.documentElement.style)) {\n ref.current.dataset.objectFit = style.objectFit ?? `cover`\n ref.current.dataset.objectPosition = `${style.objectPosition ?? `50% 50%`}`\n applyPolyfill(ref)\n }\n\n // fallback when it's not configured in gatsby-config.\n if (!gatsbyImageIsInstalled()) {\n style = {\n height: `100%`,\n left: 0,\n position: `absolute`,\n top: 0,\n transform: `translateZ(0)`,\n transition: `opacity 250ms linear`,\n width: `100%`,\n willChange: `opacity`,\n ...style,\n }\n }\n\n const result = {\n ...images,\n loading,\n shouldLoad: isLoading,\n \"data-main-image\": ``,\n style: {\n ...style,\n opacity: isLoaded ? 1 : 0,\n },\n onLoad,\n ref,\n }\n\n return result\n}\n\nexport type PlaceholderImageAttrs = ImgHTMLAttributes &\n Pick & {\n \"data-placeholder-image\"?: string\n }\n\nexport function getPlaceholderProps(\n placeholder: PlaceholderImageAttrs | undefined,\n isLoaded: boolean,\n layout: Layout,\n width?: number,\n height?: number,\n backgroundColor?: string,\n objectFit?: CSSProperties[\"objectFit\"],\n objectPosition?: CSSProperties[\"objectPosition\"]\n): PlaceholderImageAttrs {\n const wrapperStyle: CSSProperties = {}\n\n if (backgroundColor) {\n wrapperStyle.backgroundColor = backgroundColor\n\n if (layout === `fixed`) {\n wrapperStyle.width = width\n wrapperStyle.height = height\n wrapperStyle.backgroundColor = backgroundColor\n wrapperStyle.position = `relative`\n } else if (layout === `constrained`) {\n wrapperStyle.position = `absolute`\n wrapperStyle.top = 0\n wrapperStyle.left = 0\n wrapperStyle.bottom = 0\n wrapperStyle.right = 0\n } else if (layout === `fullWidth`) {\n wrapperStyle.position = `absolute`\n wrapperStyle.top = 0\n wrapperStyle.left = 0\n wrapperStyle.bottom = 0\n wrapperStyle.right = 0\n }\n }\n\n if (objectFit) {\n wrapperStyle.objectFit = objectFit\n }\n\n if (objectPosition) {\n wrapperStyle.objectPosition = objectPosition\n }\n const result: PlaceholderImageAttrs = {\n ...placeholder,\n \"aria-hidden\": true,\n \"data-placeholder-image\": ``,\n style: {\n opacity: isLoaded ? 0 : 1,\n transition: `opacity 500ms linear`,\n ...wrapperStyle,\n },\n }\n\n // fallback when it's not configured in gatsby-config.\n if (!gatsbyImageIsInstalled()) {\n result.style = {\n height: `100%`,\n left: 0,\n position: `absolute`,\n top: 0,\n width: `100%`,\n }\n }\n\n return result\n}\n\nexport function useImageLoaded(\n cacheKey: string,\n loading: \"lazy\" | \"eager\",\n ref: any\n): {\n isLoaded: boolean\n isLoading: boolean\n toggleLoaded: Dispatch>\n} {\n const [isLoaded, toggleLoaded] = useState(false)\n const [isLoading, toggleIsLoading] = useState(loading === `eager`)\n\n const rAF =\n typeof window !== `undefined` && `requestAnimationFrame` in window\n ? requestAnimationFrame\n : function (cb: TimerHandler): number {\n return setTimeout(cb, 16)\n }\n const cRAF =\n typeof window !== `undefined` && `cancelAnimationFrame` in window\n ? cancelAnimationFrame\n : clearTimeout\n\n useEffect(() => {\n let interval: number\n // @see https://stackoverflow.com/questions/44074747/componentdidmount-called-before-ref-callback/50019873#50019873\n function toggleIfRefExists(): void {\n if (ref.current) {\n if (loading === `eager` && ref.current.complete) {\n storeImageloaded(cacheKey)\n toggleLoaded(true)\n } else {\n toggleIsLoading(true)\n }\n } else {\n interval = rAF(toggleIfRefExists)\n }\n }\n toggleIfRefExists()\n\n return (): void => {\n cRAF(interval)\n }\n }, [])\n\n return {\n isLoading,\n isLoaded,\n toggleLoaded,\n }\n}\n\nexport interface IArtDirectedImage {\n media: string\n image: IGatsbyImageData\n}\n\n/**\n * Generate a Gatsby image data object with multiple, art-directed images that display at different\n * resolutions.\n *\n * @param defaultImage The image displayed when no media query matches.\n * It is also used for all other settings applied to the image, such as width, height and layout.\n * You should pass a className to the component with media queries to adjust the size of the container,\n * as this cannot be adjusted automatically.\n * @param artDirected Array of objects which each contains a `media` string which is a media query\n * such as `(min-width: 320px)`, and the image object to use when that query matches.\n */\nexport function withArtDirection(\n defaultImage: IGatsbyImageData,\n artDirected: Array\n): IGatsbyImageData {\n const { images, placeholder, ...props } = defaultImage\n const output: IGatsbyImageData = {\n ...props,\n images: {\n ...images,\n sources: [],\n },\n placeholder: placeholder && {\n ...placeholder,\n sources: [],\n },\n }\n\n artDirected.forEach(({ media, image }) => {\n if (!media) {\n if (process.env.NODE_ENV === `development`) {\n console.warn(\n \"[gatsby-plugin-image] All art-directed images passed to must have a value set for `media`. Skipping.\"\n )\n }\n return\n }\n\n if (\n image.layout !== defaultImage.layout &&\n process.env.NODE_ENV === `development`\n ) {\n console.warn(\n `[gatsby-plugin-image] Mismatched image layout: expected \"${defaultImage.layout}\" but received \"${image.layout}\". All art-directed images use the same layout as the default image`\n )\n }\n\n output.images.sources.push(\n ...image.images.sources.map(source => {\n return { ...source, media }\n }),\n {\n media,\n srcSet: image.images.fallback.srcSet,\n }\n )\n\n if (!output.placeholder) {\n return\n }\n\n output.placeholder.sources.push({\n media,\n srcSet: image.placeholder.fallback,\n })\n })\n output.images.sources.push(...images.sources)\n if (placeholder?.sources) {\n output.placeholder?.sources.push(...placeholder.sources)\n }\n return output\n}\n","// eslint-disable-next-line @typescript-eslint/triple-slash-reference\n/// \n\nimport React, { Fragment, FunctionComponent } from \"react\"\nimport terserMacro from \"../../macros/terser.macro\"\nimport { Layout } from \"../image-utils\"\n\nexport interface ILayoutWrapperProps {\n layout: Layout\n width: number\n height: number\n}\n\nconst NativeScriptLoading: FunctionComponent = () => (\n \n)\n\nexport function getSizer(\n layout: Layout,\n width: number,\n height: number\n): string {\n let sizer: string | null = null\n if (layout === `fullWidth`) {\n sizer = `
`\n }\n if (layout === `constrained`) {\n sizer = `
\"\"
`\n }\n return sizer\n}\n\nconst Sizer: FunctionComponent = function Sizer({\n layout,\n width,\n height,\n}) {\n if (layout === `fullWidth`) {\n return (\n
\n )\n }\n if (layout === `constrained`) {\n return (\n
\n \n
\n )\n }\n\n return null\n}\n\nexport const LayoutWrapper: FunctionComponent =\n function LayoutWrapper({ children, ...props }) {\n return (\n \n \n {children}\n\n {\n // eslint-disable-next-line no-undef\n SERVER && \n }\n \n )\n }\n","/* eslint-disable filenames/match-regex */\nimport React, {\n FunctionComponent,\n ImgHTMLAttributes,\n forwardRef,\n LegacyRef,\n} from \"react\"\nimport * as PropTypes from \"prop-types\"\n\nexport interface IResponsiveImageProps {\n sizes?: string\n srcSet: string\n}\n\nexport type SourceProps = IResponsiveImageProps &\n (\n | {\n media: string\n type?: string\n }\n | {\n media?: string\n type: string\n }\n )\n\ntype FallbackProps = { src: string } & Partial\n\ntype ImageProps = ImgHTMLAttributes & {\n src: string\n alt: string\n shouldLoad: boolean\n innerRef: LegacyRef\n}\n\nexport type PictureProps = ImgHTMLAttributes & {\n fallback?: FallbackProps\n sources?: Array\n alt: string\n shouldLoad?: boolean\n}\n\nconst Image: FunctionComponent = function Image({\n src,\n srcSet,\n loading,\n alt = ``,\n shouldLoad,\n innerRef,\n ...props\n}) {\n return (\n \n )\n}\n\nexport const Picture = forwardRef(\n function Picture(\n { fallback, sources = [], shouldLoad = true, ...props },\n ref\n ) {\n const sizes = props.sizes || fallback?.sizes\n const fallbackImage = (\n \n )\n\n if (!sources.length) {\n return fallbackImage\n }\n\n return (\n \n {sources.map(({ media, srcSet, type }) => (\n \n ))}\n {fallbackImage}\n \n )\n }\n)\n\nImage.propTypes = {\n src: PropTypes.string.isRequired,\n alt: PropTypes.string.isRequired,\n sizes: PropTypes.string,\n srcSet: PropTypes.string,\n shouldLoad: PropTypes.bool,\n}\n\nPicture.displayName = `Picture`\nPicture.propTypes = {\n alt: PropTypes.string.isRequired,\n shouldLoad: PropTypes.bool,\n fallback: PropTypes.exact({\n src: PropTypes.string.isRequired,\n srcSet: PropTypes.string,\n sizes: PropTypes.string,\n }),\n sources: PropTypes.arrayOf(\n PropTypes.oneOfType([\n PropTypes.exact({\n media: PropTypes.string.isRequired,\n type: PropTypes.string,\n sizes: PropTypes.string,\n srcSet: PropTypes.string.isRequired,\n }),\n PropTypes.exact({\n media: PropTypes.string,\n type: PropTypes.string.isRequired,\n sizes: PropTypes.string,\n srcSet: PropTypes.string.isRequired,\n }),\n ])\n ),\n}\n","import React, { FunctionComponent, ImgHTMLAttributes } from \"react\"\nimport * as PropTypes from \"prop-types\"\nimport { Picture, SourceProps } from \"./picture\"\n\nexport type PlaceholderProps = ImgHTMLAttributes & {\n fallback?: string\n sources?: Array\n}\n\nexport const Placeholder: FunctionComponent =\n function Placeholder({ fallback, ...props }) {\n if (fallback) {\n return (\n \n )\n } else {\n return
\n }\n }\n\nPlaceholder.displayName = `Placeholder`\nPlaceholder.propTypes = {\n fallback: PropTypes.string,\n sources: Picture.propTypes?.sources,\n alt: function (props, propName, componentName): Error | null {\n if (!props[propName]) {\n return null\n }\n return new Error(\n `Invalid prop \\`${propName}\\` supplied to \\`${componentName}\\`. Validation failed.`\n )\n },\n}\n","import React, { forwardRef } from \"react\"\nimport { Picture, PictureProps } from \"./picture\"\n\nexport type MainImageProps = PictureProps\n\nexport const MainImage = forwardRef(\n function MainImage(props, ref) {\n return (\n <>\n \n \n \n )\n }\n)\n\nMainImage.displayName = `MainImage`\nMainImage.propTypes = Picture.propTypes\n","import React, {\n ElementType,\n FunctionComponent,\n CSSProperties,\n WeakValidationMap,\n} from \"react\"\nimport { GatsbyImageProps, IGatsbyImageData } from \"./gatsby-image.browser\"\nimport { getWrapperProps, getMainProps, getPlaceholderProps } from \"./hooks\"\nimport { Placeholder } from \"./placeholder\"\nimport { MainImage, MainImageProps } from \"./main-image\"\nimport { LayoutWrapper } from \"./layout-wrapper\"\nimport PropTypes from \"prop-types\"\n\nconst removeNewLines = (str: string): string => str.replace(/\\n/g, ``)\n\nexport const GatsbyImageHydrator: FunctionComponent<{\n as?: ElementType\n style?: CSSProperties\n className?: string\n}> = function GatsbyImageHydrator({ as: Type = `div`, children, ...props }) {\n return {children}\n}\n\nexport const GatsbyImage: FunctionComponent =\n function GatsbyImage({\n as,\n className,\n class: preactClass,\n style,\n image,\n loading = `lazy`,\n imgClassName,\n imgStyle,\n backgroundColor,\n objectFit,\n objectPosition,\n ...props\n }) {\n if (!image) {\n console.warn(`[gatsby-plugin-image] Missing image prop`)\n return null\n }\n if (preactClass) {\n className = preactClass\n }\n imgStyle = {\n objectFit,\n objectPosition,\n backgroundColor,\n ...imgStyle,\n }\n\n const {\n width,\n height,\n layout,\n images,\n placeholder,\n backgroundColor: placeholderBackgroundColor,\n } = image\n\n const {\n style: wStyle,\n className: wClass,\n ...wrapperProps\n } = getWrapperProps(width, height, layout)\n\n const cleanedImages: IGatsbyImageData[\"images\"] = {\n fallback: undefined,\n sources: [],\n }\n if (images.fallback) {\n cleanedImages.fallback = {\n ...images.fallback,\n srcSet: images.fallback.srcSet\n ? removeNewLines(images.fallback.srcSet)\n : undefined,\n }\n }\n\n if (images.sources) {\n cleanedImages.sources = images.sources.map(source => {\n return {\n ...source,\n srcSet: removeNewLines(source.srcSet),\n }\n })\n }\n\n return (\n \n \n \n\n )}\n // When eager is set we want to start the isLoading state on true (we want to load the img without react)\n {...getMainProps(\n loading === `eager`,\n false,\n cleanedImages,\n loading,\n undefined,\n undefined,\n undefined,\n imgStyle\n )}\n />\n \n \n )\n }\n\nexport const altValidator: PropTypes.Validator = (\n props: GatsbyImageProps,\n propName,\n componentName,\n ...rest\n): Error | undefined => {\n if (!props.alt && props.alt !== ``) {\n return new Error(\n `The \"alt\" prop is required in ${componentName}. If the image is purely presentational then pass an empty string: e.g. alt=\"\". Learn more: https://a11y-style-guide.com/style-guide/section-media.html`\n )\n }\n return PropTypes.string(props, propName, componentName, ...rest)\n}\nexport const propTypes = {\n image: PropTypes.object.isRequired,\n alt: altValidator,\n} as WeakValidationMap\n","/* eslint-disable no-unused-expressions */\nimport React, {\n Component,\n ElementType,\n createRef,\n MutableRefObject,\n FunctionComponent,\n ImgHTMLAttributes,\n RefObject,\n CSSProperties,\n} from \"react\"\nimport {\n getWrapperProps,\n hasNativeLazyLoadSupport,\n storeImageloaded,\n hasImageLoaded,\n gatsbyImageIsInstalled,\n} from \"./hooks\"\nimport { PlaceholderProps } from \"./placeholder\"\nimport { MainImageProps } from \"./main-image\"\nimport { Layout } from \"../image-utils\"\nimport { getSizer } from \"./layout-wrapper\"\nimport { propTypes } from \"./gatsby-image.server\"\nimport { Unobserver } from \"./intersection-observer\"\nimport { render } from \"react-dom\"\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport interface GatsbyImageProps\n extends Omit<\n ImgHTMLAttributes,\n \"placeholder\" | \"onLoad\" | \"src\" | \"srcSet\" | \"width\" | \"height\"\n > {\n alt: string\n as?: ElementType\n className?: string\n class?: string\n imgClassName?: string\n image: IGatsbyImageData\n imgStyle?: CSSProperties\n backgroundColor?: string\n objectFit?: CSSProperties[\"objectFit\"]\n objectPosition?: CSSProperties[\"objectPosition\"]\n onLoad?: () => void\n onError?: () => void\n onStartLoad?: (props: { wasCached?: boolean }) => void\n}\n\nexport interface IGatsbyImageData {\n layout: Layout\n width: number\n height: number\n backgroundColor?: string\n images: Pick\n placeholder?: Pick\n}\n\nclass GatsbyImageHydrator extends Component<\n GatsbyImageProps,\n { isLoading: boolean; isLoaded: boolean }\n> {\n root: RefObject = createRef<\n HTMLImageElement | undefined\n >()\n hydrated: MutableRefObject = { current: false }\n forceRender: MutableRefObject = {\n // In dev we use render not hydrate, to avoid hydration warnings\n current: process.env.NODE_ENV === `development`,\n }\n lazyHydrator: () => void | null = null\n ref = createRef()\n unobserveRef: Unobserver\n\n constructor(props) {\n super(props)\n\n this.state = {\n isLoading: hasNativeLazyLoadSupport(),\n isLoaded: false,\n }\n }\n\n _lazyHydrate(props, state): Promise {\n const hasSSRHtml = this.root.current.querySelector(\n `[data-gatsby-image-ssr]`\n )\n // On first server hydration do nothing\n if (hasNativeLazyLoadSupport() && hasSSRHtml && !this.hydrated.current) {\n this.hydrated.current = true\n return Promise.resolve()\n }\n\n return import(`./lazy-hydrate`).then(({ lazyHydrate }) => {\n const cacheKey = JSON.stringify(this.props.image.images)\n this.lazyHydrator = lazyHydrate(\n {\n image: props.image.images,\n isLoading: state.isLoading || hasImageLoaded(cacheKey),\n isLoaded: state.isLoaded || hasImageLoaded(cacheKey),\n toggleIsLoaded: () => {\n props.onLoad?.()\n\n this.setState({\n isLoaded: true,\n })\n },\n ref: this.ref,\n ...props,\n },\n this.root,\n this.hydrated,\n this.forceRender\n )\n })\n }\n\n /**\n * Choose if setupIntersectionObserver should use the image cache or not.\n */\n _setupIntersectionObserver(useCache = true): void {\n import(`./intersection-observer`).then(({ createIntersectionObserver }) => {\n const intersectionObserver = createIntersectionObserver(() => {\n if (this.root.current) {\n const cacheKey = JSON.stringify(this.props.image.images)\n this.props.onStartLoad?.({\n wasCached: useCache && hasImageLoaded(cacheKey),\n })\n this.setState({\n isLoading: true,\n isLoaded: useCache && hasImageLoaded(cacheKey),\n })\n }\n })\n\n if (this.root.current) {\n this.unobserveRef = intersectionObserver(this.root)\n }\n })\n }\n\n shouldComponentUpdate(nextProps, nextState): boolean {\n let hasChanged = false\n if (!this.state.isLoading && nextState.isLoading && !nextState.isLoaded) {\n // Props have changed between SSR and hydration, so we need to force render instead of hydrate\n this.forceRender.current = true\n }\n // this check mostly means people do not have the correct ref checks in place, we want to reset some state to suppport loading effects\n if (this.props.image.images !== nextProps.image.images) {\n // reset state, we'll rely on intersection observer to reload\n if (this.unobserveRef) {\n // unregister intersectionObserver\n this.unobserveRef()\n\n // // on unmount, make sure we cleanup\n if (this.hydrated.current && this.lazyHydrator) {\n render(null, this.root.current)\n }\n }\n\n this.setState(\n {\n isLoading: false,\n isLoaded: false,\n },\n () => {\n this._setupIntersectionObserver(false)\n }\n )\n\n hasChanged = true\n }\n\n if (this.root.current && !hasChanged) {\n this._lazyHydrate(nextProps, nextState)\n }\n\n return false\n }\n\n componentDidMount(): void {\n if (this.root.current) {\n const ssrElement = this.root.current.querySelector(\n `[data-gatsby-image-ssr]`\n ) as HTMLImageElement\n const cacheKey = JSON.stringify(this.props.image.images)\n\n // when SSR and native lazyload is supported we'll do nothing ;)\n if (\n hasNativeLazyLoadSupport() &&\n ssrElement &&\n gatsbyImageIsInstalled()\n ) {\n this.props.onStartLoad?.({ wasCached: false })\n\n // When the image is already loaded before we have hydrated, we trigger onLoad and cache the item\n if (ssrElement.complete) {\n this.props.onLoad?.()\n storeImageloaded(cacheKey)\n } else {\n // We need the current class context (this) inside our named onLoad function\n // The named function is necessary to easily remove the listener afterward.\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n const _this = this\n // add an onLoad to the image\n ssrElement.addEventListener(`load`, function onLoad() {\n ssrElement.removeEventListener(`load`, onLoad)\n\n _this.props.onLoad?.()\n storeImageloaded(cacheKey)\n })\n }\n\n return\n }\n\n // Fallback to custom lazy loading (intersection observer)\n this._setupIntersectionObserver(true)\n }\n }\n\n componentWillUnmount(): void {\n // Cleanup when onmount happens\n if (this.unobserveRef) {\n // unregister intersectionObserver\n this.unobserveRef()\n\n // on unmount, make sure we cleanup\n if (this.hydrated.current && this.lazyHydrator) {\n this.lazyHydrator()\n }\n }\n\n return\n }\n\n render(): JSX.Element {\n const Type = this.props.as || `div`\n const { width, height, layout } = this.props.image\n const {\n style: wStyle,\n className: wClass,\n ...wrapperProps\n } = getWrapperProps(width, height, layout)\n\n let className = this.props.className\n // preact class\n if (this.props.class) {\n className = this.props.class\n }\n\n const sizer = getSizer(layout, width, height)\n\n return (\n \n )\n }\n}\n\nexport const GatsbyImage: FunctionComponent =\n function GatsbyImage(props) {\n if (!props.image) {\n if (process.env.NODE_ENV === `development`) {\n console.warn(`[gatsby-plugin-image] Missing image prop`)\n }\n return null\n }\n\n if (!gatsbyImageIsInstalled() && process.env.NODE_ENV === `development`) {\n console.warn(\n `[gatsby-plugin-image] You're missing out on some cool performance features. Please add \"gatsby-plugin-image\" to your gatsby-config.js`\n )\n }\n const { className, class: classSafe, backgroundColor, image } = props\n const { width, height, layout } = image\n const propsKey = JSON.stringify([\n width,\n height,\n layout,\n className,\n classSafe,\n backgroundColor,\n ])\n return \n }\n\nGatsbyImage.propTypes = propTypes\n\nGatsbyImage.displayName = `GatsbyImage`\n","import React, { FunctionComponent, ReactElement } from \"react\"\nimport {\n altValidator,\n GatsbyImage as GatsbyImageServer,\n} from \"./gatsby-image.server\"\nimport { GatsbyImageProps, IGatsbyImageData } from \"./gatsby-image.browser\"\nimport PropTypes from \"prop-types\"\nimport { ISharpGatsbyImageArgs } from \"../image-utils\"\n\nexport interface IStaticImageProps\n extends Omit,\n Omit {\n src: string\n}\n\n// These values are added by Babel. Do not add them manually\ninterface IPrivateProps {\n __imageData?: IGatsbyImageData\n __error?: string\n}\n\nexport function _getStaticImage(\n GatsbyImage: FunctionComponent\n): React.FC {\n return function StaticImage({\n src,\n __imageData: imageData,\n __error,\n // We extract these because they're not meant to be passed-down to GatsbyImage\n /* eslint-disable @typescript-eslint/no-unused-vars */\n width,\n height,\n aspectRatio,\n tracedSVGOptions,\n placeholder,\n formats,\n quality,\n transformOptions,\n jpgOptions,\n pngOptions,\n webpOptions,\n avifOptions,\n blurredOptions,\n /* eslint-enable @typescript-eslint/no-unused-vars */\n ...props\n }): ReactElement {\n if (__error) {\n console.warn(__error)\n }\n\n if (imageData) {\n return \n }\n console.warn(`Image not loaded`, src)\n if (!__error && process.env.NODE_ENV === `development`) {\n console.warn(\n `Please ensure that \"gatsby-plugin-image\" is included in the plugins array in gatsby-config.js, and that your version of gatsby is at least 2.24.78`\n )\n }\n return null\n }\n}\n\nconst StaticImage: React.FC =\n _getStaticImage(GatsbyImageServer)\n\nconst checkDimensionProps: PropTypes.Validator = (\n props: IStaticImageProps & IPrivateProps,\n propName: keyof IStaticImageProps & IPrivateProps,\n ...rest\n) => {\n if (\n props.layout === `fullWidth` &&\n (propName === `width` || propName === `height`) &&\n props[propName]\n ) {\n return new Error(\n `\"${propName}\" ${props[propName]} may not be passed when layout is fullWidth.`\n )\n }\n return PropTypes.number(props, propName, ...rest)\n}\n\nconst validLayouts = new Set([`fixed`, `fullWidth`, `constrained`])\n\nexport const propTypes = {\n src: PropTypes.string.isRequired,\n alt: altValidator,\n width: checkDimensionProps,\n height: checkDimensionProps,\n sizes: PropTypes.string,\n layout: (props: IStaticImageProps & IPrivateProps): Error | undefined => {\n if (props.layout === undefined) {\n return undefined\n }\n if (validLayouts.has(props.layout)) {\n return undefined\n }\n\n return new Error(\n `Invalid value ${props.layout}\" provided for prop \"layout\". Defaulting to \"constrained\". Valid values are \"fixed\", \"fullWidth\" or \"constrained\".`\n )\n },\n}\n\nStaticImage.displayName = `StaticImage`\nStaticImage.propTypes = propTypes\n\nexport { StaticImage }\n","import {\n GatsbyImage as GatsbyImageBrowser,\n IGatsbyImageData,\n} from \"./gatsby-image.browser\"\nimport React from \"react\"\nimport {\n _getStaticImage,\n propTypes,\n IStaticImageProps,\n} from \"./static-image.server\"\n// These values are added by Babel. Do not add them manually\ninterface IPrivateProps {\n __imageData?: IGatsbyImageData\n __error?: string\n}\n\nconst StaticImage: React.FC =\n _getStaticImage(GatsbyImageBrowser)\n\nStaticImage.displayName = `StaticImage`\nStaticImage.propTypes = propTypes\n\nexport { StaticImage }\n","import * as React from \"react\"\nexport function LaterHydrator({\n children,\n}: React.PropsWithChildren>): React.ReactNode {\n React.useEffect(() => {\n // eslint-disable-next-line no-unused-expressions\n import(`./lazy-hydrate`)\n }, [])\n\n return children\n}\n","import React from \"react\"\nimport { LaterHydrator } from \".\"\n\nexport function wrapRootElement({ element }) {\n return {element}\n}\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _styledComponents = require(\"styled-components\");\n\n// eslint-disable-next-line react/prop-types,react/display-name\nexports.wrapRootElement = function (_ref, pluginOptions) {\n var element = _ref.element;\n return /*#__PURE__*/_react.default.createElement(_styledComponents.StyleSheetManager, {\n disableVendorPrefixes: (pluginOptions === null || pluginOptions === void 0 ? void 0 : pluginOptions.disableVendorPrefixes) === true\n }, element);\n};","const WebFont = require('webfontloader')\n\nexports.onInitialClientRender = (a, options) => {\n\toptions = { ...options }\n\tdelete options.plugins\n\tWebFont.load(options)\n}","import invariant from \"invariant\";\n\n////////////////////////////////////////////////////////////////////////////////\n// startsWith(string, search) - Check if `string` starts with `search`\nvar startsWith = function startsWith(string, search) {\n return string.substr(0, search.length) === search;\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// pick(routes, uri)\n//\n// Ranks and picks the best route to match. Each segment gets the highest\n// amount of points, then the type of segment gets an additional amount of\n// points where\n//\n// static > dynamic > splat > root\n//\n// This way we don't have to worry about the order of our routes, let the\n// computers do it.\n//\n// A route looks like this\n//\n// { path, default, value }\n//\n// And a returned match looks like:\n//\n// { route, params, uri }\n//\n// I know, I should use TypeScript not comments for these types.\nvar pick = function pick(routes, uri) {\n var match = void 0;\n var default_ = void 0;\n var _uri$split = uri.split(\"?\"),\n uriPathname = _uri$split[0];\n var uriSegments = segmentize(uriPathname);\n var isRootUri = uriSegments[0] === \"\";\n var ranked = rankRoutes(routes);\n for (var i = 0, l = ranked.length; i < l; i++) {\n var missed = false;\n var route = ranked[i].route;\n if (route.default) {\n default_ = {\n route: route,\n params: {},\n uri: uri\n };\n continue;\n }\n var routeSegments = segmentize(route.path);\n var params = {};\n var max = Math.max(uriSegments.length, routeSegments.length);\n var index = 0;\n for (; index < max; index++) {\n var routeSegment = routeSegments[index];\n var uriSegment = uriSegments[index];\n if (isSplat(routeSegment)) {\n // Hit a splat, just grab the rest, and return a match\n // uri: /files/documents/work\n // route: /files/*\n var param = routeSegment.slice(1) || \"*\";\n params[param] = uriSegments.slice(index).map(decodeURIComponent).join(\"/\");\n break;\n }\n if (uriSegment === undefined) {\n // URI is shorter than the route, no match\n // uri: /users\n // route: /users/:userId\n missed = true;\n break;\n }\n var dynamicMatch = paramRe.exec(routeSegment);\n if (dynamicMatch && !isRootUri) {\n var matchIsNotReserved = reservedNames.indexOf(dynamicMatch[1]) === -1;\n !matchIsNotReserved ? process.env.NODE_ENV !== \"production\" ? invariant(false, \" dynamic segment \\\"\" + dynamicMatch[1] + \"\\\" is a reserved name. Please use a different name in path \\\"\" + route.path + \"\\\".\") : invariant(false) : void 0;\n var value = decodeURIComponent(uriSegment);\n params[dynamicMatch[1]] = value;\n } else if (routeSegment !== uriSegment) {\n // Current segments don't match, not dynamic, not splat, so no match\n // uri: /users/123/settings\n // route: /users/:id/profile\n missed = true;\n break;\n }\n }\n if (!missed) {\n match = {\n route: route,\n params: params,\n uri: \"/\" + uriSegments.slice(0, index).join(\"/\")\n };\n break;\n }\n }\n return match || default_ || null;\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// match(path, uri) - Matches just one path to a uri, also lol\nvar match = function match(path, uri) {\n return pick([{\n path: path\n }], uri);\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// resolve(to, basepath)\n//\n// Resolves URIs as though every path is a directory, no files. Relative URIs\n// in the browser can feel awkward because not only can you be \"in a directory\"\n// you can be \"at a file\", too. For example\n//\n// browserSpecResolve('foo', '/bar/') => /bar/foo\n// browserSpecResolve('foo', '/bar') => /foo\n//\n// But on the command line of a file system, it's not as complicated, you can't\n// `cd` from a file, only directories. This way, links have to know less about\n// their current path. To go deeper you can do this:\n//\n// \n// // instead of\n// \n//\n// Just like `cd`, if you want to go deeper from the command line, you do this:\n//\n// cd deeper\n// # not\n// cd $(pwd)/deeper\n//\n// By treating every path as a directory, linking to relative paths should\n// require less contextual information and (fingers crossed) be more intuitive.\nvar resolve = function resolve(to, base) {\n // /foo/bar, /baz/qux => /foo/bar\n if (startsWith(to, \"/\")) {\n return to;\n }\n var _to$split = to.split(\"?\"),\n toPathname = _to$split[0],\n toQuery = _to$split[1];\n var _base$split = base.split(\"?\"),\n basePathname = _base$split[0];\n var toSegments = segmentize(toPathname);\n var baseSegments = segmentize(basePathname);\n\n // ?a=b, /users?b=c => /users?a=b\n if (toSegments[0] === \"\") {\n return addQuery(basePathname, toQuery);\n }\n\n // profile, /users/789 => /users/789/profile\n if (!startsWith(toSegments[0], \".\")) {\n var pathname = baseSegments.concat(toSegments).join(\"/\");\n return addQuery((basePathname === \"/\" ? \"\" : \"/\") + pathname, toQuery);\n }\n\n // ./ /users/123 => /users/123\n // ../ /users/123 => /users\n // ../.. /users/123 => /\n // ../../one /a/b/c/d => /a/b/one\n // .././one /a/b/c/d => /a/b/c/one\n var allSegments = baseSegments.concat(toSegments);\n var segments = [];\n for (var i = 0, l = allSegments.length; i < l; i++) {\n var segment = allSegments[i];\n if (segment === \"..\") segments.pop();else if (segment !== \".\") segments.push(segment);\n }\n return addQuery(\"/\" + segments.join(\"/\"), toQuery);\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// insertParams(path, params)\n\nvar insertParams = function insertParams(path, params) {\n var _path$split = path.split(\"?\"),\n pathBase = _path$split[0],\n _path$split$ = _path$split[1],\n query = _path$split$ === undefined ? \"\" : _path$split$;\n var segments = segmentize(pathBase);\n var constructedPath = \"/\" + segments.map(function (segment) {\n var match = paramRe.exec(segment);\n return match ? params[match[1]] : segment;\n }).join(\"/\");\n var _params$location = params.location;\n _params$location = _params$location === undefined ? {} : _params$location;\n var _params$location$sear = _params$location.search,\n search = _params$location$sear === undefined ? \"\" : _params$location$sear;\n var searchSplit = search.split(\"?\")[1] || \"\";\n constructedPath = addQuery(constructedPath, query, searchSplit);\n return constructedPath;\n};\nvar validateRedirect = function validateRedirect(from, to) {\n var filter = function filter(segment) {\n return isDynamic(segment);\n };\n var fromString = segmentize(from).filter(filter).sort().join(\"/\");\n var toString = segmentize(to).filter(filter).sort().join(\"/\");\n return fromString === toString;\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// Junk\nvar paramRe = /^:(.+)/;\nvar SEGMENT_POINTS = 4;\nvar STATIC_POINTS = 3;\nvar DYNAMIC_POINTS = 2;\nvar SPLAT_PENALTY = 1;\nvar ROOT_POINTS = 1;\nvar isRootSegment = function isRootSegment(segment) {\n return segment === \"\";\n};\nvar isDynamic = function isDynamic(segment) {\n return paramRe.test(segment);\n};\nvar isSplat = function isSplat(segment) {\n return segment && segment[0] === \"*\";\n};\nvar rankRoute = function rankRoute(route, index) {\n var score = route.default ? 0 : segmentize(route.path).reduce(function (score, segment) {\n score += SEGMENT_POINTS;\n if (isRootSegment(segment)) score += ROOT_POINTS;else if (isDynamic(segment)) score += DYNAMIC_POINTS;else if (isSplat(segment)) score -= SEGMENT_POINTS + SPLAT_PENALTY;else score += STATIC_POINTS;\n return score;\n }, 0);\n return {\n route: route,\n score: score,\n index: index\n };\n};\nvar rankRoutes = function rankRoutes(routes) {\n return routes.map(rankRoute).sort(function (a, b) {\n return a.score < b.score ? 1 : a.score > b.score ? -1 : a.index - b.index;\n });\n};\nvar segmentize = function segmentize(uri) {\n return uri\n // strip starting/ending slashes\n .replace(/(^\\/+|\\/+$)/g, \"\").split(\"/\");\n};\nvar addQuery = function addQuery(pathname) {\n for (var _len = arguments.length, query = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n query[_key - 1] = arguments[_key];\n }\n query = query.filter(function (q) {\n return q && q.length > 0;\n });\n return pathname + (query && query.length > 0 ? \"?\" + query.join(\"&\") : \"\");\n};\nvar reservedNames = [\"uri\", \"path\"];\n\n/**\n * Shallow compares two objects.\n * @param {Object} obj1 The first object to compare.\n * @param {Object} obj2 The second object to compare.\n */\nvar shallowCompare = function shallowCompare(obj1, obj2) {\n var obj1Keys = Object.keys(obj1);\n return obj1Keys.length === Object.keys(obj2).length && obj1Keys.every(function (key) {\n return obj2.hasOwnProperty(key) && obj1[key] === obj2[key];\n });\n};\n\n////////////////////////////////////////////////////////////////////////////////\nexport { startsWith, pick, match, resolve, insertParams, validateRedirect, shallowCompare };","var _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n};\nvar getLocation = function getLocation(source) {\n var _source$location = source.location,\n search = _source$location.search,\n hash = _source$location.hash,\n href = _source$location.href,\n origin = _source$location.origin,\n protocol = _source$location.protocol,\n host = _source$location.host,\n hostname = _source$location.hostname,\n port = _source$location.port;\n var pathname = source.location.pathname;\n if (!pathname && href && canUseDOM) {\n var url = new URL(href);\n pathname = url.pathname;\n }\n return {\n pathname: encodeURI(decodeURI(pathname)),\n search: search,\n hash: hash,\n href: href,\n origin: origin,\n protocol: protocol,\n host: host,\n hostname: hostname,\n port: port,\n state: source.history.state,\n key: source.history.state && source.history.state.key || \"initial\"\n };\n};\nvar createHistory = function createHistory(source, options) {\n var listeners = [];\n var location = getLocation(source);\n var transitioning = false;\n var resolveTransition = function resolveTransition() {};\n return {\n get location() {\n return location;\n },\n get transitioning() {\n return transitioning;\n },\n _onTransitionComplete: function _onTransitionComplete() {\n transitioning = false;\n resolveTransition();\n },\n listen: function listen(listener) {\n listeners.push(listener);\n var popstateListener = function popstateListener() {\n location = getLocation(source);\n listener({\n location: location,\n action: \"POP\"\n });\n };\n source.addEventListener(\"popstate\", popstateListener);\n return function () {\n source.removeEventListener(\"popstate\", popstateListener);\n listeners = listeners.filter(function (fn) {\n return fn !== listener;\n });\n };\n },\n navigate: function navigate(to) {\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n state = _ref.state,\n _ref$replace = _ref.replace,\n replace = _ref$replace === undefined ? false : _ref$replace;\n if (typeof to === \"number\") {\n source.history.go(to);\n } else {\n state = _extends({}, state, {\n key: Date.now() + \"\"\n });\n // try...catch iOS Safari limits to 100 pushState calls\n try {\n if (transitioning || replace) {\n source.history.replaceState(state, null, to);\n } else {\n source.history.pushState(state, null, to);\n }\n } catch (e) {\n source.location[replace ? \"replace\" : \"assign\"](to);\n }\n }\n location = getLocation(source);\n transitioning = true;\n var transition = new Promise(function (res) {\n return resolveTransition = res;\n });\n listeners.forEach(function (listener) {\n return listener({\n location: location,\n action: \"PUSH\"\n });\n });\n return transition;\n }\n };\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// Stores history entries in memory for testing or other platforms like Native\nvar createMemorySource = function createMemorySource() {\n var initialPath = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : \"/\";\n var searchIndex = initialPath.indexOf(\"?\");\n var initialLocation = {\n pathname: searchIndex > -1 ? initialPath.substr(0, searchIndex) : initialPath,\n search: searchIndex > -1 ? initialPath.substr(searchIndex) : \"\"\n };\n var index = 0;\n var stack = [initialLocation];\n var states = [null];\n return {\n get location() {\n return stack[index];\n },\n addEventListener: function addEventListener(name, fn) {},\n removeEventListener: function removeEventListener(name, fn) {},\n history: {\n get entries() {\n return stack;\n },\n get index() {\n return index;\n },\n get state() {\n return states[index];\n },\n pushState: function pushState(state, _, uri) {\n var _uri$split = uri.split(\"?\"),\n pathname = _uri$split[0],\n _uri$split$ = _uri$split[1],\n search = _uri$split$ === undefined ? \"\" : _uri$split$;\n index++;\n stack.push({\n pathname: pathname,\n search: search.length ? \"?\" + search : search\n });\n states.push(state);\n },\n replaceState: function replaceState(state, _, uri) {\n var _uri$split2 = uri.split(\"?\"),\n pathname = _uri$split2[0],\n _uri$split2$ = _uri$split2[1],\n search = _uri$split2$ === undefined ? \"\" : _uri$split2$;\n stack[index] = {\n pathname: pathname,\n search: search\n };\n states[index] = state;\n },\n go: function go(to) {\n var newIndex = index + to;\n if (newIndex < 0 || newIndex > states.length - 1) {\n return;\n }\n index = newIndex;\n }\n }\n };\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// global history - uses window.history as the source if available, otherwise a\n// memory history\nvar canUseDOM = !!(typeof window !== \"undefined\" && window.document && window.document.createElement);\nvar getSource = function getSource() {\n return canUseDOM ? window : createMemorySource();\n};\nvar globalHistory = createHistory(getSource());\nvar navigate = globalHistory.navigate;\n\n////////////////////////////////////////////////////////////////////////////////\n\nexport { globalHistory, navigate, createHistory, createMemorySource };","var _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n};\nfunction _objectWithoutProperties(obj, keys) {\n var target = {};\n for (var i in obj) {\n if (keys.indexOf(i) >= 0) continue;\n if (!Object.prototype.hasOwnProperty.call(obj, i)) continue;\n target[i] = obj[i];\n }\n return target;\n}\nfunction _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nfunction _possibleConstructorReturn(self, call) {\n if (!self) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self;\n}\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass);\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n enumerable: false,\n writable: true,\n configurable: true\n }\n });\n if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;\n}\n\n/* eslint-disable jsx-a11y/anchor-has-content */\nimport React, { useContext, createContext } from \"react\";\nimport invariant from \"invariant\";\nimport { polyfill } from \"react-lifecycles-compat\";\nimport { startsWith, pick, resolve, match, insertParams, validateRedirect, shallowCompare } from \"./lib/utils\";\nimport { globalHistory, navigate, createHistory, createMemorySource } from \"./lib/history\";\n\n////////////////////////////////////////////////////////////////////////////////\n\nvar createNamedContext = function createNamedContext(name, defaultValue) {\n var Ctx = createContext(defaultValue);\n Ctx.displayName = name;\n return Ctx;\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// Location Context/Provider\nvar LocationContext = createNamedContext(\"Location\");\n\n// sets up a listener if there isn't one already so apps don't need to be\n// wrapped in some top level provider\nvar Location = function Location(_ref) {\n var children = _ref.children;\n return React.createElement(LocationContext.Consumer, null, function (context) {\n return context ? children(context) : React.createElement(LocationProvider, null, children);\n });\n};\nvar LocationProvider = function (_React$Component) {\n _inherits(LocationProvider, _React$Component);\n function LocationProvider() {\n var _temp, _this, _ret;\n _classCallCheck(this, LocationProvider);\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return _ret = (_temp = (_this = _possibleConstructorReturn(this, _React$Component.call.apply(_React$Component, [this].concat(args))), _this), _this.state = {\n context: _this.getContext(),\n refs: {\n unlisten: null\n }\n }, _temp), _possibleConstructorReturn(_this, _ret);\n }\n LocationProvider.prototype.getContext = function getContext() {\n var _props$history = this.props.history,\n navigate = _props$history.navigate,\n location = _props$history.location;\n return {\n navigate: navigate,\n location: location\n };\n };\n LocationProvider.prototype.componentDidCatch = function componentDidCatch(error, info) {\n if (isRedirect(error)) {\n var _navigate = this.props.history.navigate;\n _navigate(error.uri, {\n replace: true\n });\n } else {\n throw error;\n }\n };\n LocationProvider.prototype.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n if (prevState.context.location !== this.state.context.location) {\n this.props.history._onTransitionComplete();\n }\n };\n LocationProvider.prototype.componentDidMount = function componentDidMount() {\n var _this2 = this;\n var refs = this.state.refs,\n history = this.props.history;\n history._onTransitionComplete();\n refs.unlisten = history.listen(function () {\n Promise.resolve().then(function () {\n // TODO: replace rAF with react deferred update API when it's ready https://github.com/facebook/react/issues/13306\n requestAnimationFrame(function () {\n if (!_this2.unmounted) {\n _this2.setState(function () {\n return {\n context: _this2.getContext()\n };\n });\n }\n });\n });\n });\n };\n LocationProvider.prototype.componentWillUnmount = function componentWillUnmount() {\n var refs = this.state.refs;\n this.unmounted = true;\n refs.unlisten();\n };\n LocationProvider.prototype.render = function render() {\n var context = this.state.context,\n children = this.props.children;\n return React.createElement(LocationContext.Provider, {\n value: context\n }, typeof children === \"function\" ? children(context) : children || null);\n };\n return LocationProvider;\n}(React.Component);\n\n////////////////////////////////////////////////////////////////////////////////\n\nLocationProvider.defaultProps = {\n history: globalHistory\n};\nprocess.env.NODE_ENV !== \"production\" ? void 0 : void 0;\nvar ServerLocation = function ServerLocation(_ref2) {\n var url = _ref2.url,\n children = _ref2.children;\n var searchIndex = url.indexOf(\"?\");\n var searchExists = searchIndex > -1;\n var pathname = void 0;\n var search = \"\";\n var hash = \"\";\n if (searchExists) {\n pathname = url.substring(0, searchIndex);\n search = url.substring(searchIndex);\n } else {\n pathname = url;\n }\n return React.createElement(LocationContext.Provider, {\n value: {\n location: {\n pathname: pathname,\n search: search,\n hash: hash\n },\n navigate: function navigate() {\n throw new Error(\"You can't call navigate on the server.\");\n }\n }\n }, children);\n};\n////////////////////////////////////////////////////////////////////////////////\n// Sets baseuri and basepath for nested routers and links\nvar BaseContext = createNamedContext(\"Base\", {\n baseuri: \"/\",\n basepath: \"/\",\n navigate: globalHistory.navigate\n});\n\n////////////////////////////////////////////////////////////////////////////////\n// The main event, welcome to the show everybody.\nvar Router = function Router(props) {\n return React.createElement(BaseContext.Consumer, null, function (baseContext) {\n return React.createElement(Location, null, function (locationContext) {\n return React.createElement(RouterImpl, _extends({}, baseContext, locationContext, props));\n });\n });\n};\nvar RouterImpl = function (_React$PureComponent) {\n _inherits(RouterImpl, _React$PureComponent);\n function RouterImpl() {\n _classCallCheck(this, RouterImpl);\n return _possibleConstructorReturn(this, _React$PureComponent.apply(this, arguments));\n }\n RouterImpl.prototype.render = function render() {\n var _props = this.props,\n location = _props.location,\n _navigate2 = _props.navigate,\n basepath = _props.basepath,\n primary = _props.primary,\n children = _props.children,\n baseuri = _props.baseuri,\n _props$component = _props.component,\n component = _props$component === undefined ? \"div\" : _props$component,\n domProps = _objectWithoutProperties(_props, [\"location\", \"navigate\", \"basepath\", \"primary\", \"children\", \"baseuri\", \"component\"]);\n var routes = React.Children.toArray(children).reduce(function (array, child) {\n var routes = createRoute(basepath)(child);\n return array.concat(routes);\n }, []);\n var pathname = location.pathname;\n var match = pick(routes, pathname);\n if (match) {\n var params = match.params,\n uri = match.uri,\n route = match.route,\n element = match.route.value;\n\n // remove the /* from the end for child routes relative paths\n\n basepath = route.default ? basepath : route.path.replace(/\\*$/, \"\");\n var props = _extends({}, params, {\n uri: uri,\n location: location,\n navigate: function navigate(to, options) {\n return _navigate2(resolve(to, uri), options);\n }\n });\n var clone = React.cloneElement(element, props, element.props.children ? React.createElement(Router, {\n location: location,\n primary: primary\n }, element.props.children) : undefined);\n\n // using 'div' for < 16.3 support\n var FocusWrapper = primary ? FocusHandler : component;\n // don't pass any props to 'div'\n var wrapperProps = primary ? _extends({\n uri: uri,\n location: location,\n component: component\n }, domProps) : domProps;\n return React.createElement(BaseContext.Provider, {\n value: {\n baseuri: uri,\n basepath: basepath,\n navigate: props.navigate\n }\n }, React.createElement(FocusWrapper, wrapperProps, clone));\n } else {\n // Not sure if we want this, would require index routes at every level\n // warning(\n // false,\n // `\\n\\nNothing matched:\\n\\t${\n // location.pathname\n // }\\n\\nPaths checked: \\n\\t${routes\n // .map(route => route.path)\n // .join(\n // \"\\n\\t\"\n // )}\\n\\nTo get rid of this warning, add a default NotFound component as child of Router:\n // \\n\\tlet NotFound = () =>
Not Found!
\n // \\n\\t\\n\\t \\n\\t {/* ... */}\\n\\t`\n // );\n return null;\n }\n };\n return RouterImpl;\n}(React.PureComponent);\nRouterImpl.defaultProps = {\n primary: true\n};\nvar FocusContext = createNamedContext(\"Focus\");\nvar FocusHandler = function FocusHandler(_ref3) {\n var uri = _ref3.uri,\n location = _ref3.location,\n component = _ref3.component,\n domProps = _objectWithoutProperties(_ref3, [\"uri\", \"location\", \"component\"]);\n return React.createElement(FocusContext.Consumer, null, function (requestFocus) {\n return React.createElement(FocusHandlerImpl, _extends({}, domProps, {\n component: component,\n requestFocus: requestFocus,\n uri: uri,\n location: location\n }));\n });\n};\n\n// don't focus on initial render\nvar initialRender = true;\nvar focusHandlerCount = 0;\nvar FocusHandlerImpl = function (_React$Component2) {\n _inherits(FocusHandlerImpl, _React$Component2);\n function FocusHandlerImpl() {\n var _temp2, _this4, _ret2;\n _classCallCheck(this, FocusHandlerImpl);\n for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n return _ret2 = (_temp2 = (_this4 = _possibleConstructorReturn(this, _React$Component2.call.apply(_React$Component2, [this].concat(args))), _this4), _this4.state = {}, _this4.requestFocus = function (node) {\n if (!_this4.state.shouldFocus && node) {\n node.focus();\n }\n }, _temp2), _possibleConstructorReturn(_this4, _ret2);\n }\n FocusHandlerImpl.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, prevState) {\n var initial = prevState.uri == null;\n if (initial) {\n return _extends({\n shouldFocus: true\n }, nextProps);\n } else {\n var myURIChanged = nextProps.uri !== prevState.uri;\n var navigatedUpToMe = prevState.location.pathname !== nextProps.location.pathname && nextProps.location.pathname === nextProps.uri;\n return _extends({\n shouldFocus: myURIChanged || navigatedUpToMe\n }, nextProps);\n }\n };\n FocusHandlerImpl.prototype.componentDidMount = function componentDidMount() {\n focusHandlerCount++;\n this.focus();\n };\n FocusHandlerImpl.prototype.componentWillUnmount = function componentWillUnmount() {\n focusHandlerCount--;\n if (focusHandlerCount === 0) {\n initialRender = true;\n }\n };\n FocusHandlerImpl.prototype.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n if (prevProps.location !== this.props.location && this.state.shouldFocus) {\n this.focus();\n }\n };\n FocusHandlerImpl.prototype.focus = function focus() {\n if (process.env.NODE_ENV === \"test\") {\n // getting cannot read property focus of null in the tests\n // and that bit of global `initialRender` state causes problems\n // should probably figure it out!\n return;\n }\n var requestFocus = this.props.requestFocus;\n if (requestFocus) {\n requestFocus(this.node);\n } else {\n if (initialRender) {\n initialRender = false;\n } else if (this.node) {\n // React polyfills [autofocus] and it fires earlier than cDM,\n // so we were stealing focus away, this line prevents that.\n if (!this.node.contains(document.activeElement)) {\n this.node.focus();\n }\n }\n }\n };\n FocusHandlerImpl.prototype.render = function render() {\n var _this5 = this;\n var _props2 = this.props,\n children = _props2.children,\n style = _props2.style,\n requestFocus = _props2.requestFocus,\n _props2$component = _props2.component,\n Comp = _props2$component === undefined ? \"div\" : _props2$component,\n uri = _props2.uri,\n location = _props2.location,\n domProps = _objectWithoutProperties(_props2, [\"children\", \"style\", \"requestFocus\", \"component\", \"uri\", \"location\"]);\n return React.createElement(Comp, _extends({\n style: _extends({\n outline: \"none\"\n }, style),\n tabIndex: \"-1\",\n ref: function ref(n) {\n return _this5.node = n;\n }\n }, domProps), React.createElement(FocusContext.Provider, {\n value: this.requestFocus\n }, this.props.children));\n };\n return FocusHandlerImpl;\n}(React.Component);\npolyfill(FocusHandlerImpl);\nvar k = function k() {};\n\n////////////////////////////////////////////////////////////////////////////////\nvar forwardRef = React.forwardRef;\nif (typeof forwardRef === \"undefined\") {\n forwardRef = function forwardRef(C) {\n return C;\n };\n}\nvar Link = forwardRef(function (_ref4, ref) {\n var innerRef = _ref4.innerRef,\n props = _objectWithoutProperties(_ref4, [\"innerRef\"]);\n return React.createElement(BaseContext.Consumer, null, function (_ref5) {\n var basepath = _ref5.basepath,\n baseuri = _ref5.baseuri;\n return React.createElement(Location, null, function (_ref6) {\n var location = _ref6.location,\n navigate = _ref6.navigate;\n var to = props.to,\n state = props.state,\n replace = props.replace,\n _props$getProps = props.getProps,\n getProps = _props$getProps === undefined ? k : _props$getProps,\n anchorProps = _objectWithoutProperties(props, [\"to\", \"state\", \"replace\", \"getProps\"]);\n var href = resolve(to, baseuri);\n var encodedHref = encodeURI(href);\n var isCurrent = location.pathname === encodedHref;\n var isPartiallyCurrent = startsWith(location.pathname, encodedHref);\n return React.createElement(\"a\", _extends({\n ref: ref || innerRef,\n \"aria-current\": isCurrent ? \"page\" : undefined\n }, anchorProps, getProps({\n isCurrent: isCurrent,\n isPartiallyCurrent: isPartiallyCurrent,\n href: href,\n location: location\n }), {\n href: href,\n onClick: function onClick(event) {\n if (anchorProps.onClick) anchorProps.onClick(event);\n if (shouldNavigate(event)) {\n event.preventDefault();\n var shouldReplace = replace;\n if (typeof replace !== \"boolean\" && isCurrent) {\n var _location$state = _extends({}, location.state),\n key = _location$state.key,\n restState = _objectWithoutProperties(_location$state, [\"key\"]);\n shouldReplace = shallowCompare(_extends({}, state), restState);\n }\n navigate(href, {\n state: state,\n replace: shouldReplace\n });\n }\n }\n }));\n });\n });\n});\nLink.displayName = \"Link\";\nprocess.env.NODE_ENV !== \"production\" ? void 0 : void 0;\n\n////////////////////////////////////////////////////////////////////////////////\nfunction RedirectRequest(uri) {\n this.uri = uri;\n}\nvar isRedirect = function isRedirect(o) {\n return o instanceof RedirectRequest;\n};\nvar redirectTo = function redirectTo(to) {\n throw new RedirectRequest(to);\n};\nvar RedirectImpl = function (_React$Component3) {\n _inherits(RedirectImpl, _React$Component3);\n function RedirectImpl() {\n _classCallCheck(this, RedirectImpl);\n return _possibleConstructorReturn(this, _React$Component3.apply(this, arguments));\n }\n\n // Support React < 16 with this hook\n RedirectImpl.prototype.componentDidMount = function componentDidMount() {\n var _props3 = this.props,\n navigate = _props3.navigate,\n to = _props3.to,\n from = _props3.from,\n _props3$replace = _props3.replace,\n replace = _props3$replace === undefined ? true : _props3$replace,\n state = _props3.state,\n noThrow = _props3.noThrow,\n baseuri = _props3.baseuri,\n props = _objectWithoutProperties(_props3, [\"navigate\", \"to\", \"from\", \"replace\", \"state\", \"noThrow\", \"baseuri\"]);\n Promise.resolve().then(function () {\n var resolvedTo = resolve(to, baseuri);\n navigate(insertParams(resolvedTo, props), {\n replace: replace,\n state: state\n });\n });\n };\n RedirectImpl.prototype.render = function render() {\n var _props4 = this.props,\n navigate = _props4.navigate,\n to = _props4.to,\n from = _props4.from,\n replace = _props4.replace,\n state = _props4.state,\n noThrow = _props4.noThrow,\n baseuri = _props4.baseuri,\n props = _objectWithoutProperties(_props4, [\"navigate\", \"to\", \"from\", \"replace\", \"state\", \"noThrow\", \"baseuri\"]);\n var resolvedTo = resolve(to, baseuri);\n if (!noThrow) redirectTo(insertParams(resolvedTo, props));\n return null;\n };\n return RedirectImpl;\n}(React.Component);\nvar Redirect = function Redirect(props) {\n return React.createElement(BaseContext.Consumer, null, function (_ref7) {\n var baseuri = _ref7.baseuri;\n return React.createElement(Location, null, function (locationContext) {\n return React.createElement(RedirectImpl, _extends({}, locationContext, {\n baseuri: baseuri\n }, props));\n });\n });\n};\nprocess.env.NODE_ENV !== \"production\" ? void 0 : void 0;\n\n////////////////////////////////////////////////////////////////////////////////\nvar Match = function Match(_ref8) {\n var path = _ref8.path,\n children = _ref8.children;\n return React.createElement(BaseContext.Consumer, null, function (_ref9) {\n var baseuri = _ref9.baseuri;\n return React.createElement(Location, null, function (_ref10) {\n var navigate = _ref10.navigate,\n location = _ref10.location;\n var resolvedPath = resolve(path, baseuri);\n var result = match(resolvedPath, location.pathname);\n return children({\n navigate: navigate,\n location: location,\n match: result ? _extends({}, result.params, {\n uri: result.uri,\n path: path\n }) : null\n });\n });\n });\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// Hooks\n\nvar useLocation = function useLocation() {\n var context = useContext(LocationContext);\n if (!context) {\n throw new Error(\"useLocation hook was used but a LocationContext.Provider was not found in the parent tree. Make sure this is used in a component that is a child of Router\");\n }\n return context.location;\n};\nvar useNavigate = function useNavigate() {\n var context = useContext(BaseContext);\n if (!context) {\n throw new Error(\"useNavigate hook was used but a BaseContext.Provider was not found in the parent tree. Make sure this is used in a component that is a child of Router\");\n }\n return context.navigate;\n};\nvar useParams = function useParams() {\n var context = useContext(BaseContext);\n if (!context) {\n throw new Error(\"useParams hook was used but a LocationContext.Provider was not found in the parent tree. Make sure this is used in a component that is a child of Router\");\n }\n var location = useLocation();\n var results = match(context.basepath, location.pathname);\n return results ? results.params : null;\n};\nvar useMatch = function useMatch(path) {\n if (!path) {\n throw new Error(\"useMatch(path: string) requires an argument of a string to match against\");\n }\n var context = useContext(BaseContext);\n if (!context) {\n throw new Error(\"useMatch hook was used but a LocationContext.Provider was not found in the parent tree. Make sure this is used in a component that is a child of Router\");\n }\n var location = useLocation();\n var resolvedPath = resolve(path, context.baseuri);\n var result = match(resolvedPath, location.pathname);\n return result ? _extends({}, result.params, {\n uri: result.uri,\n path: path\n }) : null;\n};\n\n////////////////////////////////////////////////////////////////////////////////\n// Junk\nvar stripSlashes = function stripSlashes(str) {\n return str.replace(/(^\\/+|\\/+$)/g, \"\");\n};\nvar createRoute = function createRoute(basepath) {\n return function (element) {\n if (!element) {\n return null;\n }\n if (element.type === React.Fragment && element.props.children) {\n return React.Children.map(element.props.children, createRoute(basepath));\n }\n !(element.props.path || element.props.default || element.type === Redirect) ? process.env.NODE_ENV !== \"production\" ? invariant(false, \": Children of must have a `path` or `default` prop, or be a ``. None found on element type `\" + element.type + \"`\") : invariant(false) : void 0;\n !!(element.type === Redirect && (!element.props.from || !element.props.to)) ? process.env.NODE_ENV !== \"production\" ? invariant(false, \" requires both \\\"from\\\" and \\\"to\\\" props when inside a .\") : invariant(false) : void 0;\n !!(element.type === Redirect && !validateRedirect(element.props.from, element.props.to)) ? process.env.NODE_ENV !== \"production\" ? invariant(false, \" has mismatched dynamic segments, ensure both paths have the exact same dynamic segments.\") : invariant(false) : void 0;\n if (element.props.default) {\n return {\n value: element,\n default: true\n };\n }\n var elementPath = element.type === Redirect ? element.props.from : element.props.path;\n var path = elementPath === \"/\" ? basepath : stripSlashes(basepath) + \"/\" + stripSlashes(elementPath);\n return {\n value: element,\n default: element.props.default,\n path: element.props.children ? stripSlashes(path) + \"/*\" : path\n };\n };\n};\nvar shouldNavigate = function shouldNavigate(event) {\n return !event.defaultPrevented && event.button === 0 && !(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n};\n\n////////////////////////////////////////////////////////////////////////\nexport { Link, Location, LocationProvider, Match, Redirect, Router, ServerLocation, createHistory, createMemorySource, isRedirect, navigate, redirectTo, globalHistory, match as matchPath, useLocation, useNavigate, useParams, useMatch, resolve , BaseContext };","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\n/**\n * Use invariant() to assert state which your program assumes to be true.\n *\n * Provide sprintf-style format (only %s is supported) and arguments\n * to provide information about what broke and what you were\n * expecting.\n *\n * The invariant message will be stripped in production, but the invariant\n * will remain to ensure logic does not differ in production.\n */\n\nvar invariant = function(condition, format, a, b, c, d, e, f) {\n if (process.env.NODE_ENV !== 'production') {\n if (format === undefined) {\n throw new Error('invariant requires an error message argument');\n }\n }\n\n if (!condition) {\n var error;\n if (format === undefined) {\n error = new Error(\n 'Minified exception occurred; use the non-minified dev environment ' +\n 'for the full error message and additional helpful warnings.'\n );\n } else {\n var args = [a, b, c, d, e, f];\n var argIndex = 0;\n error = new Error(\n format.replace(/%s/g, function() { return args[argIndex++]; })\n );\n error.name = 'Invariant Violation';\n }\n\n error.framesToPop = 1; // we don't care about invariant's own frame\n throw error;\n }\n};\n\nmodule.exports = invariant;\n","function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}\n\nmodule.exports = _assertThisInitialized, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _extends() {\n module.exports = _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _extends.apply(this, arguments);\n}\n\nmodule.exports = _extends, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\n\nfunction _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n setPrototypeOf(subClass, superClass);\n}\n\nmodule.exports = _inheritsLoose, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n \"default\": obj\n };\n}\n\nmodule.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}\n\nmodule.exports = _objectWithoutPropertiesLoose, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _setPrototypeOf(o, p) {\n module.exports = _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _setPrototypeOf(o, p);\n}\n\nmodule.exports = _setPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n setPrototypeOf(subClass, superClass);\n}","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}","import arrayWithoutHoles from \"./arrayWithoutHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableSpread from \"./nonIterableSpread.js\";\nexport default function _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _arrayWithoutHoles(arr) {\n if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}","export default function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}","export default function _nonIterableSpread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}"],"names":["PROTOCOL_ERRORS_SYMBOL","Symbol","graphQLResultHasProtocolErrors","result","extensions","Array","isArray","isApolloError","err","hasOwnProperty","ApolloError","_super","_a","errors","graphQLErrors","protocolErrors","clientErrors","networkError","errorMessage","extraInfo","_this","call","this","name","message","push","map","join","cause","find","e","__proto__","prototype","Error","contextKey","for","getApolloContext","context","Object","defineProperty","value","enumerable","writable","configurable","displayName","scheduledCleanup","WeakSet","schedule","cache","size","max","has","add","setTimeout","clean","delete","AutoCleanedWeakCache","dispose","set","key","ret","AutoCleanedStrongCache","globalCaches","registerGlobalCache","getSize","getApolloClientMemoryInternals","globalThis","__DEV__","_b","_c","_d","_e","limits","parser","canonicalStringify","print","fromEntries","entries","k","v","sizes","links","linkInfo","link","queryManager","getDocumentInfo","documentTransforms","transformInfo","documentTransform","getMemoryInternals","undefined","getInMemoryCacheMemoryInternals","fragments","config","_getApolloCacheMemoryInternals","apply","addTypenameDocumentTransform","inMemoryCache","executeSelectionSet","getWrapperInformation","executeSubSelectedArray","maybeBroadcastWatch","fragmentRegistry","findFragmentSpreads","lookup","transform","getApolloCacheMemoryInternals","fragmentQueryDocuments","f","isWrapper","isDefined","recurseTransformInfo","filter","left","right","cacheSizeSymbol","cacheSizes","isReactNative","navigator","product","canUseWeakMap","WeakMap","g","HermesInternal","canUseWeakSet","canUseSymbol","canUseAsyncIteratorSymbol","asyncIterator","canUseDOM","window","document","createElement","userAgent","indexOf","compact","objects","_i","arguments","length","create","forEach","obj","keys","prefixCounts","Map","makeUniqueId","prefix","count","get","concat","Math","random","toString","slice","mergeOptions","defaults","options","variables","isNonNullObject","stringifyForDisplay","space","undefId","JSON","stringify","split","genericMessage","setPrototypeOf","proto","InvariantError","framesToPop","condition","verbosityLevels","verbosityLevel","wrapConsoleMethod","console","log","invariant","debug","warn","error","maybe","thunk","self","constructor","wrap","fn","args","arg0","getHandledErrorMsg","getFallbackErrorMsg","assign","newInvariantError","optionalParams","ApolloErrorMessageHandler","version","arg","messageArgs","global","encodeURIComponent","_extends","target","i","source","getLocation","_source$location","location","search","hash","href","origin","protocol","host","hostname","port","pathname","URL","encodeURI","decodeURI","state","history","createHistory","listeners","transitioning","resolveTransition","_onTransitionComplete","listen","listener","popstateListener","action","addEventListener","removeEventListener","navigate","to","_ref","_ref$replace","replace","go","Date","now","replaceState","pushState","transition","Promise","res","createMemorySource","initialPath","searchIndex","initialLocation","substr","index","stack","states","_","uri","_uri$split","_uri$split$","_uri$split2","_uri$split2$","newIndex","globalHistory","exports","__esModule","shallowCompare","validateRedirect","insertParams","resolve","match","pick","startsWith","_invariant","_invariant2","default","string","routes","default_","uriPathname","uriSegments","segmentize","isRootUri","ranked","rankRoutes","l","missed","route","params","routeSegments","path","routeSegment","uriSegment","isSplat","decodeURIComponent","dynamicMatch","paramRe","exec","reservedNames","isDynamic","segment","test","rankRoute","score","reduce","isRootSegment","SEGMENT_POINTS","sort","a","b","addQuery","_len","query","_key","q","base","_to$split","toPathname","toQuery","basePathname","toSegments","baseSegments","allSegments","segments","pop","_path$split","pathBase","_path$split$","constructedPath","_params$location","_params$location$sear","searchSplit","from","obj1","obj2","obj1Keys","every","defaultDispose","StrongCache","Infinity","newest","oldest","node","getNode","older","newer","noop","_WeakRef","WeakRef","deref","_WeakMap","_FinalizationRegistry","FinalizationRegistry","register","unregister","WeakCache","unfinalizedNodes","Set","finalizationScheduled","finalize","iterator","values","next","keyRef","registry","queueMicrotask","deleteNode","bind","scheduleFinalization","fnToStr","Function","previousComparisons","equal","check","clear","aTag","previouslyCompared","aKeys","definedKeys","bKeys","keyCount","aIterator","isMap","info","done","aKey","aValue","Uint8Array","len","byteLength","aCode","full","suffix","fromIndex","endsWith","nativeCodeSuffix","isDefinedKey","bSet","module","_assign","_assign2","camelCase","input","TypeError","pascalCase","x","trim","toUpperCase","toLowerCase","isLastCharLower","isLastCharUpper","isLastLastCharUpper","character","preserveCamelCase","p1","m","charAt","strings","raw","_createClass","defineProperties","props","descriptor","Constructor","protoProps","staticProps","_templateObject","freeze","TemplateTag","transformers","instance","_classCallCheck","tag","_len2","expressions","_key2","interimTag","transformEndResult","transformString","processSubstitutions","transformer","previousTag","template","_len3","substitutions","_key3","resultSoFar","remainingPart","substitution","transformSubstitution","shift","str","onString","onSubstitution","endResult","onEndResult","separator","conjunction","serial","opts","arrayLength","indent","separatorIndex","lastIndexOf","type","min","arr","arr2","_toConsumableArray","el","regexp","RegExp","side","splitBy","includes","isValidValue","Number","isNaN","replaceWhat","replaceWith","fetch","_typeof","MAX_ARRAY_LENGTH","MAX_RECURSIVE_DEPTH","inspect","formatValue","seenValues","previouslySeenValues","customInspectFn","object","String","getCustomFn","customValue","array","remaining","items","formatArray","getObjectTag","properties","formatObject","formatObjectValue","nodejsCustomInspectSymbol","defineInspect","classObject","toJSON","Boolean","Location","startToken","endToken","start","end","Token","kind","line","column","prev","isNode","maybeNode","dedentBlockStringValue","rawString","lines","commonIndent","_commonIndent","isFirstLine","isEmptyLine","charCodeAt","getBlockStringIndentation","startLine","isBlank","endLine","printBlockString","indentation","preferMultipleLines","isSingleLine","hasLeadingSpace","hasTrailingQuote","hasTrailingSlash","printAsMultipleLines","Kind","NAME","DOCUMENT","OPERATION_DEFINITION","VARIABLE_DEFINITION","SELECTION_SET","FIELD","ARGUMENT","FRAGMENT_SPREAD","INLINE_FRAGMENT","FRAGMENT_DEFINITION","VARIABLE","INT","FLOAT","STRING","BOOLEAN","NULL","ENUM","LIST","OBJECT","OBJECT_FIELD","DIRECTIVE","NAMED_TYPE","LIST_TYPE","NON_NULL_TYPE","SCHEMA_DEFINITION","OPERATION_TYPE_DEFINITION","SCALAR_TYPE_DEFINITION","OBJECT_TYPE_DEFINITION","FIELD_DEFINITION","INPUT_VALUE_DEFINITION","INTERFACE_TYPE_DEFINITION","UNION_TYPE_DEFINITION","ENUM_TYPE_DEFINITION","ENUM_VALUE_DEFINITION","INPUT_OBJECT_TYPE_DEFINITION","DIRECTIVE_DEFINITION","SCHEMA_EXTENSION","SCALAR_TYPE_EXTENSION","OBJECT_TYPE_EXTENSION","INTERFACE_TYPE_EXTENSION","UNION_TYPE_EXTENSION","ENUM_TYPE_EXTENSION","INPUT_OBJECT_TYPE_EXTENSION","reactIs","REACT_STATICS","childContextTypes","contextType","contextTypes","defaultProps","getDefaultProps","getDerivedStateFromError","getDerivedStateFromProps","mixins","propTypes","KNOWN_STATICS","caller","callee","arity","MEMO_STATICS","compare","TYPE_STATICS","getStatics","component","isMemo","ForwardRef","render","Memo","getOwnPropertyNames","getOwnPropertySymbols","getOwnPropertyDescriptor","getPrototypeOf","objectPrototype","hoistNonReactStatics","targetComponent","sourceComponent","blacklist","inheritedComponent","targetStatics","sourceStatics","c","d","h","n","p","r","t","w","y","z","u","$$typeof","A","AsyncMode","ConcurrentMode","ContextConsumer","ContextProvider","Element","Fragment","Lazy","Portal","Profiler","StrictMode","Suspense","isAsyncMode","isConcurrentMode","isContextConsumer","isContextProvider","isElement","isForwardRef","isFragment","isLazy","isPortal","isProfiler","isStrictMode","isSuspense","isValidElementType","typeOf","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","__CLIENT_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE","__SERVER_INTERNALS_DO_NOT_USE_OR_WARN_USERS_THEY_CANNOT_UPGRADE","objA","objB","compareContext","keysA","keysB","bHasOwnProperty","idx","valueA","valueB","W","M","C","K","I","B","J","F","G","N","substring","ca","O","H","X","D","da","ea","fa","L","P","Y","E","ha","Q","ia","Z","ja","ka","aa","ba","la","ma","R","na","oa","S","U","use","T","animationIterationCount","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","columns","flex","flexGrow","flexPositive","flexShrink","flexNegative","flexOrder","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","msGridRow","msGridRowSpan","msGridColumn","msGridColumnSpan","fontWeight","lineHeight","opacity","order","orphans","tabSize","widows","zIndex","zoom","WebkitLineClamp","fillOpacity","floodOpacity","stopOpacity","strokeDasharray","strokeDashoffset","strokeMiterlimit","strokeOpacity","strokeWidth","memoize","reactPropsRegex","isPropValid","prop","o","styledComponentId","process","REACT_APP_SC_ATTR","SC_ATTR","SC_DISABLE_SPEEDY","REACT_APP_SC_DISABLE_SPEEDY","j","groupSizes","Uint32Array","indexOfGroup","insertRules","s","insertRule","clearGroup","deleteRule","getGroup","getRule","V","registerName","textContent","parseInt","getTag","head","childNodes","nodeType","hasAttribute","nextSibling","setAttribute","insertBefore","element","appendChild","createTextNode","sheet","styleSheets","ownerNode","cssRules","cssText","$","nodes","removeChild","rules","splice","isServer","useCSSOMInjection","gs","names","server","querySelectorAll","getAttribute","parentNode","registerId","reconstructWithOptions","allocateGSInstance","hasNameForId","clearNames","clearRules","clearTag","fromCharCode","abs","ee","te","ne","re","oe","staticRulesId","isStatic","componentId","baseHash","baseStyle","generateAndInjectStyles","se","ie","ae","plugins","ce","ue","Consumer","le","de","he","pe","fe","me","stylisPlugins","disableCSSOMInjection","disableVendorPrefixes","Provider","children","ye","inject","id","getName","ve","ge","Se","we","Ee","be","isReactComponent","isCss","Ne","Ae","Oe","theme","Re","De","je","Te","xe","ke","Ve","Be","ze","Me","Ge","Le","Fe","Ye","attrs","parentComponentId","shouldForwardProp","componentStyle","foldedComponentIds","$as","as","style","className","ref","withComponent","_foldedDefaultProps","qe","withConfig","He","createStyles","removeStyles","renderStyles","$e","current","We","Ue","_emitSheetCSS","getStyleTags","sealed","getStyleElement","dangerouslySetInnerHTML","__html","nonce","seal","collectStyles","interleaveWithNodeStream","Je","Xe","Ze","StyleSheet","masterSheet","extendStatics","__extends","__","__assign","__rest","propertyIsEnumerable","__awaiter","thisArg","_arguments","generator","reject","fulfilled","step","rejected","then","__generator","body","label","sent","trys","ops","verb","op","__spreadArray","pack","ar","unshift","FontFace","getElementsByTagName","documentElement","lastChild","rel","media","onload","onerror","src","onreadystatechange","readyState","tagName","ga","events","classes","fonts","load","race","clearTimeout","offsetWidth","serif","qa","xa","vendor","ra","sa","ta","ua","timeout","pa","fontfamily","fontStyle","projectId","api","urls","families","testStrings","ya","za","latin","cyrillic","greek","khmer","Hanuman","Aa","thin","extralight","ultralight","light","regular","book","medium","semibold","demibold","bold","extrabold","ultrabold","black","heavy","Ba","italic","normal","Ca","Ea","Fa","Arimo","Cousine","Tinos","Ga","Ha","text","va","Da","wa","Typekit","async","__webfontfontdeckmodule__","weight","custom","fontdeck","monotype","typekit","google","it","isObject","toIObject","toLength","toAbsoluteIndex","IS_INCLUDES","$this","core","__e","aFunction","that","is","ctx","hide","PROTOTYPE","$export","own","out","IS_FORCED","IS_GLOBAL","IS_STATIC","IS_PROTO","IS_BIND","IS_WRAP","expProto","virtual","__g","dP","createDesc","cof","DESCRIPTORS","getKeys","gOPS","pIE","toObject","IObject","$assign","aLen","getSymbols","isEnum","anObject","IE8_DOM_DEFINE","toPrimitive","Attributes","arrayIndexOf","IE_PROTO","$keys","enumBugKeys","bitmap","shared","uid","SHARED","store","mode","copyright","toInteger","ceil","floor","defined","val","valueOf","px","_interopRequireDefault","_objectWithoutPropertiesLoose2","_assertThisInitialized2","_inheritsLoose2","_extends2","_propTypes","_react","_reachRouter","_utils","_parsePath","parsePath","_excluded","isAbsolutePath","withPrefix","_prefix","getGlobalBasePrefix","isLocalLink","getGlobalPathPrefix","rewriteLinkPath","relativeTo","absolutify","NavLinkPropTypes","activeClassName","activeStyle","partiallyActive","bool","GatsbyLinkLocationWrapper","_ref2","GatsbyLink","_location","_React$Component","defaultGetProps","_ref3","isPartiallyCurrent","isCurrent","IOSupported","IntersectionObserver","handleRef","_proto","_prefetch","currentPath","rewrittenPath","newPathName","___loader","enqueue","componentDidUpdate","prevProps","prevState","componentDidMount","componentWillUnmount","io","_this$io","unobserve","disconnect","cb","_this2","innerRef","entry","isIntersecting","intersectionRatio","observe","_this3","_this$props","_this$props$getProps","getProps","_onClick","onClick","_onMouseEnter","onMouseEnter","rest","prefixedTo","Link","hovering","button","defaultPrevented","metaKey","altKey","ctrlKey","shiftKey","preventDefault","shouldReplace","___navigate","Component","func","isRequired","_default","forwardRef","hashIndex","_scrollHandler","ScrollHandler","useScrollRestoration","ScrollContext","React","nodeInterop","_getRequireWildcardCache","newObj","hasPropertyDescriptor","desc","_interopRequireWildcard","_sessionStorage","cacheBabelInterop","cacheNodeInterop","createContext","SessionStorage","_stateStorage","_isTicking","_latestKnownScrollY","scrollListener","scrollY","requestAnimationFrame","_saveScroll","windowScroll","position","shouldUpdateScroll","scrollTo","scrollToHash","getElementById","scrollIntoView","prevRouterProps","routerProps","save","scrollPosition","_this$props$location","read","_this$props$location2","GATSBY_ROUTER_SCROLL_STATE","stateKey","getStateKey","sessionStorage","getItem","parse","storedValue","setItem","stateKeyBase","identifier","useLocation","useContext","useRef","useLayoutEffect","onScroll","scrollTop","components","component---src-templates-404-404-tsx","component---src-templates-calendar-index-tsx","component---src-templates-form-completed-tsx","component---src-templates-form-form-tsx","component---src-templates-games-game-tsx","component---src-templates-guideline-guideline-tsx","component---src-templates-index-index-tsx","plugin","require","getResourceURLsForPathname","loadPage","loadPageSync","defaultReturn","argTransform","results","previous","all","on","handler","off","emit","evt","mitt","pathCache","matchPaths","trimPathname","rawPathname","stripPrefix","__BASE_PATH__","setMatchPaths","findMatchPath","trimmedPathname","cleanPath","pickPaths","matchPath","originalPath","normalizePagePath","grabMatchParams","findPath","redirect","maybeGetBrowserRedirect","toPath","foundPath","loader","StaticQueryContext","useStaticQuery","_context$query","data","supportedPrefetchStrategy","feature","fakeLink","relList","supports","support","url","getElementsByName","req","XMLHttpRequest","open","status","send","preFetched","catch","PageResourceStatus","Success","preferDefault","createPageDataUrl","stripSurroundingSlashes","doFetch","method","toPageResources","pageData","page","componentChunkName","webpackCompilationHash","staticQueryHashes","json","BaseLoader","loadComponent","inFlightNetworkRequests","pageDb","inFlightDb","staticQueryDb","pageDataDb","prefetchTriggered","prefetchCompleted","memoizedGet","inFlightPromise","response","setApiRunner","apiRunner","prefetchDisabled","some","fetchPageDataJson","loadObj","pagePath","retries","responseText","jsonPayload","payload","notFound","loadPageDataJson","rawPath","loadAppData","allData","finalResult","componentChunkPromise","pageResources","createdAt","staticQueryBatchPromise","staticQueryHash","staticQueryResults","staticQueryResultsMap","emitter","_options","withErrorDetails","shouldPrefetch","doesConnectionSupportPrefetch","connection","effectiveType","saveData","prefetch","realPath","doPrefetch","pageDataUrl","prefetchHelper","crossOrigin","createComponentUrls","isPageNotFound","appData","___chunkMapping","chunk","__PATH_PREFIX__","ProdLoader","_BaseLoader","asyncRequires","chunkName","_inheritsLoose","_proto2","componentUrls","setLoader","_loader","publicLoader","getStaticQueryResults","PageRenderer","pageContext","__params","pageElement","RouteAnnouncerProps","top","width","height","padding","overflow","clip","whiteSpace","border","maybeRedirect","___replace","nextRoute","event","reason","onPreRouteUpdate","prevLocation","onRouteUpdate","___swUpdated","timeoutId","___webpackCompilationHash","serviceWorker","controller","postMessage","gatsbyApi","reachNavigate","getSavedScrollPosition","oldPathname","RouteAnnouncer","announcementRef","nextProps","pageName","title","pageHeadings","newAnnouncement","innerText","compareLocationProps","nextLocation","_prevLocation$state","_nextLocation$state","RouteUpdates","_React$Component2","shouldComponentUpdate","shallowDiffers","EnsureResources","loadResources","setState","nextState","___emitter","___push","apiRunnerAsync","RouteHandler","BaseContext","baseuri","basepath","DataContext","GatsbyRoot","LocationHandler","Router","browserLoc","SiteRoot","_ref4","App","onClientEntryRanRef","performance","mark","renderer","ReactDOM","hydrateRoot","runRender","rootElement","doc","doScroll","InternalPageRenderer","redirectMap","redirectIgnoreCaseMap","ignoreCase","fromPath","reg","installingWorker","installing","___failedResources","reload","defaultMakeData","Trie","weakness","makeData","lookupArray","getChildTrie","peek","peekArray","mapFor","remove","removeArray","child","weak","strong","isObjRef","currentContext","MISSING_VALUE","idCounter","ignored","globalKey","globalHost","Slot","hasValue","parent","slots","getValue","withValue","callback","saved","noContext","parentEntrySlot","arrayFromSet","item","maybeUnsubscribe","entryOrDep","unsubscribe","emptySetPool","POOL_TARGET_SIZE","assert","optionalMessage","valueIs","valueGet","valueCopy","Entry","parents","childValues","dirtyChildren","dirty","recomputing","deps","mightBeDirty","rememberParent","recompute","forgetChildren","recomputeNewValue","subscribe","setDirty","maybeSubscribe","reportClean","setClean","reallyRecompute","reportDirty","eachParent","forgetChild","forget","dependOn","dep","forgetDeps","reportDirtyChild","reportCleanChild","normalizeResult","oldValueCopy","parentCount","parentWasClean","childValue","removeDirtyChild","dc","_value","EntryMethods","depsByKey","depend","entryMethodName","defaultKeyTrie","defaultMakeCacheKey","trie","caches","originalFunction","pow","keyArgs","makeCacheKey","cacheOption","optimistic","dirtyKey","peekKey","forgetKey","getKey","QueryDocumentKeys","Name","Document","OperationDefinition","VariableDefinition","Variable","SelectionSet","Field","Argument","FragmentSpread","InlineFragment","FragmentDefinition","IntValue","FloatValue","StringValue","BooleanValue","NullValue","EnumValue","ListValue","ObjectValue","ObjectField","Directive","NamedType","ListType","NonNullType","SchemaDefinition","OperationTypeDefinition","ScalarTypeDefinition","ObjectTypeDefinition","FieldDefinition","InputValueDefinition","InterfaceTypeDefinition","UnionTypeDefinition","EnumTypeDefinition","EnumValueDefinition","InputObjectTypeDefinition","DirectiveDefinition","SchemaExtension","ScalarTypeExtension","ObjectTypeExtension","InterfaceTypeExtension","UnionTypeExtension","EnumTypeExtension","InputObjectTypeExtension","BREAK","root","visitor","visitorKeys","inArray","edits","ancestors","newRoot","isLeaving","isEdited","clone","_i2","_Object$keys2","editOffset","ii","editKey","editValue","_visitorKeys$node$kin","visitFn","getVisitFn","kindVisitor","kindSpecificVisitor","leave","enter","specificVisitor","specificKindVisitor","getFragmentQueryDocument","fragmentName","actualFragmentName","definitions","definition","operation","selectionSet","selections","createFragmentMap","symTable","fragment","getFragmentFromSelection","selection","fragmentMap","sortingMap","stableObjectReplacer","reset","everyKeyInOrder","unsortedKey","sortedKeys","sortedKey","sortedObject_1","makeReference","__ref","isReference","valueToObjectRepresentation","argObj","isIntValue","isFloatValue","isBooleanValue","isStringValue","isObjectValue","nestedArgObj_1","fields","isVariable","variableValue","isListValue","listValue","nestedArgArrayObj","isEnumValue","isNullValue","KNOWN_DIRECTIVES","storeKeyNameStringify","getStoreKeyName","fieldName","directives","filterKeys","filteredArgs_1","completeFieldName","stringifiedArgs","setStringify","argumentsObjectFromField","field","argObj_1","resultKeyNameFromField","alias","getTypenameFromResult","__typename","fragments_1","typename","operations","getOperationDefinition","getOperationName","getFragmentDefinitions","getQueryDefinition","queryDef","getFragmentDefinition","fragmentDef","getMainDefinition","queryDoc","fragmentDefinition","getDefaultValues","defaultValues","defs","variableDefinitions","def","defaultValue","variable","_createForOfIteratorHelperLoose","allowArrayLike","minLen","_arrayLikeToArray","_unsupportedIterableToArray","_defineProperties","hasSymbols","hasSymbol","getSymbol","observable","SymbolIterator","SymbolObservable","SymbolSpecies","getMethod","getSpecies","ctor","Observable","isObservable","hostReportError","cleanupSubscription","subscription","cleanup","_cleanup","closeSubscription","_observer","_queue","_state","notifySubscription","observer","onNotify","queue","flushSubscription","Subscription","subscriber","subscriptionObserver","SubscriptionObserver","_subscription","complete","_subscriber","_proto3","_this4","hasSeed","acc","first","_this5","sources","startNext","flatMap","_this6","subscriptions","outer","inner","completeIfDone","closed","_step","_iterator","of","symbol","mergeDeep","mergeDeepArray","merger","DeepMerger","merge","defaultReconciler","property","reconciler","pastCopies","sourceKey","targetValue","shallowCopyForMerge","shouldInclude","directive","isInclusionDirective","directiveArguments","directiveName","ifArgument","ifValue","getInclusionDirectives","evaledValue","hasDirectives","nameSet","uniqueCount","hasClientExports","getFragmentMaskMode","modeArg","equalByQuery","aData","aRest","bData","bRest","equalBySelectionSet","aResult","bResult","seenSelections","selectionHasNonreactiveDirective","resultKey","aResultChild","bResultChild","childSelectionSet","aChildIsArray","bChildIsArray","length_1","directiveIsNonreactive","dir","MapImpl","canUse","SetImpl","disableWarningsSlot","issuedWarning","warnOnImproperCacheImplementation","deepFreeze","workSet","isFrozen","shallowFreeze","maybeDeepFreeze","maskDefinition","masked","maskSelectionSet","migration","knownChanged","memo","mutableTargets","mutableTarget","getMutableTarget","keyName","getAccessorWarningDescriptor","operationName","operationType","typeCondition","fragmentMatches","lookupFragment","newValue","maskFragment","ApolloCache","assumeImmutableResults","getFragmentDoc","batch","updateResult","optimisticId","performTransaction","update","recordOptimisticTransaction","transaction","transformDocument","transformForLink","identify","gc","modify","readQuery","rootId","watchFragment","otherOptions","dataMasking","latestDiff","diffOptions","returnPartialData","watch","immediate","diff","missing","readFragment","writeQuery","write","dataId","writeFragment","updateQuery","updateFragment","MissingFieldError","identity","DocumentTransform","resultCache","getCacheKey","cached","resetCache","predicate","stableCacheKeys_1","performWork","cacheKeys","transformedDocument","otherTransform","isNonEmptyArray","TYPENAME_FIELD","isEmpty","nullIfDocIsEmpty","getDirectiveMatcher","configs","tests","testConfig","makeInUseGetterFunction","defaultKey","inUse","fragmentSpreads","removeDirectivesFromDocument","getInUseByOperationName","getInUseByFragmentName","getInUse","ancestor","operationCount","directiveMatcher","shouldRemoveField","nodeDirectives","originalFragmentDefsByPath","firstVisitMadeChanges","fieldOrInlineFragmentVisitor","docWithoutDirectiveSubtrees","_parent","_path","removed","populateTransitiveVars","transitiveVars","childFragmentName","varName","allFragmentNamesUsed","enterVisitor","usedVariableNames_1","varDef","addTypenameToDocument","added","buildQueryFromSelectionSet","removeClientSetsFromDocument","addNonReactiveToNamedFragments","printCache","printDocASTReducer","varDefs","block","argsLine","_ref5","_ref6","_ref7","_ref8","_ref9","_ref10","_ref11","_ref12","_ref13","_ref14","_ref15","_ref16","_ref17","_ref18","_ref19","addDescription","_ref20","operationTypes","_ref21","_ref22","_ref23","interfaces","_ref24","hasMultilineItems","_ref25","_ref26","_ref27","types","_ref28","_ref29","_ref30","_ref31","repeatable","locations","_ref32","_ref33","_ref34","_ref35","_ref36","_ref37","_ref38","description","maybeArray","_maybeArray$filter$jo","maybeString","isMultiline","ast","hasOwn","isNullish","defaultDataIdFromObject","_id","keyObject","defaultConfig","dataIdFromObject","addTypename","resultCaching","canonizeResults","shouldCanonizeResults","TypeOrFieldNameRegExp","fieldNameFromStoreName","storeFieldName","selectionSetMatchesResult","storeValueIsStoreObject","extractFragmentContext","DELETE","delModifier","INVALIDATE","EntityStore","policies","group","rootIds","refs","getFieldValue","objectOrReference","canRead","objOrRef","toReference","objOrIdOrRef","mergeIntoStore","storeObject","rootTypenamesById","Layer","dependOnExistence","existing","incoming","merged","storeObjectReconciler","caching","fieldsToDirty_1","__exists","hasKeyArgs","changedFields_1","needToMerge_1","allDeleted_1","sharedDetails_1","readField","fieldNameOrOptions","fieldValue","storage","getStorage","checkReference","seenReference","someNonReference","newValue_1","getStoreFieldName","evict","limit","evicted","extract","extraRootIds","getRootIdSet","__META","newData","rest_1","retain","release","ids","snapshot","findChildRefIds","idsToRemove","root_1","found_1","workSet_1","keyMaker","CacheGroup","resetCaching","makeDepKey","maybeDependOnExistenceOfEntity","entityId","supportsResultCaching","Root","seed","stump","Stump","storageTrie","addLayer","layerId","replay","removeLayer","ownStoreObject","parentStoreObject","fromParent","existingObject","incomingObject","existingValue","incomingValue","ObjectCanon","known","pool","passes","keysByJSON","empty","admit","isKnown","pass","copy","shallowCopy","original","proto_1","array_1","firstValueIndex_1","sorted","obj_1","execSelectionSetKeyArgs","StoreReader","knownResults","canon","peekArgs","other","enclosingRef","execSelectionSetImpl","resultCacheMaxSize","varString","execSubSelectedArrayImpl","resetCanon","diffQueryAgainstStore","rootRef","execResult","firstMissing","isFresh","latest","objectsToMerge","missingMerger","handleMissing","resultName","rootIdsByTypename","frozen","childResult","getTypenameFromStoreObject","assertSelectionSetForIdValue","tree","cloneDeep","cloneDeepHelper","seen","copy_1","copy_2","cacheSlot","cacheInfoMap","getCacheInfo","vars","forgetCache","rv","makeVar","broadcastWatches","broadcast","oldListeners","attach","onNextChange","attachCache","specifierInfoCache","lookupSpecifierInfo","spec","cacheKey","keyFieldsFnFromSpecifier","specifier","keyFieldsFn","collectSpecifierPaths","schemaKeyPath","extracted","extractKeyPath","extractKey","keyArgsFnFromSpecifier","keyArgsFn","collected","keyPath","firstKey","firstChar","variableName","varKeyPath","directiveName_1","directiveArgs","extractor","getSpecifierPaths","toMerge","paths","paths_1","currentPath_1","normalize","reducer","argsFromFieldSpecifier","nullKeyFieldsFn","simpleKeyArgsFn","_args","mergeTrueFn","mergeObjects","mergeFalseFn","Policies","typePolicies","toBeAdded","supertypeMap","fuzzySubtypes","usingPossibleTypes","setRootTypename","possibleTypes","addPossibleTypes","addTypePolicies","partialContext","ROOT_QUERY","normalizeReadFieldOptions","policy","getTypePolicy","keyFn","specifierOrId","queryType","mutationType","subscriptionType","updateTypePolicy","keyFields","setMerge","getFieldPolicy","which","old","supertype","getSupertypeSet","subtype","policy_1","supertypes_1","regExp","fuzzy","fuzzySupertypes","inbox","createIfMissing","fieldPolicies","supertypeSet","typenameSupertypeSet","workQueue_1","maybeEnqueue_1","needToCheckFuzzySubtypes","checkingFuzzySubtypes","fuzzyString","fieldSpec","specifierOrString","directivesObj","storeKeyNameFromField","readOptions","makeFieldFunctionOptions","getReadFunction","getMergeFunction","parentTypename","childTypename","runMergeFunction","makeMergeObjectsFunction","overwrite","readFieldArgs","argc","eType","iType","getContextFlavor","clientOnly","deferred","flavored","flavors","StoreWriter","reader","writeToStore","operationDefinition","written","incomingById","processSelectionSet","mergeTree","fieldNodeSet","entityRef","applied","applyMerges","fieldsWithSelectionSets_1","hasSelectionSet_1","childTree","hasMergeFunction_1","existingRef","incomingObj","getChild","parentType","typeDotName","warnings","childTypenames","warnAboutDataLoss","result_1","flattenFields","resultFieldKey","getChildMergeTree","processFieldValue","maybeRecycleChildMergeTree","dataRef","sets","previous_1","mergeMergeTrees","mergeTreeIsEmpty","fieldMap","limitingTrie","flatten","inheritedContext","visitedNode","visited","if","getStorageArgs","e_1","i_1","getValue_1","eVal","iVal","aVal","emptyMergeTreePool","needToMergeMaps","remainingRightKeys_1","leftTree","InMemoryCache","watches","addTypenameTransform","txCount","normalizeConfig","init","rootStore","optimisticData","resetResultCache","resetResultIdentities","previousReader","storeReader","storeWriter","broadcastWatch","restore","recallCache","resetCaches","discardWatches","removeOptimistic","idToRemove","newOptimisticData","onWatchUpdated","perform","layer","alreadyDirty","addFragmentsToDocument","lastDiff","fromOptimisticTransaction","passthrough","forward","toLink","ApolloLink","isTerminating","request","leftLink","rightLink","execute","starting","createOperation","transformedOperation","transformOperation","OPERATION_FIELDS","validateOperation","second","firstLink","nextLink","onError","setOnError","serializeFetchParameter","serialized","parseError","nodeStreamIterator","stream","waiting","onData","shiftedArr","pair","onEnd","removeListener","readerIterator","responseIterator","isAsyncIterableIterator","getReader","isReadableStream","isStreamableBlob","arrayBuffer","isBlob","promise","resolved","promiseIterator","pipe","isNodeReadableStream","throwServerError","statusCode","isExecutionPatchIncrementalResult","isApolloPayloadResult","mergeIncrementalData","prevResult","mergedData","incremental","parent_1","parseHeaders","headerText","headersInit","name_1","parseJsonBody","bodyText","getResult","fallbackHttpConfig","http","includeQuery","includeExtensions","preserveHeaderCase","headers","accept","defaultPrinter","printer","selectHttpOptionsAndBodyInternal","credentials","normalizedHeaders_1","headerData","originalName","normalizedHeaders","removeDuplicateHeaders","fromError","errorValue","backupFetch","createHttpLink","linkOptions","preferredFetch","useGETForQueries","includeUnusedVariables","requestOptions","fetcher","checkFetcher","linkConfig","fetchOptions","chosenURI","fallbackURI","contextURI","getContext","selectURI","clientAwarenessHeaders","clientAwareness","contextHeaders","contextConfig","transformedQuery","unusedNames","signal","AbortController","isSubscription","hasDefer","acceptHeader","queryParams","addQueryParam","serializedVariables","serializedExtensions","preFragment","fragmentStart","queryParamsPrefix","newURI","rewriteURIForGET","currentFetch","observerNext","setContext","ctype","nextValue","decoder","contentType","delimiter","boundaryVal","boundary","buffer","running","searchFrom","bi","contentType_1","TextDecoder","decode","hasNext","readMultipartBody","handleError","abort","HttpLink","asyncMap","mapFn","catchFn","promiseQueue","makeCallback","examiner","both","sub","graphQLResultHasError","getGraphQLErrorsFromResult","incrementalResult","iterateObserversSafely","observers","argument","observersWithMethod","obs","fixObservableSubclass","subclass","species","NetworkStatus","Concast","addObserver","removeObserver","handlers","notify","nextResultListeners","cancel","iterable","deliverLastMessage","nextOrError","beforeNext","called","isNetworkRequestInFlight","networkStatus","ObservableQuery","queryInfo","subObserver","defaultSubscriptionObserverErrorCallback","last","maskResult","reobserve","tearDownQuery","waitForOwnResult","skipCacheDataFor","fetchPolicy","isTornDown","subscribeToMore","defaultOptions","watchQuery","defaultFetchPolicy","_f","initialFetchPolicy","queryId","generateQueryId","opDef","queryName","lastQuery","removeQuery","resetDiff","getCurrentFullResult","saveAsLastResult","lastResult","getLastResult","ready","loading","hasForcedResolvers","getDiff","partial","partialRefetch","logMissingFieldErrors","updateLastResult","getCurrentResult","isDifferentFromLastResult","newResult","documentInfo","nonReactiveQuery","hasNonreactiveDirective","getLast","variablesMustMatch","getLastError","resetLastResults","resetQueryStoreErrors","resetErrors","refetch","reobserveOptions","pollInterval","resetLastWrite","fetchMore","fetchMoreOptions","combinedOptions","qid","originalNetworkStatus","notifyOnNetworkStatusChange","updatedQuerySet","isCached","fetchQuery","fetchMoreResult","reportResult","finally","reobserveCacheFirst","startGraphQLSubscription","subscriptionData","setOptions","newOptions","silentSetOptions","mergedOptions","setVariables","broadcastQueries","startPolling","updatePolling","stopPolling","applyNextFetchPolicy","nextFetchPolicy","newNetworkStatus","setObservableQuery","ssrMode","pollingInfo","hasObservers","interval","maybeFetch","skipPollAttempt","poll","reobserveAsConcast","useDisposableConcast","oldVariables","oldFetchPolicy","finishWaitingForOwnResult","concast","fromLink","reportError","resubscribeAfterError","lastError","isDifferent","errorResult","stopQuery","maskOperation","obsQuery","currentFetchPolicy","destructiveMethodCounts","wrapDestructiveCacheMethod","methodName","cancelNotifyTimeout","QueryInfo","lastRequestId","stopped","observableQuery","getDiffOptions","updateWatch","oq","updateLastDiff","setDiff","oldDiff","notifyTimeout","oqListener","shouldNotify","stop","watchOptions","watcher","lastWatch","lastWrite","shouldWrite","dmCount","markResult","cacheWriteBehavior","shouldWriteResult","errorPolicy","markReady","markError","ignoreErrors","writeWithErrors","IGNORE","QueryManager","queries","fetchCancelFns","transformCache","queryIdCounter","requestIdCounter","mutationIdCounter","inFlightLinkObservables","noCacheWarningsByQueryId","defaultDocumentTransform","queryDeduplication","localState","defaultContext","onBroadcast","mutationStore","_info","stopQueryNoBroadcast","cancelPendingFetches","mutate","mutationId","mutationStoreValue","isOptimistic","mutation","optimisticResponse","updateQueries","refetchQueries","awaitRefetchQueries","updateWithProxyFn","onQueryUpdated","_g","_h","keepRootFields","_j","generateMutationId","getVariables","addExportedVariables","markMutationOptimistic","getObservableFromLink","storeResult","markMutationResult","cacheWrites","skipCache","asQuery","updateQueries_1","updater","currentQueryResult","nextQueryResult","mutationResult","queryVariables","results_1","updateCache","isFinalResult","isExecutionPatchInitialResult","include","fetchConcastWithInfo","getQueryStore","cacheEntry","shouldForceResolvers","clientQuery","serverQuery","defaultVars","generateRequestId","stopQueryInStore","stopQueryInStoreNoBroadcast","clearStore","getObservableQueries","queryNames","queryNamesAndQueryStrings","legacyQueryOptions","queryString","getQuery","included","nameOrQueryString","reFetchObservableQueries","includeStandby","observableQueryPromises","makeObservable","hasErrors","hasProtocolErrors","observablePromise_1","getLocalState","deduplication","inFlightLinkObservables_1","prepareContext","forceFetch","printedServerQuery_1","varJson_1","runResolvers","remoteResult","getResultsFromLink","requestId","linkDocument","aqr","containsDataFromLink","normalized","fromVariables","sourcesWithInfo","fetchQueryByPolicy","cleanupCancelFn","includedQueriesById","operationId","isUnmasked","isFullyUnmaskedOperation","refetchWritePolicy","oldNetworkStatus","readCache","resultsFromCache","fromData","onlyRunForcedResolvers","resultsFromLink","newContext","isSelectionNode","LocalState","client","resolvers","fragmentMatcher","selectionsToResolveCache","addResolvers","setFragmentMatcher","resolverGroup","setResolvers","getResolvers","resolveDocument","localResult","getFragmentMatcher","document_1","buildRootValueFromCache","exportedVariables","forceResolvers","rootValue_1","rootValue","mainDefinition","selectionsToResolve","definitionOperation","defaultOperationType","execContext","collectSelectionsToResolve","resolveSelectionSet","isClientFieldDescendant","resultsToMerge","resolveField","fieldResult","isInlineFragment","fragmentResult","aliasedFieldName","aliasUsed","defaultResult","resultPromise","resolverType","resolverMap","isClientField","resolveSubSelectedArray","isSingleASTNode","collectByDefinition","definitionNode","matches_1","___","spread","fragmentSelections","hasSuggestedDevtools","ApolloClient","resetStoreCallbacks","clearStoreCallbacks","ssrForceFetchDelay","connectToDevTools","typeDefs","clientAwarenessName","clientAwarenessVersion","devtools","disableNetworkFetches","devtoolsConfig","enabled","resetStore","devToolsHookCb","mutations","dataWithOptimisticResults","windowWithDevTools","devtoolsSymbol","__APOLLO_CLIENT__","__APOLLO_DEVTOOLS_GLOBAL_HOOK__","nav","__actionHookForDevTools","__requestRaw","onResetStore","onClearStore","serializedState","setLocalStateFragmentMatcher","setLink","newLink","ApolloProvider","ApolloContext","parentContext","wrapRootElement","HTMLImageElement","dataset","objectFit","objectPosition","objectFitPolyfill","shouldLoad","onLoad","currentTarget","Image","currentSrc","backgroundColor","bottom","layout","paddingTop","maxWidth","display","alt","role","srcSet","decoding","fallback","tt","image","et","rt","hydrated","forceRender","lazyHydrator","unobserveRef","isLoading","isLoaded","_lazyHydrate","querySelector","lazyHydrate","images","toggleIsLoaded","_setupIntersectionObserver","createIntersectionObserver","onStartLoad","wasCached","class","suppressHydrationWarning","at","nt","ot","st","lt","__imageData","__error","dt","LaterHydrator","_styledComponents","pluginOptions","StyleSheetManager","WebFont","onInitialClientRender","_extends3","_objectWithoutProperties","_possibleConstructorReturn","ReferenceError","_inherits","subClass","superClass","createNamedContext","Ctx","LocationContext","LocationProvider","_temp","unlisten","_props$history","componentDidCatch","isRedirect","_navigate","unmounted","ServerLocation","baseContext","locationContext","RouterImpl","_React$PureComponent","_props","_navigate2","primary","_props$component","domProps","toArray","createRoute","FocusWrapper","FocusHandler","wrapperProps","FocusContext","requestFocus","FocusHandlerImpl","initialRender","focusHandlerCount","_temp2","shouldFocus","focus","myURIChanged","navigatedUpToMe","contains","activeElement","_props2","_props2$component","Comp","outline","tabIndex","_props$getProps","anchorProps","encodedHref","shouldNavigate","_location$state","restState","RedirectRequest","redirectTo","RedirectImpl","_React$Component3","_props3","_props3$replace","noThrow","resolvedTo","_props4","Redirect","Match","resolvedPath","useNavigate","useParams","useMatch","stripSlashes","elementPath","format","argIndex","excluded","sourceKeys","_setPrototypeOf","arrayLikeToArray","iter","unsupportedIterableToArray"],"sourceRoot":""}