{"version":3,"file":"cie-ui.js","mappings":"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","sources":["webpack://ui/webpack/runtime/load script","webpack://ui/./node_modules/@ecosystem/preference-nest-api/dist/api.js","webpack://ui/./node_modules/@ecosystem/preference-nest-api/dist/base.js","webpack://ui/./node_modules/@ecosystem/preference-nest-api/dist/common.js","webpack://ui/./node_modules/@ecosystem/preference-nest-api/dist/configuration.js","webpack://ui/./node_modules/@ecosystem/preference-nest-api/dist/index.js","webpack://ui/./node_modules/redux-thunk/es/index.js","webpack://ui/./node_modules/@reduxjs/toolkit/dist/redux-toolkit.esm.js","webpack://ui/./src/components/LoadingContent/index.module.scss?1669","webpack://ui/./src/components/LoadingContent/index.tsx","webpack://ui/./src/components/MarketAccessQuery/useMarketAccessQuery.tsx","webpack://ui/./src/config/audienceProfilerKPI.ts","webpack://ui/./src/config/filters.ts","webpack://ui/./node_modules/@apollo/client/react/context/ApolloProvider.js","webpack://ui/./src/containers/ApolloWithAuth/index.tsx","webpack://ui/./src/hooks/useFetchFilterValues/index.tsx","webpack://ui/./node_modules/pako/dist/pako.esm.mjs","webpack://ui/./src/containers/LoadFilters/index.tsx","webpack://ui/./src/hooks/useFilters/index.tsx","webpack://ui/./src/containers/RouteRestriction/index.tsx","webpack://ui/./src/containers/Segmentation/SegmentationTable/config.ts","webpack://ui/./src/hooks/useAppliedBaseFilters/index.tsx","webpack://ui/./src/hooks/useFilterSchema/index.ts","webpack://ui/./node_modules/zen-observable-ts/module.js","webpack://ui/./node_modules/@apollo/client/utilities/graphql/fragments.js","webpack://ui/./node_modules/@apollo/client/utilities/graphql/storeUtils.js","webpack://ui/./node_modules/@apollo/client/utilities/graphql/getFromAST.js","webpack://ui/./node_modules/@apollo/client/link/core/ApolloLink.js","webpack://ui/./node_modules/@apollo/client/link/utils/createOperation.js","webpack://ui/./node_modules/@apollo/client/link/utils/transformOperation.js","webpack://ui/./node_modules/@apollo/client/link/utils/validateOperation.js","webpack://ui/./node_modules/graphql/language/visitor.mjs","webpack://ui/./node_modules/@apollo/client/utilities/graphql/directives.js","webpack://ui/./node_modules/@apollo/client/link/http/serializeFetchParameter.js","webpack://ui/./node_modules/@apollo/client/link/http/iterators/reader.js","webpack://ui/./node_modules/@apollo/client/link/http/responseIterator.js","webpack://ui/./node_modules/@apollo/client/link/http/iterators/async.js","webpack://ui/./node_modules/@apollo/client/link/http/iterators/promise.js","webpack://ui/./node_modules/@apollo/client/link/http/iterators/nodeStream.js","webpack://ui/./node_modules/@apollo/client/link/utils/throwServerError.js","webpack://ui/./node_modules/@apollo/client/utilities/common/mergeDeep.js","webpack://ui/./node_modules/@apollo/client/utilities/common/incrementalResult.js","webpack://ui/./node_modules/@apollo/client/link/http/parseAndCheckHttpResponse.js","webpack://ui/./node_modules/@apollo/client/link/http/checkFetcher.js","webpack://ui/./node_modules/graphql/language/printer.mjs","webpack://ui/./node_modules/@apollo/client/utilities/graphql/print.js","webpack://ui/./node_modules/@apollo/client/link/http/selectHttpOptionsAndBody.js","webpack://ui/./node_modules/@apollo/client/link/utils/fromError.js","webpack://ui/./node_modules/@apollo/client/utilities/graphql/transform.js","webpack://ui/./node_modules/@apollo/client/link/http/createHttpLink.js","webpack://ui/./node_modules/@apollo/client/link/http/selectURI.js","webpack://ui/./node_modules/@apollo/client/link/utils/filterOperationVariables.js","webpack://ui/./node_modules/@apollo/client/link/http/rewriteURIForGET.js","webpack://ui/./node_modules/@apollo/client/link/http/HttpLink.js","webpack://ui/./node_modules/@apollo/client/link/core/execute.js","webpack://ui/./node_modules/@wry/trie/lib/index.js","webpack://ui/./node_modules/@apollo/client/cache/inmemory/object-canon.js","webpack://ui/./node_modules/@apollo/client/utilities/graphql/DocumentTransform.js","webpack://ui/./node_modules/@apollo/client/utilities/observables/asyncMap.js","webpack://ui/./node_modules/@apollo/client/utilities/common/errorHandling.js","webpack://ui/./node_modules/@apollo/client/utilities/observables/iteration.js","webpack://ui/./node_modules/@apollo/client/utilities/observables/subclassing.js","webpack://ui/./node_modules/@apollo/client/utilities/observables/Concast.js","webpack://ui/./node_modules/@apollo/client/utilities/common/cloneDeep.js","webpack://ui/./node_modules/@apollo/client/core/equalByQuery.js","webpack://ui/./node_modules/@apollo/client/core/ObservableQuery.js","webpack://ui/./node_modules/graphql/language/predicates.mjs","webpack://ui/./node_modules/optimism/lib/cache.js","webpack://ui/./node_modules/@wry/context/lib/slot.js","webpack://ui/./node_modules/@wry/context/lib/index.js","webpack://ui/./node_modules/optimism/lib/context.js","webpack://ui/./node_modules/optimism/lib/helpers.js","webpack://ui/./node_modules/optimism/lib/entry.js","webpack://ui/./node_modules/optimism/lib/dep.js","webpack://ui/./node_modules/optimism/lib/index.js","webpack://ui/./node_modules/@apollo/client/cache/inmemory/reactiveVars.js","webpack://ui/./node_modules/@apollo/client/core/LocalState.js","webpack://ui/./node_modules/@apollo/client/core/QueryInfo.js","webpack://ui/./node_modules/@apollo/client/core/QueryManager.js","webpack://ui/./node_modules/@apollo/client/core/ApolloClient.js","webpack://ui/./node_modules/@apollo/client/cache/core/cache.js","webpack://ui/./node_modules/@apollo/client/cache/core/types/common.js","webpack://ui/./node_modules/@apollo/client/cache/inmemory/helpers.js","webpack://ui/./node_modules/@apollo/client/cache/inmemory/entityStore.js","webpack://ui/./node_modules/@apollo/client/cache/inmemory/readFromStore.js","webpack://ui/./node_modules/@apollo/client/cache/inmemory/key-extractor.js","webpack://ui/./node_modules/@apollo/client/cache/inmemory/policies.js","webpack://ui/./node_modules/@apollo/client/cache/inmemory/writeToStore.js","webpack://ui/./node_modules/@apollo/client/cache/inmemory/inMemoryCache.js","webpack://ui/./src/util/env/index.ts","webpack://ui/./src/query/client.ts","webpack://ui/./src/query/fragments.ts","webpack://ui/./src/query/query.ts","webpack://ui/./src/reducers/KBQ/accordionPanels/index.tsx","webpack://ui/./src/reducers/KBQ/defaultSelectedLostShopper/index.tsx","webpack://ui/./src/reducers/KBQ/kbqChartData/index.tsx","webpack://ui/./src/reducers/KBQ/kbqTopPurchasedData/index.ts","webpack://ui/./src/reducers/KBQ/selectLostShoppers/index.tsx","webpack://ui/./src/reducers/KBQ/selectedBrand/index.ts","webpack://ui/./src/reducers/KBQ/selectedChannelVisited/index.ts","webpack://ui/./src/reducers/KBQ/selectedPurchaseDriversList/index.tsx","webpack://ui/./src/reducers/KBQ/selectedRetailer/index.ts","webpack://ui/./src/reducers/KBQ/storiesSummaryError/index.tsx","webpack://ui/./src/reducers/KBQ/topLostShoppers/index.tsx","webpack://ui/./src/reducers/KBQ/topPurchasedBrandDonut/index.tsx","webpack://ui/./src/reducers/audienceProfiler/bubbleExportVisible/index.tsx","webpack://ui/./src/reducers/audienceProfiler/navigateBackBarVisible/index.tsx","webpack://ui/./src/reducers/audienceProfiler/segmentVisibility/index.tsx","webpack://ui/./src/reducers/audienceProfiler/selectedKPI/index.tsx","webpack://ui/./src/reducers/compareBy/applied/index.ts","webpack://ui/./src/reducers/currency/selected/index.tsx","webpack://ui/./src/reducers/currency/showCurrencyWarning/index.tsx","webpack://ui/./src/reducers/error/subscription/index.tsx","webpack://ui/./src/reducers/featureFlag/consumerFeatureFlags/index.tsx","webpack://ui/./src/reducers/filtering/applied/index.ts","webpack://ui/./src/reducers/filtering/defaultFilters/index.ts","webpack://ui/./src/reducers/filtering/disabled/index.tsx","webpack://ui/./src/reducers/filtering/filterValues/index.tsx","webpack://ui/./src/reducers/filtering/lostShoppers/index.tsx","webpack://ui/./src/util/migration/index.ts","webpack://ui/./src/reducers/filtering/saved/index.ts","webpack://ui/./src/reducers/filtering/savedModalOpen/index.ts","webpack://ui/./src/reducers/filtering/selected/index.tsx","webpack://ui/./src/reducers/filtering/selectors.ts","webpack://ui/./src/reducers/filtering/timeFrameTab/index.tsx","webpack://ui/./src/reducers/filtering/topBarOpen/index.tsx","webpack://ui/./src/reducers/filtering/values/index.tsx","webpack://ui/./src/reducers/pagination/selectedPage/index.tsx","webpack://ui/./src/reducers/filtering/firstApply/index.ts","webpack://ui/./src/reducers/filtering/reviewFilterValues/index.tsx","webpack://ui/./src/reducers/filtering/index.tsx","webpack://ui/./src/reducers/tracking/index.ts","webpack://ui/./src/reducers/subscription/index.tsx","webpack://ui/./src/reducers/viewBy/index.tsx","webpack://ui/./src/reducers/error/index.tsx","webpack://ui/./src/reducers/currency/index.tsx","webpack://ui/./src/reducers/audienceProfiler/index.tsx","webpack://ui/./src/reducers/pagination/index.tsx","webpack://ui/./src/reducers/compareBy/index.ts","webpack://ui/./src/reducers/featureFlag/index.tsx","webpack://ui/./src/reducers/KBQ/donutViewByItems/index.tsx","webpack://ui/./src/reducers/KBQ/index.tsx","webpack://ui/./src/reducers/rootReducer.ts","webpack://ui/./src/reducers/store.ts","webpack://ui/./src/reducers/subscription/selectors.ts","webpack://ui/./src/reducers/subscription/user/index.tsx","webpack://ui/./src/reducers/tracking/activepage/index.tsx","webpack://ui/./src/reducers/tracking/page/index.tsx","webpack://ui/./src/reducers/tracking/section/index.tsx","webpack://ui/./src/reducers/user/index.ts","webpack://ui/./src/reducers/viewBy/selected/index.tsx","webpack://ui/./src/typings/filters.ts","webpack://ui/./src/util/analytics/index.ts","webpack://ui/./src/util/formatting/index.ts","webpack://ui/./src/util/localStorage/index.ts","webpack://ui/./src/util/urlUtils/index.tsx","webpack://ui/./src/util/validateContext/index.ts","webpack://ui/./src/components/LoadingContent/index.module.scss","webpack://ui/./src/components/OnboardingGuide/actionable-data-slide/ActionableDataSlide.scss","webpack://ui/./src/components/OnboardingGuide/focus-matters-slide/FocusMattersSlide.scss","webpack://ui/./src/components/OnboardingGuide/millions-shoppers-slide/MillionsShoppersSlide.scss","webpack://ui/./src/components/OnboardingGuide/selling-starts-slide/SellingStartsSlide.scss","webpack://ui/./src/util/confirmation/index.module.scss","webpack://ui/./node_modules/css-loader/dist/runtime/api.js","webpack://ui/./node_modules/css-loader/dist/runtime/getUrl.js","webpack://ui/./node_modules/css-loader/dist/runtime/sourceMaps.js","webpack://ui/./node_modules/graphql/jsutils/isObjectLike.mjs","webpack://ui/./node_modules/graphql/polyfills/symbols.mjs","webpack://ui/./node_modules/graphql/language/location.mjs","webpack://ui/./node_modules/graphql/language/printLocation.mjs","webpack://ui/./node_modules/graphql/error/GraphQLError.mjs","webpack://ui/./node_modules/graphql/error/syntaxError.mjs","webpack://ui/./node_modules/graphql/language/tokenKind.mjs","webpack://ui/./node_modules/graphql/jsutils/devAssert.mjs","webpack://ui/./node_modules/graphql/language/source.mjs","webpack://ui/./node_modules/graphql/language/directiveLocation.mjs","webpack://ui/./node_modules/graphql/language/lexer.mjs","webpack://ui/./node_modules/graphql/language/parser.mjs","webpack://ui/./node_modules/graphql-tag/lib/index.js","webpack://ui/./node_modules/history/node_modules/@babel/runtime/helpers/esm/extends.js","webpack://ui/./node_modules/resolve-pathname/esm/resolve-pathname.js","webpack://ui/./node_modules/history/esm/history.js","webpack://ui/./node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","webpack://ui/./node_modules/lodash/lodash.js","webpack://ui/./node_modules/object-path/index.js","webpack://ui/./node_modules/prop-types/factoryWithThrowingShims.js","webpack://ui/./node_modules/prop-types/index.js","webpack://ui/./node_modules/prop-types/lib/ReactPropTypesSecret.js","webpack://ui/./node_modules/react-dom/client.js","webpack://ui/./node_modules/react-is/cjs/react-is.production.min.js","webpack://ui/./node_modules/react-is/index.js","webpack://ui/./node_modules/react-redux/es/components/Context.js","webpack://ui/./node_modules/react-redux/es/utils/batch.js","webpack://ui/./node_modules/react-redux/es/utils/Subscription.js","webpack://ui/./node_modules/react-redux/es/utils/useIsomorphicLayoutEffect.js","webpack://ui/./node_modules/react-redux/es/components/Provider.js","webpack://ui/./node_modules/react-redux/es/hooks/useReduxContext.js","webpack://ui/./node_modules/react-redux/es/hooks/useStore.js","webpack://ui/./node_modules/react-redux/es/hooks/useDispatch.js","webpack://ui/./node_modules/react-redux/es/hooks/useSelector.js","webpack://ui/./node_modules/react-redux/es/index.js","webpack://ui/./node_modules/react-redux/node_modules/react-is/cjs/react-is.production.min.js","webpack://ui/./node_modules/react-redux/node_modules/react-is/index.js","webpack://ui/./node_modules/react-router-dom/node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","webpack://ui/./node_modules/react-router-dom/node_modules/@babel/runtime/helpers/esm/extends.js","webpack://ui/./node_modules/react-router-dom/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","webpack://ui/./node_modules/react-router-dom/esm/react-router-dom.js","webpack://ui/./node_modules/react-router-dom/node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","webpack://ui/./node_modules/react-router/node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","webpack://ui/./node_modules/react-router/node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","webpack://ui/./node_modules/react-router/node_modules/@babel/runtime/helpers/esm/extends.js","webpack://ui/./node_modules/react-router/esm/react-router.js","webpack://ui/./node_modules/react-router/node_modules/isarray/index.js","webpack://ui/./node_modules/react-router/node_modules/path-to-regexp/index.js","webpack://ui/./node_modules/react/cjs/react-jsx-runtime.production.min.js","webpack://ui/./node_modules/react/jsx-runtime.js","webpack://ui/./node_modules/redux-watch/index.js","webpack://ui/./node_modules/redux/node_modules/@babel/runtime/helpers/esm/typeof.js","webpack://ui/./node_modules/redux/node_modules/@babel/runtime/helpers/esm/defineProperty.js","webpack://ui/./node_modules/redux/node_modules/@babel/runtime/helpers/esm/toPropertyKey.js","webpack://ui/./node_modules/redux/node_modules/@babel/runtime/helpers/esm/toPrimitive.js","webpack://ui/./node_modules/redux/node_modules/@babel/runtime/helpers/esm/objectSpread2.js","webpack://ui/./node_modules/redux/es/redux.js","webpack://ui/./node_modules/reselect/es/defaultMemoize.js","webpack://ui/./node_modules/reselect/es/index.js","webpack://ui/./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js","webpack://ui/./node_modules/style-loader/dist/runtime/insertBySelector.js","webpack://ui/./node_modules/style-loader/dist/runtime/insertStyleElement.js","webpack://ui/./node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js","webpack://ui/./node_modules/style-loader/dist/runtime/styleDomAPI.js","webpack://ui/./node_modules/style-loader/dist/runtime/styleTagTransform.js","webpack://ui/./node_modules/systemjs-webpack-interop/auto-public-path/auto-public-path.js","webpack://ui/./node_modules/systemjs-webpack-interop/public-path.js","webpack://ui/external system \"@ecosystem/newron-client-collections\"","webpack://ui/external system \"@ecosystem/newron-client-lib\"","webpack://ui/external system \"@ecosystem/newron-design-system\"","webpack://ui/external system \"react\"","webpack://ui/external system \"react-dom\"","webpack://ui/./node_modules/axios/dist/browser/axios.cjs","webpack://ui/./node_modules/@apollo/client/core/networkStatus.js","webpack://ui/./node_modules/@apollo/client/errors/index.js","webpack://ui/./node_modules/@apollo/client/node_modules/tslib/tslib.es6.mjs","webpack://ui/./node_modules/@apollo/client/react/context/ApolloContext.js","webpack://ui/./node_modules/@apollo/client/react/hooks/useApolloClient.js","webpack://ui/./node_modules/@apollo/client/react/hooks/useSyncExternalStore.js","webpack://ui/./node_modules/@apollo/client/react/parser/index.js","webpack://ui/./node_modules/@apollo/client/react/hooks/useQuery.js","webpack://ui/./node_modules/@apollo/client/utilities/common/arrays.js","webpack://ui/./node_modules/@apollo/client/utilities/common/canUse.js","webpack://ui/./node_modules/@apollo/client/utilities/common/compact.js","webpack://ui/./node_modules/@apollo/client/utilities/common/makeUniqueId.js","webpack://ui/./node_modules/@apollo/client/utilities/common/maybeDeepFreeze.js","webpack://ui/./node_modules/@apollo/client/utilities/common/mergeOptions.js","webpack://ui/./node_modules/@apollo/client/utilities/common/objects.js","webpack://ui/./node_modules/@apollo/client/utilities/common/stringifyForDisplay.js","webpack://ui/./node_modules/ts-invariant/lib/invariant.js","webpack://ui/./node_modules/@apollo/client/utilities/globals/maybe.js","webpack://ui/./node_modules/@apollo/client/utilities/globals/global.js","webpack://ui/./node_modules/@apollo/client/utilities/globals/invariantWrappers.js","webpack://ui/./node_modules/@apollo/client/utilities/globals/index.js","webpack://ui/./node_modules/@apollo/client/version.js","webpack://ui/./node_modules/@wry/equality/lib/index.js","webpack://ui/./node_modules/graphql/jsutils/inspect.mjs","webpack://ui/./node_modules/graphql/jsutils/nodejsCustomInspectSymbol.mjs","webpack://ui/./node_modules/graphql/jsutils/defineInspect.mjs","webpack://ui/./node_modules/graphql/jsutils/invariant.mjs","webpack://ui/./node_modules/graphql/language/ast.mjs","webpack://ui/./node_modules/graphql/language/blockString.mjs","webpack://ui/./node_modules/graphql/language/kinds.mjs","webpack://ui/./node_modules/immer/dist/immer.esm.mjs","webpack://ui/./node_modules/tiny-invariant/dist/esm/tiny-invariant.js","webpack://ui/./node_modules/tslib/tslib.es6.mjs","webpack://ui/webpack/bootstrap","webpack://ui/webpack/runtime/__system_context__","webpack://ui/webpack/runtime/compat get default export","webpack://ui/webpack/runtime/define property getters","webpack://ui/webpack/runtime/ensure chunk","webpack://ui/webpack/runtime/get javascript chunk filename","webpack://ui/webpack/runtime/global","webpack://ui/webpack/runtime/hasOwnProperty shorthand","webpack://ui/webpack/runtime/make namespace object","webpack://ui/webpack/runtime/node module decorator","webpack://ui/webpack/runtime/publicPath","webpack://ui/webpack/runtime/jsonp chunk loading","webpack://ui/webpack/runtime/nonce","webpack://ui/./node_modules/systemjs-webpack-interop/auto-public-path/1.js","webpack://ui/./node_modules/single-spa-react/lib/esm/single-spa-react.js","webpack://ui/./src/util/confirmation/index.module.scss?77e8","webpack://ui/./src/util/confirmation/index.tsx","webpack://ui/./src/util/getConfirmation/index.tsx","webpack://ui/./src/components/OnboardingGuide/actionable-data-slide/ActionableDataSlide.scss?38c3","webpack://ui/./src/components/OnboardingGuide/actionable-data-slide/ActionableDataSlide.tsx","webpack://ui/./src/components/OnboardingGuide/focus-matters-slide/FocusMattersSlide.scss?d473","webpack://ui/./src/components/OnboardingGuide/focus-matters-slide/FocusMattersSlide.tsx","webpack://ui/./src/components/OnboardingGuide/millions-shoppers-slide/MillionsShoppersSlide.scss?360b","webpack://ui/./src/components/OnboardingGuide/millions-shoppers-slide/MillionsShoppersSlide.tsx","webpack://ui/./src/components/OnboardingGuide/selling-starts-slide/SellingStartsSlide.scss?53b7","webpack://ui/./src/components/OnboardingGuide/selling-starts-slide/SellingStartsSlide.tsx","webpack://ui/./src/util/collections/index.tsx","webpack://ui/./src/reportWebVitals.ts","webpack://ui/./src/Root.tsx","webpack://ui/./src/components/OnboardingGuide/hooks/useRegisterSlides.ts","webpack://ui/./src/cie-ui.tsx"],"sourcesContent":["var inProgress = {};\nvar dataWebpackPrefix = \"ui:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = (url, done, key, chunkId) => {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = (prev, event) => {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach((fn) => (fn(event)));\n\t\tif(prev) return prev(event);\n\t}\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","\"use strict\";\n/* tslint:disable */\n/* eslint-disable */\n/**\n * Preference Service\n * Preference API endpoints usage\n *\n * The version of the OpenAPI document: 1.0.0\n *\n *\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\n * https://openapi-generator.tech\n * Do not edit the class manually.\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(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))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\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: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.PreferencesControllerApi = exports.PreferencesControllerApiFactory = exports.PreferencesControllerApiFp = exports.PreferencesControllerApiAxiosParamCreator = exports.HealthApi = exports.HealthApiFactory = exports.HealthApiFp = exports.HealthApiAxiosParamCreator = exports.FiltersControllerApi = exports.FiltersControllerApiFactory = exports.FiltersControllerApiFp = exports.FiltersControllerApiAxiosParamCreator = exports.AccessDto = void 0;\nvar axios_1 = require(\"axios\");\n// Some imports not used depending on template conditions\n// @ts-ignore\nvar common_1 = require(\"./common\");\n// @ts-ignore\nvar base_1 = require(\"./base\");\n/**\n *\n * @export\n * @enum {string}\n */\nvar AccessDto;\n(function (AccessDto) {\n AccessDto[\"Owner\"] = \"owner\";\n AccessDto[\"View\"] = \"view\";\n})(AccessDto = exports.AccessDto || (exports.AccessDto = {}));\n/**\n * FiltersControllerApi - axios parameter creator\n * @export\n */\nexports.FiltersControllerApiAxiosParamCreator = function (configuration) {\n var _this = this;\n return {\n /**\n * creates a filters object\n * @param {CreateFilterDto} createFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerCreate: function (createFilterDto, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n // verify required parameter 'createFilterDto' is not null or undefined\n common_1.assertParamExists('filtersControllerCreate', 'createFilterDto', createFilterDto);\n localVarPath = \"/v1/filters\";\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'POST' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n localVarHeaderParameter['Content-Type'] = 'application/json';\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n localVarRequestOptions.data = common_1.serializeDataIfNeeded(createFilterDto, localVarRequestOptions, configuration);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n /**\n * deletes filter for a given filter id\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerDeleteById: function (id, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n // verify required parameter 'id' is not null or undefined\n common_1.assertParamExists('filtersControllerDeleteById', 'id', id);\n localVarPath = \"/v1/filters/{id}\"\n .replace(\"{\" + \"id\" + \"}\", encodeURIComponent(String(id)));\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'DELETE' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n /**\n * gets a collection of filters objects\n * @param {string} [product] CP product the filter is associated with, i.e. \\"NEWRON\\" or \\"CIE\\"\n * @param {string} [itemGroup]\n * @param {string} [market]\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerFindAll: function (product, itemGroup, market, namespace, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n localVarPath = \"/v1/filters\";\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'GET' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n if (product !== undefined) {\n localVarQueryParameter['product'] = product;\n }\n if (itemGroup !== undefined) {\n localVarQueryParameter['item_group'] = itemGroup;\n }\n if (market !== undefined) {\n localVarQueryParameter['market'] = market;\n }\n if (namespace !== undefined) {\n localVarQueryParameter['namespace'] = namespace;\n }\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n /**\n * updates filter for a given filter id\n * @param {string} id\n * @param {UpdateFilterDto} updateFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerUpdateById: function (id, updateFilterDto, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n // verify required parameter 'id' is not null or undefined\n common_1.assertParamExists('filtersControllerUpdateById', 'id', id);\n // verify required parameter 'updateFilterDto' is not null or undefined\n common_1.assertParamExists('filtersControllerUpdateById', 'updateFilterDto', updateFilterDto);\n localVarPath = \"/v1/filters/{id}\"\n .replace(\"{\" + \"id\" + \"}\", encodeURIComponent(String(id)));\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'PATCH' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n localVarHeaderParameter['Content-Type'] = 'application/json';\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n localVarRequestOptions.data = common_1.serializeDataIfNeeded(updateFilterDto, localVarRequestOptions, configuration);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n /**\n * creates a filters object\n * @param {CreateFilterDto} createFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2Create: function (createFilterDto, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n // verify required parameter 'createFilterDto' is not null or undefined\n common_1.assertParamExists('filtersControllerV2Create', 'createFilterDto', createFilterDto);\n localVarPath = \"/v2/filters\";\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'POST' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n localVarHeaderParameter['Content-Type'] = 'application/json';\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n localVarRequestOptions.data = common_1.serializeDataIfNeeded(createFilterDto, localVarRequestOptions, configuration);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n /**\n * deletes filter for a given filter id\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2DeleteById: function (id, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n // verify required parameter 'id' is not null or undefined\n common_1.assertParamExists('filtersControllerV2DeleteById', 'id', id);\n localVarPath = \"/v2/filters/{id}\"\n .replace(\"{\" + \"id\" + \"}\", encodeURIComponent(String(id)));\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'DELETE' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n /**\n * gets a collection of filters objects\n * @param {string} [product] CP product the filter is associated with, i.e. \\"NEWRON\\" or \\"CIE\\"\n * @param {string} [itemGroup]\n * @param {string} [market]\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2FindAll: function (product, itemGroup, market, namespace, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n localVarPath = \"/v2/filters\";\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'GET' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n if (product !== undefined) {\n localVarQueryParameter['product'] = product;\n }\n if (itemGroup !== undefined) {\n localVarQueryParameter['item_group'] = itemGroup;\n }\n if (market !== undefined) {\n localVarQueryParameter['market'] = market;\n }\n if (namespace !== undefined) {\n localVarQueryParameter['namespace'] = namespace;\n }\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n /**\n * updates filter for a given filter id\n * @param {string} id\n * @param {UpdateFilterDto} updateFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2UpdateById: function (id, updateFilterDto, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n // verify required parameter 'id' is not null or undefined\n common_1.assertParamExists('filtersControllerV2UpdateById', 'id', id);\n // verify required parameter 'updateFilterDto' is not null or undefined\n common_1.assertParamExists('filtersControllerV2UpdateById', 'updateFilterDto', updateFilterDto);\n localVarPath = \"/v2/filters/{id}\"\n .replace(\"{\" + \"id\" + \"}\", encodeURIComponent(String(id)));\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'PATCH' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n localVarHeaderParameter['Content-Type'] = 'application/json';\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n localVarRequestOptions.data = common_1.serializeDataIfNeeded(updateFilterDto, localVarRequestOptions, configuration);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n };\n};\n/**\n * FiltersControllerApi - functional programming interface\n * @export\n */\nexports.FiltersControllerApiFp = function (configuration) {\n var localVarAxiosParamCreator = exports.FiltersControllerApiAxiosParamCreator(configuration);\n return {\n /**\n * creates a filters object\n * @param {CreateFilterDto} createFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerCreate: function (createFilterDto, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.filtersControllerCreate(createFilterDto, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n /**\n * deletes filter for a given filter id\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerDeleteById: function (id, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.filtersControllerDeleteById(id, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n /**\n * gets a collection of filters objects\n * @param {string} [product] CP product the filter is associated with, i.e. \\"NEWRON\\" or \\"CIE\\"\n * @param {string} [itemGroup]\n * @param {string} [market]\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerFindAll: function (product, itemGroup, market, namespace, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.filtersControllerFindAll(product, itemGroup, market, namespace, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n /**\n * updates filter for a given filter id\n * @param {string} id\n * @param {UpdateFilterDto} updateFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerUpdateById: function (id, updateFilterDto, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.filtersControllerUpdateById(id, updateFilterDto, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n /**\n * creates a filters object\n * @param {CreateFilterDto} createFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2Create: function (createFilterDto, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.filtersControllerV2Create(createFilterDto, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n /**\n * deletes filter for a given filter id\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2DeleteById: function (id, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.filtersControllerV2DeleteById(id, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n /**\n * gets a collection of filters objects\n * @param {string} [product] CP product the filter is associated with, i.e. \\"NEWRON\\" or \\"CIE\\"\n * @param {string} [itemGroup]\n * @param {string} [market]\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2FindAll: function (product, itemGroup, market, namespace, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.filtersControllerV2FindAll(product, itemGroup, market, namespace, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n /**\n * updates filter for a given filter id\n * @param {string} id\n * @param {UpdateFilterDto} updateFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2UpdateById: function (id, updateFilterDto, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.filtersControllerV2UpdateById(id, updateFilterDto, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n };\n};\n/**\n * FiltersControllerApi - factory interface\n * @export\n */\nexports.FiltersControllerApiFactory = function (configuration, basePath, axios) {\n var localVarFp = exports.FiltersControllerApiFp(configuration);\n return {\n /**\n * creates a filters object\n * @param {CreateFilterDto} createFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerCreate: function (createFilterDto, options) {\n return localVarFp.filtersControllerCreate(createFilterDto, options).then(function (request) { return request(axios, basePath); });\n },\n /**\n * deletes filter for a given filter id\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerDeleteById: function (id, options) {\n return localVarFp.filtersControllerDeleteById(id, options).then(function (request) { return request(axios, basePath); });\n },\n /**\n * gets a collection of filters objects\n * @param {string} [product] CP product the filter is associated with, i.e. \\"NEWRON\\" or \\"CIE\\"\n * @param {string} [itemGroup]\n * @param {string} [market]\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerFindAll: function (product, itemGroup, market, namespace, options) {\n return localVarFp.filtersControllerFindAll(product, itemGroup, market, namespace, options).then(function (request) { return request(axios, basePath); });\n },\n /**\n * updates filter for a given filter id\n * @param {string} id\n * @param {UpdateFilterDto} updateFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerUpdateById: function (id, updateFilterDto, options) {\n return localVarFp.filtersControllerUpdateById(id, updateFilterDto, options).then(function (request) { return request(axios, basePath); });\n },\n /**\n * creates a filters object\n * @param {CreateFilterDto} createFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2Create: function (createFilterDto, options) {\n return localVarFp.filtersControllerV2Create(createFilterDto, options).then(function (request) { return request(axios, basePath); });\n },\n /**\n * deletes filter for a given filter id\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2DeleteById: function (id, options) {\n return localVarFp.filtersControllerV2DeleteById(id, options).then(function (request) { return request(axios, basePath); });\n },\n /**\n * gets a collection of filters objects\n * @param {string} [product] CP product the filter is associated with, i.e. \\"NEWRON\\" or \\"CIE\\"\n * @param {string} [itemGroup]\n * @param {string} [market]\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2FindAll: function (product, itemGroup, market, namespace, options) {\n return localVarFp.filtersControllerV2FindAll(product, itemGroup, market, namespace, options).then(function (request) { return request(axios, basePath); });\n },\n /**\n * updates filter for a given filter id\n * @param {string} id\n * @param {UpdateFilterDto} updateFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n filtersControllerV2UpdateById: function (id, updateFilterDto, options) {\n return localVarFp.filtersControllerV2UpdateById(id, updateFilterDto, options).then(function (request) { return request(axios, basePath); });\n },\n };\n};\n/**\n * FiltersControllerApi - object-oriented interface\n * @export\n * @class FiltersControllerApi\n * @extends {BaseAPI}\n */\nvar FiltersControllerApi = /** @class */ (function (_super) {\n __extends(FiltersControllerApi, _super);\n function FiltersControllerApi() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /**\n * creates a filters object\n * @param {CreateFilterDto} createFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof FiltersControllerApi\n */\n FiltersControllerApi.prototype.filtersControllerCreate = function (createFilterDto, options) {\n var _this = this;\n return exports.FiltersControllerApiFp(this.configuration).filtersControllerCreate(createFilterDto, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n /**\n * deletes filter for a given filter id\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof FiltersControllerApi\n */\n FiltersControllerApi.prototype.filtersControllerDeleteById = function (id, options) {\n var _this = this;\n return exports.FiltersControllerApiFp(this.configuration).filtersControllerDeleteById(id, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n /**\n * gets a collection of filters objects\n * @param {string} [product] CP product the filter is associated with, i.e. \\"NEWRON\\" or \\"CIE\\"\n * @param {string} [itemGroup]\n * @param {string} [market]\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof FiltersControllerApi\n */\n FiltersControllerApi.prototype.filtersControllerFindAll = function (product, itemGroup, market, namespace, options) {\n var _this = this;\n return exports.FiltersControllerApiFp(this.configuration).filtersControllerFindAll(product, itemGroup, market, namespace, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n /**\n * updates filter for a given filter id\n * @param {string} id\n * @param {UpdateFilterDto} updateFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof FiltersControllerApi\n */\n FiltersControllerApi.prototype.filtersControllerUpdateById = function (id, updateFilterDto, options) {\n var _this = this;\n return exports.FiltersControllerApiFp(this.configuration).filtersControllerUpdateById(id, updateFilterDto, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n /**\n * creates a filters object\n * @param {CreateFilterDto} createFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof FiltersControllerApi\n */\n FiltersControllerApi.prototype.filtersControllerV2Create = function (createFilterDto, options) {\n var _this = this;\n return exports.FiltersControllerApiFp(this.configuration).filtersControllerV2Create(createFilterDto, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n /**\n * deletes filter for a given filter id\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof FiltersControllerApi\n */\n FiltersControllerApi.prototype.filtersControllerV2DeleteById = function (id, options) {\n var _this = this;\n return exports.FiltersControllerApiFp(this.configuration).filtersControllerV2DeleteById(id, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n /**\n * gets a collection of filters objects\n * @param {string} [product] CP product the filter is associated with, i.e. \\"NEWRON\\" or \\"CIE\\"\n * @param {string} [itemGroup]\n * @param {string} [market]\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof FiltersControllerApi\n */\n FiltersControllerApi.prototype.filtersControllerV2FindAll = function (product, itemGroup, market, namespace, options) {\n var _this = this;\n return exports.FiltersControllerApiFp(this.configuration).filtersControllerV2FindAll(product, itemGroup, market, namespace, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n /**\n * updates filter for a given filter id\n * @param {string} id\n * @param {UpdateFilterDto} updateFilterDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof FiltersControllerApi\n */\n FiltersControllerApi.prototype.filtersControllerV2UpdateById = function (id, updateFilterDto, options) {\n var _this = this;\n return exports.FiltersControllerApiFp(this.configuration).filtersControllerV2UpdateById(id, updateFilterDto, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n return FiltersControllerApi;\n}(base_1.BaseAPI));\nexports.FiltersControllerApi = FiltersControllerApi;\n/**\n * HealthApi - axios parameter creator\n * @export\n */\nexports.HealthApiAxiosParamCreator = function (configuration) {\n var _this = this;\n return {\n /**\n * health check\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n actuatorHealthGet: function (options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n localVarPath = \"/actuator/health/\";\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'GET' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n });\n });\n },\n };\n};\n/**\n * HealthApi - functional programming interface\n * @export\n */\nexports.HealthApiFp = function (configuration) {\n var localVarAxiosParamCreator = exports.HealthApiAxiosParamCreator(configuration);\n return {\n /**\n * health check\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n actuatorHealthGet: function (options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.actuatorHealthGet(options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n };\n};\n/**\n * HealthApi - factory interface\n * @export\n */\nexports.HealthApiFactory = function (configuration, basePath, axios) {\n var localVarFp = exports.HealthApiFp(configuration);\n return {\n /**\n * health check\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n actuatorHealthGet: function (options) {\n return localVarFp.actuatorHealthGet(options).then(function (request) { return request(axios, basePath); });\n },\n };\n};\n/**\n * HealthApi - object-oriented interface\n * @export\n * @class HealthApi\n * @extends {BaseAPI}\n */\nvar HealthApi = /** @class */ (function (_super) {\n __extends(HealthApi, _super);\n function HealthApi() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /**\n * health check\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof HealthApi\n */\n HealthApi.prototype.actuatorHealthGet = function (options) {\n var _this = this;\n return exports.HealthApiFp(this.configuration).actuatorHealthGet(options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n return HealthApi;\n}(base_1.BaseAPI));\nexports.HealthApi = HealthApi;\n/**\n * PreferencesControllerApi - axios parameter creator\n * @export\n */\nexports.PreferencesControllerApiAxiosParamCreator = function (configuration) {\n var _this = this;\n return {\n /**\n * creates a preference\n * @param {string} product\n * @param {string} preferenceType\n * @param {CreatePreferenceDto} createPreferenceDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerCreate: function (product, preferenceType, createPreferenceDto, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n // verify required parameter 'product' is not null or undefined\n common_1.assertParamExists('preferencesControllerCreate', 'product', product);\n // verify required parameter 'preferenceType' is not null or undefined\n common_1.assertParamExists('preferencesControllerCreate', 'preferenceType', preferenceType);\n // verify required parameter 'createPreferenceDto' is not null or undefined\n common_1.assertParamExists('preferencesControllerCreate', 'createPreferenceDto', createPreferenceDto);\n localVarPath = \"/v1/preferences/{product}/{preferenceType}\"\n .replace(\"{\" + \"product\" + \"}\", encodeURIComponent(String(product)))\n .replace(\"{\" + \"preferenceType\" + \"}\", encodeURIComponent(String(preferenceType)));\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'POST' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n localVarHeaderParameter['Content-Type'] = 'application/json';\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n localVarRequestOptions.data = common_1.serializeDataIfNeeded(createPreferenceDto, localVarRequestOptions, configuration);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n /**\n * deletes preference for a given preference id\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerDeleteById: function (product, preferenceType, id, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n // verify required parameter 'product' is not null or undefined\n common_1.assertParamExists('preferencesControllerDeleteById', 'product', product);\n // verify required parameter 'preferenceType' is not null or undefined\n common_1.assertParamExists('preferencesControllerDeleteById', 'preferenceType', preferenceType);\n // verify required parameter 'id' is not null or undefined\n common_1.assertParamExists('preferencesControllerDeleteById', 'id', id);\n localVarPath = \"/v1/preferences/{product}/{preferenceType}/{id}\"\n .replace(\"{\" + \"product\" + \"}\", encodeURIComponent(String(product)))\n .replace(\"{\" + \"preferenceType\" + \"}\", encodeURIComponent(String(preferenceType)))\n .replace(\"{\" + \"id\" + \"}\", encodeURIComponent(String(id)));\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'DELETE' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n /**\n * gets a collection of preference objects\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerFindAll: function (product, preferenceType, namespace, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n // verify required parameter 'product' is not null or undefined\n common_1.assertParamExists('preferencesControllerFindAll', 'product', product);\n // verify required parameter 'preferenceType' is not null or undefined\n common_1.assertParamExists('preferencesControllerFindAll', 'preferenceType', preferenceType);\n localVarPath = \"/v1/preferences/{product}/{preferenceType}\"\n .replace(\"{\" + \"product\" + \"}\", encodeURIComponent(String(product)))\n .replace(\"{\" + \"preferenceType\" + \"}\", encodeURIComponent(String(preferenceType)));\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'GET' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n if (namespace !== undefined) {\n localVarQueryParameter['namespace'] = namespace;\n }\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n /**\n * updates preference for a given preference id\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} id\n * @param {UpdatePreferenceDto} updatePreferenceDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerUpdateById: function (product, preferenceType, id, updatePreferenceDto, options) {\n if (options === void 0) { options = {}; }\n return __awaiter(_this, void 0, void 0, function () {\n var localVarPath, localVarUrlObj, baseOptions, localVarRequestOptions, localVarHeaderParameter, localVarQueryParameter, headersFromBaseOptions;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0:\n // verify required parameter 'product' is not null or undefined\n common_1.assertParamExists('preferencesControllerUpdateById', 'product', product);\n // verify required parameter 'preferenceType' is not null or undefined\n common_1.assertParamExists('preferencesControllerUpdateById', 'preferenceType', preferenceType);\n // verify required parameter 'id' is not null or undefined\n common_1.assertParamExists('preferencesControllerUpdateById', 'id', id);\n // verify required parameter 'updatePreferenceDto' is not null or undefined\n common_1.assertParamExists('preferencesControllerUpdateById', 'updatePreferenceDto', updatePreferenceDto);\n localVarPath = \"/v1/preferences/{product}/{preferenceType}/{id}\"\n .replace(\"{\" + \"product\" + \"}\", encodeURIComponent(String(product)))\n .replace(\"{\" + \"preferenceType\" + \"}\", encodeURIComponent(String(preferenceType)))\n .replace(\"{\" + \"id\" + \"}\", encodeURIComponent(String(id)));\n localVarUrlObj = new URL(localVarPath, common_1.DUMMY_BASE_URL);\n if (configuration) {\n baseOptions = configuration.baseOptions;\n }\n localVarRequestOptions = __assign(__assign({ method: 'PATCH' }, baseOptions), options);\n localVarHeaderParameter = {};\n localVarQueryParameter = {};\n // authentication bearer required\n // http bearer authentication required\n return [4 /*yield*/, common_1.setBearerAuthToObject(localVarHeaderParameter, configuration)];\n case 1:\n // authentication bearer required\n // http bearer authentication required\n _a.sent();\n localVarHeaderParameter['Content-Type'] = 'application/json';\n common_1.setSearchParams(localVarUrlObj, localVarQueryParameter);\n headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {};\n localVarRequestOptions.headers = __assign(__assign(__assign({}, localVarHeaderParameter), headersFromBaseOptions), options.headers);\n localVarRequestOptions.data = common_1.serializeDataIfNeeded(updatePreferenceDto, localVarRequestOptions, configuration);\n return [2 /*return*/, {\n url: common_1.toPathString(localVarUrlObj),\n options: localVarRequestOptions,\n }];\n }\n });\n });\n },\n };\n};\n/**\n * PreferencesControllerApi - functional programming interface\n * @export\n */\nexports.PreferencesControllerApiFp = function (configuration) {\n var localVarAxiosParamCreator = exports.PreferencesControllerApiAxiosParamCreator(configuration);\n return {\n /**\n * creates a preference\n * @param {string} product\n * @param {string} preferenceType\n * @param {CreatePreferenceDto} createPreferenceDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerCreate: function (product, preferenceType, createPreferenceDto, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.preferencesControllerCreate(product, preferenceType, createPreferenceDto, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n /**\n * deletes preference for a given preference id\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerDeleteById: function (product, preferenceType, id, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.preferencesControllerDeleteById(product, preferenceType, id, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n /**\n * gets a collection of preference objects\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerFindAll: function (product, preferenceType, namespace, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.preferencesControllerFindAll(product, preferenceType, namespace, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n /**\n * updates preference for a given preference id\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} id\n * @param {UpdatePreferenceDto} updatePreferenceDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerUpdateById: function (product, preferenceType, id, updatePreferenceDto, options) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAxiosArgs;\n return __generator(this, function (_a) {\n switch (_a.label) {\n case 0: return [4 /*yield*/, localVarAxiosParamCreator.preferencesControllerUpdateById(product, preferenceType, id, updatePreferenceDto, options)];\n case 1:\n localVarAxiosArgs = _a.sent();\n return [2 /*return*/, common_1.createRequestFunction(localVarAxiosArgs, axios_1.default, base_1.BASE_PATH, configuration)];\n }\n });\n });\n },\n };\n};\n/**\n * PreferencesControllerApi - factory interface\n * @export\n */\nexports.PreferencesControllerApiFactory = function (configuration, basePath, axios) {\n var localVarFp = exports.PreferencesControllerApiFp(configuration);\n return {\n /**\n * creates a preference\n * @param {string} product\n * @param {string} preferenceType\n * @param {CreatePreferenceDto} createPreferenceDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerCreate: function (product, preferenceType, createPreferenceDto, options) {\n return localVarFp.preferencesControllerCreate(product, preferenceType, createPreferenceDto, options).then(function (request) { return request(axios, basePath); });\n },\n /**\n * deletes preference for a given preference id\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerDeleteById: function (product, preferenceType, id, options) {\n return localVarFp.preferencesControllerDeleteById(product, preferenceType, id, options).then(function (request) { return request(axios, basePath); });\n },\n /**\n * gets a collection of preference objects\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerFindAll: function (product, preferenceType, namespace, options) {\n return localVarFp.preferencesControllerFindAll(product, preferenceType, namespace, options).then(function (request) { return request(axios, basePath); });\n },\n /**\n * updates preference for a given preference id\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} id\n * @param {UpdatePreferenceDto} updatePreferenceDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n */\n preferencesControllerUpdateById: function (product, preferenceType, id, updatePreferenceDto, options) {\n return localVarFp.preferencesControllerUpdateById(product, preferenceType, id, updatePreferenceDto, options).then(function (request) { return request(axios, basePath); });\n },\n };\n};\n/**\n * PreferencesControllerApi - object-oriented interface\n * @export\n * @class PreferencesControllerApi\n * @extends {BaseAPI}\n */\nvar PreferencesControllerApi = /** @class */ (function (_super) {\n __extends(PreferencesControllerApi, _super);\n function PreferencesControllerApi() {\n return _super !== null && _super.apply(this, arguments) || this;\n }\n /**\n * creates a preference\n * @param {string} product\n * @param {string} preferenceType\n * @param {CreatePreferenceDto} createPreferenceDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof PreferencesControllerApi\n */\n PreferencesControllerApi.prototype.preferencesControllerCreate = function (product, preferenceType, createPreferenceDto, options) {\n var _this = this;\n return exports.PreferencesControllerApiFp(this.configuration).preferencesControllerCreate(product, preferenceType, createPreferenceDto, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n /**\n * deletes preference for a given preference id\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} id\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof PreferencesControllerApi\n */\n PreferencesControllerApi.prototype.preferencesControllerDeleteById = function (product, preferenceType, id, options) {\n var _this = this;\n return exports.PreferencesControllerApiFp(this.configuration).preferencesControllerDeleteById(product, preferenceType, id, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n /**\n * gets a collection of preference objects\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} [namespace]\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof PreferencesControllerApi\n */\n PreferencesControllerApi.prototype.preferencesControllerFindAll = function (product, preferenceType, namespace, options) {\n var _this = this;\n return exports.PreferencesControllerApiFp(this.configuration).preferencesControllerFindAll(product, preferenceType, namespace, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n /**\n * updates preference for a given preference id\n * @param {string} product\n * @param {string} preferenceType\n * @param {string} id\n * @param {UpdatePreferenceDto} updatePreferenceDto\n * @param {*} [options] Override http request option.\n * @throws {RequiredError}\n * @memberof PreferencesControllerApi\n */\n PreferencesControllerApi.prototype.preferencesControllerUpdateById = function (product, preferenceType, id, updatePreferenceDto, options) {\n var _this = this;\n return exports.PreferencesControllerApiFp(this.configuration).preferencesControllerUpdateById(product, preferenceType, id, updatePreferenceDto, options).then(function (request) { return request(_this.axios, _this.basePath); });\n };\n return PreferencesControllerApi;\n}(base_1.BaseAPI));\nexports.PreferencesControllerApi = PreferencesControllerApi;\n","\"use strict\";\n/* tslint:disable */\n/* eslint-disable */\n/**\n * Preference Service\n * Preference API endpoints usage\n *\n * The version of the OpenAPI document: 1.0.0\n *\n *\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\n * https://openapi-generator.tech\n * Do not edit the class manually.\n */\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.RequiredError = exports.BaseAPI = exports.COLLECTION_FORMATS = exports.BASE_PATH = void 0;\n// Some imports not used depending on template conditions\n// @ts-ignore\nvar axios_1 = require(\"axios\");\nexports.BASE_PATH = \"http://localhost:3000\".replace(/\\/+$/, \"\");\n/**\n *\n * @export\n */\nexports.COLLECTION_FORMATS = {\n csv: \",\",\n ssv: \" \",\n tsv: \"\\t\",\n pipes: \"|\",\n};\n/**\n *\n * @export\n * @class BaseAPI\n */\nvar BaseAPI = /** @class */ (function () {\n function BaseAPI(configuration, basePath, axios) {\n if (basePath === void 0) { basePath = exports.BASE_PATH; }\n if (axios === void 0) { axios = axios_1.default; }\n this.basePath = basePath;\n this.axios = axios;\n if (configuration) {\n this.configuration = configuration;\n this.basePath = configuration.basePath || this.basePath;\n }\n }\n return BaseAPI;\n}());\nexports.BaseAPI = BaseAPI;\n;\n/**\n *\n * @export\n * @class RequiredError\n * @extends {Error}\n */\nvar RequiredError = /** @class */ (function (_super) {\n __extends(RequiredError, _super);\n function RequiredError(field, msg) {\n var _this = _super.call(this, msg) || this;\n _this.field = field;\n _this.name = \"RequiredError\";\n return _this;\n }\n return RequiredError;\n}(Error));\nexports.RequiredError = RequiredError;\n","\"use strict\";\n/* tslint:disable */\n/* eslint-disable */\n/**\n * Preference Service\n * Preference API endpoints usage\n *\n * The version of the OpenAPI document: 1.0.0\n *\n *\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\n * https://openapi-generator.tech\n * Do not edit the class manually.\n */\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(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))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\nvar __generator = (this && this.__generator) || function (thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\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: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.createRequestFunction = exports.toPathString = exports.serializeDataIfNeeded = exports.setSearchParams = exports.setOAuthToObject = exports.setBearerAuthToObject = exports.setBasicAuthToObject = exports.setApiKeyToObject = exports.assertParamExists = exports.DUMMY_BASE_URL = void 0;\nvar base_1 = require(\"./base\");\n/**\n *\n * @export\n */\nexports.DUMMY_BASE_URL = 'https://example.com';\n/**\n *\n * @throws {RequiredError}\n * @export\n */\nexports.assertParamExists = function (functionName, paramName, paramValue) {\n if (paramValue === null || paramValue === undefined) {\n throw new base_1.RequiredError(paramName, \"Required parameter \" + paramName + \" was null or undefined when calling \" + functionName + \".\");\n }\n};\n/**\n *\n * @export\n */\nexports.setApiKeyToObject = function (object, keyParamName, configuration) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarApiKeyValue, _a;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n if (!(configuration && configuration.apiKey)) return [3 /*break*/, 5];\n if (!(typeof configuration.apiKey === 'function')) return [3 /*break*/, 2];\n return [4 /*yield*/, configuration.apiKey(keyParamName)];\n case 1:\n _a = _b.sent();\n return [3 /*break*/, 4];\n case 2: return [4 /*yield*/, configuration.apiKey];\n case 3:\n _a = _b.sent();\n _b.label = 4;\n case 4:\n localVarApiKeyValue = _a;\n object[keyParamName] = localVarApiKeyValue;\n _b.label = 5;\n case 5: return [2 /*return*/];\n }\n });\n });\n};\n/**\n *\n * @export\n */\nexports.setBasicAuthToObject = function (object, configuration) {\n if (configuration && (configuration.username || configuration.password)) {\n object[\"auth\"] = { username: configuration.username, password: configuration.password };\n }\n};\n/**\n *\n * @export\n */\nexports.setBearerAuthToObject = function (object, configuration) {\n return __awaiter(this, void 0, void 0, function () {\n var accessToken, _a;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n if (!(configuration && configuration.accessToken)) return [3 /*break*/, 5];\n if (!(typeof configuration.accessToken === 'function')) return [3 /*break*/, 2];\n return [4 /*yield*/, configuration.accessToken()];\n case 1:\n _a = _b.sent();\n return [3 /*break*/, 4];\n case 2: return [4 /*yield*/, configuration.accessToken];\n case 3:\n _a = _b.sent();\n _b.label = 4;\n case 4:\n accessToken = _a;\n object[\"Authorization\"] = \"Bearer \" + accessToken;\n _b.label = 5;\n case 5: return [2 /*return*/];\n }\n });\n });\n};\n/**\n *\n * @export\n */\nexports.setOAuthToObject = function (object, name, scopes, configuration) {\n return __awaiter(this, void 0, void 0, function () {\n var localVarAccessTokenValue, _a;\n return __generator(this, function (_b) {\n switch (_b.label) {\n case 0:\n if (!(configuration && configuration.accessToken)) return [3 /*break*/, 5];\n if (!(typeof configuration.accessToken === 'function')) return [3 /*break*/, 2];\n return [4 /*yield*/, configuration.accessToken(name, scopes)];\n case 1:\n _a = _b.sent();\n return [3 /*break*/, 4];\n case 2: return [4 /*yield*/, configuration.accessToken];\n case 3:\n _a = _b.sent();\n _b.label = 4;\n case 4:\n localVarAccessTokenValue = _a;\n object[\"Authorization\"] = \"Bearer \" + localVarAccessTokenValue;\n _b.label = 5;\n case 5: return [2 /*return*/];\n }\n });\n });\n};\n/**\n *\n * @export\n */\nexports.setSearchParams = function (url) {\n var objects = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n objects[_i - 1] = arguments[_i];\n }\n var searchParams = new URLSearchParams(url.search);\n for (var _a = 0, objects_1 = objects; _a < objects_1.length; _a++) {\n var object = objects_1[_a];\n for (var key in object) {\n if (Array.isArray(object[key])) {\n searchParams.delete(key);\n for (var _b = 0, _c = object[key]; _b < _c.length; _b++) {\n var item = _c[_b];\n searchParams.append(key, item);\n }\n }\n else {\n searchParams.set(key, object[key]);\n }\n }\n }\n url.search = searchParams.toString();\n};\n/**\n *\n * @export\n */\nexports.serializeDataIfNeeded = function (value, requestOptions, configuration) {\n var nonString = typeof value !== 'string';\n var needsSerialization = nonString && configuration && configuration.isJsonMime\n ? configuration.isJsonMime(requestOptions.headers['Content-Type'])\n : nonString;\n return needsSerialization\n ? JSON.stringify(value !== undefined ? value : {})\n : (value || \"\");\n};\n/**\n *\n * @export\n */\nexports.toPathString = function (url) {\n return url.pathname + url.search + url.hash;\n};\n/**\n *\n * @export\n */\nexports.createRequestFunction = function (axiosArgs, globalAxios, BASE_PATH, configuration) {\n return function (axios, basePath) {\n if (axios === void 0) { axios = globalAxios; }\n if (basePath === void 0) { basePath = BASE_PATH; }\n var axiosRequestArgs = __assign(__assign({}, axiosArgs.options), { url: ((configuration === null || configuration === void 0 ? void 0 : configuration.basePath) || basePath) + axiosArgs.url });\n return axios.request(axiosRequestArgs);\n };\n};\n","\"use strict\";\n/* tslint:disable */\n/* eslint-disable */\n/**\n * Preference Service\n * Preference API endpoints usage\n *\n * The version of the OpenAPI document: 1.0.0\n *\n *\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\n * https://openapi-generator.tech\n * Do not edit the class manually.\n */\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.Configuration = void 0;\nvar Configuration = /** @class */ (function () {\n function Configuration(param) {\n if (param === void 0) { param = {}; }\n this.apiKey = param.apiKey;\n this.username = param.username;\n this.password = param.password;\n this.accessToken = param.accessToken;\n this.basePath = param.basePath;\n this.baseOptions = param.baseOptions;\n this.formDataCtor = param.formDataCtor;\n }\n /**\n * Check if the given MIME is a JSON MIME.\n * JSON MIME examples:\n * application/json\n * application/json; charset=UTF8\n * APPLICATION/JSON\n * application/vnd.company+json\n * @param mime - MIME (Multipurpose Internet Mail Extensions)\n * @return True if the given MIME is JSON, false otherwise.\n */\n Configuration.prototype.isJsonMime = function (mime) {\n var jsonMime = new RegExp('^(application\\/json|[^;/ \\t]+\\/[^;/ \\t]+[+]json)[ \\t]*(;.*)?$', 'i');\n return mime !== null && (jsonMime.test(mime) || mime.toLowerCase() === 'application/json-patch+json');\n };\n return Configuration;\n}());\nexports.Configuration = Configuration;\n","\"use strict\";\n/* tslint:disable */\n/* eslint-disable */\n/**\n * Preference Service\n * Preference API endpoints usage\n *\n * The version of the OpenAPI document: 1.0.0\n *\n *\n * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).\n * https://openapi-generator.tech\n * Do not edit the class manually.\n */\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\n__exportStar(require(\"./api\"), exports);\n__exportStar(require(\"./configuration\"), exports);\n","/** A function that accepts a potential \"extra argument\" value to be injected later,\r\n * and returns an instance of the thunk middleware that uses that value\r\n */\nfunction createThunkMiddleware(extraArgument) {\n // Standard Redux middleware definition pattern:\n // See: https://redux.js.org/tutorials/fundamentals/part-4-store#writing-custom-middleware\n var middleware = function middleware(_ref) {\n var dispatch = _ref.dispatch,\n getState = _ref.getState;\n return function (next) {\n return function (action) {\n // The thunk middleware looks for any functions that were passed to `store.dispatch`.\n // If this \"action\" is really a function, call it and return the result.\n if (typeof action === 'function') {\n // Inject the store's `dispatch` and `getState` methods, as well as any \"extra arg\"\n return action(dispatch, getState, extraArgument);\n } // Otherwise, pass the action down the middleware chain as usual\n\n\n return next(action);\n };\n };\n };\n\n return middleware;\n}\n\nvar thunk = createThunkMiddleware(); // Attach the factory function so users can create a customized version\n// with whatever \"extra arg\" they want to inject into their thunks\n\nthunk.withExtraArgument = createThunkMiddleware;\nexport default thunk;","var __extends = (this && this.__extends) || (function () {\r\n var extendStatics = function (d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n };\r\n return function (d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n };\r\n})();\r\nvar __generator = (this && this.__generator) || function (thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n};\r\nvar __spreadArray = (this && this.__spreadArray) || function (to, from) {\r\n for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)\r\n to[j] = from[i];\r\n return to;\r\n};\r\nvar __defProp = Object.defineProperty;\r\nvar __defProps = Object.defineProperties;\r\nvar __getOwnPropDescs = Object.getOwnPropertyDescriptors;\r\nvar __getOwnPropSymbols = Object.getOwnPropertySymbols;\r\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\r\nvar __propIsEnum = Object.prototype.propertyIsEnumerable;\r\nvar __defNormalProp = function (obj, key, value) { return key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value: value }) : obj[key] = value; };\r\nvar __spreadValues = function (a, b) {\r\n for (var prop in b || (b = {}))\r\n if (__hasOwnProp.call(b, prop))\r\n __defNormalProp(a, prop, b[prop]);\r\n if (__getOwnPropSymbols)\r\n for (var _i = 0, _c = __getOwnPropSymbols(b); _i < _c.length; _i++) {\r\n var prop = _c[_i];\r\n if (__propIsEnum.call(b, prop))\r\n __defNormalProp(a, prop, b[prop]);\r\n }\r\n return a;\r\n};\r\nvar __spreadProps = function (a, b) { return __defProps(a, __getOwnPropDescs(b)); };\r\nvar __async = function (__this, __arguments, generator) {\r\n return new Promise(function (resolve, reject) {\r\n var fulfilled = function (value) {\r\n try {\r\n step(generator.next(value));\r\n }\r\n catch (e) {\r\n reject(e);\r\n }\r\n };\r\n var rejected = function (value) {\r\n try {\r\n step(generator.throw(value));\r\n }\r\n catch (e) {\r\n reject(e);\r\n }\r\n };\r\n var step = function (x) { return x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected); };\r\n step((generator = generator.apply(__this, __arguments)).next());\r\n });\r\n};\r\n// src/index.ts\r\nimport { enableES5 } from \"immer\";\r\nexport * from \"redux\";\r\nimport { default as default2, current as current2, freeze, original, isDraft as isDraft4 } from \"immer\";\r\nimport { createSelector as createSelector2 } from \"reselect\";\r\n// src/createDraftSafeSelector.ts\r\nimport { current, isDraft } from \"immer\";\r\nimport { createSelector } from \"reselect\";\r\nvar createDraftSafeSelector = function () {\r\n var args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n args[_i] = arguments[_i];\r\n }\r\n var selector = createSelector.apply(void 0, args);\r\n var wrappedSelector = function (value) {\r\n var rest = [];\r\n for (var _i = 1; _i < arguments.length; _i++) {\r\n rest[_i - 1] = arguments[_i];\r\n }\r\n return selector.apply(void 0, __spreadArray([isDraft(value) ? current(value) : value], rest));\r\n };\r\n return wrappedSelector;\r\n};\r\n// src/configureStore.ts\r\nimport { createStore, compose as compose2, applyMiddleware, combineReducers } from \"redux\";\r\n// src/devtoolsExtension.ts\r\nimport { compose } from \"redux\";\r\nvar composeWithDevTools = typeof window !== \"undefined\" && window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ ? window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ : function () {\r\n if (arguments.length === 0)\r\n return void 0;\r\n if (typeof arguments[0] === \"object\")\r\n return compose;\r\n return compose.apply(null, arguments);\r\n};\r\nvar devToolsEnhancer = typeof window !== \"undefined\" && window.__REDUX_DEVTOOLS_EXTENSION__ ? window.__REDUX_DEVTOOLS_EXTENSION__ : function () {\r\n return function (noop2) {\r\n return noop2;\r\n };\r\n};\r\n// src/isPlainObject.ts\r\nfunction isPlainObject(value) {\r\n if (typeof value !== \"object\" || value === null)\r\n return false;\r\n var proto = Object.getPrototypeOf(value);\r\n if (proto === null)\r\n return true;\r\n var baseProto = proto;\r\n while (Object.getPrototypeOf(baseProto) !== null) {\r\n baseProto = Object.getPrototypeOf(baseProto);\r\n }\r\n return proto === baseProto;\r\n}\r\n// src/getDefaultMiddleware.ts\r\nimport thunkMiddleware from \"redux-thunk\";\r\n// src/tsHelpers.ts\r\nvar hasMatchFunction = function (v) {\r\n return v && typeof v.match === \"function\";\r\n};\r\n// src/createAction.ts\r\nfunction createAction(type, prepareAction) {\r\n function actionCreator() {\r\n var args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n args[_i] = arguments[_i];\r\n }\r\n if (prepareAction) {\r\n var prepared = prepareAction.apply(void 0, args);\r\n if (!prepared) {\r\n throw new Error(\"prepareAction did not return an object\");\r\n }\r\n return __spreadValues(__spreadValues({\r\n type: type,\r\n payload: prepared.payload\r\n }, \"meta\" in prepared && { meta: prepared.meta }), \"error\" in prepared && { error: prepared.error });\r\n }\r\n return { type: type, payload: args[0] };\r\n }\r\n actionCreator.toString = function () { return \"\" + type; };\r\n actionCreator.type = type;\r\n actionCreator.match = function (action) { return action.type === type; };\r\n return actionCreator;\r\n}\r\nfunction isAction(action) {\r\n return isPlainObject(action) && \"type\" in action;\r\n}\r\nfunction isActionCreator(action) {\r\n return typeof action === \"function\" && \"type\" in action && hasMatchFunction(action);\r\n}\r\nfunction isFSA(action) {\r\n return isAction(action) && typeof action.type === \"string\" && Object.keys(action).every(isValidKey);\r\n}\r\nfunction isValidKey(key) {\r\n return [\"type\", \"payload\", \"error\", \"meta\"].indexOf(key) > -1;\r\n}\r\nfunction getType(actionCreator) {\r\n return \"\" + actionCreator;\r\n}\r\n// src/actionCreatorInvariantMiddleware.ts\r\nfunction getMessage(type) {\r\n var splitType = type ? (\"\" + type).split(\"/\") : [];\r\n var actionName = splitType[splitType.length - 1] || \"actionCreator\";\r\n return \"Detected an action creator with type \\\"\" + (type || \"unknown\") + \"\\\" being dispatched. \\nMake sure you're calling the action creator before dispatching, i.e. `dispatch(\" + actionName + \"())` instead of `dispatch(\" + actionName + \")`. This is necessary even if the action has no payload.\";\r\n}\r\nfunction createActionCreatorInvariantMiddleware(options) {\r\n if (options === void 0) { options = {}; }\r\n if (process.env.NODE_ENV === \"production\") {\r\n return function () { return function (next) { return function (action) { return next(action); }; }; };\r\n }\r\n var _c = options.isActionCreator, isActionCreator2 = _c === void 0 ? isActionCreator : _c;\r\n return function () { return function (next) { return function (action) {\r\n if (isActionCreator2(action)) {\r\n console.warn(getMessage(action.type));\r\n }\r\n return next(action);\r\n }; }; };\r\n}\r\n// src/utils.ts\r\nimport createNextState, { isDraftable } from \"immer\";\r\nfunction getTimeMeasureUtils(maxDelay, fnName) {\r\n var elapsed = 0;\r\n return {\r\n measureTime: function (fn) {\r\n var started = Date.now();\r\n try {\r\n return fn();\r\n }\r\n finally {\r\n var finished = Date.now();\r\n elapsed += finished - started;\r\n }\r\n },\r\n warnIfExceeded: function () {\r\n if (elapsed > maxDelay) {\r\n console.warn(fnName + \" took \" + elapsed + \"ms, which is more than the warning threshold of \" + maxDelay + \"ms. \\nIf your state or actions are very large, you may want to disable the middleware as it might cause too much of a slowdown in development mode. See https://redux-toolkit.js.org/api/getDefaultMiddleware for instructions.\\nIt is disabled in production builds, so you don't need to worry about that.\");\r\n }\r\n }\r\n };\r\n}\r\nvar MiddlewareArray = /** @class */ (function (_super) {\r\n __extends(MiddlewareArray, _super);\r\n function MiddlewareArray() {\r\n var args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n args[_i] = arguments[_i];\r\n }\r\n var _this = _super.apply(this, args) || this;\r\n Object.setPrototypeOf(_this, MiddlewareArray.prototype);\r\n return _this;\r\n }\r\n Object.defineProperty(MiddlewareArray, Symbol.species, {\r\n get: function () {\r\n return MiddlewareArray;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n MiddlewareArray.prototype.concat = function () {\r\n var arr = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n arr[_i] = arguments[_i];\r\n }\r\n return _super.prototype.concat.apply(this, arr);\r\n };\r\n MiddlewareArray.prototype.prepend = function () {\r\n var arr = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n arr[_i] = arguments[_i];\r\n }\r\n if (arr.length === 1 && Array.isArray(arr[0])) {\r\n return new (MiddlewareArray.bind.apply(MiddlewareArray, __spreadArray([void 0], arr[0].concat(this))))();\r\n }\r\n return new (MiddlewareArray.bind.apply(MiddlewareArray, __spreadArray([void 0], arr.concat(this))))();\r\n };\r\n return MiddlewareArray;\r\n}(Array));\r\nvar EnhancerArray = /** @class */ (function (_super) {\r\n __extends(EnhancerArray, _super);\r\n function EnhancerArray() {\r\n var args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n args[_i] = arguments[_i];\r\n }\r\n var _this = _super.apply(this, args) || this;\r\n Object.setPrototypeOf(_this, EnhancerArray.prototype);\r\n return _this;\r\n }\r\n Object.defineProperty(EnhancerArray, Symbol.species, {\r\n get: function () {\r\n return EnhancerArray;\r\n },\r\n enumerable: false,\r\n configurable: true\r\n });\r\n EnhancerArray.prototype.concat = function () {\r\n var arr = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n arr[_i] = arguments[_i];\r\n }\r\n return _super.prototype.concat.apply(this, arr);\r\n };\r\n EnhancerArray.prototype.prepend = function () {\r\n var arr = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n arr[_i] = arguments[_i];\r\n }\r\n if (arr.length === 1 && Array.isArray(arr[0])) {\r\n return new (EnhancerArray.bind.apply(EnhancerArray, __spreadArray([void 0], arr[0].concat(this))))();\r\n }\r\n return new (EnhancerArray.bind.apply(EnhancerArray, __spreadArray([void 0], arr.concat(this))))();\r\n };\r\n return EnhancerArray;\r\n}(Array));\r\nfunction freezeDraftable(val) {\r\n return isDraftable(val) ? createNextState(val, function () {\r\n }) : val;\r\n}\r\n// src/immutableStateInvariantMiddleware.ts\r\nvar isProduction = process.env.NODE_ENV === \"production\";\r\nvar prefix = \"Invariant failed\";\r\nfunction invariant(condition, message) {\r\n if (condition) {\r\n return;\r\n }\r\n if (isProduction) {\r\n throw new Error(prefix);\r\n }\r\n throw new Error(prefix + \": \" + (message || \"\"));\r\n}\r\nfunction stringify(obj, serializer, indent, decycler) {\r\n return JSON.stringify(obj, getSerialize(serializer, decycler), indent);\r\n}\r\nfunction getSerialize(serializer, decycler) {\r\n var stack = [], keys = [];\r\n if (!decycler)\r\n decycler = function (_, value) {\r\n if (stack[0] === value)\r\n return \"[Circular ~]\";\r\n return \"[Circular ~.\" + keys.slice(0, stack.indexOf(value)).join(\".\") + \"]\";\r\n };\r\n return function (key, value) {\r\n if (stack.length > 0) {\r\n var thisPos = stack.indexOf(this);\r\n ~thisPos ? stack.splice(thisPos + 1) : stack.push(this);\r\n ~thisPos ? keys.splice(thisPos, Infinity, key) : keys.push(key);\r\n if (~stack.indexOf(value))\r\n value = decycler.call(this, key, value);\r\n }\r\n else\r\n stack.push(value);\r\n return serializer == null ? value : serializer.call(this, key, value);\r\n };\r\n}\r\nfunction isImmutableDefault(value) {\r\n return typeof value !== \"object\" || value == null || Object.isFrozen(value);\r\n}\r\nfunction trackForMutations(isImmutable, ignorePaths, obj) {\r\n var trackedProperties = trackProperties(isImmutable, ignorePaths, obj);\r\n return {\r\n detectMutations: function () {\r\n return detectMutations(isImmutable, ignorePaths, trackedProperties, obj);\r\n }\r\n };\r\n}\r\nfunction trackProperties(isImmutable, ignorePaths, obj, path, checkedObjects) {\r\n if (ignorePaths === void 0) { ignorePaths = []; }\r\n if (path === void 0) { path = \"\"; }\r\n if (checkedObjects === void 0) { checkedObjects = new Set(); }\r\n var tracked = { value: obj };\r\n if (!isImmutable(obj) && !checkedObjects.has(obj)) {\r\n checkedObjects.add(obj);\r\n tracked.children = {};\r\n for (var key in obj) {\r\n var childPath = path ? path + \".\" + key : key;\r\n if (ignorePaths.length && ignorePaths.indexOf(childPath) !== -1) {\r\n continue;\r\n }\r\n tracked.children[key] = trackProperties(isImmutable, ignorePaths, obj[key], childPath);\r\n }\r\n }\r\n return tracked;\r\n}\r\nfunction detectMutations(isImmutable, ignoredPaths, trackedProperty, obj, sameParentRef, path) {\r\n if (ignoredPaths === void 0) { ignoredPaths = []; }\r\n if (sameParentRef === void 0) { sameParentRef = false; }\r\n if (path === void 0) { path = \"\"; }\r\n var prevObj = trackedProperty ? trackedProperty.value : void 0;\r\n var sameRef = prevObj === obj;\r\n if (sameParentRef && !sameRef && !Number.isNaN(obj)) {\r\n return { wasMutated: true, path: path };\r\n }\r\n if (isImmutable(prevObj) || isImmutable(obj)) {\r\n return { wasMutated: false };\r\n }\r\n var keysToDetect = {};\r\n for (var key in trackedProperty.children) {\r\n keysToDetect[key] = true;\r\n }\r\n for (var key in obj) {\r\n keysToDetect[key] = true;\r\n }\r\n var hasIgnoredPaths = ignoredPaths.length > 0;\r\n var _loop_1 = function (key) {\r\n var nestedPath = path ? path + \".\" + key : key;\r\n if (hasIgnoredPaths) {\r\n var hasMatches = ignoredPaths.some(function (ignored) {\r\n if (ignored instanceof RegExp) {\r\n return ignored.test(nestedPath);\r\n }\r\n return nestedPath === ignored;\r\n });\r\n if (hasMatches) {\r\n return \"continue\";\r\n }\r\n }\r\n var result = detectMutations(isImmutable, ignoredPaths, trackedProperty.children[key], obj[key], sameRef, nestedPath);\r\n if (result.wasMutated) {\r\n return { value: result };\r\n }\r\n };\r\n for (var key in keysToDetect) {\r\n var state_1 = _loop_1(key);\r\n if (typeof state_1 === \"object\")\r\n return state_1.value;\r\n }\r\n return { wasMutated: false };\r\n}\r\nfunction createImmutableStateInvariantMiddleware(options) {\r\n if (options === void 0) { options = {}; }\r\n if (process.env.NODE_ENV === \"production\") {\r\n return function () { return function (next) { return function (action) { return next(action); }; }; };\r\n }\r\n var _c = options.isImmutable, isImmutable = _c === void 0 ? isImmutableDefault : _c, ignoredPaths = options.ignoredPaths, _d = options.warnAfter, warnAfter = _d === void 0 ? 32 : _d, ignore = options.ignore;\r\n ignoredPaths = ignoredPaths || ignore;\r\n var track = trackForMutations.bind(null, isImmutable, ignoredPaths);\r\n return function (_c) {\r\n var getState = _c.getState;\r\n var state = getState();\r\n var tracker = track(state);\r\n var result;\r\n return function (next) { return function (action) {\r\n var measureUtils = getTimeMeasureUtils(warnAfter, \"ImmutableStateInvariantMiddleware\");\r\n measureUtils.measureTime(function () {\r\n state = getState();\r\n result = tracker.detectMutations();\r\n tracker = track(state);\r\n invariant(!result.wasMutated, \"A state mutation was detected between dispatches, in the path '\" + (result.path || \"\") + \"'. This may cause incorrect behavior. (https://redux.js.org/style-guide/style-guide#do-not-mutate-state)\");\r\n });\r\n var dispatchedAction = next(action);\r\n measureUtils.measureTime(function () {\r\n state = getState();\r\n result = tracker.detectMutations();\r\n tracker = track(state);\r\n result.wasMutated && invariant(!result.wasMutated, \"A state mutation was detected inside a dispatch, in the path: \" + (result.path || \"\") + \". Take a look at the reducer(s) handling the action \" + stringify(action) + \". (https://redux.js.org/style-guide/style-guide#do-not-mutate-state)\");\r\n });\r\n measureUtils.warnIfExceeded();\r\n return dispatchedAction;\r\n }; };\r\n };\r\n}\r\n// src/serializableStateInvariantMiddleware.ts\r\nfunction isPlain(val) {\r\n var type = typeof val;\r\n return val == null || type === \"string\" || type === \"boolean\" || type === \"number\" || Array.isArray(val) || isPlainObject(val);\r\n}\r\nfunction findNonSerializableValue(value, path, isSerializable, getEntries, ignoredPaths, cache) {\r\n if (path === void 0) { path = \"\"; }\r\n if (isSerializable === void 0) { isSerializable = isPlain; }\r\n if (ignoredPaths === void 0) { ignoredPaths = []; }\r\n var foundNestedSerializable;\r\n if (!isSerializable(value)) {\r\n return {\r\n keyPath: path || \"\",\r\n value: value\r\n };\r\n }\r\n if (typeof value !== \"object\" || value === null) {\r\n return false;\r\n }\r\n if (cache == null ? void 0 : cache.has(value))\r\n return false;\r\n var entries = getEntries != null ? getEntries(value) : Object.entries(value);\r\n var hasIgnoredPaths = ignoredPaths.length > 0;\r\n var _loop_2 = function (key, nestedValue) {\r\n var nestedPath = path ? path + \".\" + key : key;\r\n if (hasIgnoredPaths) {\r\n var hasMatches = ignoredPaths.some(function (ignored) {\r\n if (ignored instanceof RegExp) {\r\n return ignored.test(nestedPath);\r\n }\r\n return nestedPath === ignored;\r\n });\r\n if (hasMatches) {\r\n return \"continue\";\r\n }\r\n }\r\n if (!isSerializable(nestedValue)) {\r\n return { value: {\r\n keyPath: nestedPath,\r\n value: nestedValue\r\n } };\r\n }\r\n if (typeof nestedValue === \"object\") {\r\n foundNestedSerializable = findNonSerializableValue(nestedValue, nestedPath, isSerializable, getEntries, ignoredPaths, cache);\r\n if (foundNestedSerializable) {\r\n return { value: foundNestedSerializable };\r\n }\r\n }\r\n };\r\n for (var _i = 0, entries_1 = entries; _i < entries_1.length; _i++) {\r\n var _c = entries_1[_i], key = _c[0], nestedValue = _c[1];\r\n var state_2 = _loop_2(key, nestedValue);\r\n if (typeof state_2 === \"object\")\r\n return state_2.value;\r\n }\r\n if (cache && isNestedFrozen(value))\r\n cache.add(value);\r\n return false;\r\n}\r\nfunction isNestedFrozen(value) {\r\n if (!Object.isFrozen(value))\r\n return false;\r\n for (var _i = 0, _c = Object.values(value); _i < _c.length; _i++) {\r\n var nestedValue = _c[_i];\r\n if (typeof nestedValue !== \"object\" || nestedValue === null)\r\n continue;\r\n if (!isNestedFrozen(nestedValue))\r\n return false;\r\n }\r\n return true;\r\n}\r\nfunction createSerializableStateInvariantMiddleware(options) {\r\n if (options === void 0) { options = {}; }\r\n if (process.env.NODE_ENV === \"production\") {\r\n return function () { return function (next) { return function (action) { return next(action); }; }; };\r\n }\r\n var _c = options.isSerializable, isSerializable = _c === void 0 ? isPlain : _c, getEntries = options.getEntries, _d = options.ignoredActions, ignoredActions = _d === void 0 ? [] : _d, _e = options.ignoredActionPaths, ignoredActionPaths = _e === void 0 ? [\"meta.arg\", \"meta.baseQueryMeta\"] : _e, _f = options.ignoredPaths, ignoredPaths = _f === void 0 ? [] : _f, _g = options.warnAfter, warnAfter = _g === void 0 ? 32 : _g, _h = options.ignoreState, ignoreState = _h === void 0 ? false : _h, _j = options.ignoreActions, ignoreActions = _j === void 0 ? false : _j, _k = options.disableCache, disableCache = _k === void 0 ? false : _k;\r\n var cache = !disableCache && WeakSet ? new WeakSet() : void 0;\r\n return function (storeAPI) { return function (next) { return function (action) {\r\n var result = next(action);\r\n var measureUtils = getTimeMeasureUtils(warnAfter, \"SerializableStateInvariantMiddleware\");\r\n if (!ignoreActions && !(ignoredActions.length && ignoredActions.indexOf(action.type) !== -1)) {\r\n measureUtils.measureTime(function () {\r\n var foundActionNonSerializableValue = findNonSerializableValue(action, \"\", isSerializable, getEntries, ignoredActionPaths, cache);\r\n if (foundActionNonSerializableValue) {\r\n var keyPath = foundActionNonSerializableValue.keyPath, value = foundActionNonSerializableValue.value;\r\n console.error(\"A non-serializable value was detected in an action, in the path: `\" + keyPath + \"`. Value:\", value, \"\\nTake a look at the logic that dispatched this action: \", action, \"\\n(See https://redux.js.org/faq/actions#why-should-type-be-a-string-or-at-least-serializable-why-should-my-action-types-be-constants)\", \"\\n(To allow non-serializable values see: https://redux-toolkit.js.org/usage/usage-guide#working-with-non-serializable-data)\");\r\n }\r\n });\r\n }\r\n if (!ignoreState) {\r\n measureUtils.measureTime(function () {\r\n var state = storeAPI.getState();\r\n var foundStateNonSerializableValue = findNonSerializableValue(state, \"\", isSerializable, getEntries, ignoredPaths, cache);\r\n if (foundStateNonSerializableValue) {\r\n var keyPath = foundStateNonSerializableValue.keyPath, value = foundStateNonSerializableValue.value;\r\n console.error(\"A non-serializable value was detected in the state, in the path: `\" + keyPath + \"`. Value:\", value, \"\\nTake a look at the reducer(s) handling this action type: \" + action.type + \".\\n(See https://redux.js.org/faq/organizing-state#can-i-put-functions-promises-or-other-non-serializable-items-in-my-store-state)\");\r\n }\r\n });\r\n measureUtils.warnIfExceeded();\r\n }\r\n return result;\r\n }; }; };\r\n}\r\n// src/getDefaultMiddleware.ts\r\nfunction isBoolean(x) {\r\n return typeof x === \"boolean\";\r\n}\r\nfunction curryGetDefaultMiddleware() {\r\n return function curriedGetDefaultMiddleware(options) {\r\n return getDefaultMiddleware(options);\r\n };\r\n}\r\nfunction getDefaultMiddleware(options) {\r\n if (options === void 0) { options = {}; }\r\n var _c = options.thunk, thunk = _c === void 0 ? true : _c, _d = options.immutableCheck, immutableCheck = _d === void 0 ? true : _d, _e = options.serializableCheck, serializableCheck = _e === void 0 ? true : _e, _f = options.actionCreatorCheck, actionCreatorCheck = _f === void 0 ? true : _f;\r\n var middlewareArray = new MiddlewareArray();\r\n if (thunk) {\r\n if (isBoolean(thunk)) {\r\n middlewareArray.push(thunkMiddleware);\r\n }\r\n else {\r\n middlewareArray.push(thunkMiddleware.withExtraArgument(thunk.extraArgument));\r\n }\r\n }\r\n if (process.env.NODE_ENV !== \"production\") {\r\n if (immutableCheck) {\r\n var immutableOptions = {};\r\n if (!isBoolean(immutableCheck)) {\r\n immutableOptions = immutableCheck;\r\n }\r\n middlewareArray.unshift(createImmutableStateInvariantMiddleware(immutableOptions));\r\n }\r\n if (serializableCheck) {\r\n var serializableOptions = {};\r\n if (!isBoolean(serializableCheck)) {\r\n serializableOptions = serializableCheck;\r\n }\r\n middlewareArray.push(createSerializableStateInvariantMiddleware(serializableOptions));\r\n }\r\n if (actionCreatorCheck) {\r\n var actionCreatorOptions = {};\r\n if (!isBoolean(actionCreatorCheck)) {\r\n actionCreatorOptions = actionCreatorCheck;\r\n }\r\n middlewareArray.unshift(createActionCreatorInvariantMiddleware(actionCreatorOptions));\r\n }\r\n }\r\n return middlewareArray;\r\n}\r\n// src/configureStore.ts\r\nvar IS_PRODUCTION = process.env.NODE_ENV === \"production\";\r\nfunction configureStore(options) {\r\n var curriedGetDefaultMiddleware = curryGetDefaultMiddleware();\r\n var _c = options || {}, _d = _c.reducer, reducer = _d === void 0 ? void 0 : _d, _e = _c.middleware, middleware = _e === void 0 ? curriedGetDefaultMiddleware() : _e, _f = _c.devTools, devTools = _f === void 0 ? true : _f, _g = _c.preloadedState, preloadedState = _g === void 0 ? void 0 : _g, _h = _c.enhancers, enhancers = _h === void 0 ? void 0 : _h;\r\n var rootReducer;\r\n if (typeof reducer === \"function\") {\r\n rootReducer = reducer;\r\n }\r\n else if (isPlainObject(reducer)) {\r\n rootReducer = combineReducers(reducer);\r\n }\r\n else {\r\n throw new Error('\"reducer\" is a required argument, and must be a function or an object of functions that can be passed to combineReducers');\r\n }\r\n var finalMiddleware = middleware;\r\n if (typeof finalMiddleware === \"function\") {\r\n finalMiddleware = finalMiddleware(curriedGetDefaultMiddleware);\r\n if (!IS_PRODUCTION && !Array.isArray(finalMiddleware)) {\r\n throw new Error(\"when using a middleware builder function, an array of middleware must be returned\");\r\n }\r\n }\r\n if (!IS_PRODUCTION && finalMiddleware.some(function (item) { return typeof item !== \"function\"; })) {\r\n throw new Error(\"each middleware provided to configureStore must be a function\");\r\n }\r\n var middlewareEnhancer = applyMiddleware.apply(void 0, finalMiddleware);\r\n var finalCompose = compose2;\r\n if (devTools) {\r\n finalCompose = composeWithDevTools(__spreadValues({\r\n trace: !IS_PRODUCTION\r\n }, typeof devTools === \"object\" && devTools));\r\n }\r\n var defaultEnhancers = new EnhancerArray(middlewareEnhancer);\r\n var storeEnhancers = defaultEnhancers;\r\n if (Array.isArray(enhancers)) {\r\n storeEnhancers = __spreadArray([middlewareEnhancer], enhancers);\r\n }\r\n else if (typeof enhancers === \"function\") {\r\n storeEnhancers = enhancers(defaultEnhancers);\r\n }\r\n var composedEnhancer = finalCompose.apply(void 0, storeEnhancers);\r\n return createStore(rootReducer, preloadedState, composedEnhancer);\r\n}\r\n// src/createReducer.ts\r\nimport createNextState2, { isDraft as isDraft2, isDraftable as isDraftable2 } from \"immer\";\r\n// src/mapBuilders.ts\r\nfunction executeReducerBuilderCallback(builderCallback) {\r\n var actionsMap = {};\r\n var actionMatchers = [];\r\n var defaultCaseReducer;\r\n var builder = {\r\n addCase: function (typeOrActionCreator, reducer) {\r\n if (process.env.NODE_ENV !== \"production\") {\r\n if (actionMatchers.length > 0) {\r\n throw new Error(\"`builder.addCase` should only be called before calling `builder.addMatcher`\");\r\n }\r\n if (defaultCaseReducer) {\r\n throw new Error(\"`builder.addCase` should only be called before calling `builder.addDefaultCase`\");\r\n }\r\n }\r\n var type = typeof typeOrActionCreator === \"string\" ? typeOrActionCreator : typeOrActionCreator.type;\r\n if (!type) {\r\n throw new Error(\"`builder.addCase` cannot be called with an empty action type\");\r\n }\r\n if (type in actionsMap) {\r\n throw new Error(\"`builder.addCase` cannot be called with two reducers for the same action type\");\r\n }\r\n actionsMap[type] = reducer;\r\n return builder;\r\n },\r\n addMatcher: function (matcher, reducer) {\r\n if (process.env.NODE_ENV !== \"production\") {\r\n if (defaultCaseReducer) {\r\n throw new Error(\"`builder.addMatcher` should only be called before calling `builder.addDefaultCase`\");\r\n }\r\n }\r\n actionMatchers.push({ matcher: matcher, reducer: reducer });\r\n return builder;\r\n },\r\n addDefaultCase: function (reducer) {\r\n if (process.env.NODE_ENV !== \"production\") {\r\n if (defaultCaseReducer) {\r\n throw new Error(\"`builder.addDefaultCase` can only be called once\");\r\n }\r\n }\r\n defaultCaseReducer = reducer;\r\n return builder;\r\n }\r\n };\r\n builderCallback(builder);\r\n return [actionsMap, actionMatchers, defaultCaseReducer];\r\n}\r\n// src/createReducer.ts\r\nfunction isStateFunction(x) {\r\n return typeof x === \"function\";\r\n}\r\nvar hasWarnedAboutObjectNotation = false;\r\nfunction createReducer(initialState, mapOrBuilderCallback, actionMatchers, defaultCaseReducer) {\r\n if (actionMatchers === void 0) { actionMatchers = []; }\r\n if (process.env.NODE_ENV !== \"production\") {\r\n if (typeof mapOrBuilderCallback === \"object\") {\r\n if (!hasWarnedAboutObjectNotation) {\r\n hasWarnedAboutObjectNotation = true;\r\n console.warn(\"The object notation for `createReducer` is deprecated, and will be removed in RTK 2.0. Please use the 'builder callback' notation instead: https://redux-toolkit.js.org/api/createReducer\");\r\n }\r\n }\r\n }\r\n var _c = typeof mapOrBuilderCallback === \"function\" ? executeReducerBuilderCallback(mapOrBuilderCallback) : [mapOrBuilderCallback, actionMatchers, defaultCaseReducer], actionsMap = _c[0], finalActionMatchers = _c[1], finalDefaultCaseReducer = _c[2];\r\n var getInitialState;\r\n if (isStateFunction(initialState)) {\r\n getInitialState = function () { return freezeDraftable(initialState()); };\r\n }\r\n else {\r\n var frozenInitialState_1 = freezeDraftable(initialState);\r\n getInitialState = function () { return frozenInitialState_1; };\r\n }\r\n function reducer(state, action) {\r\n if (state === void 0) { state = getInitialState(); }\r\n var caseReducers = __spreadArray([\r\n actionsMap[action.type]\r\n ], finalActionMatchers.filter(function (_c) {\r\n var matcher = _c.matcher;\r\n return matcher(action);\r\n }).map(function (_c) {\r\n var reducer2 = _c.reducer;\r\n return reducer2;\r\n }));\r\n if (caseReducers.filter(function (cr) { return !!cr; }).length === 0) {\r\n caseReducers = [finalDefaultCaseReducer];\r\n }\r\n return caseReducers.reduce(function (previousState, caseReducer) {\r\n if (caseReducer) {\r\n if (isDraft2(previousState)) {\r\n var draft = previousState;\r\n var result = caseReducer(draft, action);\r\n if (result === void 0) {\r\n return previousState;\r\n }\r\n return result;\r\n }\r\n else if (!isDraftable2(previousState)) {\r\n var result = caseReducer(previousState, action);\r\n if (result === void 0) {\r\n if (previousState === null) {\r\n return previousState;\r\n }\r\n throw Error(\"A case reducer on a non-draftable value must not return undefined\");\r\n }\r\n return result;\r\n }\r\n else {\r\n return createNextState2(previousState, function (draft) {\r\n return caseReducer(draft, action);\r\n });\r\n }\r\n }\r\n return previousState;\r\n }, state);\r\n }\r\n reducer.getInitialState = getInitialState;\r\n return reducer;\r\n}\r\n// src/createSlice.ts\r\nvar hasWarnedAboutObjectNotation2 = false;\r\nfunction getType2(slice, actionKey) {\r\n return slice + \"/\" + actionKey;\r\n}\r\nfunction createSlice(options) {\r\n var name = options.name;\r\n if (!name) {\r\n throw new Error(\"`name` is a required option for createSlice\");\r\n }\r\n if (typeof process !== \"undefined\" && process.env.NODE_ENV === \"development\") {\r\n if (options.initialState === void 0) {\r\n console.error(\"You must provide an `initialState` value that is not `undefined`. You may have misspelled `initialState`\");\r\n }\r\n }\r\n var initialState = typeof options.initialState == \"function\" ? options.initialState : freezeDraftable(options.initialState);\r\n var reducers = options.reducers || {};\r\n var reducerNames = Object.keys(reducers);\r\n var sliceCaseReducersByName = {};\r\n var sliceCaseReducersByType = {};\r\n var actionCreators = {};\r\n reducerNames.forEach(function (reducerName) {\r\n var maybeReducerWithPrepare = reducers[reducerName];\r\n var type = getType2(name, reducerName);\r\n var caseReducer;\r\n var prepareCallback;\r\n if (\"reducer\" in maybeReducerWithPrepare) {\r\n caseReducer = maybeReducerWithPrepare.reducer;\r\n prepareCallback = maybeReducerWithPrepare.prepare;\r\n }\r\n else {\r\n caseReducer = maybeReducerWithPrepare;\r\n }\r\n sliceCaseReducersByName[reducerName] = caseReducer;\r\n sliceCaseReducersByType[type] = caseReducer;\r\n actionCreators[reducerName] = prepareCallback ? createAction(type, prepareCallback) : createAction(type);\r\n });\r\n function buildReducer() {\r\n if (process.env.NODE_ENV !== \"production\") {\r\n if (typeof options.extraReducers === \"object\") {\r\n if (!hasWarnedAboutObjectNotation2) {\r\n hasWarnedAboutObjectNotation2 = true;\r\n console.warn(\"The object notation for `createSlice.extraReducers` is deprecated, and will be removed in RTK 2.0. Please use the 'builder callback' notation instead: https://redux-toolkit.js.org/api/createSlice\");\r\n }\r\n }\r\n }\r\n var _c = typeof options.extraReducers === \"function\" ? executeReducerBuilderCallback(options.extraReducers) : [options.extraReducers], _d = _c[0], extraReducers = _d === void 0 ? {} : _d, _e = _c[1], actionMatchers = _e === void 0 ? [] : _e, _f = _c[2], defaultCaseReducer = _f === void 0 ? void 0 : _f;\r\n var finalCaseReducers = __spreadValues(__spreadValues({}, extraReducers), sliceCaseReducersByType);\r\n return createReducer(initialState, function (builder) {\r\n for (var key in finalCaseReducers) {\r\n builder.addCase(key, finalCaseReducers[key]);\r\n }\r\n for (var _i = 0, actionMatchers_1 = actionMatchers; _i < actionMatchers_1.length; _i++) {\r\n var m = actionMatchers_1[_i];\r\n builder.addMatcher(m.matcher, m.reducer);\r\n }\r\n if (defaultCaseReducer) {\r\n builder.addDefaultCase(defaultCaseReducer);\r\n }\r\n });\r\n }\r\n var _reducer;\r\n return {\r\n name: name,\r\n reducer: function (state, action) {\r\n if (!_reducer)\r\n _reducer = buildReducer();\r\n return _reducer(state, action);\r\n },\r\n actions: actionCreators,\r\n caseReducers: sliceCaseReducersByName,\r\n getInitialState: function () {\r\n if (!_reducer)\r\n _reducer = buildReducer();\r\n return _reducer.getInitialState();\r\n }\r\n };\r\n}\r\n// src/entities/entity_state.ts\r\nfunction getInitialEntityState() {\r\n return {\r\n ids: [],\r\n entities: {}\r\n };\r\n}\r\nfunction createInitialStateFactory() {\r\n function getInitialState(additionalState) {\r\n if (additionalState === void 0) { additionalState = {}; }\r\n return Object.assign(getInitialEntityState(), additionalState);\r\n }\r\n return { getInitialState: getInitialState };\r\n}\r\n// src/entities/state_selectors.ts\r\nfunction createSelectorsFactory() {\r\n function getSelectors(selectState) {\r\n var selectIds = function (state) { return state.ids; };\r\n var selectEntities = function (state) { return state.entities; };\r\n var selectAll = createDraftSafeSelector(selectIds, selectEntities, function (ids, entities) { return ids.map(function (id) { return entities[id]; }); });\r\n var selectId = function (_, id) { return id; };\r\n var selectById = function (entities, id) { return entities[id]; };\r\n var selectTotal = createDraftSafeSelector(selectIds, function (ids) { return ids.length; });\r\n if (!selectState) {\r\n return {\r\n selectIds: selectIds,\r\n selectEntities: selectEntities,\r\n selectAll: selectAll,\r\n selectTotal: selectTotal,\r\n selectById: createDraftSafeSelector(selectEntities, selectId, selectById)\r\n };\r\n }\r\n var selectGlobalizedEntities = createDraftSafeSelector(selectState, selectEntities);\r\n return {\r\n selectIds: createDraftSafeSelector(selectState, selectIds),\r\n selectEntities: selectGlobalizedEntities,\r\n selectAll: createDraftSafeSelector(selectState, selectAll),\r\n selectTotal: createDraftSafeSelector(selectState, selectTotal),\r\n selectById: createDraftSafeSelector(selectGlobalizedEntities, selectId, selectById)\r\n };\r\n }\r\n return { getSelectors: getSelectors };\r\n}\r\n// src/entities/state_adapter.ts\r\nimport createNextState3, { isDraft as isDraft3 } from \"immer\";\r\nfunction createSingleArgumentStateOperator(mutator) {\r\n var operator = createStateOperator(function (_, state) { return mutator(state); });\r\n return function operation(state) {\r\n return operator(state, void 0);\r\n };\r\n}\r\nfunction createStateOperator(mutator) {\r\n return function operation(state, arg) {\r\n function isPayloadActionArgument(arg2) {\r\n return isFSA(arg2);\r\n }\r\n var runMutator = function (draft) {\r\n if (isPayloadActionArgument(arg)) {\r\n mutator(arg.payload, draft);\r\n }\r\n else {\r\n mutator(arg, draft);\r\n }\r\n };\r\n if (isDraft3(state)) {\r\n runMutator(state);\r\n return state;\r\n }\r\n else {\r\n return createNextState3(state, runMutator);\r\n }\r\n };\r\n}\r\n// src/entities/utils.ts\r\nfunction selectIdValue(entity, selectId) {\r\n var key = selectId(entity);\r\n if (process.env.NODE_ENV !== \"production\" && key === void 0) {\r\n console.warn(\"The entity passed to the `selectId` implementation returned undefined.\", \"You should probably provide your own `selectId` implementation.\", \"The entity that was passed:\", entity, \"The `selectId` implementation:\", selectId.toString());\r\n }\r\n return key;\r\n}\r\nfunction ensureEntitiesArray(entities) {\r\n if (!Array.isArray(entities)) {\r\n entities = Object.values(entities);\r\n }\r\n return entities;\r\n}\r\nfunction splitAddedUpdatedEntities(newEntities, selectId, state) {\r\n newEntities = ensureEntitiesArray(newEntities);\r\n var added = [];\r\n var updated = [];\r\n for (var _i = 0, newEntities_1 = newEntities; _i < newEntities_1.length; _i++) {\r\n var entity = newEntities_1[_i];\r\n var id = selectIdValue(entity, selectId);\r\n if (id in state.entities) {\r\n updated.push({ id: id, changes: entity });\r\n }\r\n else {\r\n added.push(entity);\r\n }\r\n }\r\n return [added, updated];\r\n}\r\n// src/entities/unsorted_state_adapter.ts\r\nfunction createUnsortedStateAdapter(selectId) {\r\n function addOneMutably(entity, state) {\r\n var key = selectIdValue(entity, selectId);\r\n if (key in state.entities) {\r\n return;\r\n }\r\n state.ids.push(key);\r\n state.entities[key] = entity;\r\n }\r\n function addManyMutably(newEntities, state) {\r\n newEntities = ensureEntitiesArray(newEntities);\r\n for (var _i = 0, newEntities_2 = newEntities; _i < newEntities_2.length; _i++) {\r\n var entity = newEntities_2[_i];\r\n addOneMutably(entity, state);\r\n }\r\n }\r\n function setOneMutably(entity, state) {\r\n var key = selectIdValue(entity, selectId);\r\n if (!(key in state.entities)) {\r\n state.ids.push(key);\r\n }\r\n state.entities[key] = entity;\r\n }\r\n function setManyMutably(newEntities, state) {\r\n newEntities = ensureEntitiesArray(newEntities);\r\n for (var _i = 0, newEntities_3 = newEntities; _i < newEntities_3.length; _i++) {\r\n var entity = newEntities_3[_i];\r\n setOneMutably(entity, state);\r\n }\r\n }\r\n function setAllMutably(newEntities, state) {\r\n newEntities = ensureEntitiesArray(newEntities);\r\n state.ids = [];\r\n state.entities = {};\r\n addManyMutably(newEntities, state);\r\n }\r\n function removeOneMutably(key, state) {\r\n return removeManyMutably([key], state);\r\n }\r\n function removeManyMutably(keys, state) {\r\n var didMutate = false;\r\n keys.forEach(function (key) {\r\n if (key in state.entities) {\r\n delete state.entities[key];\r\n didMutate = true;\r\n }\r\n });\r\n if (didMutate) {\r\n state.ids = state.ids.filter(function (id) { return id in state.entities; });\r\n }\r\n }\r\n function removeAllMutably(state) {\r\n Object.assign(state, {\r\n ids: [],\r\n entities: {}\r\n });\r\n }\r\n function takeNewKey(keys, update, state) {\r\n var original2 = state.entities[update.id];\r\n var updated = Object.assign({}, original2, update.changes);\r\n var newKey = selectIdValue(updated, selectId);\r\n var hasNewKey = newKey !== update.id;\r\n if (hasNewKey) {\r\n keys[update.id] = newKey;\r\n delete state.entities[update.id];\r\n }\r\n state.entities[newKey] = updated;\r\n return hasNewKey;\r\n }\r\n function updateOneMutably(update, state) {\r\n return updateManyMutably([update], state);\r\n }\r\n function updateManyMutably(updates, state) {\r\n var newKeys = {};\r\n var updatesPerEntity = {};\r\n updates.forEach(function (update) {\r\n if (update.id in state.entities) {\r\n updatesPerEntity[update.id] = {\r\n id: update.id,\r\n changes: __spreadValues(__spreadValues({}, updatesPerEntity[update.id] ? updatesPerEntity[update.id].changes : null), update.changes)\r\n };\r\n }\r\n });\r\n updates = Object.values(updatesPerEntity);\r\n var didMutateEntities = updates.length > 0;\r\n if (didMutateEntities) {\r\n var didMutateIds = updates.filter(function (update) { return takeNewKey(newKeys, update, state); }).length > 0;\r\n if (didMutateIds) {\r\n state.ids = Object.keys(state.entities);\r\n }\r\n }\r\n }\r\n function upsertOneMutably(entity, state) {\r\n return upsertManyMutably([entity], state);\r\n }\r\n function upsertManyMutably(newEntities, state) {\r\n var _c = splitAddedUpdatedEntities(newEntities, selectId, state), added = _c[0], updated = _c[1];\r\n updateManyMutably(updated, state);\r\n addManyMutably(added, state);\r\n }\r\n return {\r\n removeAll: createSingleArgumentStateOperator(removeAllMutably),\r\n addOne: createStateOperator(addOneMutably),\r\n addMany: createStateOperator(addManyMutably),\r\n setOne: createStateOperator(setOneMutably),\r\n setMany: createStateOperator(setManyMutably),\r\n setAll: createStateOperator(setAllMutably),\r\n updateOne: createStateOperator(updateOneMutably),\r\n updateMany: createStateOperator(updateManyMutably),\r\n upsertOne: createStateOperator(upsertOneMutably),\r\n upsertMany: createStateOperator(upsertManyMutably),\r\n removeOne: createStateOperator(removeOneMutably),\r\n removeMany: createStateOperator(removeManyMutably)\r\n };\r\n}\r\n// src/entities/sorted_state_adapter.ts\r\nfunction createSortedStateAdapter(selectId, sort) {\r\n var _c = createUnsortedStateAdapter(selectId), removeOne = _c.removeOne, removeMany = _c.removeMany, removeAll = _c.removeAll;\r\n function addOneMutably(entity, state) {\r\n return addManyMutably([entity], state);\r\n }\r\n function addManyMutably(newEntities, state) {\r\n newEntities = ensureEntitiesArray(newEntities);\r\n var models = newEntities.filter(function (model) { return !(selectIdValue(model, selectId) in state.entities); });\r\n if (models.length !== 0) {\r\n merge(models, state);\r\n }\r\n }\r\n function setOneMutably(entity, state) {\r\n return setManyMutably([entity], state);\r\n }\r\n function setManyMutably(newEntities, state) {\r\n newEntities = ensureEntitiesArray(newEntities);\r\n if (newEntities.length !== 0) {\r\n merge(newEntities, state);\r\n }\r\n }\r\n function setAllMutably(newEntities, state) {\r\n newEntities = ensureEntitiesArray(newEntities);\r\n state.entities = {};\r\n state.ids = [];\r\n addManyMutably(newEntities, state);\r\n }\r\n function updateOneMutably(update, state) {\r\n return updateManyMutably([update], state);\r\n }\r\n function updateManyMutably(updates, state) {\r\n var appliedUpdates = false;\r\n for (var _i = 0, updates_1 = updates; _i < updates_1.length; _i++) {\r\n var update = updates_1[_i];\r\n var entity = state.entities[update.id];\r\n if (!entity) {\r\n continue;\r\n }\r\n appliedUpdates = true;\r\n Object.assign(entity, update.changes);\r\n var newId = selectId(entity);\r\n if (update.id !== newId) {\r\n delete state.entities[update.id];\r\n state.entities[newId] = entity;\r\n }\r\n }\r\n if (appliedUpdates) {\r\n resortEntities(state);\r\n }\r\n }\r\n function upsertOneMutably(entity, state) {\r\n return upsertManyMutably([entity], state);\r\n }\r\n function upsertManyMutably(newEntities, state) {\r\n var _c = splitAddedUpdatedEntities(newEntities, selectId, state), added = _c[0], updated = _c[1];\r\n updateManyMutably(updated, state);\r\n addManyMutably(added, state);\r\n }\r\n function areArraysEqual(a, b) {\r\n if (a.length !== b.length) {\r\n return false;\r\n }\r\n for (var i = 0; i < a.length && i < b.length; i++) {\r\n if (a[i] === b[i]) {\r\n continue;\r\n }\r\n return false;\r\n }\r\n return true;\r\n }\r\n function merge(models, state) {\r\n models.forEach(function (model) {\r\n state.entities[selectId(model)] = model;\r\n });\r\n resortEntities(state);\r\n }\r\n function resortEntities(state) {\r\n var allEntities = Object.values(state.entities);\r\n allEntities.sort(sort);\r\n var newSortedIds = allEntities.map(selectId);\r\n var ids = state.ids;\r\n if (!areArraysEqual(ids, newSortedIds)) {\r\n state.ids = newSortedIds;\r\n }\r\n }\r\n return {\r\n removeOne: removeOne,\r\n removeMany: removeMany,\r\n removeAll: removeAll,\r\n addOne: createStateOperator(addOneMutably),\r\n updateOne: createStateOperator(updateOneMutably),\r\n upsertOne: createStateOperator(upsertOneMutably),\r\n setOne: createStateOperator(setOneMutably),\r\n setMany: createStateOperator(setManyMutably),\r\n setAll: createStateOperator(setAllMutably),\r\n addMany: createStateOperator(addManyMutably),\r\n updateMany: createStateOperator(updateManyMutably),\r\n upsertMany: createStateOperator(upsertManyMutably)\r\n };\r\n}\r\n// src/entities/create_adapter.ts\r\nfunction createEntityAdapter(options) {\r\n if (options === void 0) { options = {}; }\r\n var _c = __spreadValues({\r\n sortComparer: false,\r\n selectId: function (instance) { return instance.id; }\r\n }, options), selectId = _c.selectId, sortComparer = _c.sortComparer;\r\n var stateFactory = createInitialStateFactory();\r\n var selectorsFactory = createSelectorsFactory();\r\n var stateAdapter = sortComparer ? createSortedStateAdapter(selectId, sortComparer) : createUnsortedStateAdapter(selectId);\r\n return __spreadValues(__spreadValues(__spreadValues({\r\n selectId: selectId,\r\n sortComparer: sortComparer\r\n }, stateFactory), selectorsFactory), stateAdapter);\r\n}\r\n// src/nanoid.ts\r\nvar urlAlphabet = \"ModuleSymbhasOwnPr-0123456789ABCDEFGHNRVfgctiUvz_KqYTJkLxpZXIjQW\";\r\nvar nanoid = function (size) {\r\n if (size === void 0) { size = 21; }\r\n var id = \"\";\r\n var i = size;\r\n while (i--) {\r\n id += urlAlphabet[Math.random() * 64 | 0];\r\n }\r\n return id;\r\n};\r\n// src/createAsyncThunk.ts\r\nvar commonProperties = [\r\n \"name\",\r\n \"message\",\r\n \"stack\",\r\n \"code\"\r\n];\r\nvar RejectWithValue = /** @class */ (function () {\r\n function RejectWithValue(payload, meta) {\r\n this.payload = payload;\r\n this.meta = meta;\r\n }\r\n return RejectWithValue;\r\n}());\r\nvar FulfillWithMeta = /** @class */ (function () {\r\n function FulfillWithMeta(payload, meta) {\r\n this.payload = payload;\r\n this.meta = meta;\r\n }\r\n return FulfillWithMeta;\r\n}());\r\nvar miniSerializeError = function (value) {\r\n if (typeof value === \"object\" && value !== null) {\r\n var simpleError = {};\r\n for (var _i = 0, commonProperties_1 = commonProperties; _i < commonProperties_1.length; _i++) {\r\n var property = commonProperties_1[_i];\r\n if (typeof value[property] === \"string\") {\r\n simpleError[property] = value[property];\r\n }\r\n }\r\n return simpleError;\r\n }\r\n return { message: String(value) };\r\n};\r\nvar createAsyncThunk = (function () {\r\n function createAsyncThunk2(typePrefix, payloadCreator, options) {\r\n var fulfilled = createAction(typePrefix + \"/fulfilled\", function (payload, requestId, arg, meta) { return ({\r\n payload: payload,\r\n meta: __spreadProps(__spreadValues({}, meta || {}), {\r\n arg: arg,\r\n requestId: requestId,\r\n requestStatus: \"fulfilled\"\r\n })\r\n }); });\r\n var pending = createAction(typePrefix + \"/pending\", function (requestId, arg, meta) { return ({\r\n payload: void 0,\r\n meta: __spreadProps(__spreadValues({}, meta || {}), {\r\n arg: arg,\r\n requestId: requestId,\r\n requestStatus: \"pending\"\r\n })\r\n }); });\r\n var rejected = createAction(typePrefix + \"/rejected\", function (error, requestId, arg, payload, meta) { return ({\r\n payload: payload,\r\n error: (options && options.serializeError || miniSerializeError)(error || \"Rejected\"),\r\n meta: __spreadProps(__spreadValues({}, meta || {}), {\r\n arg: arg,\r\n requestId: requestId,\r\n rejectedWithValue: !!payload,\r\n requestStatus: \"rejected\",\r\n aborted: (error == null ? void 0 : error.name) === \"AbortError\",\r\n condition: (error == null ? void 0 : error.name) === \"ConditionError\"\r\n })\r\n }); });\r\n var displayedWarning = false;\r\n var AC = typeof AbortController !== \"undefined\" ? AbortController : /** @class */ (function () {\r\n function class_1() {\r\n this.signal = {\r\n aborted: false,\r\n addEventListener: function () {\r\n },\r\n dispatchEvent: function () {\r\n return false;\r\n },\r\n onabort: function () {\r\n },\r\n removeEventListener: function () {\r\n },\r\n reason: void 0,\r\n throwIfAborted: function () {\r\n }\r\n };\r\n }\r\n class_1.prototype.abort = function () {\r\n if (process.env.NODE_ENV !== \"production\") {\r\n if (!displayedWarning) {\r\n displayedWarning = true;\r\n console.info(\"This platform does not implement AbortController. \\nIf you want to use the AbortController to react to `abort` events, please consider importing a polyfill like 'abortcontroller-polyfill/dist/abortcontroller-polyfill-only'.\");\r\n }\r\n }\r\n };\r\n return class_1;\r\n }());\r\n function actionCreator(arg) {\r\n return function (dispatch, getState, extra) {\r\n var requestId = (options == null ? void 0 : options.idGenerator) ? options.idGenerator(arg) : nanoid();\r\n var abortController = new AC();\r\n var abortReason;\r\n var started = false;\r\n function abort(reason) {\r\n abortReason = reason;\r\n abortController.abort();\r\n }\r\n var promise2 = function () {\r\n return __async(this, null, function () {\r\n var _a, _b, finalAction, conditionResult, abortedPromise, err_1, skipDispatch;\r\n return __generator(this, function (_c) {\r\n switch (_c.label) {\r\n case 0:\r\n _c.trys.push([0, 4, , 5]);\r\n conditionResult = (_a = options == null ? void 0 : options.condition) == null ? void 0 : _a.call(options, arg, { getState: getState, extra: extra });\r\n if (!isThenable(conditionResult)) return [3 /*break*/, 2];\r\n return [4 /*yield*/, conditionResult];\r\n case 1:\r\n conditionResult = _c.sent();\r\n _c.label = 2;\r\n case 2:\r\n if (conditionResult === false || abortController.signal.aborted) {\r\n throw {\r\n name: \"ConditionError\",\r\n message: \"Aborted due to condition callback returning false.\"\r\n };\r\n }\r\n started = true;\r\n abortedPromise = new Promise(function (_, reject) { return abortController.signal.addEventListener(\"abort\", function () { return reject({\r\n name: \"AbortError\",\r\n message: abortReason || \"Aborted\"\r\n }); }); });\r\n dispatch(pending(requestId, arg, (_b = options == null ? void 0 : options.getPendingMeta) == null ? void 0 : _b.call(options, { requestId: requestId, arg: arg }, { getState: getState, extra: extra })));\r\n return [4 /*yield*/, Promise.race([\r\n abortedPromise,\r\n Promise.resolve(payloadCreator(arg, {\r\n dispatch: dispatch,\r\n getState: getState,\r\n extra: extra,\r\n requestId: requestId,\r\n signal: abortController.signal,\r\n abort: abort,\r\n rejectWithValue: function (value, meta) {\r\n return new RejectWithValue(value, meta);\r\n },\r\n fulfillWithValue: function (value, meta) {\r\n return new FulfillWithMeta(value, meta);\r\n }\r\n })).then(function (result) {\r\n if (result instanceof RejectWithValue) {\r\n throw result;\r\n }\r\n if (result instanceof FulfillWithMeta) {\r\n return fulfilled(result.payload, requestId, arg, result.meta);\r\n }\r\n return fulfilled(result, requestId, arg);\r\n })\r\n ])];\r\n case 3:\r\n finalAction = _c.sent();\r\n return [3 /*break*/, 5];\r\n case 4:\r\n err_1 = _c.sent();\r\n finalAction = err_1 instanceof RejectWithValue ? rejected(null, requestId, arg, err_1.payload, err_1.meta) : rejected(err_1, requestId, arg);\r\n return [3 /*break*/, 5];\r\n case 5:\r\n skipDispatch = options && !options.dispatchConditionRejection && rejected.match(finalAction) && finalAction.meta.condition;\r\n if (!skipDispatch) {\r\n dispatch(finalAction);\r\n }\r\n return [2 /*return*/, finalAction];\r\n }\r\n });\r\n });\r\n }();\r\n return Object.assign(promise2, {\r\n abort: abort,\r\n requestId: requestId,\r\n arg: arg,\r\n unwrap: function () {\r\n return promise2.then(unwrapResult);\r\n }\r\n });\r\n };\r\n }\r\n return Object.assign(actionCreator, {\r\n pending: pending,\r\n rejected: rejected,\r\n fulfilled: fulfilled,\r\n typePrefix: typePrefix\r\n });\r\n }\r\n createAsyncThunk2.withTypes = function () { return createAsyncThunk2; };\r\n return createAsyncThunk2;\r\n})();\r\nfunction unwrapResult(action) {\r\n if (action.meta && action.meta.rejectedWithValue) {\r\n throw action.payload;\r\n }\r\n if (action.error) {\r\n throw action.error;\r\n }\r\n return action.payload;\r\n}\r\nfunction isThenable(value) {\r\n return value !== null && typeof value === \"object\" && typeof value.then === \"function\";\r\n}\r\n// src/matchers.ts\r\nvar matches = function (matcher, action) {\r\n if (hasMatchFunction(matcher)) {\r\n return matcher.match(action);\r\n }\r\n else {\r\n return matcher(action);\r\n }\r\n};\r\nfunction isAnyOf() {\r\n var matchers = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n matchers[_i] = arguments[_i];\r\n }\r\n return function (action) {\r\n return matchers.some(function (matcher) { return matches(matcher, action); });\r\n };\r\n}\r\nfunction isAllOf() {\r\n var matchers = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n matchers[_i] = arguments[_i];\r\n }\r\n return function (action) {\r\n return matchers.every(function (matcher) { return matches(matcher, action); });\r\n };\r\n}\r\nfunction hasExpectedRequestMetadata(action, validStatus) {\r\n if (!action || !action.meta)\r\n return false;\r\n var hasValidRequestId = typeof action.meta.requestId === \"string\";\r\n var hasValidRequestStatus = validStatus.indexOf(action.meta.requestStatus) > -1;\r\n return hasValidRequestId && hasValidRequestStatus;\r\n}\r\nfunction isAsyncThunkArray(a) {\r\n return typeof a[0] === \"function\" && \"pending\" in a[0] && \"fulfilled\" in a[0] && \"rejected\" in a[0];\r\n}\r\nfunction isPending() {\r\n var asyncThunks = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n asyncThunks[_i] = arguments[_i];\r\n }\r\n if (asyncThunks.length === 0) {\r\n return function (action) { return hasExpectedRequestMetadata(action, [\"pending\"]); };\r\n }\r\n if (!isAsyncThunkArray(asyncThunks)) {\r\n return isPending()(asyncThunks[0]);\r\n }\r\n return function (action) {\r\n var matchers = asyncThunks.map(function (asyncThunk) { return asyncThunk.pending; });\r\n var combinedMatcher = isAnyOf.apply(void 0, matchers);\r\n return combinedMatcher(action);\r\n };\r\n}\r\nfunction isRejected() {\r\n var asyncThunks = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n asyncThunks[_i] = arguments[_i];\r\n }\r\n if (asyncThunks.length === 0) {\r\n return function (action) { return hasExpectedRequestMetadata(action, [\"rejected\"]); };\r\n }\r\n if (!isAsyncThunkArray(asyncThunks)) {\r\n return isRejected()(asyncThunks[0]);\r\n }\r\n return function (action) {\r\n var matchers = asyncThunks.map(function (asyncThunk) { return asyncThunk.rejected; });\r\n var combinedMatcher = isAnyOf.apply(void 0, matchers);\r\n return combinedMatcher(action);\r\n };\r\n}\r\nfunction isRejectedWithValue() {\r\n var asyncThunks = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n asyncThunks[_i] = arguments[_i];\r\n }\r\n var hasFlag = function (action) {\r\n return action && action.meta && action.meta.rejectedWithValue;\r\n };\r\n if (asyncThunks.length === 0) {\r\n return function (action) {\r\n var combinedMatcher = isAllOf(isRejected.apply(void 0, asyncThunks), hasFlag);\r\n return combinedMatcher(action);\r\n };\r\n }\r\n if (!isAsyncThunkArray(asyncThunks)) {\r\n return isRejectedWithValue()(asyncThunks[0]);\r\n }\r\n return function (action) {\r\n var combinedMatcher = isAllOf(isRejected.apply(void 0, asyncThunks), hasFlag);\r\n return combinedMatcher(action);\r\n };\r\n}\r\nfunction isFulfilled() {\r\n var asyncThunks = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n asyncThunks[_i] = arguments[_i];\r\n }\r\n if (asyncThunks.length === 0) {\r\n return function (action) { return hasExpectedRequestMetadata(action, [\"fulfilled\"]); };\r\n }\r\n if (!isAsyncThunkArray(asyncThunks)) {\r\n return isFulfilled()(asyncThunks[0]);\r\n }\r\n return function (action) {\r\n var matchers = asyncThunks.map(function (asyncThunk) { return asyncThunk.fulfilled; });\r\n var combinedMatcher = isAnyOf.apply(void 0, matchers);\r\n return combinedMatcher(action);\r\n };\r\n}\r\nfunction isAsyncThunkAction() {\r\n var asyncThunks = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n asyncThunks[_i] = arguments[_i];\r\n }\r\n if (asyncThunks.length === 0) {\r\n return function (action) { return hasExpectedRequestMetadata(action, [\"pending\", \"fulfilled\", \"rejected\"]); };\r\n }\r\n if (!isAsyncThunkArray(asyncThunks)) {\r\n return isAsyncThunkAction()(asyncThunks[0]);\r\n }\r\n return function (action) {\r\n var matchers = [];\r\n for (var _i = 0, asyncThunks_1 = asyncThunks; _i < asyncThunks_1.length; _i++) {\r\n var asyncThunk = asyncThunks_1[_i];\r\n matchers.push(asyncThunk.pending, asyncThunk.rejected, asyncThunk.fulfilled);\r\n }\r\n var combinedMatcher = isAnyOf.apply(void 0, matchers);\r\n return combinedMatcher(action);\r\n };\r\n}\r\n// src/listenerMiddleware/utils.ts\r\nvar assertFunction = function (func, expected) {\r\n if (typeof func !== \"function\") {\r\n throw new TypeError(expected + \" is not a function\");\r\n }\r\n};\r\nvar noop = function () {\r\n};\r\nvar catchRejection = function (promise2, onError) {\r\n if (onError === void 0) { onError = noop; }\r\n promise2.catch(onError);\r\n return promise2;\r\n};\r\nvar addAbortSignalListener = function (abortSignal, callback) {\r\n abortSignal.addEventListener(\"abort\", callback, { once: true });\r\n return function () { return abortSignal.removeEventListener(\"abort\", callback); };\r\n};\r\nvar abortControllerWithReason = function (abortController, reason) {\r\n var signal = abortController.signal;\r\n if (signal.aborted) {\r\n return;\r\n }\r\n if (!(\"reason\" in signal)) {\r\n Object.defineProperty(signal, \"reason\", {\r\n enumerable: true,\r\n value: reason,\r\n configurable: true,\r\n writable: true\r\n });\r\n }\r\n ;\r\n abortController.abort(reason);\r\n};\r\n// src/listenerMiddleware/exceptions.ts\r\nvar task = \"task\";\r\nvar listener = \"listener\";\r\nvar completed = \"completed\";\r\nvar cancelled = \"cancelled\";\r\nvar taskCancelled = \"task-\" + cancelled;\r\nvar taskCompleted = \"task-\" + completed;\r\nvar listenerCancelled = listener + \"-\" + cancelled;\r\nvar listenerCompleted = listener + \"-\" + completed;\r\nvar TaskAbortError = /** @class */ (function () {\r\n function TaskAbortError(code) {\r\n this.code = code;\r\n this.name = \"TaskAbortError\";\r\n this.message = task + \" \" + cancelled + \" (reason: \" + code + \")\";\r\n }\r\n return TaskAbortError;\r\n}());\r\n// src/listenerMiddleware/task.ts\r\nvar validateActive = function (signal) {\r\n if (signal.aborted) {\r\n throw new TaskAbortError(signal.reason);\r\n }\r\n};\r\nfunction raceWithSignal(signal, promise2) {\r\n var cleanup = noop;\r\n return new Promise(function (resolve, reject) {\r\n var notifyRejection = function () { return reject(new TaskAbortError(signal.reason)); };\r\n if (signal.aborted) {\r\n notifyRejection();\r\n return;\r\n }\r\n cleanup = addAbortSignalListener(signal, notifyRejection);\r\n promise2.finally(function () { return cleanup(); }).then(resolve, reject);\r\n }).finally(function () {\r\n cleanup = noop;\r\n });\r\n}\r\nvar runTask = function (task2, cleanUp) { return __async(void 0, null, function () {\r\n var value, error_1;\r\n return __generator(this, function (_c) {\r\n switch (_c.label) {\r\n case 0:\r\n _c.trys.push([0, 3, 4, 5]);\r\n return [4 /*yield*/, Promise.resolve()];\r\n case 1:\r\n _c.sent();\r\n return [4 /*yield*/, task2()];\r\n case 2:\r\n value = _c.sent();\r\n return [2 /*return*/, {\r\n status: \"ok\",\r\n value: value\r\n }];\r\n case 3:\r\n error_1 = _c.sent();\r\n return [2 /*return*/, {\r\n status: error_1 instanceof TaskAbortError ? \"cancelled\" : \"rejected\",\r\n error: error_1\r\n }];\r\n case 4:\r\n cleanUp == null ? void 0 : cleanUp();\r\n return [7 /*endfinally*/];\r\n case 5: return [2 /*return*/];\r\n }\r\n });\r\n}); };\r\nvar createPause = function (signal) {\r\n return function (promise2) {\r\n return catchRejection(raceWithSignal(signal, promise2).then(function (output) {\r\n validateActive(signal);\r\n return output;\r\n }));\r\n };\r\n};\r\nvar createDelay = function (signal) {\r\n var pause = createPause(signal);\r\n return function (timeoutMs) {\r\n return pause(new Promise(function (resolve) { return setTimeout(resolve, timeoutMs); }));\r\n };\r\n};\r\n// src/listenerMiddleware/index.ts\r\nvar assign = Object.assign;\r\nvar INTERNAL_NIL_TOKEN = {};\r\nvar alm = \"listenerMiddleware\";\r\nvar createFork = function (parentAbortSignal, parentBlockingPromises) {\r\n var linkControllers = function (controller) { return addAbortSignalListener(parentAbortSignal, function () { return abortControllerWithReason(controller, parentAbortSignal.reason); }); };\r\n return function (taskExecutor, opts) {\r\n assertFunction(taskExecutor, \"taskExecutor\");\r\n var childAbortController = new AbortController();\r\n linkControllers(childAbortController);\r\n var result = runTask(function () { return __async(void 0, null, function () {\r\n var result2;\r\n return __generator(this, function (_c) {\r\n switch (_c.label) {\r\n case 0:\r\n validateActive(parentAbortSignal);\r\n validateActive(childAbortController.signal);\r\n return [4 /*yield*/, taskExecutor({\r\n pause: createPause(childAbortController.signal),\r\n delay: createDelay(childAbortController.signal),\r\n signal: childAbortController.signal\r\n })];\r\n case 1:\r\n result2 = _c.sent();\r\n validateActive(childAbortController.signal);\r\n return [2 /*return*/, result2];\r\n }\r\n });\r\n }); }, function () { return abortControllerWithReason(childAbortController, taskCompleted); });\r\n if (opts == null ? void 0 : opts.autoJoin) {\r\n parentBlockingPromises.push(result);\r\n }\r\n return {\r\n result: createPause(parentAbortSignal)(result),\r\n cancel: function () {\r\n abortControllerWithReason(childAbortController, taskCancelled);\r\n }\r\n };\r\n };\r\n};\r\nvar createTakePattern = function (startListening, signal) {\r\n var take = function (predicate, timeout) { return __async(void 0, null, function () {\r\n var unsubscribe, tuplePromise, promises, output;\r\n return __generator(this, function (_c) {\r\n switch (_c.label) {\r\n case 0:\r\n validateActive(signal);\r\n unsubscribe = function () {\r\n };\r\n tuplePromise = new Promise(function (resolve, reject) {\r\n var stopListening = startListening({\r\n predicate: predicate,\r\n effect: function (action, listenerApi) {\r\n listenerApi.unsubscribe();\r\n resolve([\r\n action,\r\n listenerApi.getState(),\r\n listenerApi.getOriginalState()\r\n ]);\r\n }\r\n });\r\n unsubscribe = function () {\r\n stopListening();\r\n reject();\r\n };\r\n });\r\n promises = [\r\n tuplePromise\r\n ];\r\n if (timeout != null) {\r\n promises.push(new Promise(function (resolve) { return setTimeout(resolve, timeout, null); }));\r\n }\r\n _c.label = 1;\r\n case 1:\r\n _c.trys.push([1, , 3, 4]);\r\n return [4 /*yield*/, raceWithSignal(signal, Promise.race(promises))];\r\n case 2:\r\n output = _c.sent();\r\n validateActive(signal);\r\n return [2 /*return*/, output];\r\n case 3:\r\n unsubscribe();\r\n return [7 /*endfinally*/];\r\n case 4: return [2 /*return*/];\r\n }\r\n });\r\n }); };\r\n return function (predicate, timeout) { return catchRejection(take(predicate, timeout)); };\r\n};\r\nvar getListenerEntryPropsFrom = function (options) {\r\n var type = options.type, actionCreator = options.actionCreator, matcher = options.matcher, predicate = options.predicate, effect = options.effect;\r\n if (type) {\r\n predicate = createAction(type).match;\r\n }\r\n else if (actionCreator) {\r\n type = actionCreator.type;\r\n predicate = actionCreator.match;\r\n }\r\n else if (matcher) {\r\n predicate = matcher;\r\n }\r\n else if (predicate) {\r\n }\r\n else {\r\n throw new Error(\"Creating or removing a listener requires one of the known fields for matching an action\");\r\n }\r\n assertFunction(effect, \"options.listener\");\r\n return { predicate: predicate, type: type, effect: effect };\r\n};\r\nvar createListenerEntry = function (options) {\r\n var _c = getListenerEntryPropsFrom(options), type = _c.type, predicate = _c.predicate, effect = _c.effect;\r\n var id = nanoid();\r\n var entry = {\r\n id: id,\r\n effect: effect,\r\n type: type,\r\n predicate: predicate,\r\n pending: new Set(),\r\n unsubscribe: function () {\r\n throw new Error(\"Unsubscribe not initialized\");\r\n }\r\n };\r\n return entry;\r\n};\r\nvar cancelActiveListeners = function (entry) {\r\n entry.pending.forEach(function (controller) {\r\n abortControllerWithReason(controller, listenerCancelled);\r\n });\r\n};\r\nvar createClearListenerMiddleware = function (listenerMap) {\r\n return function () {\r\n listenerMap.forEach(cancelActiveListeners);\r\n listenerMap.clear();\r\n };\r\n};\r\nvar safelyNotifyError = function (errorHandler, errorToNotify, errorInfo) {\r\n try {\r\n errorHandler(errorToNotify, errorInfo);\r\n }\r\n catch (errorHandlerError) {\r\n setTimeout(function () {\r\n throw errorHandlerError;\r\n }, 0);\r\n }\r\n};\r\nvar addListener = createAction(alm + \"/add\");\r\nvar clearAllListeners = createAction(alm + \"/removeAll\");\r\nvar removeListener = createAction(alm + \"/remove\");\r\nvar defaultErrorHandler = function () {\r\n var args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n args[_i] = arguments[_i];\r\n }\r\n console.error.apply(console, __spreadArray([alm + \"/error\"], args));\r\n};\r\nfunction createListenerMiddleware(middlewareOptions) {\r\n var _this = this;\r\n if (middlewareOptions === void 0) { middlewareOptions = {}; }\r\n var listenerMap = new Map();\r\n var extra = middlewareOptions.extra, _c = middlewareOptions.onError, onError = _c === void 0 ? defaultErrorHandler : _c;\r\n assertFunction(onError, \"onError\");\r\n var insertEntry = function (entry) {\r\n entry.unsubscribe = function () { return listenerMap.delete(entry.id); };\r\n listenerMap.set(entry.id, entry);\r\n return function (cancelOptions) {\r\n entry.unsubscribe();\r\n if (cancelOptions == null ? void 0 : cancelOptions.cancelActive) {\r\n cancelActiveListeners(entry);\r\n }\r\n };\r\n };\r\n var findListenerEntry = function (comparator) {\r\n for (var _i = 0, _c = Array.from(listenerMap.values()); _i < _c.length; _i++) {\r\n var entry = _c[_i];\r\n if (comparator(entry)) {\r\n return entry;\r\n }\r\n }\r\n return void 0;\r\n };\r\n var startListening = function (options) {\r\n var entry = findListenerEntry(function (existingEntry) { return existingEntry.effect === options.effect; });\r\n if (!entry) {\r\n entry = createListenerEntry(options);\r\n }\r\n return insertEntry(entry);\r\n };\r\n var stopListening = function (options) {\r\n var _c = getListenerEntryPropsFrom(options), type = _c.type, effect = _c.effect, predicate = _c.predicate;\r\n var entry = findListenerEntry(function (entry2) {\r\n var matchPredicateOrType = typeof type === \"string\" ? entry2.type === type : entry2.predicate === predicate;\r\n return matchPredicateOrType && entry2.effect === effect;\r\n });\r\n if (entry) {\r\n entry.unsubscribe();\r\n if (options.cancelActive) {\r\n cancelActiveListeners(entry);\r\n }\r\n }\r\n return !!entry;\r\n };\r\n var notifyListener = function (entry, action, api, getOriginalState) { return __async(_this, null, function () {\r\n var internalTaskController, take, autoJoinPromises, listenerError_1;\r\n return __generator(this, function (_c) {\r\n switch (_c.label) {\r\n case 0:\r\n internalTaskController = new AbortController();\r\n take = createTakePattern(startListening, internalTaskController.signal);\r\n autoJoinPromises = [];\r\n _c.label = 1;\r\n case 1:\r\n _c.trys.push([1, 3, 4, 6]);\r\n entry.pending.add(internalTaskController);\r\n return [4 /*yield*/, Promise.resolve(entry.effect(action, assign({}, api, {\r\n getOriginalState: getOriginalState,\r\n condition: function (predicate, timeout) { return take(predicate, timeout).then(Boolean); },\r\n take: take,\r\n delay: createDelay(internalTaskController.signal),\r\n pause: createPause(internalTaskController.signal),\r\n extra: extra,\r\n signal: internalTaskController.signal,\r\n fork: createFork(internalTaskController.signal, autoJoinPromises),\r\n unsubscribe: entry.unsubscribe,\r\n subscribe: function () {\r\n listenerMap.set(entry.id, entry);\r\n },\r\n cancelActiveListeners: function () {\r\n entry.pending.forEach(function (controller, _, set) {\r\n if (controller !== internalTaskController) {\r\n abortControllerWithReason(controller, listenerCancelled);\r\n set.delete(controller);\r\n }\r\n });\r\n }\r\n })))];\r\n case 2:\r\n _c.sent();\r\n return [3 /*break*/, 6];\r\n case 3:\r\n listenerError_1 = _c.sent();\r\n if (!(listenerError_1 instanceof TaskAbortError)) {\r\n safelyNotifyError(onError, listenerError_1, {\r\n raisedBy: \"effect\"\r\n });\r\n }\r\n return [3 /*break*/, 6];\r\n case 4: return [4 /*yield*/, Promise.allSettled(autoJoinPromises)];\r\n case 5:\r\n _c.sent();\r\n abortControllerWithReason(internalTaskController, listenerCompleted);\r\n entry.pending.delete(internalTaskController);\r\n return [7 /*endfinally*/];\r\n case 6: return [2 /*return*/];\r\n }\r\n });\r\n }); };\r\n var clearListenerMiddleware = createClearListenerMiddleware(listenerMap);\r\n var middleware = function (api) { return function (next) { return function (action) {\r\n if (!isAction(action)) {\r\n return next(action);\r\n }\r\n if (addListener.match(action)) {\r\n return startListening(action.payload);\r\n }\r\n if (clearAllListeners.match(action)) {\r\n clearListenerMiddleware();\r\n return;\r\n }\r\n if (removeListener.match(action)) {\r\n return stopListening(action.payload);\r\n }\r\n var originalState = api.getState();\r\n var getOriginalState = function () {\r\n if (originalState === INTERNAL_NIL_TOKEN) {\r\n throw new Error(alm + \": getOriginalState can only be called synchronously\");\r\n }\r\n return originalState;\r\n };\r\n var result;\r\n try {\r\n result = next(action);\r\n if (listenerMap.size > 0) {\r\n var currentState = api.getState();\r\n var listenerEntries = Array.from(listenerMap.values());\r\n for (var _i = 0, listenerEntries_1 = listenerEntries; _i < listenerEntries_1.length; _i++) {\r\n var entry = listenerEntries_1[_i];\r\n var runListener = false;\r\n try {\r\n runListener = entry.predicate(action, currentState, originalState);\r\n }\r\n catch (predicateError) {\r\n runListener = false;\r\n safelyNotifyError(onError, predicateError, {\r\n raisedBy: \"predicate\"\r\n });\r\n }\r\n if (!runListener) {\r\n continue;\r\n }\r\n notifyListener(entry, action, api, getOriginalState);\r\n }\r\n }\r\n }\r\n finally {\r\n originalState = INTERNAL_NIL_TOKEN;\r\n }\r\n return result;\r\n }; }; };\r\n return {\r\n middleware: middleware,\r\n startListening: startListening,\r\n stopListening: stopListening,\r\n clearListeners: clearListenerMiddleware\r\n };\r\n}\r\n// src/autoBatchEnhancer.ts\r\nvar SHOULD_AUTOBATCH = \"RTK_autoBatch\";\r\nvar prepareAutoBatched = function () { return function (payload) {\r\n var _c;\r\n return ({\r\n payload: payload,\r\n meta: (_c = {}, _c[SHOULD_AUTOBATCH] = true, _c)\r\n });\r\n}; };\r\nvar promise;\r\nvar queueMicrotaskShim = typeof queueMicrotask === \"function\" ? queueMicrotask.bind(typeof window !== \"undefined\" ? window : typeof global !== \"undefined\" ? global : globalThis) : function (cb) { return (promise || (promise = Promise.resolve())).then(cb).catch(function (err) { return setTimeout(function () {\r\n throw err;\r\n}, 0); }); };\r\nvar createQueueWithTimer = function (timeout) {\r\n return function (notify) {\r\n setTimeout(notify, timeout);\r\n };\r\n};\r\nvar rAF = typeof window !== \"undefined\" && window.requestAnimationFrame ? window.requestAnimationFrame : createQueueWithTimer(10);\r\nvar autoBatchEnhancer = function (options) {\r\n if (options === void 0) { options = { type: \"raf\" }; }\r\n return function (next) { return function () {\r\n var args = [];\r\n for (var _i = 0; _i < arguments.length; _i++) {\r\n args[_i] = arguments[_i];\r\n }\r\n var store = next.apply(void 0, args);\r\n var notifying = true;\r\n var shouldNotifyAtEndOfTick = false;\r\n var notificationQueued = false;\r\n var listeners = new Set();\r\n var queueCallback = options.type === \"tick\" ? queueMicrotaskShim : options.type === \"raf\" ? rAF : options.type === \"callback\" ? options.queueNotification : createQueueWithTimer(options.timeout);\r\n var notifyListeners = function () {\r\n notificationQueued = false;\r\n if (shouldNotifyAtEndOfTick) {\r\n shouldNotifyAtEndOfTick = false;\r\n listeners.forEach(function (l) { return l(); });\r\n }\r\n };\r\n return Object.assign({}, store, {\r\n subscribe: function (listener2) {\r\n var wrappedListener = function () { return notifying && listener2(); };\r\n var unsubscribe = store.subscribe(wrappedListener);\r\n listeners.add(listener2);\r\n return function () {\r\n unsubscribe();\r\n listeners.delete(listener2);\r\n };\r\n },\r\n dispatch: function (action) {\r\n var _a;\r\n try {\r\n notifying = !((_a = action == null ? void 0 : action.meta) == null ? void 0 : _a[SHOULD_AUTOBATCH]);\r\n shouldNotifyAtEndOfTick = !notifying;\r\n if (shouldNotifyAtEndOfTick) {\r\n if (!notificationQueued) {\r\n notificationQueued = true;\r\n queueCallback(notifyListeners);\r\n }\r\n }\r\n return store.dispatch(action);\r\n }\r\n finally {\r\n notifying = true;\r\n }\r\n }\r\n });\r\n }; };\r\n};\r\n// src/index.ts\r\nenableES5();\r\nexport { EnhancerArray, MiddlewareArray, SHOULD_AUTOBATCH, TaskAbortError, addListener, autoBatchEnhancer, clearAllListeners, configureStore, createAction, createActionCreatorInvariantMiddleware, createAsyncThunk, createDraftSafeSelector, createEntityAdapter, createImmutableStateInvariantMiddleware, createListenerMiddleware, default2 as createNextState, createReducer, createSelector2 as createSelector, createSerializableStateInvariantMiddleware, createSlice, current2 as current, findNonSerializableValue, freeze, getDefaultMiddleware, getType, isAction, isActionCreator, isAllOf, isAnyOf, isAsyncThunkAction, isDraft4 as isDraft, isFSA as isFluxStandardAction, isFulfilled, isImmutableDefault, isPending, isPlain, isPlainObject, isRejected, isRejectedWithValue, miniSerializeError, nanoid, original, prepareAutoBatched, removeListener, unwrapResult };\r\n//# sourceMappingURL=redux-toolkit.esm.js.map","\n import API from \"!../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[8].use[1]!../../../node_modules/sass-loader/dist/cjs.js!./index.module.scss\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[8].use[1]!../../../node_modules/sass-loader/dist/cjs.js!./index.module.scss\";\n export default content && content.locals ? content.locals : undefined;\n","import { feedback } from '@ecosystem/newron-design-system'\nimport * as styles from './index.module.scss'\n\nconst LoadingContent = () => {\n const { DotsLoader } = feedback\n return (\n
\n
\n \n

Loading...

\n
\n
\n )\n}\n\nexport default LoadingContent\n","import { gql, useQuery } from '@apollo/client'\n\nimport { AccessModules, UserAccess } from './types'\n\nconst endpoint = '/graphql'\n\nconst allMarketsAccessQueryString = `\nquery allMarketsAccessQuery {\n userModules {\n modules\n products\n }\n}\n`\n// tslint:disable-next-line: variable-name\nconst All_MARKETS_ACCESS_QUERY = gql(allMarketsAccessQueryString)\n\nexport const useMarketAccessQuery = (): {\n modules: AccessModules[]\n products: string[]\n loading: boolean\n} => {\n const { data, loading } = useQuery<{ userModules: UserAccess }>(All_MARKETS_ACCESS_QUERY, {\n context: { name: 'ECOSYSTEM' },\n })\n if (!data?.userModules?.modules) {\n return { modules: [], products: [], loading }\n }\n return {\n modules: data.userModules.modules as AccessModules[],\n products: data.userModules.products || [],\n loading,\n }\n}\n\nexport const getAccessModules = async (token: string) => {\n const response = await fetch(endpoint, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n Authorization: `Bearer ${token}`,\n },\n body: JSON.stringify([\n { query: allMarketsAccessQueryString, operationName: 'allMarketsAccessQuery' },\n ]),\n })\n\n const json = (await response.json())[0]\n const modules = json.data?.userModules?.modules || []\n const products = json.data?.userModules?.products || []\n return [...modules, ...products]\n}\n","import { AudienceProfilerKPI } from 'components/Segmentation/SegmentationBubble/AudienceProfilerChartHeader'\nimport { ITEM_GROUP } from 'containers/RouteRestriction'\nimport { QueryType } from 'containers/Segmentation/SegmentationTable/config'\n\nexport const AudienceProfilerKPIOptions: AudienceProfilerKPI[] = [\n {\n id: 'purchaseChannel',\n value: 'purchaseChannel',\n label: 'Traditional vs Digital shopper',\n yAxisTitle: 'Traditional shopper',\n yAxisTooltipText: 'Proportion of Shoppers buying in-store',\n secondCrossFilters: [\n { variable_id: 27, answer_code: 3 }, // In-store\n { variable_id: 27, answer_code: 4 }, // Talking to someone over the phone\n ],\n xAxisTitle: 'Digital shopper',\n xAxisTooltipText: 'Proportion of Shoppers buying online',\n firstCrossFilters: [\n { variable_id: 27, answer_code: 1 }, // Online (delivered to a home, work, or other address)\n { variable_id: 27, answer_code: 2 }, // Click-and-Collect\n ],\n queryType: QueryType.PercentOfMarket,\n },\n {\n id: 'keyPurchaseTrigger',\n value: 'keyPurchaseTrigger',\n label: 'In-store vs Digital ad triggers',\n xAxisTitle: 'Digital ad trigger',\n xAxisTooltipText: 'Proportion saying social media or online advertising inspired them to buy.',\n firstCrossFilters: [\n { variable_id: 691, answer_code: 1 }, // Yes\n ],\n yAxisTitle: 'In-store trigger',\n yAxisTooltipText:\n 'Proportion saying in-store staff, leaflets or display advertising inspired them to buy',\n secondCrossFilters: [\n { variable_id: 692, answer_code: 1 }, // Yes\n ],\n queryType: QueryType.PercentOfMarket,\n },\n {\n id: 'engagementComparison',\n value: 'engagementComparison',\n label: 'Brand vs Retailer engagements',\n xAxisTitle: 'Retailers visited (2 or more)',\n xAxisTooltipText: 'Number of retailers visited in-store / online as part of purchase journey',\n firstCrossFilters: [\n { variable_id: 695, answer_code: 2 }, // 2\n { variable_id: 695, answer_code: 3 }, // 3 or more\n ],\n yAxisTitle: 'Brands considered (3 or more)',\n yAxisTooltipText: 'Number of brands considered during purchase journey',\n secondCrossFilters: [\n { variable_id: 683, answer_code: 3 }, // 3\n { variable_id: 683, answer_code: 4 }, // 4\n { variable_id: 683, answer_code: 2919 }, // 5 or more\n ],\n queryType: QueryType.PercentOfMarket,\n },\n {\n id: 'keyChoiceFocus',\n value: 'keyChoiceFocus',\n label: 'Feature vs Brand importance',\n xAxisTitle: 'Brand is key',\n xAxisTooltipText: \"Proportion mentioning 'Product brand' in their top 3 choice drivers.\",\n firstCrossFilters: [{ variable_id: 697, answer_code: 1 }], // Yes\n yAxisTitle: 'Features are key',\n yAxisTooltipText: \"Proportion mentioning 'Product features' in their top 3 choice drivers.\",\n secondCrossFilters: [{ variable_id: 698, answer_code: 1 }], // Yes\n queryType: QueryType.PercentOfMarket,\n },\n {\n id: 'valuePriceSensitivity',\n value: 'valuePriceSensitivity',\n label: 'Price sensitivity vs Price paid ',\n secondaryVar: 'globalPurchasePriceMidPoint',\n xAxisTitle: 'Price paid',\n xAxisTooltipText: 'Average price paid (€).',\n firstCrossFilters: [\n { variable_id: 689, answer_code: 2 },\n { variable_id: 689, answer_code: 3 },\n { variable_id: 689, answer_code: 2920 },\n ],\n yAxisTitle: 'High price sensitivity',\n yAxisTooltipText:\n \"Price sensitivity is a typology derived from answers given across the survey. A scoring system is developed from mentions of 'Price' and 'Promotions' at key brand and retailer choice drivers questions as well as 'Price comparison site' usage. The more mentions of these, the higher the sensitivity score.\",\n queryType: QueryType.AveragePrice,\n },\n {\n id: 'valuePriceSensitivityMobile',\n value: 'valuePriceSensitivityMobile',\n label: 'Price sensitivity (Mobile) vs NSP ',\n secondaryVar: 'mobileHandsetNSPMidPoint',\n xAxisTitle: 'Non Subsidised Price (Mobile)',\n xAxisTooltipText: 'Average price paid (€).',\n firstCrossFilters: [\n { variable_id: 689, answer_code: 2 },\n { variable_id: 689, answer_code: 3 },\n { variable_id: 689, answer_code: 2920 },\n ],\n yAxisTitle: 'High price sensitivity',\n yAxisTooltipText:\n \"Price sensitivity is a typology derived from answers given across the survey. A scoring system is developed from mentions of 'Price' and 'Promotions' at key brand and retailer choice drivers questions as well as 'Price comparison site' usage. The more mentions of these, the higher the sensitivity score.\",\n queryType: QueryType.AveragePrice,\n restrictions: [ITEM_GROUP.MOBILE_PHONE],\n },\n]\n","import { CategoryGroupName } from 'typings/filters'\n\nexport const generalCategoryGroupNames = [\n CategoryGroupName.General_Base,\n CategoryGroupName.General_Shopper,\n CategoryGroupName.General_Purchase,\n CategoryGroupName.General_Product,\n CategoryGroupName.General_Archive,\n]\n\nexport const productReviewCategoryGroupNames = [\n CategoryGroupName.ProductReview_Base,\n CategoryGroupName.ProductReview_Purchase,\n CategoryGroupName.ProductReview_Review,\n]\n\nexport const allCategoryGroupNames: CategoryGroupName[] = [\n ...generalCategoryGroupNames,\n ...productReviewCategoryGroupNames,\n]\n\nexport const categoryGroupShortNames: Record = {\n [CategoryGroupName.General_Base]: 'Base',\n [CategoryGroupName.General_Shopper]: 'Shopper',\n [CategoryGroupName.General_Purchase]: 'Purchase',\n [CategoryGroupName.General_Product]: 'Product',\n [CategoryGroupName.General_Archive]: 'Archive',\n\n [CategoryGroupName.ProductReview_Base]: 'Base',\n [CategoryGroupName.ProductReview_Purchase]: 'Purchase',\n [CategoryGroupName.ProductReview_Review]: 'Review',\n}\n\nexport const generalCategoryGroupLabelToName: Record = {\n Base: CategoryGroupName.General_Base,\n Shopper: CategoryGroupName.General_Shopper,\n Purchase: CategoryGroupName.General_Purchase,\n 'Product Specification': CategoryGroupName.General_Product,\n Archive: CategoryGroupName.General_Archive,\n}\n\nexport const productReviewCategoryGroupLabelToName: Record = {\n Base: CategoryGroupName.ProductReview_Base,\n Purchase: CategoryGroupName.ProductReview_Purchase,\n Review: CategoryGroupName.ProductReview_Review,\n}\n","import { __assign } from \"tslib\";\nimport { invariant } from \"../../utilities/globals/index.js\";\nimport * as React from \"react\";\nimport { getApolloContext } from \"./ApolloContext.js\";\nexport var ApolloProvider = function (_a) {\n var client = _a.client, children = _a.children;\n var ApolloContext = getApolloContext();\n var parentContext = React.useContext(ApolloContext);\n var context = React.useMemo(function () {\n return __assign(__assign({}, parentContext), { client: client || parentContext.client });\n }, [parentContext, client]);\n invariant(context.client, 46);\n return (React.createElement(ApolloContext.Provider, { value: context }, children));\n};\n//# sourceMappingURL=ApolloProvider.js.map","import { FC, useEffect, useState } from 'react'\n\nimport { ApolloProvider } from '@apollo/client'\nimport { useDispatch } from 'react-redux'\nimport { useAuthentication } from '@ecosystem/newron-client-lib'\nimport { setUserJwt } from 'reducers/user'\nimport { getApolloClientWithAuthentication } from 'query/client'\n\nconst ApolloWithAuth: FC = ({ children }) => {\n const { isAuthenticated, user, getAccessToken } = useAuthentication()\n const [token, setToken] = useState('')\n const dispatch = useDispatch()\n\n useEffect(() => {\n async function getToken() {\n // eslint-disable-next-line no-useless-catch\n try {\n if (isAuthenticated) {\n const atoken = (await getAccessToken()) || ''\n setToken(atoken)\n dispatch(setUserJwt(atoken))\n }\n } catch (e: any) {\n throw e\n }\n }\n getToken()\n }, [user, isAuthenticated, dispatch, getAccessToken])\n\n return isAuthenticated && token?.length ? (\n {children}\n ) : null\n}\n\nexport default ApolloWithAuth\n","import { useQuery } from '@apollo/client'\nimport { GET_FILTER_VALUES } from 'query/query'\nimport { useSelector } from 'react-redux'\nimport { selectUserSubscription } from 'reducers/subscription/selectors'\nimport { RootState } from 'reducers/store'\n\nexport const useFetchFilterValues = (variable_id: number, filterSchema: string) => {\n const context = useSelector((state: RootState) => selectUserSubscription(state))\n const { data, loading } = useQuery(GET_FILTER_VALUES, {\n variables: {\n variableId: variable_id,\n schema: filterSchema,\n filters: [],\n context,\n },\n fetchPolicy: 'no-cache',\n skip: !context || !variable_id,\n })\n return { data, loading }\n}\n","\n/*! pako 2.1.0 https://github.com/nodeca/pako @license (MIT AND Zlib) */\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n/* eslint-disable space-unary-ops */\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\n\n//const Z_FILTERED = 1;\n//const Z_HUFFMAN_ONLY = 2;\n//const Z_RLE = 3;\nconst Z_FIXED$1 = 4;\n//const Z_DEFAULT_STRATEGY = 0;\n\n/* Possible values of the data_type field (though see inflate()) */\nconst Z_BINARY = 0;\nconst Z_TEXT = 1;\n//const Z_ASCII = 1; // = Z_TEXT\nconst Z_UNKNOWN$1 = 2;\n\n/*============================================================================*/\n\n\nfunction zero$1(buf) { let len = buf.length; while (--len >= 0) { buf[len] = 0; } }\n\n// From zutil.h\n\nconst STORED_BLOCK = 0;\nconst STATIC_TREES = 1;\nconst DYN_TREES = 2;\n/* The three kinds of block type */\n\nconst MIN_MATCH$1 = 3;\nconst MAX_MATCH$1 = 258;\n/* The minimum and maximum match lengths */\n\n// From deflate.h\n/* ===========================================================================\n * Internal compression state.\n */\n\nconst LENGTH_CODES$1 = 29;\n/* number of length codes, not counting the special END_BLOCK code */\n\nconst LITERALS$1 = 256;\n/* number of literal bytes 0..255 */\n\nconst L_CODES$1 = LITERALS$1 + 1 + LENGTH_CODES$1;\n/* number of Literal or Length codes, including the END_BLOCK code */\n\nconst D_CODES$1 = 30;\n/* number of distance codes */\n\nconst BL_CODES$1 = 19;\n/* number of codes used to transfer the bit lengths */\n\nconst HEAP_SIZE$1 = 2 * L_CODES$1 + 1;\n/* maximum heap size */\n\nconst MAX_BITS$1 = 15;\n/* All codes must not exceed MAX_BITS bits */\n\nconst Buf_size = 16;\n/* size of bit buffer in bi_buf */\n\n\n/* ===========================================================================\n * Constants\n */\n\nconst MAX_BL_BITS = 7;\n/* Bit length codes must not exceed MAX_BL_BITS bits */\n\nconst END_BLOCK = 256;\n/* end of block literal code */\n\nconst REP_3_6 = 16;\n/* repeat previous bit length 3-6 times (2 bits of repeat count) */\n\nconst REPZ_3_10 = 17;\n/* repeat a zero length 3-10 times (3 bits of repeat count) */\n\nconst REPZ_11_138 = 18;\n/* repeat a zero length 11-138 times (7 bits of repeat count) */\n\n/* eslint-disable comma-spacing,array-bracket-spacing */\nconst extra_lbits = /* extra bits for each length code */\n new Uint8Array([0,0,0,0,0,0,0,0,1,1,1,1,2,2,2,2,3,3,3,3,4,4,4,4,5,5,5,5,0]);\n\nconst extra_dbits = /* extra bits for each distance code */\n new Uint8Array([0,0,0,0,1,1,2,2,3,3,4,4,5,5,6,6,7,7,8,8,9,9,10,10,11,11,12,12,13,13]);\n\nconst extra_blbits = /* extra bits for each bit length code */\n new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]);\n\nconst bl_order =\n new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);\n/* eslint-enable comma-spacing,array-bracket-spacing */\n\n/* The lengths of the bit length codes are sent in order of decreasing\n * probability, to avoid transmitting the lengths for unused bit length codes.\n */\n\n/* ===========================================================================\n * Local data. These are initialized only once.\n */\n\n// We pre-fill arrays with 0 to avoid uninitialized gaps\n\nconst DIST_CODE_LEN = 512; /* see definition of array dist_code below */\n\n// !!!! Use flat array instead of structure, Freq = i*2, Len = i*2+1\nconst static_ltree = new Array((L_CODES$1 + 2) * 2);\nzero$1(static_ltree);\n/* The static literal tree. Since the bit lengths are imposed, there is no\n * need for the L_CODES extra codes used during heap construction. However\n * The codes 286 and 287 are needed to build a canonical tree (see _tr_init\n * below).\n */\n\nconst static_dtree = new Array(D_CODES$1 * 2);\nzero$1(static_dtree);\n/* The static distance tree. (Actually a trivial tree since all codes use\n * 5 bits.)\n */\n\nconst _dist_code = new Array(DIST_CODE_LEN);\nzero$1(_dist_code);\n/* Distance codes. The first 256 values correspond to the distances\n * 3 .. 258, the last 256 values correspond to the top 8 bits of\n * the 15 bit distances.\n */\n\nconst _length_code = new Array(MAX_MATCH$1 - MIN_MATCH$1 + 1);\nzero$1(_length_code);\n/* length code for each normalized match length (0 == MIN_MATCH) */\n\nconst base_length = new Array(LENGTH_CODES$1);\nzero$1(base_length);\n/* First normalized length for each code (0 = MIN_MATCH) */\n\nconst base_dist = new Array(D_CODES$1);\nzero$1(base_dist);\n/* First normalized distance for each code (0 = distance of 1) */\n\n\nfunction StaticTreeDesc(static_tree, extra_bits, extra_base, elems, max_length) {\n\n this.static_tree = static_tree; /* static tree or NULL */\n this.extra_bits = extra_bits; /* extra bits for each code or NULL */\n this.extra_base = extra_base; /* base index for extra_bits */\n this.elems = elems; /* max number of elements in the tree */\n this.max_length = max_length; /* max bit length for the codes */\n\n // show if `static_tree` has data or dummy - needed for monomorphic objects\n this.has_stree = static_tree && static_tree.length;\n}\n\n\nlet static_l_desc;\nlet static_d_desc;\nlet static_bl_desc;\n\n\nfunction TreeDesc(dyn_tree, stat_desc) {\n this.dyn_tree = dyn_tree; /* the dynamic tree */\n this.max_code = 0; /* largest code with non zero frequency */\n this.stat_desc = stat_desc; /* the corresponding static tree */\n}\n\n\n\nconst d_code = (dist) => {\n\n return dist < 256 ? _dist_code[dist] : _dist_code[256 + (dist >>> 7)];\n};\n\n\n/* ===========================================================================\n * Output a short LSB first on the stream.\n * IN assertion: there is enough room in pendingBuf.\n */\nconst put_short = (s, w) => {\n// put_byte(s, (uch)((w) & 0xff));\n// put_byte(s, (uch)((ush)(w) >> 8));\n s.pending_buf[s.pending++] = (w) & 0xff;\n s.pending_buf[s.pending++] = (w >>> 8) & 0xff;\n};\n\n\n/* ===========================================================================\n * Send a value on a given number of bits.\n * IN assertion: length <= 16 and value fits in length bits.\n */\nconst send_bits = (s, value, length) => {\n\n if (s.bi_valid > (Buf_size - length)) {\n s.bi_buf |= (value << s.bi_valid) & 0xffff;\n put_short(s, s.bi_buf);\n s.bi_buf = value >> (Buf_size - s.bi_valid);\n s.bi_valid += length - Buf_size;\n } else {\n s.bi_buf |= (value << s.bi_valid) & 0xffff;\n s.bi_valid += length;\n }\n};\n\n\nconst send_code = (s, c, tree) => {\n\n send_bits(s, tree[c * 2]/*.Code*/, tree[c * 2 + 1]/*.Len*/);\n};\n\n\n/* ===========================================================================\n * Reverse the first len bits of a code, using straightforward code (a faster\n * method would use a table)\n * IN assertion: 1 <= len <= 15\n */\nconst bi_reverse = (code, len) => {\n\n let res = 0;\n do {\n res |= code & 1;\n code >>>= 1;\n res <<= 1;\n } while (--len > 0);\n return res >>> 1;\n};\n\n\n/* ===========================================================================\n * Flush the bit buffer, keeping at most 7 bits in it.\n */\nconst bi_flush = (s) => {\n\n if (s.bi_valid === 16) {\n put_short(s, s.bi_buf);\n s.bi_buf = 0;\n s.bi_valid = 0;\n\n } else if (s.bi_valid >= 8) {\n s.pending_buf[s.pending++] = s.bi_buf & 0xff;\n s.bi_buf >>= 8;\n s.bi_valid -= 8;\n }\n};\n\n\n/* ===========================================================================\n * Compute the optimal bit lengths for a tree and update the total bit length\n * for the current block.\n * IN assertion: the fields freq and dad are set, heap[heap_max] and\n * above are the tree nodes sorted by increasing frequency.\n * OUT assertions: the field len is set to the optimal bit length, the\n * array bl_count contains the frequencies for each bit length.\n * The length opt_len is updated; static_len is also updated if stree is\n * not null.\n */\nconst gen_bitlen = (s, desc) => {\n// deflate_state *s;\n// tree_desc *desc; /* the tree descriptor */\n\n const tree = desc.dyn_tree;\n const max_code = desc.max_code;\n const stree = desc.stat_desc.static_tree;\n const has_stree = desc.stat_desc.has_stree;\n const extra = desc.stat_desc.extra_bits;\n const base = desc.stat_desc.extra_base;\n const max_length = desc.stat_desc.max_length;\n let h; /* heap index */\n let n, m; /* iterate over the tree elements */\n let bits; /* bit length */\n let xbits; /* extra bits */\n let f; /* frequency */\n let overflow = 0; /* number of elements with bit length too large */\n\n for (bits = 0; bits <= MAX_BITS$1; bits++) {\n s.bl_count[bits] = 0;\n }\n\n /* In a first pass, compute the optimal bit lengths (which may\n * overflow in the case of the bit length tree).\n */\n tree[s.heap[s.heap_max] * 2 + 1]/*.Len*/ = 0; /* root of the heap */\n\n for (h = s.heap_max + 1; h < HEAP_SIZE$1; h++) {\n n = s.heap[h];\n bits = tree[tree[n * 2 + 1]/*.Dad*/ * 2 + 1]/*.Len*/ + 1;\n if (bits > max_length) {\n bits = max_length;\n overflow++;\n }\n tree[n * 2 + 1]/*.Len*/ = bits;\n /* We overwrite tree[n].Dad which is no longer needed */\n\n if (n > max_code) { continue; } /* not a leaf node */\n\n s.bl_count[bits]++;\n xbits = 0;\n if (n >= base) {\n xbits = extra[n - base];\n }\n f = tree[n * 2]/*.Freq*/;\n s.opt_len += f * (bits + xbits);\n if (has_stree) {\n s.static_len += f * (stree[n * 2 + 1]/*.Len*/ + xbits);\n }\n }\n if (overflow === 0) { return; }\n\n // Tracev((stderr,\"\\nbit length overflow\\n\"));\n /* This happens for example on obj2 and pic of the Calgary corpus */\n\n /* Find the first bit length which could increase: */\n do {\n bits = max_length - 1;\n while (s.bl_count[bits] === 0) { bits--; }\n s.bl_count[bits]--; /* move one leaf down the tree */\n s.bl_count[bits + 1] += 2; /* move one overflow item as its brother */\n s.bl_count[max_length]--;\n /* The brother of the overflow item also moves one step up,\n * but this does not affect bl_count[max_length]\n */\n overflow -= 2;\n } while (overflow > 0);\n\n /* Now recompute all bit lengths, scanning in increasing frequency.\n * h is still equal to HEAP_SIZE. (It is simpler to reconstruct all\n * lengths instead of fixing only the wrong ones. This idea is taken\n * from 'ar' written by Haruhiko Okumura.)\n */\n for (bits = max_length; bits !== 0; bits--) {\n n = s.bl_count[bits];\n while (n !== 0) {\n m = s.heap[--h];\n if (m > max_code) { continue; }\n if (tree[m * 2 + 1]/*.Len*/ !== bits) {\n // Tracev((stderr,\"code %d bits %d->%d\\n\", m, tree[m].Len, bits));\n s.opt_len += (bits - tree[m * 2 + 1]/*.Len*/) * tree[m * 2]/*.Freq*/;\n tree[m * 2 + 1]/*.Len*/ = bits;\n }\n n--;\n }\n }\n};\n\n\n/* ===========================================================================\n * Generate the codes for a given tree and bit counts (which need not be\n * optimal).\n * IN assertion: the array bl_count contains the bit length statistics for\n * the given tree and the field len is set for all tree elements.\n * OUT assertion: the field code is set for all tree elements of non\n * zero code length.\n */\nconst gen_codes = (tree, max_code, bl_count) => {\n// ct_data *tree; /* the tree to decorate */\n// int max_code; /* largest code with non zero frequency */\n// ushf *bl_count; /* number of codes at each bit length */\n\n const next_code = new Array(MAX_BITS$1 + 1); /* next code value for each bit length */\n let code = 0; /* running code value */\n let bits; /* bit index */\n let n; /* code index */\n\n /* The distribution counts are first used to generate the code values\n * without bit reversal.\n */\n for (bits = 1; bits <= MAX_BITS$1; bits++) {\n code = (code + bl_count[bits - 1]) << 1;\n next_code[bits] = code;\n }\n /* Check that the bit counts in bl_count are consistent. The last code\n * must be all ones.\n */\n //Assert (code + bl_count[MAX_BITS]-1 == (1< {\n\n let n; /* iterates over tree elements */\n let bits; /* bit counter */\n let length; /* length value */\n let code; /* code value */\n let dist; /* distance index */\n const bl_count = new Array(MAX_BITS$1 + 1);\n /* number of codes at each bit length for an optimal tree */\n\n // do check in _tr_init()\n //if (static_init_done) return;\n\n /* For some embedded targets, global variables are not initialized: */\n/*#ifdef NO_INIT_GLOBAL_POINTERS\n static_l_desc.static_tree = static_ltree;\n static_l_desc.extra_bits = extra_lbits;\n static_d_desc.static_tree = static_dtree;\n static_d_desc.extra_bits = extra_dbits;\n static_bl_desc.extra_bits = extra_blbits;\n#endif*/\n\n /* Initialize the mapping length (0..255) -> length code (0..28) */\n length = 0;\n for (code = 0; code < LENGTH_CODES$1 - 1; code++) {\n base_length[code] = length;\n for (n = 0; n < (1 << extra_lbits[code]); n++) {\n _length_code[length++] = code;\n }\n }\n //Assert (length == 256, \"tr_static_init: length != 256\");\n /* Note that the length 255 (match length 258) can be represented\n * in two different ways: code 284 + 5 bits or code 285, so we\n * overwrite length_code[255] to use the best encoding:\n */\n _length_code[length - 1] = code;\n\n /* Initialize the mapping dist (0..32K) -> dist code (0..29) */\n dist = 0;\n for (code = 0; code < 16; code++) {\n base_dist[code] = dist;\n for (n = 0; n < (1 << extra_dbits[code]); n++) {\n _dist_code[dist++] = code;\n }\n }\n //Assert (dist == 256, \"tr_static_init: dist != 256\");\n dist >>= 7; /* from now on, all distances are divided by 128 */\n for (; code < D_CODES$1; code++) {\n base_dist[code] = dist << 7;\n for (n = 0; n < (1 << (extra_dbits[code] - 7)); n++) {\n _dist_code[256 + dist++] = code;\n }\n }\n //Assert (dist == 256, \"tr_static_init: 256+dist != 512\");\n\n /* Construct the codes of the static literal tree */\n for (bits = 0; bits <= MAX_BITS$1; bits++) {\n bl_count[bits] = 0;\n }\n\n n = 0;\n while (n <= 143) {\n static_ltree[n * 2 + 1]/*.Len*/ = 8;\n n++;\n bl_count[8]++;\n }\n while (n <= 255) {\n static_ltree[n * 2 + 1]/*.Len*/ = 9;\n n++;\n bl_count[9]++;\n }\n while (n <= 279) {\n static_ltree[n * 2 + 1]/*.Len*/ = 7;\n n++;\n bl_count[7]++;\n }\n while (n <= 287) {\n static_ltree[n * 2 + 1]/*.Len*/ = 8;\n n++;\n bl_count[8]++;\n }\n /* Codes 286 and 287 do not exist, but we must include them in the\n * tree construction to get a canonical Huffman tree (longest code\n * all ones)\n */\n gen_codes(static_ltree, L_CODES$1 + 1, bl_count);\n\n /* The static distance tree is trivial: */\n for (n = 0; n < D_CODES$1; n++) {\n static_dtree[n * 2 + 1]/*.Len*/ = 5;\n static_dtree[n * 2]/*.Code*/ = bi_reverse(n, 5);\n }\n\n // Now data ready and we can init static trees\n static_l_desc = new StaticTreeDesc(static_ltree, extra_lbits, LITERALS$1 + 1, L_CODES$1, MAX_BITS$1);\n static_d_desc = new StaticTreeDesc(static_dtree, extra_dbits, 0, D_CODES$1, MAX_BITS$1);\n static_bl_desc = new StaticTreeDesc(new Array(0), extra_blbits, 0, BL_CODES$1, MAX_BL_BITS);\n\n //static_init_done = true;\n};\n\n\n/* ===========================================================================\n * Initialize a new block.\n */\nconst init_block = (s) => {\n\n let n; /* iterates over tree elements */\n\n /* Initialize the trees. */\n for (n = 0; n < L_CODES$1; n++) { s.dyn_ltree[n * 2]/*.Freq*/ = 0; }\n for (n = 0; n < D_CODES$1; n++) { s.dyn_dtree[n * 2]/*.Freq*/ = 0; }\n for (n = 0; n < BL_CODES$1; n++) { s.bl_tree[n * 2]/*.Freq*/ = 0; }\n\n s.dyn_ltree[END_BLOCK * 2]/*.Freq*/ = 1;\n s.opt_len = s.static_len = 0;\n s.sym_next = s.matches = 0;\n};\n\n\n/* ===========================================================================\n * Flush the bit buffer and align the output on a byte boundary\n */\nconst bi_windup = (s) =>\n{\n if (s.bi_valid > 8) {\n put_short(s, s.bi_buf);\n } else if (s.bi_valid > 0) {\n //put_byte(s, (Byte)s->bi_buf);\n s.pending_buf[s.pending++] = s.bi_buf;\n }\n s.bi_buf = 0;\n s.bi_valid = 0;\n};\n\n/* ===========================================================================\n * Compares to subtrees, using the tree depth as tie breaker when\n * the subtrees have equal frequency. This minimizes the worst case length.\n */\nconst smaller = (tree, n, m, depth) => {\n\n const _n2 = n * 2;\n const _m2 = m * 2;\n return (tree[_n2]/*.Freq*/ < tree[_m2]/*.Freq*/ ||\n (tree[_n2]/*.Freq*/ === tree[_m2]/*.Freq*/ && depth[n] <= depth[m]));\n};\n\n/* ===========================================================================\n * Restore the heap property by moving down the tree starting at node k,\n * exchanging a node with the smallest of its two sons if necessary, stopping\n * when the heap property is re-established (each father smaller than its\n * two sons).\n */\nconst pqdownheap = (s, tree, k) => {\n// deflate_state *s;\n// ct_data *tree; /* the tree to restore */\n// int k; /* node to move down */\n\n const v = s.heap[k];\n let j = k << 1; /* left son of k */\n while (j <= s.heap_len) {\n /* Set j to the smallest of the two sons: */\n if (j < s.heap_len &&\n smaller(tree, s.heap[j + 1], s.heap[j], s.depth)) {\n j++;\n }\n /* Exit if v is smaller than both sons */\n if (smaller(tree, v, s.heap[j], s.depth)) { break; }\n\n /* Exchange v with the smallest son */\n s.heap[k] = s.heap[j];\n k = j;\n\n /* And continue down the tree, setting j to the left son of k */\n j <<= 1;\n }\n s.heap[k] = v;\n};\n\n\n// inlined manually\n// const SMALLEST = 1;\n\n/* ===========================================================================\n * Send the block data compressed using the given Huffman trees\n */\nconst compress_block = (s, ltree, dtree) => {\n// deflate_state *s;\n// const ct_data *ltree; /* literal tree */\n// const ct_data *dtree; /* distance tree */\n\n let dist; /* distance of matched string */\n let lc; /* match length or unmatched char (if dist == 0) */\n let sx = 0; /* running index in sym_buf */\n let code; /* the code to send */\n let extra; /* number of extra bits to send */\n\n if (s.sym_next !== 0) {\n do {\n dist = s.pending_buf[s.sym_buf + sx++] & 0xff;\n dist += (s.pending_buf[s.sym_buf + sx++] & 0xff) << 8;\n lc = s.pending_buf[s.sym_buf + sx++];\n if (dist === 0) {\n send_code(s, lc, ltree); /* send a literal byte */\n //Tracecv(isgraph(lc), (stderr,\" '%c' \", lc));\n } else {\n /* Here, lc is the match length - MIN_MATCH */\n code = _length_code[lc];\n send_code(s, code + LITERALS$1 + 1, ltree); /* send the length code */\n extra = extra_lbits[code];\n if (extra !== 0) {\n lc -= base_length[code];\n send_bits(s, lc, extra); /* send the extra length bits */\n }\n dist--; /* dist is now the match distance - 1 */\n code = d_code(dist);\n //Assert (code < D_CODES, \"bad d_code\");\n\n send_code(s, code, dtree); /* send the distance code */\n extra = extra_dbits[code];\n if (extra !== 0) {\n dist -= base_dist[code];\n send_bits(s, dist, extra); /* send the extra distance bits */\n }\n } /* literal or match pair ? */\n\n /* Check that the overlay between pending_buf and sym_buf is ok: */\n //Assert(s->pending < s->lit_bufsize + sx, \"pendingBuf overflow\");\n\n } while (sx < s.sym_next);\n }\n\n send_code(s, END_BLOCK, ltree);\n};\n\n\n/* ===========================================================================\n * Construct one Huffman tree and assigns the code bit strings and lengths.\n * Update the total bit length for the current block.\n * IN assertion: the field freq is set for all tree elements.\n * OUT assertions: the fields len and code are set to the optimal bit length\n * and corresponding code. The length opt_len is updated; static_len is\n * also updated if stree is not null. The field max_code is set.\n */\nconst build_tree = (s, desc) => {\n// deflate_state *s;\n// tree_desc *desc; /* the tree descriptor */\n\n const tree = desc.dyn_tree;\n const stree = desc.stat_desc.static_tree;\n const has_stree = desc.stat_desc.has_stree;\n const elems = desc.stat_desc.elems;\n let n, m; /* iterate over heap elements */\n let max_code = -1; /* largest code with non zero frequency */\n let node; /* new node being created */\n\n /* Construct the initial heap, with least frequent element in\n * heap[SMALLEST]. The sons of heap[n] are heap[2*n] and heap[2*n+1].\n * heap[0] is not used.\n */\n s.heap_len = 0;\n s.heap_max = HEAP_SIZE$1;\n\n for (n = 0; n < elems; n++) {\n if (tree[n * 2]/*.Freq*/ !== 0) {\n s.heap[++s.heap_len] = max_code = n;\n s.depth[n] = 0;\n\n } else {\n tree[n * 2 + 1]/*.Len*/ = 0;\n }\n }\n\n /* The pkzip format requires that at least one distance code exists,\n * and that at least one bit should be sent even if there is only one\n * possible code. So to avoid special checks later on we force at least\n * two codes of non zero frequency.\n */\n while (s.heap_len < 2) {\n node = s.heap[++s.heap_len] = (max_code < 2 ? ++max_code : 0);\n tree[node * 2]/*.Freq*/ = 1;\n s.depth[node] = 0;\n s.opt_len--;\n\n if (has_stree) {\n s.static_len -= stree[node * 2 + 1]/*.Len*/;\n }\n /* node is 0 or 1 so it does not have extra bits */\n }\n desc.max_code = max_code;\n\n /* The elements heap[heap_len/2+1 .. heap_len] are leaves of the tree,\n * establish sub-heaps of increasing lengths:\n */\n for (n = (s.heap_len >> 1/*int /2*/); n >= 1; n--) { pqdownheap(s, tree, n); }\n\n /* Construct the Huffman tree by repeatedly combining the least two\n * frequent nodes.\n */\n node = elems; /* next internal node of the tree */\n do {\n //pqremove(s, tree, n); /* n = node of least frequency */\n /*** pqremove ***/\n n = s.heap[1/*SMALLEST*/];\n s.heap[1/*SMALLEST*/] = s.heap[s.heap_len--];\n pqdownheap(s, tree, 1/*SMALLEST*/);\n /***/\n\n m = s.heap[1/*SMALLEST*/]; /* m = node of next least frequency */\n\n s.heap[--s.heap_max] = n; /* keep the nodes sorted by frequency */\n s.heap[--s.heap_max] = m;\n\n /* Create a new node father of n and m */\n tree[node * 2]/*.Freq*/ = tree[n * 2]/*.Freq*/ + tree[m * 2]/*.Freq*/;\n s.depth[node] = (s.depth[n] >= s.depth[m] ? s.depth[n] : s.depth[m]) + 1;\n tree[n * 2 + 1]/*.Dad*/ = tree[m * 2 + 1]/*.Dad*/ = node;\n\n /* and insert the new node in the heap */\n s.heap[1/*SMALLEST*/] = node++;\n pqdownheap(s, tree, 1/*SMALLEST*/);\n\n } while (s.heap_len >= 2);\n\n s.heap[--s.heap_max] = s.heap[1/*SMALLEST*/];\n\n /* At this point, the fields freq and dad are set. We can now\n * generate the bit lengths.\n */\n gen_bitlen(s, desc);\n\n /* The field len is now set, we can generate the bit codes */\n gen_codes(tree, max_code, s.bl_count);\n};\n\n\n/* ===========================================================================\n * Scan a literal or distance tree to determine the frequencies of the codes\n * in the bit length tree.\n */\nconst scan_tree = (s, tree, max_code) => {\n// deflate_state *s;\n// ct_data *tree; /* the tree to be scanned */\n// int max_code; /* and its largest code of non zero frequency */\n\n let n; /* iterates over all tree elements */\n let prevlen = -1; /* last emitted length */\n let curlen; /* length of current code */\n\n let nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */\n\n let count = 0; /* repeat count of the current code */\n let max_count = 7; /* max repeat count */\n let min_count = 4; /* min repeat count */\n\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n }\n tree[(max_code + 1) * 2 + 1]/*.Len*/ = 0xffff; /* guard */\n\n for (n = 0; n <= max_code; n++) {\n curlen = nextlen;\n nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;\n\n if (++count < max_count && curlen === nextlen) {\n continue;\n\n } else if (count < min_count) {\n s.bl_tree[curlen * 2]/*.Freq*/ += count;\n\n } else if (curlen !== 0) {\n\n if (curlen !== prevlen) { s.bl_tree[curlen * 2]/*.Freq*/++; }\n s.bl_tree[REP_3_6 * 2]/*.Freq*/++;\n\n } else if (count <= 10) {\n s.bl_tree[REPZ_3_10 * 2]/*.Freq*/++;\n\n } else {\n s.bl_tree[REPZ_11_138 * 2]/*.Freq*/++;\n }\n\n count = 0;\n prevlen = curlen;\n\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n\n } else if (curlen === nextlen) {\n max_count = 6;\n min_count = 3;\n\n } else {\n max_count = 7;\n min_count = 4;\n }\n }\n};\n\n\n/* ===========================================================================\n * Send a literal or distance tree in compressed form, using the codes in\n * bl_tree.\n */\nconst send_tree = (s, tree, max_code) => {\n// deflate_state *s;\n// ct_data *tree; /* the tree to be scanned */\n// int max_code; /* and its largest code of non zero frequency */\n\n let n; /* iterates over all tree elements */\n let prevlen = -1; /* last emitted length */\n let curlen; /* length of current code */\n\n let nextlen = tree[0 * 2 + 1]/*.Len*/; /* length of next code */\n\n let count = 0; /* repeat count of the current code */\n let max_count = 7; /* max repeat count */\n let min_count = 4; /* min repeat count */\n\n /* tree[max_code+1].Len = -1; */ /* guard already set */\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n }\n\n for (n = 0; n <= max_code; n++) {\n curlen = nextlen;\n nextlen = tree[(n + 1) * 2 + 1]/*.Len*/;\n\n if (++count < max_count && curlen === nextlen) {\n continue;\n\n } else if (count < min_count) {\n do { send_code(s, curlen, s.bl_tree); } while (--count !== 0);\n\n } else if (curlen !== 0) {\n if (curlen !== prevlen) {\n send_code(s, curlen, s.bl_tree);\n count--;\n }\n //Assert(count >= 3 && count <= 6, \" 3_6?\");\n send_code(s, REP_3_6, s.bl_tree);\n send_bits(s, count - 3, 2);\n\n } else if (count <= 10) {\n send_code(s, REPZ_3_10, s.bl_tree);\n send_bits(s, count - 3, 3);\n\n } else {\n send_code(s, REPZ_11_138, s.bl_tree);\n send_bits(s, count - 11, 7);\n }\n\n count = 0;\n prevlen = curlen;\n if (nextlen === 0) {\n max_count = 138;\n min_count = 3;\n\n } else if (curlen === nextlen) {\n max_count = 6;\n min_count = 3;\n\n } else {\n max_count = 7;\n min_count = 4;\n }\n }\n};\n\n\n/* ===========================================================================\n * Construct the Huffman tree for the bit lengths and return the index in\n * bl_order of the last bit length code to send.\n */\nconst build_bl_tree = (s) => {\n\n let max_blindex; /* index of last bit length code of non zero freq */\n\n /* Determine the bit length frequencies for literal and distance trees */\n scan_tree(s, s.dyn_ltree, s.l_desc.max_code);\n scan_tree(s, s.dyn_dtree, s.d_desc.max_code);\n\n /* Build the bit length tree: */\n build_tree(s, s.bl_desc);\n /* opt_len now includes the length of the tree representations, except\n * the lengths of the bit lengths codes and the 5+5+4 bits for the counts.\n */\n\n /* Determine the number of bit length codes to send. The pkzip format\n * requires that at least 4 bit length codes be sent. (appnote.txt says\n * 3 but the actual value used is 4.)\n */\n for (max_blindex = BL_CODES$1 - 1; max_blindex >= 3; max_blindex--) {\n if (s.bl_tree[bl_order[max_blindex] * 2 + 1]/*.Len*/ !== 0) {\n break;\n }\n }\n /* Update opt_len to include the bit length tree and counts */\n s.opt_len += 3 * (max_blindex + 1) + 5 + 5 + 4;\n //Tracev((stderr, \"\\ndyn trees: dyn %ld, stat %ld\",\n // s->opt_len, s->static_len));\n\n return max_blindex;\n};\n\n\n/* ===========================================================================\n * Send the header for a block using dynamic Huffman trees: the counts, the\n * lengths of the bit length codes, the literal tree and the distance tree.\n * IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4.\n */\nconst send_all_trees = (s, lcodes, dcodes, blcodes) => {\n// deflate_state *s;\n// int lcodes, dcodes, blcodes; /* number of codes for each tree */\n\n let rank; /* index in bl_order */\n\n //Assert (lcodes >= 257 && dcodes >= 1 && blcodes >= 4, \"not enough codes\");\n //Assert (lcodes <= L_CODES && dcodes <= D_CODES && blcodes <= BL_CODES,\n // \"too many codes\");\n //Tracev((stderr, \"\\nbl counts: \"));\n send_bits(s, lcodes - 257, 5); /* not +255 as stated in appnote.txt */\n send_bits(s, dcodes - 1, 5);\n send_bits(s, blcodes - 4, 4); /* not -3 as stated in appnote.txt */\n for (rank = 0; rank < blcodes; rank++) {\n //Tracev((stderr, \"\\nbl code %2d \", bl_order[rank]));\n send_bits(s, s.bl_tree[bl_order[rank] * 2 + 1]/*.Len*/, 3);\n }\n //Tracev((stderr, \"\\nbl tree: sent %ld\", s->bits_sent));\n\n send_tree(s, s.dyn_ltree, lcodes - 1); /* literal tree */\n //Tracev((stderr, \"\\nlit tree: sent %ld\", s->bits_sent));\n\n send_tree(s, s.dyn_dtree, dcodes - 1); /* distance tree */\n //Tracev((stderr, \"\\ndist tree: sent %ld\", s->bits_sent));\n};\n\n\n/* ===========================================================================\n * Check if the data type is TEXT or BINARY, using the following algorithm:\n * - TEXT if the two conditions below are satisfied:\n * a) There are no non-portable control characters belonging to the\n * \"block list\" (0..6, 14..25, 28..31).\n * b) There is at least one printable character belonging to the\n * \"allow list\" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255).\n * - BINARY otherwise.\n * - The following partially-portable control characters form a\n * \"gray list\" that is ignored in this detection algorithm:\n * (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}).\n * IN assertion: the fields Freq of dyn_ltree are set.\n */\nconst detect_data_type = (s) => {\n /* block_mask is the bit mask of block-listed bytes\n * set bits 0..6, 14..25, and 28..31\n * 0xf3ffc07f = binary 11110011111111111100000001111111\n */\n let block_mask = 0xf3ffc07f;\n let n;\n\n /* Check for non-textual (\"block-listed\") bytes. */\n for (n = 0; n <= 31; n++, block_mask >>>= 1) {\n if ((block_mask & 1) && (s.dyn_ltree[n * 2]/*.Freq*/ !== 0)) {\n return Z_BINARY;\n }\n }\n\n /* Check for textual (\"allow-listed\") bytes. */\n if (s.dyn_ltree[9 * 2]/*.Freq*/ !== 0 || s.dyn_ltree[10 * 2]/*.Freq*/ !== 0 ||\n s.dyn_ltree[13 * 2]/*.Freq*/ !== 0) {\n return Z_TEXT;\n }\n for (n = 32; n < LITERALS$1; n++) {\n if (s.dyn_ltree[n * 2]/*.Freq*/ !== 0) {\n return Z_TEXT;\n }\n }\n\n /* There are no \"block-listed\" or \"allow-listed\" bytes:\n * this stream either is empty or has tolerated (\"gray-listed\") bytes only.\n */\n return Z_BINARY;\n};\n\n\nlet static_init_done = false;\n\n/* ===========================================================================\n * Initialize the tree data structures for a new zlib stream.\n */\nconst _tr_init$1 = (s) =>\n{\n\n if (!static_init_done) {\n tr_static_init();\n static_init_done = true;\n }\n\n s.l_desc = new TreeDesc(s.dyn_ltree, static_l_desc);\n s.d_desc = new TreeDesc(s.dyn_dtree, static_d_desc);\n s.bl_desc = new TreeDesc(s.bl_tree, static_bl_desc);\n\n s.bi_buf = 0;\n s.bi_valid = 0;\n\n /* Initialize the first block of the first file: */\n init_block(s);\n};\n\n\n/* ===========================================================================\n * Send a stored block\n */\nconst _tr_stored_block$1 = (s, buf, stored_len, last) => {\n//DeflateState *s;\n//charf *buf; /* input block */\n//ulg stored_len; /* length of input block */\n//int last; /* one if this is the last block for a file */\n\n send_bits(s, (STORED_BLOCK << 1) + (last ? 1 : 0), 3); /* send block type */\n bi_windup(s); /* align on byte boundary */\n put_short(s, stored_len);\n put_short(s, ~stored_len);\n if (stored_len) {\n s.pending_buf.set(s.window.subarray(buf, buf + stored_len), s.pending);\n }\n s.pending += stored_len;\n};\n\n\n/* ===========================================================================\n * Send one empty static block to give enough lookahead for inflate.\n * This takes 10 bits, of which 7 may remain in the bit buffer.\n */\nconst _tr_align$1 = (s) => {\n send_bits(s, STATIC_TREES << 1, 3);\n send_code(s, END_BLOCK, static_ltree);\n bi_flush(s);\n};\n\n\n/* ===========================================================================\n * Determine the best encoding for the current block: dynamic trees, static\n * trees or store, and write out the encoded block.\n */\nconst _tr_flush_block$1 = (s, buf, stored_len, last) => {\n//DeflateState *s;\n//charf *buf; /* input block, or NULL if too old */\n//ulg stored_len; /* length of input block */\n//int last; /* one if this is the last block for a file */\n\n let opt_lenb, static_lenb; /* opt_len and static_len in bytes */\n let max_blindex = 0; /* index of last bit length code of non zero freq */\n\n /* Build the Huffman trees unless a stored block is forced */\n if (s.level > 0) {\n\n /* Check if the file is binary or text */\n if (s.strm.data_type === Z_UNKNOWN$1) {\n s.strm.data_type = detect_data_type(s);\n }\n\n /* Construct the literal and distance trees */\n build_tree(s, s.l_desc);\n // Tracev((stderr, \"\\nlit data: dyn %ld, stat %ld\", s->opt_len,\n // s->static_len));\n\n build_tree(s, s.d_desc);\n // Tracev((stderr, \"\\ndist data: dyn %ld, stat %ld\", s->opt_len,\n // s->static_len));\n /* At this point, opt_len and static_len are the total bit lengths of\n * the compressed block data, excluding the tree representations.\n */\n\n /* Build the bit length tree for the above two trees, and get the index\n * in bl_order of the last bit length code to send.\n */\n max_blindex = build_bl_tree(s);\n\n /* Determine the best encoding. Compute the block lengths in bytes. */\n opt_lenb = (s.opt_len + 3 + 7) >>> 3;\n static_lenb = (s.static_len + 3 + 7) >>> 3;\n\n // Tracev((stderr, \"\\nopt %lu(%lu) stat %lu(%lu) stored %lu lit %u \",\n // opt_lenb, s->opt_len, static_lenb, s->static_len, stored_len,\n // s->sym_next / 3));\n\n if (static_lenb <= opt_lenb) { opt_lenb = static_lenb; }\n\n } else {\n // Assert(buf != (char*)0, \"lost buf\");\n opt_lenb = static_lenb = stored_len + 5; /* force a stored block */\n }\n\n if ((stored_len + 4 <= opt_lenb) && (buf !== -1)) {\n /* 4: two words for the lengths */\n\n /* The test buf != NULL is only necessary if LIT_BUFSIZE > WSIZE.\n * Otherwise we can't have processed more than WSIZE input bytes since\n * the last block flush, because compression would have been\n * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to\n * transform a block into a stored block.\n */\n _tr_stored_block$1(s, buf, stored_len, last);\n\n } else if (s.strategy === Z_FIXED$1 || static_lenb === opt_lenb) {\n\n send_bits(s, (STATIC_TREES << 1) + (last ? 1 : 0), 3);\n compress_block(s, static_ltree, static_dtree);\n\n } else {\n send_bits(s, (DYN_TREES << 1) + (last ? 1 : 0), 3);\n send_all_trees(s, s.l_desc.max_code + 1, s.d_desc.max_code + 1, max_blindex + 1);\n compress_block(s, s.dyn_ltree, s.dyn_dtree);\n }\n // Assert (s->compressed_len == s->bits_sent, \"bad compressed size\");\n /* The above check is made mod 2^32, for files larger than 512 MB\n * and uLong implemented on 32 bits.\n */\n init_block(s);\n\n if (last) {\n bi_windup(s);\n }\n // Tracev((stderr,\"\\ncomprlen %lu(%lu) \", s->compressed_len>>3,\n // s->compressed_len-7*last));\n};\n\n/* ===========================================================================\n * Save the match info and tally the frequency counts. Return true if\n * the current block must be flushed.\n */\nconst _tr_tally$1 = (s, dist, lc) => {\n// deflate_state *s;\n// unsigned dist; /* distance of matched string */\n// unsigned lc; /* match length-MIN_MATCH or unmatched char (if dist==0) */\n\n s.pending_buf[s.sym_buf + s.sym_next++] = dist;\n s.pending_buf[s.sym_buf + s.sym_next++] = dist >> 8;\n s.pending_buf[s.sym_buf + s.sym_next++] = lc;\n if (dist === 0) {\n /* lc is the unmatched char */\n s.dyn_ltree[lc * 2]/*.Freq*/++;\n } else {\n s.matches++;\n /* Here, lc is the match length - MIN_MATCH */\n dist--; /* dist = match distance - 1 */\n //Assert((ush)dist < (ush)MAX_DIST(s) &&\n // (ush)lc <= (ush)(MAX_MATCH-MIN_MATCH) &&\n // (ush)d_code(dist) < (ush)D_CODES, \"_tr_tally: bad match\");\n\n s.dyn_ltree[(_length_code[lc] + LITERALS$1 + 1) * 2]/*.Freq*/++;\n s.dyn_dtree[d_code(dist) * 2]/*.Freq*/++;\n }\n\n return (s.sym_next === s.sym_end);\n};\n\nvar _tr_init_1 = _tr_init$1;\nvar _tr_stored_block_1 = _tr_stored_block$1;\nvar _tr_flush_block_1 = _tr_flush_block$1;\nvar _tr_tally_1 = _tr_tally$1;\nvar _tr_align_1 = _tr_align$1;\n\nvar trees = {\n\t_tr_init: _tr_init_1,\n\t_tr_stored_block: _tr_stored_block_1,\n\t_tr_flush_block: _tr_flush_block_1,\n\t_tr_tally: _tr_tally_1,\n\t_tr_align: _tr_align_1\n};\n\n// Note: adler32 takes 12% for level 0 and 2% for level 6.\n// It isn't worth it to make additional optimizations as in original.\n// Small size is preferable.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nconst adler32 = (adler, buf, len, pos) => {\n let s1 = (adler & 0xffff) |0,\n s2 = ((adler >>> 16) & 0xffff) |0,\n n = 0;\n\n while (len !== 0) {\n // Set limit ~ twice less than 5552, to keep\n // s2 in 31-bits, because we force signed ints.\n // in other case %= will fail.\n n = len > 2000 ? 2000 : len;\n len -= n;\n\n do {\n s1 = (s1 + buf[pos++]) |0;\n s2 = (s2 + s1) |0;\n } while (--n);\n\n s1 %= 65521;\n s2 %= 65521;\n }\n\n return (s1 | (s2 << 16)) |0;\n};\n\n\nvar adler32_1 = adler32;\n\n// Note: we can't get significant speed boost here.\n// So write code to minimize size - no pregenerated tables\n// and array tools dependencies.\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// Use ordinary array, since untyped makes no boost here\nconst makeTable = () => {\n let c, table = [];\n\n for (var n = 0; n < 256; n++) {\n c = n;\n for (var k = 0; k < 8; k++) {\n c = ((c & 1) ? (0xEDB88320 ^ (c >>> 1)) : (c >>> 1));\n }\n table[n] = c;\n }\n\n return table;\n};\n\n// Create table on load. Just 255 signed longs. Not a problem.\nconst crcTable = new Uint32Array(makeTable());\n\n\nconst crc32 = (crc, buf, len, pos) => {\n const t = crcTable;\n const end = pos + len;\n\n crc ^= -1;\n\n for (let i = pos; i < end; i++) {\n crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xFF];\n }\n\n return (crc ^ (-1)); // >>> 0;\n};\n\n\nvar crc32_1 = crc32;\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar messages = {\n 2: 'need dictionary', /* Z_NEED_DICT 2 */\n 1: 'stream end', /* Z_STREAM_END 1 */\n 0: '', /* Z_OK 0 */\n '-1': 'file error', /* Z_ERRNO (-1) */\n '-2': 'stream error', /* Z_STREAM_ERROR (-2) */\n '-3': 'data error', /* Z_DATA_ERROR (-3) */\n '-4': 'insufficient memory', /* Z_MEM_ERROR (-4) */\n '-5': 'buffer error', /* Z_BUF_ERROR (-5) */\n '-6': 'incompatible version' /* Z_VERSION_ERROR (-6) */\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nvar constants$2 = {\n\n /* Allowed flush values; see deflate() and inflate() below for details */\n Z_NO_FLUSH: 0,\n Z_PARTIAL_FLUSH: 1,\n Z_SYNC_FLUSH: 2,\n Z_FULL_FLUSH: 3,\n Z_FINISH: 4,\n Z_BLOCK: 5,\n Z_TREES: 6,\n\n /* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\n Z_OK: 0,\n Z_STREAM_END: 1,\n Z_NEED_DICT: 2,\n Z_ERRNO: -1,\n Z_STREAM_ERROR: -2,\n Z_DATA_ERROR: -3,\n Z_MEM_ERROR: -4,\n Z_BUF_ERROR: -5,\n //Z_VERSION_ERROR: -6,\n\n /* compression levels */\n Z_NO_COMPRESSION: 0,\n Z_BEST_SPEED: 1,\n Z_BEST_COMPRESSION: 9,\n Z_DEFAULT_COMPRESSION: -1,\n\n\n Z_FILTERED: 1,\n Z_HUFFMAN_ONLY: 2,\n Z_RLE: 3,\n Z_FIXED: 4,\n Z_DEFAULT_STRATEGY: 0,\n\n /* Possible values of the data_type field (though see inflate()) */\n Z_BINARY: 0,\n Z_TEXT: 1,\n //Z_ASCII: 1, // = Z_TEXT (deprecated)\n Z_UNKNOWN: 2,\n\n /* The deflate compression method */\n Z_DEFLATED: 8\n //Z_NULL: null // Use -1 or null inline, depending on var type\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nconst { _tr_init, _tr_stored_block, _tr_flush_block, _tr_tally, _tr_align } = trees;\n\n\n\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_NO_FLUSH: Z_NO_FLUSH$2, Z_PARTIAL_FLUSH, Z_FULL_FLUSH: Z_FULL_FLUSH$1, Z_FINISH: Z_FINISH$3, Z_BLOCK: Z_BLOCK$1,\n Z_OK: Z_OK$3, Z_STREAM_END: Z_STREAM_END$3, Z_STREAM_ERROR: Z_STREAM_ERROR$2, Z_DATA_ERROR: Z_DATA_ERROR$2, Z_BUF_ERROR: Z_BUF_ERROR$1,\n Z_DEFAULT_COMPRESSION: Z_DEFAULT_COMPRESSION$1,\n Z_FILTERED, Z_HUFFMAN_ONLY, Z_RLE, Z_FIXED, Z_DEFAULT_STRATEGY: Z_DEFAULT_STRATEGY$1,\n Z_UNKNOWN,\n Z_DEFLATED: Z_DEFLATED$2\n} = constants$2;\n\n/*============================================================================*/\n\n\nconst MAX_MEM_LEVEL = 9;\n/* Maximum value for memLevel in deflateInit2 */\nconst MAX_WBITS$1 = 15;\n/* 32K LZ77 window */\nconst DEF_MEM_LEVEL = 8;\n\n\nconst LENGTH_CODES = 29;\n/* number of length codes, not counting the special END_BLOCK code */\nconst LITERALS = 256;\n/* number of literal bytes 0..255 */\nconst L_CODES = LITERALS + 1 + LENGTH_CODES;\n/* number of Literal or Length codes, including the END_BLOCK code */\nconst D_CODES = 30;\n/* number of distance codes */\nconst BL_CODES = 19;\n/* number of codes used to transfer the bit lengths */\nconst HEAP_SIZE = 2 * L_CODES + 1;\n/* maximum heap size */\nconst MAX_BITS = 15;\n/* All codes must not exceed MAX_BITS bits */\n\nconst MIN_MATCH = 3;\nconst MAX_MATCH = 258;\nconst MIN_LOOKAHEAD = (MAX_MATCH + MIN_MATCH + 1);\n\nconst PRESET_DICT = 0x20;\n\nconst INIT_STATE = 42; /* zlib header -> BUSY_STATE */\n//#ifdef GZIP\nconst GZIP_STATE = 57; /* gzip header -> BUSY_STATE | EXTRA_STATE */\n//#endif\nconst EXTRA_STATE = 69; /* gzip extra block -> NAME_STATE */\nconst NAME_STATE = 73; /* gzip file name -> COMMENT_STATE */\nconst COMMENT_STATE = 91; /* gzip comment -> HCRC_STATE */\nconst HCRC_STATE = 103; /* gzip header CRC -> BUSY_STATE */\nconst BUSY_STATE = 113; /* deflate -> FINISH_STATE */\nconst FINISH_STATE = 666; /* stream complete */\n\nconst BS_NEED_MORE = 1; /* block not completed, need more input or more output */\nconst BS_BLOCK_DONE = 2; /* block flush performed */\nconst BS_FINISH_STARTED = 3; /* finish started, need only more output at next deflate */\nconst BS_FINISH_DONE = 4; /* finish done, accept no more input or output */\n\nconst OS_CODE = 0x03; // Unix :) . Don't detect, use this default.\n\nconst err = (strm, errorCode) => {\n strm.msg = messages[errorCode];\n return errorCode;\n};\n\nconst rank = (f) => {\n return ((f) * 2) - ((f) > 4 ? 9 : 0);\n};\n\nconst zero = (buf) => {\n let len = buf.length; while (--len >= 0) { buf[len] = 0; }\n};\n\n/* ===========================================================================\n * Slide the hash table when sliding the window down (could be avoided with 32\n * bit values at the expense of memory usage). We slide even when level == 0 to\n * keep the hash table consistent if we switch back to level > 0 later.\n */\nconst slide_hash = (s) => {\n let n, m;\n let p;\n let wsize = s.w_size;\n\n n = s.hash_size;\n p = n;\n do {\n m = s.head[--p];\n s.head[p] = (m >= wsize ? m - wsize : 0);\n } while (--n);\n n = wsize;\n//#ifndef FASTEST\n p = n;\n do {\n m = s.prev[--p];\n s.prev[p] = (m >= wsize ? m - wsize : 0);\n /* If n is not on any hash chain, prev[n] is garbage but\n * its value will never be used.\n */\n } while (--n);\n//#endif\n};\n\n/* eslint-disable new-cap */\nlet HASH_ZLIB = (s, prev, data) => ((prev << s.hash_shift) ^ data) & s.hash_mask;\n// This hash causes less collisions, https://github.com/nodeca/pako/issues/135\n// But breaks binary compatibility\n//let HASH_FAST = (s, prev, data) => ((prev << 8) + (prev >> 8) + (data << 4)) & s.hash_mask;\nlet HASH = HASH_ZLIB;\n\n\n/* =========================================================================\n * Flush as much pending output as possible. All deflate() output, except for\n * some deflate_stored() output, goes through this function so some\n * applications may wish to modify it to avoid allocating a large\n * strm->next_out buffer and copying into it. (See also read_buf()).\n */\nconst flush_pending = (strm) => {\n const s = strm.state;\n\n //_tr_flush_bits(s);\n let len = s.pending;\n if (len > strm.avail_out) {\n len = strm.avail_out;\n }\n if (len === 0) { return; }\n\n strm.output.set(s.pending_buf.subarray(s.pending_out, s.pending_out + len), strm.next_out);\n strm.next_out += len;\n s.pending_out += len;\n strm.total_out += len;\n strm.avail_out -= len;\n s.pending -= len;\n if (s.pending === 0) {\n s.pending_out = 0;\n }\n};\n\n\nconst flush_block_only = (s, last) => {\n _tr_flush_block(s, (s.block_start >= 0 ? s.block_start : -1), s.strstart - s.block_start, last);\n s.block_start = s.strstart;\n flush_pending(s.strm);\n};\n\n\nconst put_byte = (s, b) => {\n s.pending_buf[s.pending++] = b;\n};\n\n\n/* =========================================================================\n * Put a short in the pending buffer. The 16-bit value is put in MSB order.\n * IN assertion: the stream state is correct and there is enough room in\n * pending_buf.\n */\nconst putShortMSB = (s, b) => {\n\n // put_byte(s, (Byte)(b >> 8));\n// put_byte(s, (Byte)(b & 0xff));\n s.pending_buf[s.pending++] = (b >>> 8) & 0xff;\n s.pending_buf[s.pending++] = b & 0xff;\n};\n\n\n/* ===========================================================================\n * Read a new buffer from the current input stream, update the adler32\n * and total number of bytes read. All deflate() input goes through\n * this function so some applications may wish to modify it to avoid\n * allocating a large strm->input buffer and copying from it.\n * (See also flush_pending()).\n */\nconst read_buf = (strm, buf, start, size) => {\n\n let len = strm.avail_in;\n\n if (len > size) { len = size; }\n if (len === 0) { return 0; }\n\n strm.avail_in -= len;\n\n // zmemcpy(buf, strm->next_in, len);\n buf.set(strm.input.subarray(strm.next_in, strm.next_in + len), start);\n if (strm.state.wrap === 1) {\n strm.adler = adler32_1(strm.adler, buf, len, start);\n }\n\n else if (strm.state.wrap === 2) {\n strm.adler = crc32_1(strm.adler, buf, len, start);\n }\n\n strm.next_in += len;\n strm.total_in += len;\n\n return len;\n};\n\n\n/* ===========================================================================\n * Set match_start to the longest match starting at the given string and\n * return its length. Matches shorter or equal to prev_length are discarded,\n * in which case the result is equal to prev_length and match_start is\n * garbage.\n * IN assertions: cur_match is the head of the hash chain for the current\n * string (strstart) and its distance is <= MAX_DIST, and prev_length >= 1\n * OUT assertion: the match length is not greater than s->lookahead.\n */\nconst longest_match = (s, cur_match) => {\n\n let chain_length = s.max_chain_length; /* max hash chain length */\n let scan = s.strstart; /* current string */\n let match; /* matched string */\n let len; /* length of current match */\n let best_len = s.prev_length; /* best match length so far */\n let nice_match = s.nice_match; /* stop if match long enough */\n const limit = (s.strstart > (s.w_size - MIN_LOOKAHEAD)) ?\n s.strstart - (s.w_size - MIN_LOOKAHEAD) : 0/*NIL*/;\n\n const _win = s.window; // shortcut\n\n const wmask = s.w_mask;\n const prev = s.prev;\n\n /* Stop when cur_match becomes <= limit. To simplify the code,\n * we prevent matches with the string of window index 0.\n */\n\n const strend = s.strstart + MAX_MATCH;\n let scan_end1 = _win[scan + best_len - 1];\n let scan_end = _win[scan + best_len];\n\n /* The code is optimized for HASH_BITS >= 8 and MAX_MATCH-2 multiple of 16.\n * It is easy to get rid of this optimization if necessary.\n */\n // Assert(s->hash_bits >= 8 && MAX_MATCH == 258, \"Code too clever\");\n\n /* Do not waste too much time if we already have a good match: */\n if (s.prev_length >= s.good_match) {\n chain_length >>= 2;\n }\n /* Do not look for matches beyond the end of the input. This is necessary\n * to make deflate deterministic.\n */\n if (nice_match > s.lookahead) { nice_match = s.lookahead; }\n\n // Assert((ulg)s->strstart <= s->window_size-MIN_LOOKAHEAD, \"need lookahead\");\n\n do {\n // Assert(cur_match < s->strstart, \"no future\");\n match = cur_match;\n\n /* Skip to next match if the match length cannot increase\n * or if the match length is less than 2. Note that the checks below\n * for insufficient lookahead only occur occasionally for performance\n * reasons. Therefore uninitialized memory will be accessed, and\n * conditional jumps will be made that depend on those values.\n * However the length of the match is limited to the lookahead, so\n * the output of deflate is not affected by the uninitialized values.\n */\n\n if (_win[match + best_len] !== scan_end ||\n _win[match + best_len - 1] !== scan_end1 ||\n _win[match] !== _win[scan] ||\n _win[++match] !== _win[scan + 1]) {\n continue;\n }\n\n /* The check at best_len-1 can be removed because it will be made\n * again later. (This heuristic is not always a win.)\n * It is not necessary to compare scan[2] and match[2] since they\n * are always equal when the other bytes match, given that\n * the hash keys are equal and that HASH_BITS >= 8.\n */\n scan += 2;\n match++;\n // Assert(*scan == *match, \"match[2]?\");\n\n /* We check for insufficient lookahead only every 8th comparison;\n * the 256th check will be made at strstart+258.\n */\n do {\n /*jshint noempty:false*/\n } while (_win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n _win[++scan] === _win[++match] && _win[++scan] === _win[++match] &&\n scan < strend);\n\n // Assert(scan <= s->window+(unsigned)(s->window_size-1), \"wild scan\");\n\n len = MAX_MATCH - (strend - scan);\n scan = strend - MAX_MATCH;\n\n if (len > best_len) {\n s.match_start = cur_match;\n best_len = len;\n if (len >= nice_match) {\n break;\n }\n scan_end1 = _win[scan + best_len - 1];\n scan_end = _win[scan + best_len];\n }\n } while ((cur_match = prev[cur_match & wmask]) > limit && --chain_length !== 0);\n\n if (best_len <= s.lookahead) {\n return best_len;\n }\n return s.lookahead;\n};\n\n\n/* ===========================================================================\n * Fill the window when the lookahead becomes insufficient.\n * Updates strstart and lookahead.\n *\n * IN assertion: lookahead < MIN_LOOKAHEAD\n * OUT assertions: strstart <= window_size-MIN_LOOKAHEAD\n * At least one byte has been read, or avail_in == 0; reads are\n * performed for at least two bytes (required for the zip translate_eol\n * option -- not supported here).\n */\nconst fill_window = (s) => {\n\n const _w_size = s.w_size;\n let n, more, str;\n\n //Assert(s->lookahead < MIN_LOOKAHEAD, \"already enough lookahead\");\n\n do {\n more = s.window_size - s.lookahead - s.strstart;\n\n // JS ints have 32 bit, block below not needed\n /* Deal with !@#$% 64K limit: */\n //if (sizeof(int) <= 2) {\n // if (more == 0 && s->strstart == 0 && s->lookahead == 0) {\n // more = wsize;\n //\n // } else if (more == (unsigned)(-1)) {\n // /* Very unlikely, but possible on 16 bit machine if\n // * strstart == 0 && lookahead == 1 (input done a byte at time)\n // */\n // more--;\n // }\n //}\n\n\n /* If the window is almost full and there is insufficient lookahead,\n * move the upper half to the lower one to make room in the upper half.\n */\n if (s.strstart >= _w_size + (_w_size - MIN_LOOKAHEAD)) {\n\n s.window.set(s.window.subarray(_w_size, _w_size + _w_size - more), 0);\n s.match_start -= _w_size;\n s.strstart -= _w_size;\n /* we now have strstart >= MAX_DIST */\n s.block_start -= _w_size;\n if (s.insert > s.strstart) {\n s.insert = s.strstart;\n }\n slide_hash(s);\n more += _w_size;\n }\n if (s.strm.avail_in === 0) {\n break;\n }\n\n /* If there was no sliding:\n * strstart <= WSIZE+MAX_DIST-1 && lookahead <= MIN_LOOKAHEAD - 1 &&\n * more == window_size - lookahead - strstart\n * => more >= window_size - (MIN_LOOKAHEAD-1 + WSIZE + MAX_DIST-1)\n * => more >= window_size - 2*WSIZE + 2\n * In the BIG_MEM or MMAP case (not yet supported),\n * window_size == input_size + MIN_LOOKAHEAD &&\n * strstart + s->lookahead <= input_size => more >= MIN_LOOKAHEAD.\n * Otherwise, window_size == 2*WSIZE so more >= 2.\n * If there was sliding, more >= WSIZE. So in all cases, more >= 2.\n */\n //Assert(more >= 2, \"more < 2\");\n n = read_buf(s.strm, s.window, s.strstart + s.lookahead, more);\n s.lookahead += n;\n\n /* Initialize the hash value now that we have some input: */\n if (s.lookahead + s.insert >= MIN_MATCH) {\n str = s.strstart - s.insert;\n s.ins_h = s.window[str];\n\n /* UPDATE_HASH(s, s->ins_h, s->window[str + 1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[str + 1]);\n//#if MIN_MATCH != 3\n// Call update_hash() MIN_MATCH-3 more times\n//#endif\n while (s.insert) {\n /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[str + MIN_MATCH - 1]);\n\n s.prev[str & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = str;\n str++;\n s.insert--;\n if (s.lookahead + s.insert < MIN_MATCH) {\n break;\n }\n }\n }\n /* If the whole input has less than MIN_MATCH bytes, ins_h is garbage,\n * but this is not important since only literal bytes will be emitted.\n */\n\n } while (s.lookahead < MIN_LOOKAHEAD && s.strm.avail_in !== 0);\n\n /* If the WIN_INIT bytes after the end of the current data have never been\n * written, then zero those bytes in order to avoid memory check reports of\n * the use of uninitialized (or uninitialised as Julian writes) bytes by\n * the longest match routines. Update the high water mark for the next\n * time through here. WIN_INIT is set to MAX_MATCH since the longest match\n * routines allow scanning to strstart + MAX_MATCH, ignoring lookahead.\n */\n// if (s.high_water < s.window_size) {\n// const curr = s.strstart + s.lookahead;\n// let init = 0;\n//\n// if (s.high_water < curr) {\n// /* Previous high water mark below current data -- zero WIN_INIT\n// * bytes or up to end of window, whichever is less.\n// */\n// init = s.window_size - curr;\n// if (init > WIN_INIT)\n// init = WIN_INIT;\n// zmemzero(s->window + curr, (unsigned)init);\n// s->high_water = curr + init;\n// }\n// else if (s->high_water < (ulg)curr + WIN_INIT) {\n// /* High water mark at or above current data, but below current data\n// * plus WIN_INIT -- zero out to current data plus WIN_INIT, or up\n// * to end of window, whichever is less.\n// */\n// init = (ulg)curr + WIN_INIT - s->high_water;\n// if (init > s->window_size - s->high_water)\n// init = s->window_size - s->high_water;\n// zmemzero(s->window + s->high_water, (unsigned)init);\n// s->high_water += init;\n// }\n// }\n//\n// Assert((ulg)s->strstart <= s->window_size - MIN_LOOKAHEAD,\n// \"not enough room for search\");\n};\n\n/* ===========================================================================\n * Copy without compression as much as possible from the input stream, return\n * the current block state.\n *\n * In case deflateParams() is used to later switch to a non-zero compression\n * level, s->matches (otherwise unused when storing) keeps track of the number\n * of hash table slides to perform. If s->matches is 1, then one hash table\n * slide will be done when switching. If s->matches is 2, the maximum value\n * allowed here, then the hash table will be cleared, since two or more slides\n * is the same as a clear.\n *\n * deflate_stored() is written to minimize the number of times an input byte is\n * copied. It is most efficient with large input and output buffers, which\n * maximizes the opportunites to have a single copy from next_in to next_out.\n */\nconst deflate_stored = (s, flush) => {\n\n /* Smallest worthy block size when not flushing or finishing. By default\n * this is 32K. This can be as small as 507 bytes for memLevel == 1. For\n * large input and output buffers, the stored block size will be larger.\n */\n let min_block = s.pending_buf_size - 5 > s.w_size ? s.w_size : s.pending_buf_size - 5;\n\n /* Copy as many min_block or larger stored blocks directly to next_out as\n * possible. If flushing, copy the remaining available input to next_out as\n * stored blocks, if there is enough space.\n */\n let len, left, have, last = 0;\n let used = s.strm.avail_in;\n do {\n /* Set len to the maximum size block that we can copy directly with the\n * available input data and output space. Set left to how much of that\n * would be copied from what's left in the window.\n */\n len = 65535/* MAX_STORED */; /* maximum deflate stored block length */\n have = (s.bi_valid + 42) >> 3; /* number of header bytes */\n if (s.strm.avail_out < have) { /* need room for header */\n break;\n }\n /* maximum stored block length that will fit in avail_out: */\n have = s.strm.avail_out - have;\n left = s.strstart - s.block_start; /* bytes left in window */\n if (len > left + s.strm.avail_in) {\n len = left + s.strm.avail_in; /* limit len to the input */\n }\n if (len > have) {\n len = have; /* limit len to the output */\n }\n\n /* If the stored block would be less than min_block in length, or if\n * unable to copy all of the available input when flushing, then try\n * copying to the window and the pending buffer instead. Also don't\n * write an empty block when flushing -- deflate() does that.\n */\n if (len < min_block && ((len === 0 && flush !== Z_FINISH$3) ||\n flush === Z_NO_FLUSH$2 ||\n len !== left + s.strm.avail_in)) {\n break;\n }\n\n /* Make a dummy stored block in pending to get the header bytes,\n * including any pending bits. This also updates the debugging counts.\n */\n last = flush === Z_FINISH$3 && len === left + s.strm.avail_in ? 1 : 0;\n _tr_stored_block(s, 0, 0, last);\n\n /* Replace the lengths in the dummy stored block with len. */\n s.pending_buf[s.pending - 4] = len;\n s.pending_buf[s.pending - 3] = len >> 8;\n s.pending_buf[s.pending - 2] = ~len;\n s.pending_buf[s.pending - 1] = ~len >> 8;\n\n /* Write the stored block header bytes. */\n flush_pending(s.strm);\n\n//#ifdef ZLIB_DEBUG\n// /* Update debugging counts for the data about to be copied. */\n// s->compressed_len += len << 3;\n// s->bits_sent += len << 3;\n//#endif\n\n /* Copy uncompressed bytes from the window to next_out. */\n if (left) {\n if (left > len) {\n left = len;\n }\n //zmemcpy(s->strm->next_out, s->window + s->block_start, left);\n s.strm.output.set(s.window.subarray(s.block_start, s.block_start + left), s.strm.next_out);\n s.strm.next_out += left;\n s.strm.avail_out -= left;\n s.strm.total_out += left;\n s.block_start += left;\n len -= left;\n }\n\n /* Copy uncompressed bytes directly from next_in to next_out, updating\n * the check value.\n */\n if (len) {\n read_buf(s.strm, s.strm.output, s.strm.next_out, len);\n s.strm.next_out += len;\n s.strm.avail_out -= len;\n s.strm.total_out += len;\n }\n } while (last === 0);\n\n /* Update the sliding window with the last s->w_size bytes of the copied\n * data, or append all of the copied data to the existing window if less\n * than s->w_size bytes were copied. Also update the number of bytes to\n * insert in the hash tables, in the event that deflateParams() switches to\n * a non-zero compression level.\n */\n used -= s.strm.avail_in; /* number of input bytes directly copied */\n if (used) {\n /* If any input was used, then no unused input remains in the window,\n * therefore s->block_start == s->strstart.\n */\n if (used >= s.w_size) { /* supplant the previous history */\n s.matches = 2; /* clear hash */\n //zmemcpy(s->window, s->strm->next_in - s->w_size, s->w_size);\n s.window.set(s.strm.input.subarray(s.strm.next_in - s.w_size, s.strm.next_in), 0);\n s.strstart = s.w_size;\n s.insert = s.strstart;\n }\n else {\n if (s.window_size - s.strstart <= used) {\n /* Slide the window down. */\n s.strstart -= s.w_size;\n //zmemcpy(s->window, s->window + s->w_size, s->strstart);\n s.window.set(s.window.subarray(s.w_size, s.w_size + s.strstart), 0);\n if (s.matches < 2) {\n s.matches++; /* add a pending slide_hash() */\n }\n if (s.insert > s.strstart) {\n s.insert = s.strstart;\n }\n }\n //zmemcpy(s->window + s->strstart, s->strm->next_in - used, used);\n s.window.set(s.strm.input.subarray(s.strm.next_in - used, s.strm.next_in), s.strstart);\n s.strstart += used;\n s.insert += used > s.w_size - s.insert ? s.w_size - s.insert : used;\n }\n s.block_start = s.strstart;\n }\n if (s.high_water < s.strstart) {\n s.high_water = s.strstart;\n }\n\n /* If the last block was written to next_out, then done. */\n if (last) {\n return BS_FINISH_DONE;\n }\n\n /* If flushing and all input has been consumed, then done. */\n if (flush !== Z_NO_FLUSH$2 && flush !== Z_FINISH$3 &&\n s.strm.avail_in === 0 && s.strstart === s.block_start) {\n return BS_BLOCK_DONE;\n }\n\n /* Fill the window with any remaining input. */\n have = s.window_size - s.strstart;\n if (s.strm.avail_in > have && s.block_start >= s.w_size) {\n /* Slide the window down. */\n s.block_start -= s.w_size;\n s.strstart -= s.w_size;\n //zmemcpy(s->window, s->window + s->w_size, s->strstart);\n s.window.set(s.window.subarray(s.w_size, s.w_size + s.strstart), 0);\n if (s.matches < 2) {\n s.matches++; /* add a pending slide_hash() */\n }\n have += s.w_size; /* more space now */\n if (s.insert > s.strstart) {\n s.insert = s.strstart;\n }\n }\n if (have > s.strm.avail_in) {\n have = s.strm.avail_in;\n }\n if (have) {\n read_buf(s.strm, s.window, s.strstart, have);\n s.strstart += have;\n s.insert += have > s.w_size - s.insert ? s.w_size - s.insert : have;\n }\n if (s.high_water < s.strstart) {\n s.high_water = s.strstart;\n }\n\n /* There was not enough avail_out to write a complete worthy or flushed\n * stored block to next_out. Write a stored block to pending instead, if we\n * have enough input for a worthy block, or if flushing and there is enough\n * room for the remaining input as a stored block in the pending buffer.\n */\n have = (s.bi_valid + 42) >> 3; /* number of header bytes */\n /* maximum stored block length that will fit in pending: */\n have = s.pending_buf_size - have > 65535/* MAX_STORED */ ? 65535/* MAX_STORED */ : s.pending_buf_size - have;\n min_block = have > s.w_size ? s.w_size : have;\n left = s.strstart - s.block_start;\n if (left >= min_block ||\n ((left || flush === Z_FINISH$3) && flush !== Z_NO_FLUSH$2 &&\n s.strm.avail_in === 0 && left <= have)) {\n len = left > have ? have : left;\n last = flush === Z_FINISH$3 && s.strm.avail_in === 0 &&\n len === left ? 1 : 0;\n _tr_stored_block(s, s.block_start, len, last);\n s.block_start += len;\n flush_pending(s.strm);\n }\n\n /* We've done all we can with the available input and output. */\n return last ? BS_FINISH_STARTED : BS_NEED_MORE;\n};\n\n\n/* ===========================================================================\n * Compress as much as possible from the input stream, return the current\n * block state.\n * This function does not perform lazy evaluation of matches and inserts\n * new strings in the dictionary only for unmatched strings or for short\n * matches. It is used only for the fast compression options.\n */\nconst deflate_fast = (s, flush) => {\n\n let hash_head; /* head of the hash chain */\n let bflush; /* set if current block must be flushed */\n\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the next match, plus MIN_MATCH bytes to insert the\n * string following the next match.\n */\n if (s.lookahead < MIN_LOOKAHEAD) {\n fill_window(s);\n if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH$2) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) {\n break; /* flush the current block */\n }\n }\n\n /* Insert the string window[strstart .. strstart+2] in the\n * dictionary, and set hash_head to the head of the hash chain:\n */\n hash_head = 0/*NIL*/;\n if (s.lookahead >= MIN_MATCH) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n\n /* Find the longest match, discarding those <= prev_length.\n * At this point we have always match_length < MIN_MATCH\n */\n if (hash_head !== 0/*NIL*/ && ((s.strstart - hash_head) <= (s.w_size - MIN_LOOKAHEAD))) {\n /* To simplify the code, we prevent matches with the string\n * of window index 0 (in particular we have to avoid a match\n * of the string with itself at the start of the input file).\n */\n s.match_length = longest_match(s, hash_head);\n /* longest_match() sets match_start */\n }\n if (s.match_length >= MIN_MATCH) {\n // check_match(s, s.strstart, s.match_start, s.match_length); // for debug only\n\n /*** _tr_tally_dist(s, s.strstart - s.match_start,\n s.match_length - MIN_MATCH, bflush); ***/\n bflush = _tr_tally(s, s.strstart - s.match_start, s.match_length - MIN_MATCH);\n\n s.lookahead -= s.match_length;\n\n /* Insert new strings in the hash table only if the match length\n * is not too large. This saves time but degrades compression.\n */\n if (s.match_length <= s.max_lazy_match/*max_insert_length*/ && s.lookahead >= MIN_MATCH) {\n s.match_length--; /* string at strstart already in table */\n do {\n s.strstart++;\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n /* strstart never exceeds WSIZE-MAX_MATCH, so there are\n * always MIN_MATCH bytes ahead.\n */\n } while (--s.match_length !== 0);\n s.strstart++;\n } else\n {\n s.strstart += s.match_length;\n s.match_length = 0;\n s.ins_h = s.window[s.strstart];\n /* UPDATE_HASH(s, s.ins_h, s.window[s.strstart+1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + 1]);\n\n//#if MIN_MATCH != 3\n// Call UPDATE_HASH() MIN_MATCH-3 more times\n//#endif\n /* If lookahead < MIN_MATCH, ins_h is garbage, but it does not\n * matter since it will be recomputed at next deflate call.\n */\n }\n } else {\n /* No match, output a literal byte */\n //Tracevv((stderr,\"%c\", s.window[s.strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart]);\n\n s.lookahead--;\n s.strstart++;\n }\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = ((s.strstart < (MIN_MATCH - 1)) ? s.strstart : MIN_MATCH - 1);\n if (flush === Z_FINISH$3) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.sym_next) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n};\n\n/* ===========================================================================\n * Same as above, but achieves better compression. We use a lazy\n * evaluation for matches: a match is finally adopted only if there is\n * no better match at the next window position.\n */\nconst deflate_slow = (s, flush) => {\n\n let hash_head; /* head of hash chain */\n let bflush; /* set if current block must be flushed */\n\n let max_insert;\n\n /* Process the input block. */\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the next match, plus MIN_MATCH bytes to insert the\n * string following the next match.\n */\n if (s.lookahead < MIN_LOOKAHEAD) {\n fill_window(s);\n if (s.lookahead < MIN_LOOKAHEAD && flush === Z_NO_FLUSH$2) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) { break; } /* flush the current block */\n }\n\n /* Insert the string window[strstart .. strstart+2] in the\n * dictionary, and set hash_head to the head of the hash chain:\n */\n hash_head = 0/*NIL*/;\n if (s.lookahead >= MIN_MATCH) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n\n /* Find the longest match, discarding those <= prev_length.\n */\n s.prev_length = s.match_length;\n s.prev_match = s.match_start;\n s.match_length = MIN_MATCH - 1;\n\n if (hash_head !== 0/*NIL*/ && s.prev_length < s.max_lazy_match &&\n s.strstart - hash_head <= (s.w_size - MIN_LOOKAHEAD)/*MAX_DIST(s)*/) {\n /* To simplify the code, we prevent matches with the string\n * of window index 0 (in particular we have to avoid a match\n * of the string with itself at the start of the input file).\n */\n s.match_length = longest_match(s, hash_head);\n /* longest_match() sets match_start */\n\n if (s.match_length <= 5 &&\n (s.strategy === Z_FILTERED || (s.match_length === MIN_MATCH && s.strstart - s.match_start > 4096/*TOO_FAR*/))) {\n\n /* If prev_match is also MIN_MATCH, match_start is garbage\n * but we will ignore the current match anyway.\n */\n s.match_length = MIN_MATCH - 1;\n }\n }\n /* If there was a match at the previous step and the current\n * match is not better, output the previous match:\n */\n if (s.prev_length >= MIN_MATCH && s.match_length <= s.prev_length) {\n max_insert = s.strstart + s.lookahead - MIN_MATCH;\n /* Do not insert strings in hash table beyond this. */\n\n //check_match(s, s.strstart-1, s.prev_match, s.prev_length);\n\n /***_tr_tally_dist(s, s.strstart - 1 - s.prev_match,\n s.prev_length - MIN_MATCH, bflush);***/\n bflush = _tr_tally(s, s.strstart - 1 - s.prev_match, s.prev_length - MIN_MATCH);\n /* Insert in hash table all strings up to the end of the match.\n * strstart-1 and strstart are already inserted. If there is not\n * enough lookahead, the last two strings are not inserted in\n * the hash table.\n */\n s.lookahead -= s.prev_length - 1;\n s.prev_length -= 2;\n do {\n if (++s.strstart <= max_insert) {\n /*** INSERT_STRING(s, s.strstart, hash_head); ***/\n s.ins_h = HASH(s, s.ins_h, s.window[s.strstart + MIN_MATCH - 1]);\n hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h];\n s.head[s.ins_h] = s.strstart;\n /***/\n }\n } while (--s.prev_length !== 0);\n s.match_available = 0;\n s.match_length = MIN_MATCH - 1;\n s.strstart++;\n\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n } else if (s.match_available) {\n /* If there was no match at the previous position, output a\n * single literal. If there was a match but the current match\n * is longer, truncate the previous match to a single literal.\n */\n //Tracevv((stderr,\"%c\", s->window[s->strstart-1]));\n /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart - 1]);\n\n if (bflush) {\n /*** FLUSH_BLOCK_ONLY(s, 0) ***/\n flush_block_only(s, false);\n /***/\n }\n s.strstart++;\n s.lookahead--;\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n } else {\n /* There is no previous match to compare with, wait for\n * the next step to decide.\n */\n s.match_available = 1;\n s.strstart++;\n s.lookahead--;\n }\n }\n //Assert (flush != Z_NO_FLUSH, \"no flush?\");\n if (s.match_available) {\n //Tracevv((stderr,\"%c\", s->window[s->strstart-1]));\n /*** _tr_tally_lit(s, s.window[s.strstart-1], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart - 1]);\n\n s.match_available = 0;\n }\n s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1;\n if (flush === Z_FINISH$3) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.sym_next) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n\n return BS_BLOCK_DONE;\n};\n\n\n/* ===========================================================================\n * For Z_RLE, simply look for runs of bytes, generate matches only of distance\n * one. Do not maintain a hash table. (It will be regenerated if this run of\n * deflate switches away from Z_RLE.)\n */\nconst deflate_rle = (s, flush) => {\n\n let bflush; /* set if current block must be flushed */\n let prev; /* byte at distance one to match */\n let scan, strend; /* scan goes up to strend for length of run */\n\n const _win = s.window;\n\n for (;;) {\n /* Make sure that we always have enough lookahead, except\n * at the end of the input file. We need MAX_MATCH bytes\n * for the longest run, plus one for the unrolled loop.\n */\n if (s.lookahead <= MAX_MATCH) {\n fill_window(s);\n if (s.lookahead <= MAX_MATCH && flush === Z_NO_FLUSH$2) {\n return BS_NEED_MORE;\n }\n if (s.lookahead === 0) { break; } /* flush the current block */\n }\n\n /* See how many times the previous byte repeats */\n s.match_length = 0;\n if (s.lookahead >= MIN_MATCH && s.strstart > 0) {\n scan = s.strstart - 1;\n prev = _win[scan];\n if (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan]) {\n strend = s.strstart + MAX_MATCH;\n do {\n /*jshint noempty:false*/\n } while (prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n prev === _win[++scan] && prev === _win[++scan] &&\n scan < strend);\n s.match_length = MAX_MATCH - (strend - scan);\n if (s.match_length > s.lookahead) {\n s.match_length = s.lookahead;\n }\n }\n //Assert(scan <= s->window+(uInt)(s->window_size-1), \"wild scan\");\n }\n\n /* Emit match if have run of MIN_MATCH or longer, else emit literal */\n if (s.match_length >= MIN_MATCH) {\n //check_match(s, s.strstart, s.strstart - 1, s.match_length);\n\n /*** _tr_tally_dist(s, 1, s.match_length - MIN_MATCH, bflush); ***/\n bflush = _tr_tally(s, 1, s.match_length - MIN_MATCH);\n\n s.lookahead -= s.match_length;\n s.strstart += s.match_length;\n s.match_length = 0;\n } else {\n /* No match, output a literal byte */\n //Tracevv((stderr,\"%c\", s->window[s->strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart]);\n\n s.lookahead--;\n s.strstart++;\n }\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = 0;\n if (flush === Z_FINISH$3) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.sym_next) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n};\n\n/* ===========================================================================\n * For Z_HUFFMAN_ONLY, do not look for matches. Do not maintain a hash table.\n * (It will be regenerated if this run of deflate switches away from Huffman.)\n */\nconst deflate_huff = (s, flush) => {\n\n let bflush; /* set if current block must be flushed */\n\n for (;;) {\n /* Make sure that we have a literal to write. */\n if (s.lookahead === 0) {\n fill_window(s);\n if (s.lookahead === 0) {\n if (flush === Z_NO_FLUSH$2) {\n return BS_NEED_MORE;\n }\n break; /* flush the current block */\n }\n }\n\n /* Output a literal byte */\n s.match_length = 0;\n //Tracevv((stderr,\"%c\", s->window[s->strstart]));\n /*** _tr_tally_lit(s, s.window[s.strstart], bflush); ***/\n bflush = _tr_tally(s, 0, s.window[s.strstart]);\n s.lookahead--;\n s.strstart++;\n if (bflush) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n }\n s.insert = 0;\n if (flush === Z_FINISH$3) {\n /*** FLUSH_BLOCK(s, 1); ***/\n flush_block_only(s, true);\n if (s.strm.avail_out === 0) {\n return BS_FINISH_STARTED;\n }\n /***/\n return BS_FINISH_DONE;\n }\n if (s.sym_next) {\n /*** FLUSH_BLOCK(s, 0); ***/\n flush_block_only(s, false);\n if (s.strm.avail_out === 0) {\n return BS_NEED_MORE;\n }\n /***/\n }\n return BS_BLOCK_DONE;\n};\n\n/* Values for max_lazy_match, good_match and max_chain_length, depending on\n * the desired pack level (0..9). The values given below have been tuned to\n * exclude worst case performance for pathological files. Better values may be\n * found for specific files.\n */\nfunction Config(good_length, max_lazy, nice_length, max_chain, func) {\n\n this.good_length = good_length;\n this.max_lazy = max_lazy;\n this.nice_length = nice_length;\n this.max_chain = max_chain;\n this.func = func;\n}\n\nconst configuration_table = [\n /* good lazy nice chain */\n new Config(0, 0, 0, 0, deflate_stored), /* 0 store only */\n new Config(4, 4, 8, 4, deflate_fast), /* 1 max speed, no lazy matches */\n new Config(4, 5, 16, 8, deflate_fast), /* 2 */\n new Config(4, 6, 32, 32, deflate_fast), /* 3 */\n\n new Config(4, 4, 16, 16, deflate_slow), /* 4 lazy matches */\n new Config(8, 16, 32, 32, deflate_slow), /* 5 */\n new Config(8, 16, 128, 128, deflate_slow), /* 6 */\n new Config(8, 32, 128, 256, deflate_slow), /* 7 */\n new Config(32, 128, 258, 1024, deflate_slow), /* 8 */\n new Config(32, 258, 258, 4096, deflate_slow) /* 9 max compression */\n];\n\n\n/* ===========================================================================\n * Initialize the \"longest match\" routines for a new zlib stream\n */\nconst lm_init = (s) => {\n\n s.window_size = 2 * s.w_size;\n\n /*** CLEAR_HASH(s); ***/\n zero(s.head); // Fill with NIL (= 0);\n\n /* Set the default configuration parameters:\n */\n s.max_lazy_match = configuration_table[s.level].max_lazy;\n s.good_match = configuration_table[s.level].good_length;\n s.nice_match = configuration_table[s.level].nice_length;\n s.max_chain_length = configuration_table[s.level].max_chain;\n\n s.strstart = 0;\n s.block_start = 0;\n s.lookahead = 0;\n s.insert = 0;\n s.match_length = s.prev_length = MIN_MATCH - 1;\n s.match_available = 0;\n s.ins_h = 0;\n};\n\n\nfunction DeflateState() {\n this.strm = null; /* pointer back to this zlib stream */\n this.status = 0; /* as the name implies */\n this.pending_buf = null; /* output still pending */\n this.pending_buf_size = 0; /* size of pending_buf */\n this.pending_out = 0; /* next pending byte to output to the stream */\n this.pending = 0; /* nb of bytes in the pending buffer */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n this.gzhead = null; /* gzip header information to write */\n this.gzindex = 0; /* where in extra, name, or comment */\n this.method = Z_DEFLATED$2; /* can only be DEFLATED */\n this.last_flush = -1; /* value of flush param for previous deflate call */\n\n this.w_size = 0; /* LZ77 window size (32K by default) */\n this.w_bits = 0; /* log2(w_size) (8..16) */\n this.w_mask = 0; /* w_size - 1 */\n\n this.window = null;\n /* Sliding window. Input bytes are read into the second half of the window,\n * and move to the first half later to keep a dictionary of at least wSize\n * bytes. With this organization, matches are limited to a distance of\n * wSize-MAX_MATCH bytes, but this ensures that IO is always\n * performed with a length multiple of the block size.\n */\n\n this.window_size = 0;\n /* Actual size of window: 2*wSize, except when the user input buffer\n * is directly used as sliding window.\n */\n\n this.prev = null;\n /* Link to older string with same hash index. To limit the size of this\n * array to 64K, this link is maintained only for the last 32K strings.\n * An index in this array is thus a window index modulo 32K.\n */\n\n this.head = null; /* Heads of the hash chains or NIL. */\n\n this.ins_h = 0; /* hash index of string to be inserted */\n this.hash_size = 0; /* number of elements in hash table */\n this.hash_bits = 0; /* log2(hash_size) */\n this.hash_mask = 0; /* hash_size-1 */\n\n this.hash_shift = 0;\n /* Number of bits by which ins_h must be shifted at each input\n * step. It must be such that after MIN_MATCH steps, the oldest\n * byte no longer takes part in the hash key, that is:\n * hash_shift * MIN_MATCH >= hash_bits\n */\n\n this.block_start = 0;\n /* Window position at the beginning of the current output block. Gets\n * negative when the window is moved backwards.\n */\n\n this.match_length = 0; /* length of best match */\n this.prev_match = 0; /* previous match */\n this.match_available = 0; /* set if previous match exists */\n this.strstart = 0; /* start of string to insert */\n this.match_start = 0; /* start of matching string */\n this.lookahead = 0; /* number of valid bytes ahead in window */\n\n this.prev_length = 0;\n /* Length of the best match at previous step. Matches not greater than this\n * are discarded. This is used in the lazy match evaluation.\n */\n\n this.max_chain_length = 0;\n /* To speed up deflation, hash chains are never searched beyond this\n * length. A higher limit improves compression ratio but degrades the\n * speed.\n */\n\n this.max_lazy_match = 0;\n /* Attempt to find a better match only when the current match is strictly\n * smaller than this value. This mechanism is used only for compression\n * levels >= 4.\n */\n // That's alias to max_lazy_match, don't use directly\n //this.max_insert_length = 0;\n /* Insert new strings in the hash table only if the match length is not\n * greater than this length. This saves time but degrades compression.\n * max_insert_length is used only for compression levels <= 3.\n */\n\n this.level = 0; /* compression level (1..9) */\n this.strategy = 0; /* favor or force Huffman coding*/\n\n this.good_match = 0;\n /* Use a faster search when the previous match is longer than this */\n\n this.nice_match = 0; /* Stop searching when current match exceeds this */\n\n /* used by trees.c: */\n\n /* Didn't use ct_data typedef below to suppress compiler warning */\n\n // struct ct_data_s dyn_ltree[HEAP_SIZE]; /* literal and length tree */\n // struct ct_data_s dyn_dtree[2*D_CODES+1]; /* distance tree */\n // struct ct_data_s bl_tree[2*BL_CODES+1]; /* Huffman tree for bit lengths */\n\n // Use flat array of DOUBLE size, with interleaved fata,\n // because JS does not support effective\n this.dyn_ltree = new Uint16Array(HEAP_SIZE * 2);\n this.dyn_dtree = new Uint16Array((2 * D_CODES + 1) * 2);\n this.bl_tree = new Uint16Array((2 * BL_CODES + 1) * 2);\n zero(this.dyn_ltree);\n zero(this.dyn_dtree);\n zero(this.bl_tree);\n\n this.l_desc = null; /* desc. for literal tree */\n this.d_desc = null; /* desc. for distance tree */\n this.bl_desc = null; /* desc. for bit length tree */\n\n //ush bl_count[MAX_BITS+1];\n this.bl_count = new Uint16Array(MAX_BITS + 1);\n /* number of codes at each bit length for an optimal tree */\n\n //int heap[2*L_CODES+1]; /* heap used to build the Huffman trees */\n this.heap = new Uint16Array(2 * L_CODES + 1); /* heap used to build the Huffman trees */\n zero(this.heap);\n\n this.heap_len = 0; /* number of elements in the heap */\n this.heap_max = 0; /* element of largest frequency */\n /* The sons of heap[n] are heap[2*n] and heap[2*n+1]. heap[0] is not used.\n * The same heap array is used to build all trees.\n */\n\n this.depth = new Uint16Array(2 * L_CODES + 1); //uch depth[2*L_CODES+1];\n zero(this.depth);\n /* Depth of each subtree used as tie breaker for trees of equal frequency\n */\n\n this.sym_buf = 0; /* buffer for distances and literals/lengths */\n\n this.lit_bufsize = 0;\n /* Size of match buffer for literals/lengths. There are 4 reasons for\n * limiting lit_bufsize to 64K:\n * - frequencies can be kept in 16 bit counters\n * - if compression is not successful for the first block, all input\n * data is still in the window so we can still emit a stored block even\n * when input comes from standard input. (This can also be done for\n * all blocks if lit_bufsize is not greater than 32K.)\n * - if compression is not successful for a file smaller than 64K, we can\n * even emit a stored file instead of a stored block (saving 5 bytes).\n * This is applicable only for zip (not gzip or zlib).\n * - creating new Huffman trees less frequently may not provide fast\n * adaptation to changes in the input data statistics. (Take for\n * example a binary file with poorly compressible code followed by\n * a highly compressible string table.) Smaller buffer sizes give\n * fast adaptation but have of course the overhead of transmitting\n * trees more frequently.\n * - I can't count above 4\n */\n\n this.sym_next = 0; /* running index in sym_buf */\n this.sym_end = 0; /* symbol table full when sym_next reaches this */\n\n this.opt_len = 0; /* bit length of current block with optimal trees */\n this.static_len = 0; /* bit length of current block with static trees */\n this.matches = 0; /* number of string matches in current block */\n this.insert = 0; /* bytes at end of window left to insert */\n\n\n this.bi_buf = 0;\n /* Output buffer. bits are inserted starting at the bottom (least\n * significant bits).\n */\n this.bi_valid = 0;\n /* Number of valid bits in bi_buf. All bits above the last valid bit\n * are always zero.\n */\n\n // Used for window memory init. We safely ignore it for JS. That makes\n // sense only for pointers and memory check tools.\n //this.high_water = 0;\n /* High water mark offset in window for initialized bytes -- bytes above\n * this are set to zero in order to avoid memory check warnings when\n * longest match routines access bytes past the input. This is then\n * updated to the new high water mark.\n */\n}\n\n\n/* =========================================================================\n * Check for a valid deflate stream state. Return 0 if ok, 1 if not.\n */\nconst deflateStateCheck = (strm) => {\n\n if (!strm) {\n return 1;\n }\n const s = strm.state;\n if (!s || s.strm !== strm || (s.status !== INIT_STATE &&\n//#ifdef GZIP\n s.status !== GZIP_STATE &&\n//#endif\n s.status !== EXTRA_STATE &&\n s.status !== NAME_STATE &&\n s.status !== COMMENT_STATE &&\n s.status !== HCRC_STATE &&\n s.status !== BUSY_STATE &&\n s.status !== FINISH_STATE)) {\n return 1;\n }\n return 0;\n};\n\n\nconst deflateResetKeep = (strm) => {\n\n if (deflateStateCheck(strm)) {\n return err(strm, Z_STREAM_ERROR$2);\n }\n\n strm.total_in = strm.total_out = 0;\n strm.data_type = Z_UNKNOWN;\n\n const s = strm.state;\n s.pending = 0;\n s.pending_out = 0;\n\n if (s.wrap < 0) {\n s.wrap = -s.wrap;\n /* was made negative by deflate(..., Z_FINISH); */\n }\n s.status =\n//#ifdef GZIP\n s.wrap === 2 ? GZIP_STATE :\n//#endif\n s.wrap ? INIT_STATE : BUSY_STATE;\n strm.adler = (s.wrap === 2) ?\n 0 // crc32(0, Z_NULL, 0)\n :\n 1; // adler32(0, Z_NULL, 0)\n s.last_flush = -2;\n _tr_init(s);\n return Z_OK$3;\n};\n\n\nconst deflateReset = (strm) => {\n\n const ret = deflateResetKeep(strm);\n if (ret === Z_OK$3) {\n lm_init(strm.state);\n }\n return ret;\n};\n\n\nconst deflateSetHeader = (strm, head) => {\n\n if (deflateStateCheck(strm) || strm.state.wrap !== 2) {\n return Z_STREAM_ERROR$2;\n }\n strm.state.gzhead = head;\n return Z_OK$3;\n};\n\n\nconst deflateInit2 = (strm, level, method, windowBits, memLevel, strategy) => {\n\n if (!strm) { // === Z_NULL\n return Z_STREAM_ERROR$2;\n }\n let wrap = 1;\n\n if (level === Z_DEFAULT_COMPRESSION$1) {\n level = 6;\n }\n\n if (windowBits < 0) { /* suppress zlib wrapper */\n wrap = 0;\n windowBits = -windowBits;\n }\n\n else if (windowBits > 15) {\n wrap = 2; /* write gzip wrapper instead */\n windowBits -= 16;\n }\n\n\n if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method !== Z_DEFLATED$2 ||\n windowBits < 8 || windowBits > 15 || level < 0 || level > 9 ||\n strategy < 0 || strategy > Z_FIXED || (windowBits === 8 && wrap !== 1)) {\n return err(strm, Z_STREAM_ERROR$2);\n }\n\n\n if (windowBits === 8) {\n windowBits = 9;\n }\n /* until 256-byte window bug fixed */\n\n const s = new DeflateState();\n\n strm.state = s;\n s.strm = strm;\n s.status = INIT_STATE; /* to pass state test in deflateReset() */\n\n s.wrap = wrap;\n s.gzhead = null;\n s.w_bits = windowBits;\n s.w_size = 1 << s.w_bits;\n s.w_mask = s.w_size - 1;\n\n s.hash_bits = memLevel + 7;\n s.hash_size = 1 << s.hash_bits;\n s.hash_mask = s.hash_size - 1;\n s.hash_shift = ~~((s.hash_bits + MIN_MATCH - 1) / MIN_MATCH);\n\n s.window = new Uint8Array(s.w_size * 2);\n s.head = new Uint16Array(s.hash_size);\n s.prev = new Uint16Array(s.w_size);\n\n // Don't need mem init magic for JS.\n //s.high_water = 0; /* nothing written to s->window yet */\n\n s.lit_bufsize = 1 << (memLevel + 6); /* 16K elements by default */\n\n /* We overlay pending_buf and sym_buf. This works since the average size\n * for length/distance pairs over any compressed block is assured to be 31\n * bits or less.\n *\n * Analysis: The longest fixed codes are a length code of 8 bits plus 5\n * extra bits, for lengths 131 to 257. The longest fixed distance codes are\n * 5 bits plus 13 extra bits, for distances 16385 to 32768. The longest\n * possible fixed-codes length/distance pair is then 31 bits total.\n *\n * sym_buf starts one-fourth of the way into pending_buf. So there are\n * three bytes in sym_buf for every four bytes in pending_buf. Each symbol\n * in sym_buf is three bytes -- two for the distance and one for the\n * literal/length. As each symbol is consumed, the pointer to the next\n * sym_buf value to read moves forward three bytes. From that symbol, up to\n * 31 bits are written to pending_buf. The closest the written pending_buf\n * bits gets to the next sym_buf symbol to read is just before the last\n * code is written. At that time, 31*(n-2) bits have been written, just\n * after 24*(n-2) bits have been consumed from sym_buf. sym_buf starts at\n * 8*n bits into pending_buf. (Note that the symbol buffer fills when n-1\n * symbols are written.) The closest the writing gets to what is unread is\n * then n+14 bits. Here n is lit_bufsize, which is 16384 by default, and\n * can range from 128 to 32768.\n *\n * Therefore, at a minimum, there are 142 bits of space between what is\n * written and what is read in the overlain buffers, so the symbols cannot\n * be overwritten by the compressed data. That space is actually 139 bits,\n * due to the three-bit fixed-code block header.\n *\n * That covers the case where either Z_FIXED is specified, forcing fixed\n * codes, or when the use of fixed codes is chosen, because that choice\n * results in a smaller compressed block than dynamic codes. That latter\n * condition then assures that the above analysis also covers all dynamic\n * blocks. A dynamic-code block will only be chosen to be emitted if it has\n * fewer bits than a fixed-code block would for the same set of symbols.\n * Therefore its average symbol length is assured to be less than 31. So\n * the compressed data for a dynamic block also cannot overwrite the\n * symbols from which it is being constructed.\n */\n\n s.pending_buf_size = s.lit_bufsize * 4;\n s.pending_buf = new Uint8Array(s.pending_buf_size);\n\n // It is offset from `s.pending_buf` (size is `s.lit_bufsize * 2`)\n //s->sym_buf = s->pending_buf + s->lit_bufsize;\n s.sym_buf = s.lit_bufsize;\n\n //s->sym_end = (s->lit_bufsize - 1) * 3;\n s.sym_end = (s.lit_bufsize - 1) * 3;\n /* We avoid equality with lit_bufsize*3 because of wraparound at 64K\n * on 16 bit machines and because stored blocks are restricted to\n * 64K-1 bytes.\n */\n\n s.level = level;\n s.strategy = strategy;\n s.method = method;\n\n return deflateReset(strm);\n};\n\nconst deflateInit = (strm, level) => {\n\n return deflateInit2(strm, level, Z_DEFLATED$2, MAX_WBITS$1, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY$1);\n};\n\n\n/* ========================================================================= */\nconst deflate$2 = (strm, flush) => {\n\n if (deflateStateCheck(strm) || flush > Z_BLOCK$1 || flush < 0) {\n return strm ? err(strm, Z_STREAM_ERROR$2) : Z_STREAM_ERROR$2;\n }\n\n const s = strm.state;\n\n if (!strm.output ||\n (strm.avail_in !== 0 && !strm.input) ||\n (s.status === FINISH_STATE && flush !== Z_FINISH$3)) {\n return err(strm, (strm.avail_out === 0) ? Z_BUF_ERROR$1 : Z_STREAM_ERROR$2);\n }\n\n const old_flush = s.last_flush;\n s.last_flush = flush;\n\n /* Flush as much pending output as possible */\n if (s.pending !== 0) {\n flush_pending(strm);\n if (strm.avail_out === 0) {\n /* Since avail_out is 0, deflate will be called again with\n * more output space, but possibly with both pending and\n * avail_in equal to zero. There won't be anything to do,\n * but this is not an error situation so make sure we\n * return OK instead of BUF_ERROR at next call of deflate:\n */\n s.last_flush = -1;\n return Z_OK$3;\n }\n\n /* Make sure there is something to do and avoid duplicate consecutive\n * flushes. For repeated and useless calls with Z_FINISH, we keep\n * returning Z_STREAM_END instead of Z_BUF_ERROR.\n */\n } else if (strm.avail_in === 0 && rank(flush) <= rank(old_flush) &&\n flush !== Z_FINISH$3) {\n return err(strm, Z_BUF_ERROR$1);\n }\n\n /* User must not provide more input after the first FINISH: */\n if (s.status === FINISH_STATE && strm.avail_in !== 0) {\n return err(strm, Z_BUF_ERROR$1);\n }\n\n /* Write the header */\n if (s.status === INIT_STATE && s.wrap === 0) {\n s.status = BUSY_STATE;\n }\n if (s.status === INIT_STATE) {\n /* zlib header */\n let header = (Z_DEFLATED$2 + ((s.w_bits - 8) << 4)) << 8;\n let level_flags = -1;\n\n if (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2) {\n level_flags = 0;\n } else if (s.level < 6) {\n level_flags = 1;\n } else if (s.level === 6) {\n level_flags = 2;\n } else {\n level_flags = 3;\n }\n header |= (level_flags << 6);\n if (s.strstart !== 0) { header |= PRESET_DICT; }\n header += 31 - (header % 31);\n\n putShortMSB(s, header);\n\n /* Save the adler32 of the preset dictionary: */\n if (s.strstart !== 0) {\n putShortMSB(s, strm.adler >>> 16);\n putShortMSB(s, strm.adler & 0xffff);\n }\n strm.adler = 1; // adler32(0L, Z_NULL, 0);\n s.status = BUSY_STATE;\n\n /* Compression must start with an empty pending buffer */\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK$3;\n }\n }\n//#ifdef GZIP\n if (s.status === GZIP_STATE) {\n /* gzip header */\n strm.adler = 0; //crc32(0L, Z_NULL, 0);\n put_byte(s, 31);\n put_byte(s, 139);\n put_byte(s, 8);\n if (!s.gzhead) { // s->gzhead == Z_NULL\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, 0);\n put_byte(s, s.level === 9 ? 2 :\n (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?\n 4 : 0));\n put_byte(s, OS_CODE);\n s.status = BUSY_STATE;\n\n /* Compression must start with an empty pending buffer */\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK$3;\n }\n }\n else {\n put_byte(s, (s.gzhead.text ? 1 : 0) +\n (s.gzhead.hcrc ? 2 : 0) +\n (!s.gzhead.extra ? 0 : 4) +\n (!s.gzhead.name ? 0 : 8) +\n (!s.gzhead.comment ? 0 : 16)\n );\n put_byte(s, s.gzhead.time & 0xff);\n put_byte(s, (s.gzhead.time >> 8) & 0xff);\n put_byte(s, (s.gzhead.time >> 16) & 0xff);\n put_byte(s, (s.gzhead.time >> 24) & 0xff);\n put_byte(s, s.level === 9 ? 2 :\n (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ?\n 4 : 0));\n put_byte(s, s.gzhead.os & 0xff);\n if (s.gzhead.extra && s.gzhead.extra.length) {\n put_byte(s, s.gzhead.extra.length & 0xff);\n put_byte(s, (s.gzhead.extra.length >> 8) & 0xff);\n }\n if (s.gzhead.hcrc) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending, 0);\n }\n s.gzindex = 0;\n s.status = EXTRA_STATE;\n }\n }\n if (s.status === EXTRA_STATE) {\n if (s.gzhead.extra/* != Z_NULL*/) {\n let beg = s.pending; /* start of bytes to update crc */\n let left = (s.gzhead.extra.length & 0xffff) - s.gzindex;\n while (s.pending + left > s.pending_buf_size) {\n let copy = s.pending_buf_size - s.pending;\n // zmemcpy(s.pending_buf + s.pending,\n // s.gzhead.extra + s.gzindex, copy);\n s.pending_buf.set(s.gzhead.extra.subarray(s.gzindex, s.gzindex + copy), s.pending);\n s.pending = s.pending_buf_size;\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n s.gzindex += copy;\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK$3;\n }\n beg = 0;\n left -= copy;\n }\n // JS specific: s.gzhead.extra may be TypedArray or Array for backward compatibility\n // TypedArray.slice and TypedArray.from don't exist in IE10-IE11\n let gzhead_extra = new Uint8Array(s.gzhead.extra);\n // zmemcpy(s->pending_buf + s->pending,\n // s->gzhead->extra + s->gzindex, left);\n s.pending_buf.set(gzhead_extra.subarray(s.gzindex, s.gzindex + left), s.pending);\n s.pending += left;\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n s.gzindex = 0;\n }\n s.status = NAME_STATE;\n }\n if (s.status === NAME_STATE) {\n if (s.gzhead.name/* != Z_NULL*/) {\n let beg = s.pending; /* start of bytes to update crc */\n let val;\n do {\n if (s.pending === s.pending_buf_size) {\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK$3;\n }\n beg = 0;\n }\n // JS specific: little magic to add zero terminator to end of string\n if (s.gzindex < s.gzhead.name.length) {\n val = s.gzhead.name.charCodeAt(s.gzindex++) & 0xff;\n } else {\n val = 0;\n }\n put_byte(s, val);\n } while (val !== 0);\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n s.gzindex = 0;\n }\n s.status = COMMENT_STATE;\n }\n if (s.status === COMMENT_STATE) {\n if (s.gzhead.comment/* != Z_NULL*/) {\n let beg = s.pending; /* start of bytes to update crc */\n let val;\n do {\n if (s.pending === s.pending_buf_size) {\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK$3;\n }\n beg = 0;\n }\n // JS specific: little magic to add zero terminator to end of string\n if (s.gzindex < s.gzhead.comment.length) {\n val = s.gzhead.comment.charCodeAt(s.gzindex++) & 0xff;\n } else {\n val = 0;\n }\n put_byte(s, val);\n } while (val !== 0);\n //--- HCRC_UPDATE(beg) ---//\n if (s.gzhead.hcrc && s.pending > beg) {\n strm.adler = crc32_1(strm.adler, s.pending_buf, s.pending - beg, beg);\n }\n //---//\n }\n s.status = HCRC_STATE;\n }\n if (s.status === HCRC_STATE) {\n if (s.gzhead.hcrc) {\n if (s.pending + 2 > s.pending_buf_size) {\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK$3;\n }\n }\n put_byte(s, strm.adler & 0xff);\n put_byte(s, (strm.adler >> 8) & 0xff);\n strm.adler = 0; //crc32(0L, Z_NULL, 0);\n }\n s.status = BUSY_STATE;\n\n /* Compression must start with an empty pending buffer */\n flush_pending(strm);\n if (s.pending !== 0) {\n s.last_flush = -1;\n return Z_OK$3;\n }\n }\n//#endif\n\n /* Start a new block or continue the current one.\n */\n if (strm.avail_in !== 0 || s.lookahead !== 0 ||\n (flush !== Z_NO_FLUSH$2 && s.status !== FINISH_STATE)) {\n let bstate = s.level === 0 ? deflate_stored(s, flush) :\n s.strategy === Z_HUFFMAN_ONLY ? deflate_huff(s, flush) :\n s.strategy === Z_RLE ? deflate_rle(s, flush) :\n configuration_table[s.level].func(s, flush);\n\n if (bstate === BS_FINISH_STARTED || bstate === BS_FINISH_DONE) {\n s.status = FINISH_STATE;\n }\n if (bstate === BS_NEED_MORE || bstate === BS_FINISH_STARTED) {\n if (strm.avail_out === 0) {\n s.last_flush = -1;\n /* avoid BUF_ERROR next call, see above */\n }\n return Z_OK$3;\n /* If flush != Z_NO_FLUSH && avail_out == 0, the next call\n * of deflate should use the same flush parameter to make sure\n * that the flush is complete. So we don't have to output an\n * empty block here, this will be done at next call. This also\n * ensures that for a very small output buffer, we emit at most\n * one empty block.\n */\n }\n if (bstate === BS_BLOCK_DONE) {\n if (flush === Z_PARTIAL_FLUSH) {\n _tr_align(s);\n }\n else if (flush !== Z_BLOCK$1) { /* FULL_FLUSH or SYNC_FLUSH */\n\n _tr_stored_block(s, 0, 0, false);\n /* For a full flush, this empty block will be recognized\n * as a special marker by inflate_sync().\n */\n if (flush === Z_FULL_FLUSH$1) {\n /*** CLEAR_HASH(s); ***/ /* forget history */\n zero(s.head); // Fill with NIL (= 0);\n\n if (s.lookahead === 0) {\n s.strstart = 0;\n s.block_start = 0;\n s.insert = 0;\n }\n }\n }\n flush_pending(strm);\n if (strm.avail_out === 0) {\n s.last_flush = -1; /* avoid BUF_ERROR at next call, see above */\n return Z_OK$3;\n }\n }\n }\n\n if (flush !== Z_FINISH$3) { return Z_OK$3; }\n if (s.wrap <= 0) { return Z_STREAM_END$3; }\n\n /* Write the trailer */\n if (s.wrap === 2) {\n put_byte(s, strm.adler & 0xff);\n put_byte(s, (strm.adler >> 8) & 0xff);\n put_byte(s, (strm.adler >> 16) & 0xff);\n put_byte(s, (strm.adler >> 24) & 0xff);\n put_byte(s, strm.total_in & 0xff);\n put_byte(s, (strm.total_in >> 8) & 0xff);\n put_byte(s, (strm.total_in >> 16) & 0xff);\n put_byte(s, (strm.total_in >> 24) & 0xff);\n }\n else\n {\n putShortMSB(s, strm.adler >>> 16);\n putShortMSB(s, strm.adler & 0xffff);\n }\n\n flush_pending(strm);\n /* If avail_out is zero, the application will call deflate again\n * to flush the rest.\n */\n if (s.wrap > 0) { s.wrap = -s.wrap; }\n /* write the trailer only once! */\n return s.pending !== 0 ? Z_OK$3 : Z_STREAM_END$3;\n};\n\n\nconst deflateEnd = (strm) => {\n\n if (deflateStateCheck(strm)) {\n return Z_STREAM_ERROR$2;\n }\n\n const status = strm.state.status;\n\n strm.state = null;\n\n return status === BUSY_STATE ? err(strm, Z_DATA_ERROR$2) : Z_OK$3;\n};\n\n\n/* =========================================================================\n * Initializes the compression dictionary from the given byte\n * sequence without producing any compressed output.\n */\nconst deflateSetDictionary = (strm, dictionary) => {\n\n let dictLength = dictionary.length;\n\n if (deflateStateCheck(strm)) {\n return Z_STREAM_ERROR$2;\n }\n\n const s = strm.state;\n const wrap = s.wrap;\n\n if (wrap === 2 || (wrap === 1 && s.status !== INIT_STATE) || s.lookahead) {\n return Z_STREAM_ERROR$2;\n }\n\n /* when using zlib wrappers, compute Adler-32 for provided dictionary */\n if (wrap === 1) {\n /* adler32(strm->adler, dictionary, dictLength); */\n strm.adler = adler32_1(strm.adler, dictionary, dictLength, 0);\n }\n\n s.wrap = 0; /* avoid computing Adler-32 in read_buf */\n\n /* if dictionary would fill window, just replace the history */\n if (dictLength >= s.w_size) {\n if (wrap === 0) { /* already empty otherwise */\n /*** CLEAR_HASH(s); ***/\n zero(s.head); // Fill with NIL (= 0);\n s.strstart = 0;\n s.block_start = 0;\n s.insert = 0;\n }\n /* use the tail */\n // dictionary = dictionary.slice(dictLength - s.w_size);\n let tmpDict = new Uint8Array(s.w_size);\n tmpDict.set(dictionary.subarray(dictLength - s.w_size, dictLength), 0);\n dictionary = tmpDict;\n dictLength = s.w_size;\n }\n /* insert dictionary into window and hash */\n const avail = strm.avail_in;\n const next = strm.next_in;\n const input = strm.input;\n strm.avail_in = dictLength;\n strm.next_in = 0;\n strm.input = dictionary;\n fill_window(s);\n while (s.lookahead >= MIN_MATCH) {\n let str = s.strstart;\n let n = s.lookahead - (MIN_MATCH - 1);\n do {\n /* UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); */\n s.ins_h = HASH(s, s.ins_h, s.window[str + MIN_MATCH - 1]);\n\n s.prev[str & s.w_mask] = s.head[s.ins_h];\n\n s.head[s.ins_h] = str;\n str++;\n } while (--n);\n s.strstart = str;\n s.lookahead = MIN_MATCH - 1;\n fill_window(s);\n }\n s.strstart += s.lookahead;\n s.block_start = s.strstart;\n s.insert = s.lookahead;\n s.lookahead = 0;\n s.match_length = s.prev_length = MIN_MATCH - 1;\n s.match_available = 0;\n strm.next_in = next;\n strm.input = input;\n strm.avail_in = avail;\n s.wrap = wrap;\n return Z_OK$3;\n};\n\n\nvar deflateInit_1 = deflateInit;\nvar deflateInit2_1 = deflateInit2;\nvar deflateReset_1 = deflateReset;\nvar deflateResetKeep_1 = deflateResetKeep;\nvar deflateSetHeader_1 = deflateSetHeader;\nvar deflate_2$1 = deflate$2;\nvar deflateEnd_1 = deflateEnd;\nvar deflateSetDictionary_1 = deflateSetDictionary;\nvar deflateInfo = 'pako deflate (from Nodeca project)';\n\n/* Not implemented\nmodule.exports.deflateBound = deflateBound;\nmodule.exports.deflateCopy = deflateCopy;\nmodule.exports.deflateGetDictionary = deflateGetDictionary;\nmodule.exports.deflateParams = deflateParams;\nmodule.exports.deflatePending = deflatePending;\nmodule.exports.deflatePrime = deflatePrime;\nmodule.exports.deflateTune = deflateTune;\n*/\n\nvar deflate_1$2 = {\n\tdeflateInit: deflateInit_1,\n\tdeflateInit2: deflateInit2_1,\n\tdeflateReset: deflateReset_1,\n\tdeflateResetKeep: deflateResetKeep_1,\n\tdeflateSetHeader: deflateSetHeader_1,\n\tdeflate: deflate_2$1,\n\tdeflateEnd: deflateEnd_1,\n\tdeflateSetDictionary: deflateSetDictionary_1,\n\tdeflateInfo: deflateInfo\n};\n\nconst _has = (obj, key) => {\n return Object.prototype.hasOwnProperty.call(obj, key);\n};\n\nvar assign = function (obj /*from1, from2, from3, ...*/) {\n const sources = Array.prototype.slice.call(arguments, 1);\n while (sources.length) {\n const source = sources.shift();\n if (!source) { continue; }\n\n if (typeof source !== 'object') {\n throw new TypeError(source + 'must be non-object');\n }\n\n for (const p in source) {\n if (_has(source, p)) {\n obj[p] = source[p];\n }\n }\n }\n\n return obj;\n};\n\n\n// Join array of chunks to single array.\nvar flattenChunks = (chunks) => {\n // calculate data length\n let len = 0;\n\n for (let i = 0, l = chunks.length; i < l; i++) {\n len += chunks[i].length;\n }\n\n // join chunks\n const result = new Uint8Array(len);\n\n for (let i = 0, pos = 0, l = chunks.length; i < l; i++) {\n let chunk = chunks[i];\n result.set(chunk, pos);\n pos += chunk.length;\n }\n\n return result;\n};\n\nvar common = {\n\tassign: assign,\n\tflattenChunks: flattenChunks\n};\n\n// String encode/decode helpers\n\n\n// Quick check if we can use fast array to bin string conversion\n//\n// - apply(Array) can fail on Android 2.2\n// - apply(Uint8Array) can fail on iOS 5.1 Safari\n//\nlet STR_APPLY_UIA_OK = true;\n\ntry { String.fromCharCode.apply(null, new Uint8Array(1)); } catch (__) { STR_APPLY_UIA_OK = false; }\n\n\n// Table with utf8 lengths (calculated by first byte of sequence)\n// Note, that 5 & 6-byte values and some 4-byte values can not be represented in JS,\n// because max possible codepoint is 0x10ffff\nconst _utf8len = new Uint8Array(256);\nfor (let q = 0; q < 256; q++) {\n _utf8len[q] = (q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1);\n}\n_utf8len[254] = _utf8len[254] = 1; // Invalid sequence start\n\n\n// convert string to array (typed, when possible)\nvar string2buf = (str) => {\n if (typeof TextEncoder === 'function' && TextEncoder.prototype.encode) {\n return new TextEncoder().encode(str);\n }\n\n let buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0;\n\n // count binary size\n for (m_pos = 0; m_pos < str_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n buf_len += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;\n }\n\n // allocate buffer\n buf = new Uint8Array(buf_len);\n\n // convert\n for (i = 0, m_pos = 0; i < buf_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && (m_pos + 1 < str_len)) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n if (c < 0x80) {\n /* one byte */\n buf[i++] = c;\n } else if (c < 0x800) {\n /* two bytes */\n buf[i++] = 0xC0 | (c >>> 6);\n buf[i++] = 0x80 | (c & 0x3f);\n } else if (c < 0x10000) {\n /* three bytes */\n buf[i++] = 0xE0 | (c >>> 12);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n } else {\n /* four bytes */\n buf[i++] = 0xf0 | (c >>> 18);\n buf[i++] = 0x80 | (c >>> 12 & 0x3f);\n buf[i++] = 0x80 | (c >>> 6 & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n }\n }\n\n return buf;\n};\n\n// Helper\nconst buf2binstring = (buf, len) => {\n // On Chrome, the arguments in a function call that are allowed is `65534`.\n // If the length of the buffer is smaller than that, we can use this optimization,\n // otherwise we will take a slower path.\n if (len < 65534) {\n if (buf.subarray && STR_APPLY_UIA_OK) {\n return String.fromCharCode.apply(null, buf.length === len ? buf : buf.subarray(0, len));\n }\n }\n\n let result = '';\n for (let i = 0; i < len; i++) {\n result += String.fromCharCode(buf[i]);\n }\n return result;\n};\n\n\n// convert array to string\nvar buf2string = (buf, max) => {\n const len = max || buf.length;\n\n if (typeof TextDecoder === 'function' && TextDecoder.prototype.decode) {\n return new TextDecoder().decode(buf.subarray(0, max));\n }\n\n let i, out;\n\n // Reserve max possible length (2 words per char)\n // NB: by unknown reasons, Array is significantly faster for\n // String.fromCharCode.apply than Uint16Array.\n const utf16buf = new Array(len * 2);\n\n for (out = 0, i = 0; i < len;) {\n let c = buf[i++];\n // quick process ascii\n if (c < 0x80) { utf16buf[out++] = c; continue; }\n\n let c_len = _utf8len[c];\n // skip 5 & 6 byte codes\n if (c_len > 4) { utf16buf[out++] = 0xfffd; i += c_len - 1; continue; }\n\n // apply mask on first byte\n c &= c_len === 2 ? 0x1f : c_len === 3 ? 0x0f : 0x07;\n // join the rest\n while (c_len > 1 && i < len) {\n c = (c << 6) | (buf[i++] & 0x3f);\n c_len--;\n }\n\n // terminated by end of string?\n if (c_len > 1) { utf16buf[out++] = 0xfffd; continue; }\n\n if (c < 0x10000) {\n utf16buf[out++] = c;\n } else {\n c -= 0x10000;\n utf16buf[out++] = 0xd800 | ((c >> 10) & 0x3ff);\n utf16buf[out++] = 0xdc00 | (c & 0x3ff);\n }\n }\n\n return buf2binstring(utf16buf, out);\n};\n\n\n// Calculate max possible position in utf8 buffer,\n// that will not break sequence. If that's not possible\n// - (very small limits) return max size as is.\n//\n// buf[] - utf8 bytes array\n// max - length limit (mandatory);\nvar utf8border = (buf, max) => {\n\n max = max || buf.length;\n if (max > buf.length) { max = buf.length; }\n\n // go back from last position, until start of sequence found\n let pos = max - 1;\n while (pos >= 0 && (buf[pos] & 0xC0) === 0x80) { pos--; }\n\n // Very small and broken sequence,\n // return max, because we should return something anyway.\n if (pos < 0) { return max; }\n\n // If we came to start of buffer - that means buffer is too small,\n // return max too.\n if (pos === 0) { return max; }\n\n return (pos + _utf8len[buf[pos]] > max) ? pos : max;\n};\n\nvar strings = {\n\tstring2buf: string2buf,\n\tbuf2string: buf2string,\n\tutf8border: utf8border\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction ZStream() {\n /* next input byte */\n this.input = null; // JS specific, because we have no pointers\n this.next_in = 0;\n /* number of bytes available at input */\n this.avail_in = 0;\n /* total number of input bytes read so far */\n this.total_in = 0;\n /* next output byte should be put there */\n this.output = null; // JS specific, because we have no pointers\n this.next_out = 0;\n /* remaining free space at output */\n this.avail_out = 0;\n /* total number of bytes output so far */\n this.total_out = 0;\n /* last error message, NULL if no error */\n this.msg = ''/*Z_NULL*/;\n /* not visible by applications */\n this.state = null;\n /* best guess about the data type: binary or text */\n this.data_type = 2/*Z_UNKNOWN*/;\n /* adler32 value of the uncompressed data */\n this.adler = 0;\n}\n\nvar zstream = ZStream;\n\nconst toString$1 = Object.prototype.toString;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_NO_FLUSH: Z_NO_FLUSH$1, Z_SYNC_FLUSH, Z_FULL_FLUSH, Z_FINISH: Z_FINISH$2,\n Z_OK: Z_OK$2, Z_STREAM_END: Z_STREAM_END$2,\n Z_DEFAULT_COMPRESSION,\n Z_DEFAULT_STRATEGY,\n Z_DEFLATED: Z_DEFLATED$1\n} = constants$2;\n\n/* ===========================================================================*/\n\n\n/**\n * class Deflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[deflate]],\n * [[deflateRaw]] and [[gzip]].\n **/\n\n/* internal\n * Deflate.chunks -> Array\n *\n * Chunks of output data, if [[Deflate#onData]] not overridden.\n **/\n\n/**\n * Deflate.result -> Uint8Array\n *\n * Compressed result, generated by default [[Deflate#onData]]\n * and [[Deflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Deflate#push]] with `Z_FINISH` / `true` param).\n **/\n\n/**\n * Deflate.err -> Number\n *\n * Error code after deflate finished. 0 (Z_OK) on success.\n * You will not need it in real life, because deflate errors\n * are possible only on wrong options or bad `onData` / `onEnd`\n * custom handlers.\n **/\n\n/**\n * Deflate.msg -> String\n *\n * Error message, if [[Deflate.err]] != 0\n **/\n\n\n/**\n * new Deflate(options)\n * - options (Object): zlib deflate options.\n *\n * Creates new deflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `level`\n * - `windowBits`\n * - `memLevel`\n * - `strategy`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw deflate\n * - `gzip` (Boolean) - create gzip wrapper\n * - `header` (Object) - custom header for gzip\n * - `text` (Boolean) - true if compressed data believed to be text\n * - `time` (Number) - modification time, unix timestamp\n * - `os` (Number) - operation system code\n * - `extra` (Array) - array of bytes with extra data (max 65536)\n * - `name` (String) - file name (binary string)\n * - `comment` (String) - comment (binary string)\n * - `hcrc` (Boolean) - true if header crc should be added\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako')\n * , chunk1 = new Uint8Array([1,2,3,4,5,6,7,8,9])\n * , chunk2 = new Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * const deflate = new pako.Deflate({ level: 3});\n *\n * deflate.push(chunk1, false);\n * deflate.push(chunk2, true); // true -> last chunk\n *\n * if (deflate.err) { throw new Error(deflate.err); }\n *\n * console.log(deflate.result);\n * ```\n **/\nfunction Deflate$1(options) {\n this.options = common.assign({\n level: Z_DEFAULT_COMPRESSION,\n method: Z_DEFLATED$1,\n chunkSize: 16384,\n windowBits: 15,\n memLevel: 8,\n strategy: Z_DEFAULT_STRATEGY\n }, options || {});\n\n let opt = this.options;\n\n if (opt.raw && (opt.windowBits > 0)) {\n opt.windowBits = -opt.windowBits;\n }\n\n else if (opt.gzip && (opt.windowBits > 0) && (opt.windowBits < 16)) {\n opt.windowBits += 16;\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new zstream();\n this.strm.avail_out = 0;\n\n let status = deflate_1$2.deflateInit2(\n this.strm,\n opt.level,\n opt.method,\n opt.windowBits,\n opt.memLevel,\n opt.strategy\n );\n\n if (status !== Z_OK$2) {\n throw new Error(messages[status]);\n }\n\n if (opt.header) {\n deflate_1$2.deflateSetHeader(this.strm, opt.header);\n }\n\n if (opt.dictionary) {\n let dict;\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n // If we need to compress text, change encoding to utf8.\n dict = strings.string2buf(opt.dictionary);\n } else if (toString$1.call(opt.dictionary) === '[object ArrayBuffer]') {\n dict = new Uint8Array(opt.dictionary);\n } else {\n dict = opt.dictionary;\n }\n\n status = deflate_1$2.deflateSetDictionary(this.strm, dict);\n\n if (status !== Z_OK$2) {\n throw new Error(messages[status]);\n }\n\n this._dict_set = true;\n }\n}\n\n/**\n * Deflate#push(data[, flush_mode]) -> Boolean\n * - data (Uint8Array|ArrayBuffer|String): input data. Strings will be\n * converted to utf8 byte sequence.\n * - flush_mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.\n * See constants. Skipped or `false` means Z_NO_FLUSH, `true` means Z_FINISH.\n *\n * Sends input data to deflate pipe, generating [[Deflate#onData]] calls with\n * new compressed chunks. Returns `true` on success. The last data block must\n * have `flush_mode` Z_FINISH (or `true`). That will flush internal pending\n * buffers and call [[Deflate#onEnd]].\n *\n * On fail call [[Deflate#onEnd]] with error code and return false.\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nDeflate$1.prototype.push = function (data, flush_mode) {\n const strm = this.strm;\n const chunkSize = this.options.chunkSize;\n let status, _flush_mode;\n\n if (this.ended) { return false; }\n\n if (flush_mode === ~~flush_mode) _flush_mode = flush_mode;\n else _flush_mode = flush_mode === true ? Z_FINISH$2 : Z_NO_FLUSH$1;\n\n // Convert data if needed\n if (typeof data === 'string') {\n // If we need to compress text, change encoding to utf8.\n strm.input = strings.string2buf(data);\n } else if (toString$1.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n for (;;) {\n if (strm.avail_out === 0) {\n strm.output = new Uint8Array(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n\n // Make sure avail_out > 6 to avoid repeating markers\n if ((_flush_mode === Z_SYNC_FLUSH || _flush_mode === Z_FULL_FLUSH) && strm.avail_out <= 6) {\n this.onData(strm.output.subarray(0, strm.next_out));\n strm.avail_out = 0;\n continue;\n }\n\n status = deflate_1$2.deflate(strm, _flush_mode);\n\n // Ended => flush and finish\n if (status === Z_STREAM_END$2) {\n if (strm.next_out > 0) {\n this.onData(strm.output.subarray(0, strm.next_out));\n }\n status = deflate_1$2.deflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return status === Z_OK$2;\n }\n\n // Flush if out buffer full\n if (strm.avail_out === 0) {\n this.onData(strm.output);\n continue;\n }\n\n // Flush if requested and has data\n if (_flush_mode > 0 && strm.next_out > 0) {\n this.onData(strm.output.subarray(0, strm.next_out));\n strm.avail_out = 0;\n continue;\n }\n\n if (strm.avail_in === 0) break;\n }\n\n return true;\n};\n\n\n/**\n * Deflate#onData(chunk) -> Void\n * - chunk (Uint8Array): output data.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nDeflate$1.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Deflate#onEnd(status) -> Void\n * - status (Number): deflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called once after you tell deflate that the input stream is\n * complete (Z_FINISH). By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nDeflate$1.prototype.onEnd = function (status) {\n // On success - join\n if (status === Z_OK$2) {\n this.result = common.flattenChunks(this.chunks);\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * deflate(data[, options]) -> Uint8Array\n * - data (Uint8Array|ArrayBuffer|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * Compress `data` with deflate algorithm and `options`.\n *\n * Supported options are:\n *\n * - level\n * - windowBits\n * - memLevel\n * - strategy\n * - dictionary\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako')\n * const data = new Uint8Array([1,2,3,4,5,6,7,8,9]);\n *\n * console.log(pako.deflate(data));\n * ```\n **/\nfunction deflate$1(input, options) {\n const deflator = new Deflate$1(options);\n\n deflator.push(input, true);\n\n // That will never happens, if you don't cheat with options :)\n if (deflator.err) { throw deflator.msg || messages[deflator.err]; }\n\n return deflator.result;\n}\n\n\n/**\n * deflateRaw(data[, options]) -> Uint8Array\n * - data (Uint8Array|ArrayBuffer|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * The same as [[deflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction deflateRaw$1(input, options) {\n options = options || {};\n options.raw = true;\n return deflate$1(input, options);\n}\n\n\n/**\n * gzip(data[, options]) -> Uint8Array\n * - data (Uint8Array|ArrayBuffer|String): input data to compress.\n * - options (Object): zlib deflate options.\n *\n * The same as [[deflate]], but create gzip wrapper instead of\n * deflate one.\n **/\nfunction gzip$1(input, options) {\n options = options || {};\n options.gzip = true;\n return deflate$1(input, options);\n}\n\n\nvar Deflate_1$1 = Deflate$1;\nvar deflate_2 = deflate$1;\nvar deflateRaw_1$1 = deflateRaw$1;\nvar gzip_1$1 = gzip$1;\nvar constants$1 = constants$2;\n\nvar deflate_1$1 = {\n\tDeflate: Deflate_1$1,\n\tdeflate: deflate_2,\n\tdeflateRaw: deflateRaw_1$1,\n\tgzip: gzip_1$1,\n\tconstants: constants$1\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n// See state defs from inflate.js\nconst BAD$1 = 16209; /* got a data error -- remain here until reset */\nconst TYPE$1 = 16191; /* i: waiting for type bits, including last-flag bit */\n\n/*\n Decode literal, length, and distance codes and write out the resulting\n literal and match bytes until either not enough input or output is\n available, an end-of-block is encountered, or a data error is encountered.\n When large enough input and output buffers are supplied to inflate(), for\n example, a 16K input buffer and a 64K output buffer, more than 95% of the\n inflate execution time is spent in this routine.\n\n Entry assumptions:\n\n state.mode === LEN\n strm.avail_in >= 6\n strm.avail_out >= 258\n start >= strm.avail_out\n state.bits < 8\n\n On return, state.mode is one of:\n\n LEN -- ran out of enough output space or enough available input\n TYPE -- reached end of block code, inflate() to interpret next block\n BAD -- error in block data\n\n Notes:\n\n - The maximum input bits used by a length/distance pair is 15 bits for the\n length code, 5 bits for the length extra, 15 bits for the distance code,\n and 13 bits for the distance extra. This totals 48 bits, or six bytes.\n Therefore if strm.avail_in >= 6, then there is enough input to avoid\n checking for available input while decoding.\n\n - The maximum bytes that a single length/distance pair can output is 258\n bytes, which is the maximum length that can be coded. inflate_fast()\n requires strm.avail_out >= 258 for each loop to avoid checking for\n output space.\n */\nvar inffast = function inflate_fast(strm, start) {\n let _in; /* local strm.input */\n let last; /* have enough input while in < last */\n let _out; /* local strm.output */\n let beg; /* inflate()'s initial strm.output */\n let end; /* while out < end, enough space available */\n//#ifdef INFLATE_STRICT\n let dmax; /* maximum distance from zlib header */\n//#endif\n let wsize; /* window size or zero if not using window */\n let whave; /* valid bytes in the window */\n let wnext; /* window write index */\n // Use `s_window` instead `window`, avoid conflict with instrumentation tools\n let s_window; /* allocated sliding window, if wsize != 0 */\n let hold; /* local strm.hold */\n let bits; /* local strm.bits */\n let lcode; /* local strm.lencode */\n let dcode; /* local strm.distcode */\n let lmask; /* mask for first level of length codes */\n let dmask; /* mask for first level of distance codes */\n let here; /* retrieved table entry */\n let op; /* code bits, operation, extra bits, or */\n /* window position, window bytes to copy */\n let len; /* match length, unused bytes */\n let dist; /* match distance */\n let from; /* where to copy match from */\n let from_source;\n\n\n let input, output; // JS specific, because we have no pointers\n\n /* copy state to local variables */\n const state = strm.state;\n //here = state.here;\n _in = strm.next_in;\n input = strm.input;\n last = _in + (strm.avail_in - 5);\n _out = strm.next_out;\n output = strm.output;\n beg = _out - (start - strm.avail_out);\n end = _out + (strm.avail_out - 257);\n//#ifdef INFLATE_STRICT\n dmax = state.dmax;\n//#endif\n wsize = state.wsize;\n whave = state.whave;\n wnext = state.wnext;\n s_window = state.window;\n hold = state.hold;\n bits = state.bits;\n lcode = state.lencode;\n dcode = state.distcode;\n lmask = (1 << state.lenbits) - 1;\n dmask = (1 << state.distbits) - 1;\n\n\n /* decode literals and length/distances until end-of-block or not enough\n input data or output space */\n\n top:\n do {\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n\n here = lcode[hold & lmask];\n\n dolen:\n for (;;) { // Goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n if (op === 0) { /* literal */\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n output[_out++] = here & 0xffff/*here.val*/;\n }\n else if (op & 16) { /* length base */\n len = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (op) {\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n len += hold & ((1 << op) - 1);\n hold >>>= op;\n bits -= op;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", len));\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n here = dcode[hold & dmask];\n\n dodist:\n for (;;) { // goto emulation\n op = here >>> 24/*here.bits*/;\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff/*here.op*/;\n\n if (op & 16) { /* distance base */\n dist = here & 0xffff/*here.val*/;\n op &= 15; /* number of extra bits */\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n }\n dist += hold & ((1 << op) - 1);\n//#ifdef INFLATE_STRICT\n if (dist > dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD$1;\n break top;\n }\n//#endif\n hold >>>= op;\n bits -= op;\n //Tracevv((stderr, \"inflate: distance %u\\n\", dist));\n op = _out - beg; /* max distance in output */\n if (dist > op) { /* see if copy from window */\n op = dist - op; /* distance back in window */\n if (op > whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD$1;\n break top;\n }\n\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// if (len <= op - whave) {\n// do {\n// output[_out++] = 0;\n// } while (--len);\n// continue top;\n// }\n// len -= op - whave;\n// do {\n// output[_out++] = 0;\n// } while (--op > whave);\n// if (op === 0) {\n// from = _out - dist;\n// do {\n// output[_out++] = output[from++];\n// } while (--len);\n// continue top;\n// }\n//#endif\n }\n from = 0; // window index\n from_source = s_window;\n if (wnext === 0) { /* very common case */\n from += wsize - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n else if (wnext < op) { /* wrap around window */\n from += wsize + wnext - op;\n op -= wnext;\n if (op < len) { /* some from end of window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = 0;\n if (wnext < len) { /* some from start of window */\n op = wnext;\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n }\n else { /* contiguous in window */\n from += wnext - op;\n if (op < len) { /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n while (len > 2) {\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n len -= 3;\n }\n if (len) {\n output[_out++] = from_source[from++];\n if (len > 1) {\n output[_out++] = from_source[from++];\n }\n }\n }\n else {\n from = _out - dist; /* copy direct from output */\n do { /* minimum length is three */\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n len -= 3;\n } while (len > 2);\n if (len) {\n output[_out++] = output[from++];\n if (len > 1) {\n output[_out++] = output[from++];\n }\n }\n }\n }\n else if ((op & 64) === 0) { /* 2nd level distance code */\n here = dcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dodist;\n }\n else {\n strm.msg = 'invalid distance code';\n state.mode = BAD$1;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n }\n else if ((op & 64) === 0) { /* 2nd level length code */\n here = lcode[(here & 0xffff)/*here.val*/ + (hold & ((1 << op) - 1))];\n continue dolen;\n }\n else if (op & 32) { /* end-of-block */\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.mode = TYPE$1;\n break top;\n }\n else {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD$1;\n break top;\n }\n\n break; // need to emulate goto via \"continue\"\n }\n } while (_in < last && _out < end);\n\n /* return unused bytes (on entry, bits < 8, so in won't go too far back) */\n len = bits >> 3;\n _in -= len;\n bits -= len << 3;\n hold &= (1 << bits) - 1;\n\n /* update state and return */\n strm.next_in = _in;\n strm.next_out = _out;\n strm.avail_in = (_in < last ? 5 + (last - _in) : 5 - (_in - last));\n strm.avail_out = (_out < end ? 257 + (end - _out) : 257 - (_out - end));\n state.hold = hold;\n state.bits = bits;\n return;\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nconst MAXBITS = 15;\nconst ENOUGH_LENS$1 = 852;\nconst ENOUGH_DISTS$1 = 592;\n//const ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nconst CODES$1 = 0;\nconst LENS$1 = 1;\nconst DISTS$1 = 2;\n\nconst lbase = new Uint16Array([ /* Length codes 257..285 base */\n 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,\n 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0\n]);\n\nconst lext = new Uint8Array([ /* Length codes 257..285 extra */\n 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18,\n 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78\n]);\n\nconst dbase = new Uint16Array([ /* Distance codes 0..29 base */\n 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,\n 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,\n 8193, 12289, 16385, 24577, 0, 0\n]);\n\nconst dext = new Uint8Array([ /* Distance codes 0..29 extra */\n 16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22,\n 23, 23, 24, 24, 25, 25, 26, 26, 27, 27,\n 28, 28, 29, 29, 64, 64\n]);\n\nconst inflate_table = (type, lens, lens_index, codes, table, table_index, work, opts) =>\n{\n const bits = opts.bits;\n //here = opts.here; /* table entry for duplication */\n\n let len = 0; /* a code's length in bits */\n let sym = 0; /* index of code symbols */\n let min = 0, max = 0; /* minimum and maximum code lengths */\n let root = 0; /* number of index bits for root table */\n let curr = 0; /* number of index bits for current table */\n let drop = 0; /* code bits to drop for sub-table */\n let left = 0; /* number of prefix codes available */\n let used = 0; /* code entries in table used */\n let huff = 0; /* Huffman code */\n let incr; /* for incrementing code, index */\n let fill; /* index for replicating entries */\n let low; /* low bits for current root entry */\n let mask; /* mask for low root bits */\n let next; /* next available space in table */\n let base = null; /* base value table to use */\n// let shoextra; /* extra bits table to use */\n let match; /* use base and extra for symbol >= match */\n const count = new Uint16Array(MAXBITS + 1); //[MAXBITS+1]; /* number of codes of each length */\n const offs = new Uint16Array(MAXBITS + 1); //[MAXBITS+1]; /* offsets in table for each length */\n let extra = null;\n\n let here_bits, here_op, here_val;\n\n /*\n Process a set of code lengths to create a canonical Huffman code. The\n code lengths are lens[0..codes-1]. Each length corresponds to the\n symbols 0..codes-1. The Huffman code is generated by first sorting the\n symbols by length from short to long, and retaining the symbol order\n for codes with equal lengths. Then the code starts with all zero bits\n for the first code of the shortest length, and the codes are integer\n increments for the same length, and zeros are appended as the length\n increases. For the deflate format, these bits are stored backwards\n from their more natural integer increment ordering, and so when the\n decoding tables are built in the large loop below, the integer codes\n are incremented backwards.\n\n This routine assumes, but does not check, that all of the entries in\n lens[] are in the range 0..MAXBITS. The caller must assure this.\n 1..MAXBITS is interpreted as that code length. zero means that that\n symbol does not occur in this code.\n\n The codes are sorted by computing a count of codes for each length,\n creating from that a table of starting indices for each length in the\n sorted table, and then entering the symbols in order in the sorted\n table. The sorted table is work[], with that space being provided by\n the caller.\n\n The length counts are used for other purposes as well, i.e. finding\n the minimum and maximum length codes, determining if there are any\n codes at all, checking for a valid set of lengths, and looking ahead\n at length counts to determine sub-table sizes when building the\n decoding tables.\n */\n\n /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */\n for (len = 0; len <= MAXBITS; len++) {\n count[len] = 0;\n }\n for (sym = 0; sym < codes; sym++) {\n count[lens[lens_index + sym]]++;\n }\n\n /* bound code lengths, force root to be within code lengths */\n root = bits;\n for (max = MAXBITS; max >= 1; max--) {\n if (count[max] !== 0) { break; }\n }\n if (root > max) {\n root = max;\n }\n if (max === 0) { /* no symbols to code at all */\n //table.op[opts.table_index] = 64; //here.op = (var char)64; /* invalid code marker */\n //table.bits[opts.table_index] = 1; //here.bits = (var char)1;\n //table.val[opts.table_index++] = 0; //here.val = (var short)0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n\n //table.op[opts.table_index] = 64;\n //table.bits[opts.table_index] = 1;\n //table.val[opts.table_index++] = 0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n\n opts.bits = 1;\n return 0; /* no symbols, but wait for decoding to report error */\n }\n for (min = 1; min < max; min++) {\n if (count[min] !== 0) { break; }\n }\n if (root < min) {\n root = min;\n }\n\n /* check for an over-subscribed or incomplete set of lengths */\n left = 1;\n for (len = 1; len <= MAXBITS; len++) {\n left <<= 1;\n left -= count[len];\n if (left < 0) {\n return -1;\n } /* over-subscribed */\n }\n if (left > 0 && (type === CODES$1 || max !== 1)) {\n return -1; /* incomplete set */\n }\n\n /* generate offsets into symbol table for each length for sorting */\n offs[1] = 0;\n for (len = 1; len < MAXBITS; len++) {\n offs[len + 1] = offs[len] + count[len];\n }\n\n /* sort symbols by length, by symbol order within each length */\n for (sym = 0; sym < codes; sym++) {\n if (lens[lens_index + sym] !== 0) {\n work[offs[lens[lens_index + sym]]++] = sym;\n }\n }\n\n /*\n Create and fill in decoding tables. In this loop, the table being\n filled is at next and has curr index bits. The code being used is huff\n with length len. That code is converted to an index by dropping drop\n bits off of the bottom. For codes where len is less than drop + curr,\n those top drop + curr - len bits are incremented through all values to\n fill the table with replicated entries.\n\n root is the number of index bits for the root table. When len exceeds\n root, sub-tables are created pointed to by the root entry with an index\n of the low root bits of huff. This is saved in low to check for when a\n new sub-table should be started. drop is zero when the root table is\n being filled, and drop is root when sub-tables are being filled.\n\n When a new sub-table is needed, it is necessary to look ahead in the\n code lengths to determine what size sub-table is needed. The length\n counts are used for this, and so count[] is decremented as codes are\n entered in the tables.\n\n used keeps track of how many table entries have been allocated from the\n provided *table space. It is checked for LENS and DIST tables against\n the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in\n the initial root table size constants. See the comments in inftrees.h\n for more information.\n\n sym increments through all symbols, and the loop terminates when\n all codes of length max, i.e. all codes, have been processed. This\n routine permits incomplete codes, so another loop after this one fills\n in the rest of the decoding tables with invalid code markers.\n */\n\n /* set up for code type */\n // poor man optimization - use if-else instead of switch,\n // to avoid deopts in old v8\n if (type === CODES$1) {\n base = extra = work; /* dummy value--not used */\n match = 20;\n\n } else if (type === LENS$1) {\n base = lbase;\n extra = lext;\n match = 257;\n\n } else { /* DISTS */\n base = dbase;\n extra = dext;\n match = 0;\n }\n\n /* initialize opts for loop */\n huff = 0; /* starting code */\n sym = 0; /* starting code symbol */\n len = min; /* starting code length */\n next = table_index; /* current table to fill in */\n curr = root; /* current table index bits */\n drop = 0; /* current bits to drop from code for index */\n low = -1; /* trigger new sub-table when len > root */\n used = 1 << root; /* use root table entries */\n mask = used - 1; /* mask for comparing low */\n\n /* check available table space */\n if ((type === LENS$1 && used > ENOUGH_LENS$1) ||\n (type === DISTS$1 && used > ENOUGH_DISTS$1)) {\n return 1;\n }\n\n /* process all codes and make table entries */\n for (;;) {\n /* create table entry */\n here_bits = len - drop;\n if (work[sym] + 1 < match) {\n here_op = 0;\n here_val = work[sym];\n }\n else if (work[sym] >= match) {\n here_op = extra[work[sym] - match];\n here_val = base[work[sym] - match];\n }\n else {\n here_op = 32 + 64; /* end of block */\n here_val = 0;\n }\n\n /* replicate for those indices with low len bits equal to huff */\n incr = 1 << (len - drop);\n fill = 1 << curr;\n min = fill; /* save offset to next table */\n do {\n fill -= incr;\n table[next + (huff >> drop) + fill] = (here_bits << 24) | (here_op << 16) | here_val |0;\n } while (fill !== 0);\n\n /* backwards increment the len-bit code huff */\n incr = 1 << (len - 1);\n while (huff & incr) {\n incr >>= 1;\n }\n if (incr !== 0) {\n huff &= incr - 1;\n huff += incr;\n } else {\n huff = 0;\n }\n\n /* go to next symbol, update count, len */\n sym++;\n if (--count[len] === 0) {\n if (len === max) { break; }\n len = lens[lens_index + work[sym]];\n }\n\n /* create new sub-table if needed */\n if (len > root && (huff & mask) !== low) {\n /* if first time, transition to sub-tables */\n if (drop === 0) {\n drop = root;\n }\n\n /* increment past last table */\n next += min; /* here min is 1 << curr */\n\n /* determine length of next table */\n curr = len - drop;\n left = 1 << curr;\n while (curr + drop < max) {\n left -= count[curr + drop];\n if (left <= 0) { break; }\n curr++;\n left <<= 1;\n }\n\n /* check for enough space */\n used += 1 << curr;\n if ((type === LENS$1 && used > ENOUGH_LENS$1) ||\n (type === DISTS$1 && used > ENOUGH_DISTS$1)) {\n return 1;\n }\n\n /* point entry in root table to sub-table */\n low = huff & mask;\n /*table.op[low] = curr;\n table.bits[low] = root;\n table.val[low] = next - opts.table_index;*/\n table[low] = (root << 24) | (curr << 16) | (next - table_index) |0;\n }\n }\n\n /* fill in remaining table entry if code is incomplete (guaranteed to have\n at most one remaining entry, since if the code is incomplete, the\n maximum code length that was allowed to get this far is one bit) */\n if (huff !== 0) {\n //table.op[next + huff] = 64; /* invalid code marker */\n //table.bits[next + huff] = len - drop;\n //table.val[next + huff] = 0;\n table[next + huff] = ((len - drop) << 24) | (64 << 16) |0;\n }\n\n /* set return parameters */\n //opts.table_index += used;\n opts.bits = root;\n return 0;\n};\n\n\nvar inftrees = inflate_table;\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\n\n\n\n\n\nconst CODES = 0;\nconst LENS = 1;\nconst DISTS = 2;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_FINISH: Z_FINISH$1, Z_BLOCK, Z_TREES,\n Z_OK: Z_OK$1, Z_STREAM_END: Z_STREAM_END$1, Z_NEED_DICT: Z_NEED_DICT$1, Z_STREAM_ERROR: Z_STREAM_ERROR$1, Z_DATA_ERROR: Z_DATA_ERROR$1, Z_MEM_ERROR: Z_MEM_ERROR$1, Z_BUF_ERROR,\n Z_DEFLATED\n} = constants$2;\n\n\n/* STATES ====================================================================*/\n/* ===========================================================================*/\n\n\nconst HEAD = 16180; /* i: waiting for magic header */\nconst FLAGS = 16181; /* i: waiting for method and flags (gzip) */\nconst TIME = 16182; /* i: waiting for modification time (gzip) */\nconst OS = 16183; /* i: waiting for extra flags and operating system (gzip) */\nconst EXLEN = 16184; /* i: waiting for extra length (gzip) */\nconst EXTRA = 16185; /* i: waiting for extra bytes (gzip) */\nconst NAME = 16186; /* i: waiting for end of file name (gzip) */\nconst COMMENT = 16187; /* i: waiting for end of comment (gzip) */\nconst HCRC = 16188; /* i: waiting for header crc (gzip) */\nconst DICTID = 16189; /* i: waiting for dictionary check value */\nconst DICT = 16190; /* waiting for inflateSetDictionary() call */\nconst TYPE = 16191; /* i: waiting for type bits, including last-flag bit */\nconst TYPEDO = 16192; /* i: same, but skip check to exit inflate on new block */\nconst STORED = 16193; /* i: waiting for stored size (length and complement) */\nconst COPY_ = 16194; /* i/o: same as COPY below, but only first time in */\nconst COPY = 16195; /* i/o: waiting for input or output to copy stored block */\nconst TABLE = 16196; /* i: waiting for dynamic block table lengths */\nconst LENLENS = 16197; /* i: waiting for code length code lengths */\nconst CODELENS = 16198; /* i: waiting for length/lit and distance code lengths */\nconst LEN_ = 16199; /* i: same as LEN below, but only first time in */\nconst LEN = 16200; /* i: waiting for length/lit/eob code */\nconst LENEXT = 16201; /* i: waiting for length extra bits */\nconst DIST = 16202; /* i: waiting for distance code */\nconst DISTEXT = 16203; /* i: waiting for distance extra bits */\nconst MATCH = 16204; /* o: waiting for output space to copy string */\nconst LIT = 16205; /* o: waiting for output space to write literal */\nconst CHECK = 16206; /* i: waiting for 32-bit check value */\nconst LENGTH = 16207; /* i: waiting for 32-bit length (gzip) */\nconst DONE = 16208; /* finished check, done -- remain here until reset */\nconst BAD = 16209; /* got a data error -- remain here until reset */\nconst MEM = 16210; /* got an inflate() memory error -- remain here until reset */\nconst SYNC = 16211; /* looking for synchronization bytes to restart inflate() */\n\n/* ===========================================================================*/\n\n\n\nconst ENOUGH_LENS = 852;\nconst ENOUGH_DISTS = 592;\n//const ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\n\nconst MAX_WBITS = 15;\n/* 32K LZ77 window */\nconst DEF_WBITS = MAX_WBITS;\n\n\nconst zswap32 = (q) => {\n\n return (((q >>> 24) & 0xff) +\n ((q >>> 8) & 0xff00) +\n ((q & 0xff00) << 8) +\n ((q & 0xff) << 24));\n};\n\n\nfunction InflateState() {\n this.strm = null; /* pointer back to this zlib stream */\n this.mode = 0; /* current inflate mode */\n this.last = false; /* true if processing last block */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip,\n bit 2 true to validate check value */\n this.havedict = false; /* true if dictionary provided */\n this.flags = 0; /* gzip header method and flags (0 if zlib), or\n -1 if raw or no header yet */\n this.dmax = 0; /* zlib header max distance (INFLATE_STRICT) */\n this.check = 0; /* protected copy of check value */\n this.total = 0; /* protected copy of output count */\n // TODO: may be {}\n this.head = null; /* where to save gzip header information */\n\n /* sliding window */\n this.wbits = 0; /* log base 2 of requested window size */\n this.wsize = 0; /* window size or zero if not using window */\n this.whave = 0; /* valid bytes in the window */\n this.wnext = 0; /* window write index */\n this.window = null; /* allocated sliding window, if needed */\n\n /* bit accumulator */\n this.hold = 0; /* input bit accumulator */\n this.bits = 0; /* number of bits in \"in\" */\n\n /* for string and stored block copying */\n this.length = 0; /* literal or length of data to copy */\n this.offset = 0; /* distance back to copy string from */\n\n /* for table and code decoding */\n this.extra = 0; /* extra bits needed */\n\n /* fixed and dynamic code tables */\n this.lencode = null; /* starting table for length/literal codes */\n this.distcode = null; /* starting table for distance codes */\n this.lenbits = 0; /* index bits for lencode */\n this.distbits = 0; /* index bits for distcode */\n\n /* dynamic table building */\n this.ncode = 0; /* number of code length code lengths */\n this.nlen = 0; /* number of length code lengths */\n this.ndist = 0; /* number of distance code lengths */\n this.have = 0; /* number of code lengths in lens[] */\n this.next = null; /* next available space in codes[] */\n\n this.lens = new Uint16Array(320); /* temporary storage for code lengths */\n this.work = new Uint16Array(288); /* work area for code table building */\n\n /*\n because we don't have pointers in js, we use lencode and distcode directly\n as buffers so we don't need codes\n */\n //this.codes = new Int32Array(ENOUGH); /* space for code tables */\n this.lendyn = null; /* dynamic table for length/literal codes (JS specific) */\n this.distdyn = null; /* dynamic table for distance codes (JS specific) */\n this.sane = 0; /* if false, allow invalid distance too far */\n this.back = 0; /* bits back of last unprocessed length/lit */\n this.was = 0; /* initial length of match */\n}\n\n\nconst inflateStateCheck = (strm) => {\n\n if (!strm) {\n return 1;\n }\n const state = strm.state;\n if (!state || state.strm !== strm ||\n state.mode < HEAD || state.mode > SYNC) {\n return 1;\n }\n return 0;\n};\n\n\nconst inflateResetKeep = (strm) => {\n\n if (inflateStateCheck(strm)) { return Z_STREAM_ERROR$1; }\n const state = strm.state;\n strm.total_in = strm.total_out = state.total = 0;\n strm.msg = ''; /*Z_NULL*/\n if (state.wrap) { /* to support ill-conceived Java test suite */\n strm.adler = state.wrap & 1;\n }\n state.mode = HEAD;\n state.last = 0;\n state.havedict = 0;\n state.flags = -1;\n state.dmax = 32768;\n state.head = null/*Z_NULL*/;\n state.hold = 0;\n state.bits = 0;\n //state.lencode = state.distcode = state.next = state.codes;\n state.lencode = state.lendyn = new Int32Array(ENOUGH_LENS);\n state.distcode = state.distdyn = new Int32Array(ENOUGH_DISTS);\n\n state.sane = 1;\n state.back = -1;\n //Tracev((stderr, \"inflate: reset\\n\"));\n return Z_OK$1;\n};\n\n\nconst inflateReset = (strm) => {\n\n if (inflateStateCheck(strm)) { return Z_STREAM_ERROR$1; }\n const state = strm.state;\n state.wsize = 0;\n state.whave = 0;\n state.wnext = 0;\n return inflateResetKeep(strm);\n\n};\n\n\nconst inflateReset2 = (strm, windowBits) => {\n let wrap;\n\n /* get the state */\n if (inflateStateCheck(strm)) { return Z_STREAM_ERROR$1; }\n const state = strm.state;\n\n /* extract wrap request from windowBits parameter */\n if (windowBits < 0) {\n wrap = 0;\n windowBits = -windowBits;\n }\n else {\n wrap = (windowBits >> 4) + 5;\n if (windowBits < 48) {\n windowBits &= 15;\n }\n }\n\n /* set number of window bits, free window if different */\n if (windowBits && (windowBits < 8 || windowBits > 15)) {\n return Z_STREAM_ERROR$1;\n }\n if (state.window !== null && state.wbits !== windowBits) {\n state.window = null;\n }\n\n /* update state and reset the rest of it */\n state.wrap = wrap;\n state.wbits = windowBits;\n return inflateReset(strm);\n};\n\n\nconst inflateInit2 = (strm, windowBits) => {\n\n if (!strm) { return Z_STREAM_ERROR$1; }\n //strm.msg = Z_NULL; /* in case we return an error */\n\n const state = new InflateState();\n\n //if (state === Z_NULL) return Z_MEM_ERROR;\n //Tracev((stderr, \"inflate: allocated\\n\"));\n strm.state = state;\n state.strm = strm;\n state.window = null/*Z_NULL*/;\n state.mode = HEAD; /* to pass state test in inflateReset2() */\n const ret = inflateReset2(strm, windowBits);\n if (ret !== Z_OK$1) {\n strm.state = null/*Z_NULL*/;\n }\n return ret;\n};\n\n\nconst inflateInit = (strm) => {\n\n return inflateInit2(strm, DEF_WBITS);\n};\n\n\n/*\n Return state with length and distance decoding tables and index sizes set to\n fixed code decoding. Normally this returns fixed tables from inffixed.h.\n If BUILDFIXED is defined, then instead this routine builds the tables the\n first time it's called, and returns those tables the first time and\n thereafter. This reduces the size of the code by about 2K bytes, in\n exchange for a little execution time. However, BUILDFIXED should not be\n used for threaded applications, since the rewriting of the tables and virgin\n may not be thread-safe.\n */\nlet virgin = true;\n\nlet lenfix, distfix; // We have no pointers in JS, so keep tables separate\n\n\nconst fixedtables = (state) => {\n\n /* build fixed huffman tables if first call (may not be thread safe) */\n if (virgin) {\n lenfix = new Int32Array(512);\n distfix = new Int32Array(32);\n\n /* literal/length table */\n let sym = 0;\n while (sym < 144) { state.lens[sym++] = 8; }\n while (sym < 256) { state.lens[sym++] = 9; }\n while (sym < 280) { state.lens[sym++] = 7; }\n while (sym < 288) { state.lens[sym++] = 8; }\n\n inftrees(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 });\n\n /* distance table */\n sym = 0;\n while (sym < 32) { state.lens[sym++] = 5; }\n\n inftrees(DISTS, state.lens, 0, 32, distfix, 0, state.work, { bits: 5 });\n\n /* do this just once */\n virgin = false;\n }\n\n state.lencode = lenfix;\n state.lenbits = 9;\n state.distcode = distfix;\n state.distbits = 5;\n};\n\n\n/*\n Update the window with the last wsize (normally 32K) bytes written before\n returning. If window does not exist yet, create it. This is only called\n when a window is already in use, or when output has been written during this\n inflate call, but the end of the deflate stream has not been reached yet.\n It is also called to create a window for dictionary data when a dictionary\n is loaded.\n\n Providing output buffers larger than 32K to inflate() should provide a speed\n advantage, since only the last 32K of output is copied to the sliding window\n upon return from inflate(), and since all distances after the first 32K of\n output will fall in the output data, making match copies simpler and faster.\n The advantage may be dependent on the size of the processor's data caches.\n */\nconst updatewindow = (strm, src, end, copy) => {\n\n let dist;\n const state = strm.state;\n\n /* if it hasn't been done already, allocate space for the window */\n if (state.window === null) {\n state.wsize = 1 << state.wbits;\n state.wnext = 0;\n state.whave = 0;\n\n state.window = new Uint8Array(state.wsize);\n }\n\n /* copy state->wsize or less output bytes into the circular window */\n if (copy >= state.wsize) {\n state.window.set(src.subarray(end - state.wsize, end), 0);\n state.wnext = 0;\n state.whave = state.wsize;\n }\n else {\n dist = state.wsize - state.wnext;\n if (dist > copy) {\n dist = copy;\n }\n //zmemcpy(state->window + state->wnext, end - copy, dist);\n state.window.set(src.subarray(end - copy, end - copy + dist), state.wnext);\n copy -= dist;\n if (copy) {\n //zmemcpy(state->window, end - copy, copy);\n state.window.set(src.subarray(end - copy, end), 0);\n state.wnext = copy;\n state.whave = state.wsize;\n }\n else {\n state.wnext += dist;\n if (state.wnext === state.wsize) { state.wnext = 0; }\n if (state.whave < state.wsize) { state.whave += dist; }\n }\n }\n return 0;\n};\n\n\nconst inflate$2 = (strm, flush) => {\n\n let state;\n let input, output; // input/output buffers\n let next; /* next input INDEX */\n let put; /* next output INDEX */\n let have, left; /* available input and output */\n let hold; /* bit buffer */\n let bits; /* bits in bit buffer */\n let _in, _out; /* save starting available input and output */\n let copy; /* number of stored or match bytes to copy */\n let from; /* where to copy match bytes from */\n let from_source;\n let here = 0; /* current decoding table entry */\n let here_bits, here_op, here_val; // paked \"here\" denormalized (JS specific)\n //let last; /* parent table entry */\n let last_bits, last_op, last_val; // paked \"last\" denormalized (JS specific)\n let len; /* length to copy for repeats, bits to drop */\n let ret; /* return code */\n const hbuf = new Uint8Array(4); /* buffer for gzip header crc calculation */\n let opts;\n\n let n; // temporary variable for NEED_BITS\n\n const order = /* permutation of code lengths */\n new Uint8Array([ 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 ]);\n\n\n if (inflateStateCheck(strm) || !strm.output ||\n (!strm.input && strm.avail_in !== 0)) {\n return Z_STREAM_ERROR$1;\n }\n\n state = strm.state;\n if (state.mode === TYPE) { state.mode = TYPEDO; } /* skip check */\n\n\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n _in = have;\n _out = left;\n ret = Z_OK$1;\n\n inf_leave: // goto emulation\n for (;;) {\n switch (state.mode) {\n case HEAD:\n if (state.wrap === 0) {\n state.mode = TYPEDO;\n break;\n }\n //=== NEEDBITS(16);\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((state.wrap & 2) && hold === 0x8b1f) { /* gzip header */\n if (state.wbits === 0) {\n state.wbits = 15;\n }\n state.check = 0/*crc32(0L, Z_NULL, 0)*/;\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32_1(state.check, hbuf, 2, 0);\n //===//\n\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = FLAGS;\n break;\n }\n if (state.head) {\n state.head.done = false;\n }\n if (!(state.wrap & 1) || /* check if zlib header allowed */\n (((hold & 0xff)/*BITS(8)*/ << 8) + (hold >> 8)) % 31) {\n strm.msg = 'incorrect header check';\n state.mode = BAD;\n break;\n }\n if ((hold & 0x0f)/*BITS(4)*/ !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n len = (hold & 0x0f)/*BITS(4)*/ + 8;\n if (state.wbits === 0) {\n state.wbits = len;\n }\n if (len > 15 || len > state.wbits) {\n strm.msg = 'invalid window size';\n state.mode = BAD;\n break;\n }\n\n // !!! pako patch. Force use `options.windowBits` if passed.\n // Required to always use max window size by default.\n state.dmax = 1 << state.wbits;\n //state.dmax = 1 << len;\n\n state.flags = 0; /* indicate zlib header */\n //Tracev((stderr, \"inflate: zlib header ok\\n\"));\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = hold & 0x200 ? DICTID : TYPE;\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n break;\n case FLAGS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.flags = hold;\n if ((state.flags & 0xff) !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n if (state.flags & 0xe000) {\n strm.msg = 'unknown header flags set';\n state.mode = BAD;\n break;\n }\n if (state.head) {\n state.head.text = ((hold >> 8) & 1);\n }\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32_1(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = TIME;\n /* falls through */\n case TIME:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.time = hold;\n }\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n //=== CRC4(state.check, hold)\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n hbuf[2] = (hold >>> 16) & 0xff;\n hbuf[3] = (hold >>> 24) & 0xff;\n state.check = crc32_1(state.check, hbuf, 4, 0);\n //===\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = OS;\n /* falls through */\n case OS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.xflags = (hold & 0xff);\n state.head.os = (hold >> 8);\n }\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32_1(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = EXLEN;\n /* falls through */\n case EXLEN:\n if (state.flags & 0x0400) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length = hold;\n if (state.head) {\n state.head.extra_len = hold;\n }\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32_1(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n else if (state.head) {\n state.head.extra = null/*Z_NULL*/;\n }\n state.mode = EXTRA;\n /* falls through */\n case EXTRA:\n if (state.flags & 0x0400) {\n copy = state.length;\n if (copy > have) { copy = have; }\n if (copy) {\n if (state.head) {\n len = state.head.extra_len - state.length;\n if (!state.head.extra) {\n // Use untyped array for more convenient processing later\n state.head.extra = new Uint8Array(state.head.extra_len);\n }\n state.head.extra.set(\n input.subarray(\n next,\n // extra field is limited to 65536 bytes\n // - no need for additional size check\n next + copy\n ),\n /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/\n len\n );\n //zmemcpy(state.head.extra + len, next,\n // len + copy > state.head.extra_max ?\n // state.head.extra_max - len : copy);\n }\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n state.check = crc32_1(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n state.length -= copy;\n }\n if (state.length) { break inf_leave; }\n }\n state.length = 0;\n state.mode = NAME;\n /* falls through */\n case NAME:\n if (state.flags & 0x0800) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n // TODO: 2 or 1 bytes?\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.name_max*/)) {\n state.head.name += String.fromCharCode(len);\n }\n } while (len && copy < have);\n\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n state.check = crc32_1(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.name = null;\n }\n state.length = 0;\n state.mode = COMMENT;\n /* falls through */\n case COMMENT:\n if (state.flags & 0x1000) {\n if (have === 0) { break inf_leave; }\n copy = 0;\n do {\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head && len &&\n (state.length < 65536 /*state.head.comm_max*/)) {\n state.head.comment += String.fromCharCode(len);\n }\n } while (len && copy < have);\n if ((state.flags & 0x0200) && (state.wrap & 4)) {\n state.check = crc32_1(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) { break inf_leave; }\n }\n else if (state.head) {\n state.head.comment = null;\n }\n state.mode = HCRC;\n /* falls through */\n case HCRC:\n if (state.flags & 0x0200) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((state.wrap & 4) && hold !== (state.check & 0xffff)) {\n strm.msg = 'header crc mismatch';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n if (state.head) {\n state.head.hcrc = ((state.flags >> 9) & 1);\n state.head.done = true;\n }\n strm.adler = state.check = 0;\n state.mode = TYPE;\n break;\n case DICTID:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n strm.adler = state.check = zswap32(hold);\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = DICT;\n /* falls through */\n case DICT:\n if (state.havedict === 0) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n return Z_NEED_DICT$1;\n }\n strm.adler = state.check = 1/*adler32(0L, Z_NULL, 0)*/;\n state.mode = TYPE;\n /* falls through */\n case TYPE:\n if (flush === Z_BLOCK || flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case TYPEDO:\n if (state.last) {\n //--- BYTEBITS() ---//\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n state.mode = CHECK;\n break;\n }\n //=== NEEDBITS(3); */\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.last = (hold & 0x01)/*BITS(1)*/;\n //--- DROPBITS(1) ---//\n hold >>>= 1;\n bits -= 1;\n //---//\n\n switch ((hold & 0x03)/*BITS(2)*/) {\n case 0: /* stored block */\n //Tracev((stderr, \"inflate: stored block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = STORED;\n break;\n case 1: /* fixed block */\n fixedtables(state);\n //Tracev((stderr, \"inflate: fixed codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = LEN_; /* decode codes */\n if (flush === Z_TREES) {\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break inf_leave;\n }\n break;\n case 2: /* dynamic block */\n //Tracev((stderr, \"inflate: dynamic codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = TABLE;\n break;\n case 3:\n strm.msg = 'invalid block type';\n state.mode = BAD;\n }\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break;\n case STORED:\n //--- BYTEBITS() ---// /* go to byte boundary */\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((hold & 0xffff) !== ((hold >>> 16) ^ 0xffff)) {\n strm.msg = 'invalid stored block lengths';\n state.mode = BAD;\n break;\n }\n state.length = hold & 0xffff;\n //Tracev((stderr, \"inflate: stored length %u\\n\",\n // state.length));\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = COPY_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case COPY_:\n state.mode = COPY;\n /* falls through */\n case COPY:\n copy = state.length;\n if (copy) {\n if (copy > have) { copy = have; }\n if (copy > left) { copy = left; }\n if (copy === 0) { break inf_leave; }\n //--- zmemcpy(put, next, copy); ---\n output.set(input.subarray(next, next + copy), put);\n //---//\n have -= copy;\n next += copy;\n left -= copy;\n put += copy;\n state.length -= copy;\n break;\n }\n //Tracev((stderr, \"inflate: stored end\\n\"));\n state.mode = TYPE;\n break;\n case TABLE:\n //=== NEEDBITS(14); */\n while (bits < 14) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.nlen = (hold & 0x1f)/*BITS(5)*/ + 257;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ndist = (hold & 0x1f)/*BITS(5)*/ + 1;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ncode = (hold & 0x0f)/*BITS(4)*/ + 4;\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n//#ifndef PKZIP_BUG_WORKAROUND\n if (state.nlen > 286 || state.ndist > 30) {\n strm.msg = 'too many length or distance symbols';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracev((stderr, \"inflate: table sizes ok\\n\"));\n state.have = 0;\n state.mode = LENLENS;\n /* falls through */\n case LENLENS:\n while (state.have < state.ncode) {\n //=== NEEDBITS(3);\n while (bits < 3) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.lens[order[state.have++]] = (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n while (state.have < 19) {\n state.lens[order[state.have++]] = 0;\n }\n // We have separate tables & no pointers. 2 commented lines below not needed.\n //state.next = state.codes;\n //state.lencode = state.next;\n // Switch to use dynamic table\n state.lencode = state.lendyn;\n state.lenbits = 7;\n\n opts = { bits: state.lenbits };\n ret = inftrees(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts);\n state.lenbits = opts.bits;\n\n if (ret) {\n strm.msg = 'invalid code lengths set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, \"inflate: code lengths ok\\n\"));\n state.have = 0;\n state.mode = CODELENS;\n /* falls through */\n case CODELENS:\n while (state.have < state.nlen + state.ndist) {\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)];/*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_val < 16) {\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.lens[state.have++] = here_val;\n }\n else {\n if (here_val === 16) {\n //=== NEEDBITS(here.bits + 2);\n n = here_bits + 2;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n if (state.have === 0) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n len = state.lens[state.have - 1];\n copy = 3 + (hold & 0x03);//BITS(2);\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n }\n else if (here_val === 17) {\n //=== NEEDBITS(here.bits + 3);\n n = here_bits + 3;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 3 + (hold & 0x07);//BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n else {\n //=== NEEDBITS(here.bits + 7);\n n = here_bits + 7;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 11 + (hold & 0x7f);//BITS(7);\n //--- DROPBITS(7) ---//\n hold >>>= 7;\n bits -= 7;\n //---//\n }\n if (state.have + copy > state.nlen + state.ndist) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n while (copy--) {\n state.lens[state.have++] = len;\n }\n }\n }\n\n /* handle error breaks in while */\n if (state.mode === BAD) { break; }\n\n /* check for end-of-block code (better have one) */\n if (state.lens[256] === 0) {\n strm.msg = 'invalid code -- missing end-of-block';\n state.mode = BAD;\n break;\n }\n\n /* build code tables -- note: do not change the lenbits or distbits\n values here (9 and 6) without reading the comments in inftrees.h\n concerning the ENOUGH constants, which depend on those values */\n state.lenbits = 9;\n\n opts = { bits: state.lenbits };\n ret = inftrees(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.lenbits = opts.bits;\n // state.lencode = state.next;\n\n if (ret) {\n strm.msg = 'invalid literal/lengths set';\n state.mode = BAD;\n break;\n }\n\n state.distbits = 6;\n //state.distcode.copy(state.codes);\n // Switch to use dynamic table\n state.distcode = state.distdyn;\n opts = { bits: state.distbits };\n ret = inftrees(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.distbits = opts.bits;\n // state.distcode = state.next;\n\n if (ret) {\n strm.msg = 'invalid distances set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, 'inflate: codes ok\\n'));\n state.mode = LEN_;\n if (flush === Z_TREES) { break inf_leave; }\n /* falls through */\n case LEN_:\n state.mode = LEN;\n /* falls through */\n case LEN:\n if (have >= 6 && left >= 258) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n inffast(strm, _out);\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n\n if (state.mode === TYPE) {\n state.back = -1;\n }\n break;\n }\n state.back = 0;\n for (;;) {\n here = state.lencode[hold & ((1 << state.lenbits) - 1)]; /*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if (here_bits <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_op && (here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.lencode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n state.length = here_val;\n if (here_op === 0) {\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n state.mode = LIT;\n break;\n }\n if (here_op & 32) {\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.back = -1;\n state.mode = TYPE;\n break;\n }\n if (here_op & 64) {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break;\n }\n state.extra = here_op & 15;\n state.mode = LENEXT;\n /* falls through */\n case LENEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", state.length));\n state.was = state.length;\n state.mode = DIST;\n /* falls through */\n case DIST:\n for (;;) {\n here = state.distcode[hold & ((1 << state.distbits) - 1)];/*BITS(state.distbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if ((here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here = state.distcode[last_val +\n ((hold & ((1 << (last_bits + last_op)) - 1))/*BITS(last.bits + last.op)*/ >> last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n\n if ((last_bits + here_bits) <= bits) { break; }\n //--- PULLBYTE() ---//\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n if (here_op & 64) {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break;\n }\n state.offset = here_val;\n state.extra = (here_op) & 15;\n state.mode = DISTEXT;\n /* falls through */\n case DISTEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.offset += hold & ((1 << state.extra) - 1)/*BITS(state.extra)*/;\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n//#ifdef INFLATE_STRICT\n if (state.offset > state.dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n//#endif\n //Tracevv((stderr, \"inflate: distance %u\\n\", state.offset));\n state.mode = MATCH;\n /* falls through */\n case MATCH:\n if (left === 0) { break inf_leave; }\n copy = _out - left;\n if (state.offset > copy) { /* copy from window */\n copy = state.offset - copy;\n if (copy > state.whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n// (!) This block is disabled in zlib defaults,\n// don't enable it for binary compatibility\n//#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n// Trace((stderr, \"inflate.c too far\\n\"));\n// copy -= state.whave;\n// if (copy > state.length) { copy = state.length; }\n// if (copy > left) { copy = left; }\n// left -= copy;\n// state.length -= copy;\n// do {\n// output[put++] = 0;\n// } while (--copy);\n// if (state.length === 0) { state.mode = LEN; }\n// break;\n//#endif\n }\n if (copy > state.wnext) {\n copy -= state.wnext;\n from = state.wsize - copy;\n }\n else {\n from = state.wnext - copy;\n }\n if (copy > state.length) { copy = state.length; }\n from_source = state.window;\n }\n else { /* copy from output */\n from_source = output;\n from = put - state.offset;\n copy = state.length;\n }\n if (copy > left) { copy = left; }\n left -= copy;\n state.length -= copy;\n do {\n output[put++] = from_source[from++];\n } while (--copy);\n if (state.length === 0) { state.mode = LEN; }\n break;\n case LIT:\n if (left === 0) { break inf_leave; }\n output[put++] = state.length;\n left--;\n state.mode = LEN;\n break;\n case CHECK:\n if (state.wrap) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n // Use '|' instead of '+' to make sure that result is signed\n hold |= input[next++] << bits;\n bits += 8;\n }\n //===//\n _out -= left;\n strm.total_out += _out;\n state.total += _out;\n if ((state.wrap & 4) && _out) {\n strm.adler = state.check =\n /*UPDATE_CHECK(state.check, put - _out, _out);*/\n (state.flags ? crc32_1(state.check, output, _out, put - _out) : adler32_1(state.check, output, _out, put - _out));\n\n }\n _out = left;\n // NB: crc32 stored as signed 32-bit int, zswap32 returns signed too\n if ((state.wrap & 4) && (state.flags ? hold : zswap32(hold)) !== state.check) {\n strm.msg = 'incorrect data check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: check matches trailer\\n\"));\n }\n state.mode = LENGTH;\n /* falls through */\n case LENGTH:\n if (state.wrap && state.flags) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) { break inf_leave; }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((state.wrap & 4) && hold !== (state.total & 0xffffffff)) {\n strm.msg = 'incorrect length check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: length matches trailer\\n\"));\n }\n state.mode = DONE;\n /* falls through */\n case DONE:\n ret = Z_STREAM_END$1;\n break inf_leave;\n case BAD:\n ret = Z_DATA_ERROR$1;\n break inf_leave;\n case MEM:\n return Z_MEM_ERROR$1;\n case SYNC:\n /* falls through */\n default:\n return Z_STREAM_ERROR$1;\n }\n }\n\n // inf_leave <- here is real place for \"goto inf_leave\", emulated via \"break inf_leave\"\n\n /*\n Return from inflate(), updating the total counts and the check value.\n If there was no progress during the inflate() call, return a buffer\n error. Call updatewindow() to create and/or update the window state.\n Note: a memory error from inflate() is non-recoverable.\n */\n\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n\n if (state.wsize || (_out !== strm.avail_out && state.mode < BAD &&\n (state.mode < CHECK || flush !== Z_FINISH$1))) {\n if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) ;\n }\n _in -= strm.avail_in;\n _out -= strm.avail_out;\n strm.total_in += _in;\n strm.total_out += _out;\n state.total += _out;\n if ((state.wrap & 4) && _out) {\n strm.adler = state.check = /*UPDATE_CHECK(state.check, strm.next_out - _out, _out);*/\n (state.flags ? crc32_1(state.check, output, _out, strm.next_out - _out) : adler32_1(state.check, output, _out, strm.next_out - _out));\n }\n strm.data_type = state.bits + (state.last ? 64 : 0) +\n (state.mode === TYPE ? 128 : 0) +\n (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0);\n if (((_in === 0 && _out === 0) || flush === Z_FINISH$1) && ret === Z_OK$1) {\n ret = Z_BUF_ERROR;\n }\n return ret;\n};\n\n\nconst inflateEnd = (strm) => {\n\n if (inflateStateCheck(strm)) {\n return Z_STREAM_ERROR$1;\n }\n\n let state = strm.state;\n if (state.window) {\n state.window = null;\n }\n strm.state = null;\n return Z_OK$1;\n};\n\n\nconst inflateGetHeader = (strm, head) => {\n\n /* check state */\n if (inflateStateCheck(strm)) { return Z_STREAM_ERROR$1; }\n const state = strm.state;\n if ((state.wrap & 2) === 0) { return Z_STREAM_ERROR$1; }\n\n /* save header structure */\n state.head = head;\n head.done = false;\n return Z_OK$1;\n};\n\n\nconst inflateSetDictionary = (strm, dictionary) => {\n const dictLength = dictionary.length;\n\n let state;\n let dictid;\n let ret;\n\n /* check state */\n if (inflateStateCheck(strm)) { return Z_STREAM_ERROR$1; }\n state = strm.state;\n\n if (state.wrap !== 0 && state.mode !== DICT) {\n return Z_STREAM_ERROR$1;\n }\n\n /* check for correct dictionary identifier */\n if (state.mode === DICT) {\n dictid = 1; /* adler32(0, null, 0)*/\n /* dictid = adler32(dictid, dictionary, dictLength); */\n dictid = adler32_1(dictid, dictionary, dictLength, 0);\n if (dictid !== state.check) {\n return Z_DATA_ERROR$1;\n }\n }\n /* copy dictionary to window using updatewindow(), which will amend the\n existing dictionary if appropriate */\n ret = updatewindow(strm, dictionary, dictLength, dictLength);\n if (ret) {\n state.mode = MEM;\n return Z_MEM_ERROR$1;\n }\n state.havedict = 1;\n // Tracev((stderr, \"inflate: dictionary set\\n\"));\n return Z_OK$1;\n};\n\n\nvar inflateReset_1 = inflateReset;\nvar inflateReset2_1 = inflateReset2;\nvar inflateResetKeep_1 = inflateResetKeep;\nvar inflateInit_1 = inflateInit;\nvar inflateInit2_1 = inflateInit2;\nvar inflate_2$1 = inflate$2;\nvar inflateEnd_1 = inflateEnd;\nvar inflateGetHeader_1 = inflateGetHeader;\nvar inflateSetDictionary_1 = inflateSetDictionary;\nvar inflateInfo = 'pako inflate (from Nodeca project)';\n\n/* Not implemented\nmodule.exports.inflateCodesUsed = inflateCodesUsed;\nmodule.exports.inflateCopy = inflateCopy;\nmodule.exports.inflateGetDictionary = inflateGetDictionary;\nmodule.exports.inflateMark = inflateMark;\nmodule.exports.inflatePrime = inflatePrime;\nmodule.exports.inflateSync = inflateSync;\nmodule.exports.inflateSyncPoint = inflateSyncPoint;\nmodule.exports.inflateUndermine = inflateUndermine;\nmodule.exports.inflateValidate = inflateValidate;\n*/\n\nvar inflate_1$2 = {\n\tinflateReset: inflateReset_1,\n\tinflateReset2: inflateReset2_1,\n\tinflateResetKeep: inflateResetKeep_1,\n\tinflateInit: inflateInit_1,\n\tinflateInit2: inflateInit2_1,\n\tinflate: inflate_2$1,\n\tinflateEnd: inflateEnd_1,\n\tinflateGetHeader: inflateGetHeader_1,\n\tinflateSetDictionary: inflateSetDictionary_1,\n\tinflateInfo: inflateInfo\n};\n\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n\nfunction GZheader() {\n /* true if compressed data believed to be text */\n this.text = 0;\n /* modification time */\n this.time = 0;\n /* extra flags (not used when writing a gzip file) */\n this.xflags = 0;\n /* operating system */\n this.os = 0;\n /* pointer to extra field or Z_NULL if none */\n this.extra = null;\n /* extra field length (valid if extra != Z_NULL) */\n this.extra_len = 0; // Actually, we don't need it in JS,\n // but leave for few code modifications\n\n //\n // Setup limits is not necessary because in js we should not preallocate memory\n // for inflate use constant limit in 65536 bytes\n //\n\n /* space at extra (only when reading header) */\n // this.extra_max = 0;\n /* pointer to zero-terminated file name or Z_NULL */\n this.name = '';\n /* space at name (only when reading header) */\n // this.name_max = 0;\n /* pointer to zero-terminated comment or Z_NULL */\n this.comment = '';\n /* space at comment (only when reading header) */\n // this.comm_max = 0;\n /* true if there was or will be a header crc */\n this.hcrc = 0;\n /* true when done reading gzip header (not used when writing a gzip file) */\n this.done = false;\n}\n\nvar gzheader = GZheader;\n\nconst toString = Object.prototype.toString;\n\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n\nconst {\n Z_NO_FLUSH, Z_FINISH,\n Z_OK, Z_STREAM_END, Z_NEED_DICT, Z_STREAM_ERROR, Z_DATA_ERROR, Z_MEM_ERROR\n} = constants$2;\n\n/* ===========================================================================*/\n\n\n/**\n * class Inflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[inflate]]\n * and [[inflateRaw]].\n **/\n\n/* internal\n * inflate.chunks -> Array\n *\n * Chunks of output data, if [[Inflate#onData]] not overridden.\n **/\n\n/**\n * Inflate.result -> Uint8Array|String\n *\n * Uncompressed result, generated by default [[Inflate#onData]]\n * and [[Inflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Inflate#push]] with `Z_FINISH` / `true` param).\n **/\n\n/**\n * Inflate.err -> Number\n *\n * Error code after inflate finished. 0 (Z_OK) on success.\n * Should be checked if broken data possible.\n **/\n\n/**\n * Inflate.msg -> String\n *\n * Error message, if [[Inflate.err]] != 0\n **/\n\n\n/**\n * new Inflate(options)\n * - options (Object): zlib inflate options.\n *\n * Creates new inflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `windowBits`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw inflate\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n * By default, when no options set, autodetect deflate/gzip data format via\n * wrapper header.\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako')\n * const chunk1 = new Uint8Array([1,2,3,4,5,6,7,8,9])\n * const chunk2 = new Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * const inflate = new pako.Inflate({ level: 3});\n *\n * inflate.push(chunk1, false);\n * inflate.push(chunk2, true); // true -> last chunk\n *\n * if (inflate.err) { throw new Error(inflate.err); }\n *\n * console.log(inflate.result);\n * ```\n **/\nfunction Inflate$1(options) {\n this.options = common.assign({\n chunkSize: 1024 * 64,\n windowBits: 15,\n to: ''\n }, options || {});\n\n const opt = this.options;\n\n // Force window size for `raw` data, if not set directly,\n // because we have no header for autodetect.\n if (opt.raw && (opt.windowBits >= 0) && (opt.windowBits < 16)) {\n opt.windowBits = -opt.windowBits;\n if (opt.windowBits === 0) { opt.windowBits = -15; }\n }\n\n // If `windowBits` not defined (and mode not raw) - set autodetect flag for gzip/deflate\n if ((opt.windowBits >= 0) && (opt.windowBits < 16) &&\n !(options && options.windowBits)) {\n opt.windowBits += 32;\n }\n\n // Gzip header has no info about windows size, we can do autodetect only\n // for deflate. So, if window size not set, force it to max when gzip possible\n if ((opt.windowBits > 15) && (opt.windowBits < 48)) {\n // bit 3 (16) -> gzipped data\n // bit 4 (32) -> autodetect gzip/deflate\n if ((opt.windowBits & 15) === 0) {\n opt.windowBits |= 15;\n }\n }\n\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n\n this.strm = new zstream();\n this.strm.avail_out = 0;\n\n let status = inflate_1$2.inflateInit2(\n this.strm,\n opt.windowBits\n );\n\n if (status !== Z_OK) {\n throw new Error(messages[status]);\n }\n\n this.header = new gzheader();\n\n inflate_1$2.inflateGetHeader(this.strm, this.header);\n\n // Setup dictionary\n if (opt.dictionary) {\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n opt.dictionary = strings.string2buf(opt.dictionary);\n } else if (toString.call(opt.dictionary) === '[object ArrayBuffer]') {\n opt.dictionary = new Uint8Array(opt.dictionary);\n }\n if (opt.raw) { //In raw mode we need to set the dictionary early\n status = inflate_1$2.inflateSetDictionary(this.strm, opt.dictionary);\n if (status !== Z_OK) {\n throw new Error(messages[status]);\n }\n }\n }\n}\n\n/**\n * Inflate#push(data[, flush_mode]) -> Boolean\n * - data (Uint8Array|ArrayBuffer): input data\n * - flush_mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE\n * flush modes. See constants. Skipped or `false` means Z_NO_FLUSH,\n * `true` means Z_FINISH.\n *\n * Sends input data to inflate pipe, generating [[Inflate#onData]] calls with\n * new output chunks. Returns `true` on success. If end of stream detected,\n * [[Inflate#onEnd]] will be called.\n *\n * `flush_mode` is not needed for normal operation, because end of stream\n * detected automatically. You may try to use it for advanced things, but\n * this functionality was not tested.\n *\n * On fail call [[Inflate#onEnd]] with error code and return false.\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\nInflate$1.prototype.push = function (data, flush_mode) {\n const strm = this.strm;\n const chunkSize = this.options.chunkSize;\n const dictionary = this.options.dictionary;\n let status, _flush_mode, last_avail_out;\n\n if (this.ended) return false;\n\n if (flush_mode === ~~flush_mode) _flush_mode = flush_mode;\n else _flush_mode = flush_mode === true ? Z_FINISH : Z_NO_FLUSH;\n\n // Convert data if needed\n if (toString.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n } else {\n strm.input = data;\n }\n\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n\n for (;;) {\n if (strm.avail_out === 0) {\n strm.output = new Uint8Array(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n\n status = inflate_1$2.inflate(strm, _flush_mode);\n\n if (status === Z_NEED_DICT && dictionary) {\n status = inflate_1$2.inflateSetDictionary(strm, dictionary);\n\n if (status === Z_OK) {\n status = inflate_1$2.inflate(strm, _flush_mode);\n } else if (status === Z_DATA_ERROR) {\n // Replace code with more verbose\n status = Z_NEED_DICT;\n }\n }\n\n // Skip snyc markers if more data follows and not raw mode\n while (strm.avail_in > 0 &&\n status === Z_STREAM_END &&\n strm.state.wrap > 0 &&\n data[strm.next_in] !== 0)\n {\n inflate_1$2.inflateReset(strm);\n status = inflate_1$2.inflate(strm, _flush_mode);\n }\n\n switch (status) {\n case Z_STREAM_ERROR:\n case Z_DATA_ERROR:\n case Z_NEED_DICT:\n case Z_MEM_ERROR:\n this.onEnd(status);\n this.ended = true;\n return false;\n }\n\n // Remember real `avail_out` value, because we may patch out buffer content\n // to align utf8 strings boundaries.\n last_avail_out = strm.avail_out;\n\n if (strm.next_out) {\n if (strm.avail_out === 0 || status === Z_STREAM_END) {\n\n if (this.options.to === 'string') {\n\n let next_out_utf8 = strings.utf8border(strm.output, strm.next_out);\n\n let tail = strm.next_out - next_out_utf8;\n let utf8str = strings.buf2string(strm.output, next_out_utf8);\n\n // move tail & realign counters\n strm.next_out = tail;\n strm.avail_out = chunkSize - tail;\n if (tail) strm.output.set(strm.output.subarray(next_out_utf8, next_out_utf8 + tail), 0);\n\n this.onData(utf8str);\n\n } else {\n this.onData(strm.output.length === strm.next_out ? strm.output : strm.output.subarray(0, strm.next_out));\n }\n }\n }\n\n // Must repeat iteration if out buffer is full\n if (status === Z_OK && last_avail_out === 0) continue;\n\n // Finalize if end of stream reached.\n if (status === Z_STREAM_END) {\n status = inflate_1$2.inflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return true;\n }\n\n if (strm.avail_in === 0) break;\n }\n\n return true;\n};\n\n\n/**\n * Inflate#onData(chunk) -> Void\n * - chunk (Uint8Array|String): output data. When string output requested,\n * each chunk will be string.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\nInflate$1.prototype.onData = function (chunk) {\n this.chunks.push(chunk);\n};\n\n\n/**\n * Inflate#onEnd(status) -> Void\n * - status (Number): inflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called either after you tell inflate that the input stream is\n * complete (Z_FINISH). By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\nInflate$1.prototype.onEnd = function (status) {\n // On success - join\n if (status === Z_OK) {\n if (this.options.to === 'string') {\n this.result = this.chunks.join('');\n } else {\n this.result = common.flattenChunks(this.chunks);\n }\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n};\n\n\n/**\n * inflate(data[, options]) -> Uint8Array|String\n * - data (Uint8Array|ArrayBuffer): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Decompress `data` with inflate/ungzip and `options`. Autodetect\n * format via wrapper header by default. That's why we don't provide\n * separate `ungzip` method.\n *\n * Supported options are:\n *\n * - windowBits\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n *\n * ##### Example:\n *\n * ```javascript\n * const pako = require('pako');\n * const input = pako.deflate(new Uint8Array([1,2,3,4,5,6,7,8,9]));\n * let output;\n *\n * try {\n * output = pako.inflate(input);\n * } catch (err) {\n * console.log(err);\n * }\n * ```\n **/\nfunction inflate$1(input, options) {\n const inflator = new Inflate$1(options);\n\n inflator.push(input);\n\n // That will never happens, if you don't cheat with options :)\n if (inflator.err) throw inflator.msg || messages[inflator.err];\n\n return inflator.result;\n}\n\n\n/**\n * inflateRaw(data[, options]) -> Uint8Array|String\n * - data (Uint8Array|ArrayBuffer): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * The same as [[inflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nfunction inflateRaw$1(input, options) {\n options = options || {};\n options.raw = true;\n return inflate$1(input, options);\n}\n\n\n/**\n * ungzip(data[, options]) -> Uint8Array|String\n * - data (Uint8Array|ArrayBuffer): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Just shortcut to [[inflate]], because it autodetects format\n * by header.content. Done for convenience.\n **/\n\n\nvar Inflate_1$1 = Inflate$1;\nvar inflate_2 = inflate$1;\nvar inflateRaw_1$1 = inflateRaw$1;\nvar ungzip$1 = inflate$1;\nvar constants = constants$2;\n\nvar inflate_1$1 = {\n\tInflate: Inflate_1$1,\n\tinflate: inflate_2,\n\tinflateRaw: inflateRaw_1$1,\n\tungzip: ungzip$1,\n\tconstants: constants\n};\n\nconst { Deflate, deflate, deflateRaw, gzip } = deflate_1$1;\n\nconst { Inflate, inflate, inflateRaw, ungzip } = inflate_1$1;\n\n\n\nvar Deflate_1 = Deflate;\nvar deflate_1 = deflate;\nvar deflateRaw_1 = deflateRaw;\nvar gzip_1 = gzip;\nvar Inflate_1 = Inflate;\nvar inflate_1 = inflate;\nvar inflateRaw_1 = inflateRaw;\nvar ungzip_1 = ungzip;\nvar constants_1 = constants$2;\n\nvar pako = {\n\tDeflate: Deflate_1,\n\tdeflate: deflate_1,\n\tdeflateRaw: deflateRaw_1,\n\tgzip: gzip_1,\n\tInflate: Inflate_1,\n\tinflate: inflate_1,\n\tinflateRaw: inflateRaw_1,\n\tungzip: ungzip_1,\n\tconstants: constants_1\n};\n\nexport { Deflate_1 as Deflate, Inflate_1 as Inflate, constants_1 as constants, pako as default, deflate_1 as deflate, deflateRaw_1 as deflateRaw, gzip_1 as gzip, inflate_1 as inflate, inflateRaw_1 as inflateRaw, ungzip_1 as ungzip };\n","import { PropsWithChildren, useEffect, useState, useCallback } from 'react'\nimport LoadingContent from 'components/LoadingContent'\nimport { Answer, CategoryGroup, Schema, Variable } from 'typings/filters'\nimport { Variables } from 'reducers/filtering/selectors'\nimport { useDispatch } from 'react-redux'\nimport { setFilterValues } from 'reducers/filtering/filterValues'\nimport { useFetchFilterValues } from 'hooks/useFetchFilterValues'\nimport { useFilters } from 'hooks/useFilters'\nimport pako from 'pako'\n\nconst isBase64 = (str: string) => {\n try {\n return btoa(atob(str)) === str\n } catch (err) {\n return false\n }\n}\n\nexport const decompressData = (compressedData: string) => {\n if (compressedData && isBase64(compressedData)) {\n const binaryString = atob(compressedData)\n const len = binaryString.length\n const bytes = new Uint8Array(len)\n for (let i = 0; i < len; i++) {\n bytes[i] = binaryString.charCodeAt(i)\n }\n const decompressedData = pako.inflate(bytes, { to: 'string' })\n return { filters: JSON.parse(decompressedData) }\n }\n}\n\nexport const LoadFilters = ({ children }: PropsWithChildren) => {\n const [shouldDisplayChildren, setShouldDisplayChildren] = useState(false)\n const dispatch = useDispatch()\n\n const { data: countryCIE, loading: loadingCountryCIE } = useFetchFilterValues(\n Variables.COUNTRY,\n Schema.CIE\n )\n const { data: productGroupCIE, loading: loadingProductGroupCIE } = useFetchFilterValues(\n Variables.PRODUCT_GROUP,\n Schema.CIE\n )\n const { data: liveCIE, loading: loadingLiveCIE } = useFetchFilterValues(\n Variables.TIME_FRAME_LIVE,\n Schema.CIE\n )\n const { data: yearlyCIE, loading: loadingYearlyCIE } = useFetchFilterValues(\n Variables.TIME_FRAME_YEARLY,\n Schema.CIE\n )\n const { data: reviewFilters, loading: reviewFiltersLoading } = useFilters(Schema.CIE_REVIEW)\n const finalReviewFilters = decompressData(reviewFilters?.filters)\n const loading = [\n loadingCountryCIE,\n loadingProductGroupCIE,\n loadingLiveCIE,\n loadingYearlyCIE,\n reviewFiltersLoading,\n ].some(Boolean)\n\n const dispatchFilterValues = useCallback(\n (variableId: number, schema: Schema, data: any, reviewFiltersMap?: Map) => {\n const values =\n schema === Schema.CIE_REVIEW\n ? reviewFiltersMap?.get(variableId)?.values\n : data?.filterValues\n dispatch(\n setFilterValues({\n variableId: variableId.toString() + schema,\n values: values as Answer[],\n })\n )\n },\n [dispatch]\n )\n\n useEffect(() => {\n if (loading) {\n return\n }\n const reviewFiltersMap = new Map()\n finalReviewFilters?.filters.forEach((obj: CategoryGroup) => {\n obj.categories.forEach((category) => {\n category.variables.forEach((variable) => {\n reviewFiltersMap.set(variable.variable_id, variable)\n })\n })\n })\n dispatchFilterValues(Variables.COUNTRY, Schema.CIE, countryCIE)\n dispatchFilterValues(Variables.PRODUCT_GROUP, Schema.CIE, productGroupCIE)\n dispatchFilterValues(Variables.TIME_FRAME_LIVE, Schema.CIE, liveCIE)\n dispatchFilterValues(Variables.TIME_FRAME_YEARLY, Schema.CIE, yearlyCIE)\n dispatchFilterValues(Variables.COUNTRY, Schema.CIE_REVIEW, null, reviewFiltersMap)\n dispatchFilterValues(Variables.PRODUCT_GROUP, Schema.CIE_REVIEW, null, reviewFiltersMap)\n dispatchFilterValues(Variables.TIME_FRAME_LIVE, Schema.CIE_REVIEW, null, reviewFiltersMap)\n dispatchFilterValues(Variables.TIME_FRAME_YEARLY, Schema.CIE_REVIEW, null, reviewFiltersMap)\n\n setShouldDisplayChildren(true)\n }, [loading, countryCIE, productGroupCIE, liveCIE, yearlyCIE, dispatchFilterValues])\n\n if (loading) {\n return \n }\n\n return <>{shouldDisplayChildren && children}\n}\n","import { useQuery } from '@apollo/client'\nimport { GET_ALL_FILTERS } from 'query/query'\nimport { useSelector } from 'react-redux'\nimport { selectUserSubscription } from 'reducers/subscription/selectors'\nimport { RootState } from 'reducers/store'\n\nexport const useFilters = (filterSchema: string) => {\n const context = useSelector((state: RootState) => selectUserSubscription(state))\n const { data, loading } = useQuery(GET_ALL_FILTERS, {\n variables: {\n schema: filterSchema,\n context,\n },\n fetchPolicy: 'network-only',\n nextFetchPolicy: 'cache-first',\n })\n return { data, loading }\n}\n","import { PropsWithChildren } from 'react'\nimport { useAppliedBaseFilters } from 'hooks/useAppliedBaseFilters'\nimport { feedback, feedbackV2 } from '@ecosystem/newron-design-system'\nimport { Cell } from 'reducers/subscription/user'\nimport { isEmpty } from 'lodash'\n\ninterface RouteRestrictionProps {\n codes?: ITEM_GROUP[]\n restrictionType: RESTRICTION_TYPE\n notInCodes?: ITEM_GROUP[]\n pageRestriction?: boolean\n}\nexport enum RESTRICTION_TYPE {\n ITEM_GROUP = 'itemGroup',\n COUNTRY = 'country',\n WAVE = 'wave',\n}\n\nexport enum ITEM_GROUP {\n HOT_BEVERAGE_MAKER = 'HotBeverageMaker',\n PRINTER = 'Printer',\n MOBILE_PHONE = 'MobilePhone',\n TV = 'TV',\n LAPTOP = 'Laptop',\n HEADPHONES = 'Headphones',\n HOMEASSISTANT = 'HomeAssistant',\n FR = 'FR',\n DE = 'DE',\n UK = 'UK',\n RU = 'RU',\n IN = 'IN',\n TABLET = 'Tablet',\n VACUUM_CLEANER = 'VacuumCleaner',\n DIGITAL_CAMERAS = 'DigitalCameraCamcorder',\n DENTAL_CARE = 'dentalcare',\n TUMBLE_DRYER = 'TumbleDryer',\n COOKER_HOB = 'CookerHob',\n REFRIGERATOR = 'RefrigeratorsFreezers',\n DISHWASHER = 'Dishwasher',\n WASHING_MACHINE = 'WashingMachine',\n GAMING_CONSOLE = 'GamingConsole',\n HAIR_CARE = 'haircare',\n CORE_WEARABLES = 'smartwatch',\n SHAVERS = 'Shaver',\n FOOD_PREP = 'foodprep',\n}\n\nexport const hasNotValidAppliedFilters = (\n ids: string[],\n restrictionType: RESTRICTION_TYPE,\n marketFilters?: string[],\n productFilters?: string[]\n): boolean => {\n switch (restrictionType) {\n case RESTRICTION_TYPE.ITEM_GROUP: {\n const productAppliedFilters = productFilters?.filter((product) => !ids.includes(product))\n return !productAppliedFilters?.length\n }\n case RESTRICTION_TYPE.COUNTRY: {\n const contryRestriction = marketFilters?.filter((market) => !ids.includes(market))\n return !contryRestriction?.length\n }\n default:\n return false\n }\n}\nexport const hasValidSubcription = (\n ids: string[] | undefined,\n subscriptions: Cell[] | null,\n restrictionType: RESTRICTION_TYPE\n): boolean => {\n if (!subscriptions) return false\n\n if (isEmpty(subscriptions)) return true\n\n switch (restrictionType) {\n case RESTRICTION_TYPE.ITEM_GROUP:\n return !!subscriptions.filter((sub) => ids?.includes(sub.itemGroup)).length\n case RESTRICTION_TYPE.COUNTRY:\n return !!subscriptions.filter((sub) => ids?.includes(sub.country)).length\n case RESTRICTION_TYPE.WAVE:\n return !!subscriptions.flatMap((sub) => sub.waves.filter((wave) => ids?.includes(wave)))\n .length\n default:\n return false\n }\n}\nexport const hasValidAppliedFilters = (\n ids: string[] | undefined,\n restrictionType: RESTRICTION_TYPE,\n marketFilters?: string[],\n productFilters?: string[]\n): boolean => {\n switch (restrictionType) {\n case RESTRICTION_TYPE.ITEM_GROUP:\n return !!productFilters?.filter((product) => ids?.includes(product)).length\n case RESTRICTION_TYPE.COUNTRY:\n return !!marketFilters?.filter((market) => ids?.includes(market)).length\n\n default:\n return false\n }\n}\n\nexport const RouteRestriction = ({\n codes,\n restrictionType,\n children,\n notInCodes,\n pageRestriction,\n}: PropsWithChildren) => {\n const { Alert: InlineAlert } = feedbackV2\n const { countryFilters, productFilters } = useAppliedBaseFilters()\n const countries = countryFilters?.map((item) => item?.categoryName)\n const itemGroups = productFilters?.map((item) => item?.categoryName)\n if (notInCodes?.length) {\n return hasNotValidAppliedFilters(\n notInCodes,\n restrictionType,\n countries as string[],\n itemGroups as string[]\n ) ? (\n <>\n ) : (\n <>{children} \n )\n } else if (\n hasValidAppliedFilters(codes, restrictionType, countries as string[], itemGroups as string[])\n ) {\n return <>{children}\n } else if (pageRestriction) {\n return (\n \n )\n } else {\n return <>\n }\n}\n","import { ITEM_GROUP } from 'containers/RouteRestriction'\nimport {\n CROSS_SINGLE_AVERAGE_PRICE_REVENUE_QUERY,\n SOLITARY_SINGLE_SEGMENTATION_QUERY,\n} from 'query/query'\nimport { Options } from 'hooks/useSegmentLeaderboardKPIs'\n\nexport enum QueryType {\n PercentOfMarket,\n PercentOfSegment,\n WeightedUnits,\n AveragePrice,\n}\n\ninterface ColumnConfig {\n queryDocument: Options['queryDocument']\n dataAccessor: Options['dataAccessor']\n}\n\nconst queryTypeConfig: Record = {\n [QueryType.PercentOfMarket]: {\n queryDocument: SOLITARY_SINGLE_SEGMENTATION_QUERY,\n dataAccessor: 'marketShare',\n },\n [QueryType.PercentOfSegment]: {\n queryDocument: SOLITARY_SINGLE_SEGMENTATION_QUERY,\n dataAccessor: 'percent',\n },\n [QueryType.WeightedUnits]: {\n queryDocument: SOLITARY_SINGLE_SEGMENTATION_QUERY,\n dataAccessor: 'weighted',\n },\n [QueryType.AveragePrice]: {\n queryDocument: CROSS_SINGLE_AVERAGE_PRICE_REVENUE_QUERY,\n dataAccessor: 'average',\n },\n}\n\nexport type KPIColumn = Options & {\n label: string\n restrictions?: ITEM_GROUP[]\n}\n\nexport const kpiColumn = (\n label: string,\n queryType: QueryType,\n {\n crossVar,\n filters = [],\n hintText,\n }: { crossVar?: string; filters?: Options['filters']; hintText?: Options['hintText'] } = {},\n restrictions?: ITEM_GROUP[]\n): KPIColumn => ({\n ...queryTypeConfig[queryType],\n crossVar,\n filters,\n label,\n hintText,\n restrictions,\n})\n\nexport const kpiColumns: Tuple = [\n kpiColumn('Market Share', QueryType.PercentOfMarket),\n kpiColumn('No. of Units', QueryType.WeightedUnits),\n kpiColumn('Traditional shopper', QueryType.PercentOfSegment, {\n filters: [\n { variable_id: 27, answer_code: 3 }, // Advertising on social media\n { variable_id: 27, answer_code: 4 }, // Advertising online\n ],\n hintText: 'Proportion of Shoppers buying in-store.',\n }),\n kpiColumn('Digital shopper', QueryType.PercentOfSegment, {\n filters: [\n { variable_id: 27, answer_code: 1 }, // Advertising on TV\n { variable_id: 27, answer_code: 2 }, // Advertising in magazine / newspaper\n ],\n hintText: 'Proportion of Shoppers buying online.',\n }),\n kpiColumn('Digital ad trigger', QueryType.PercentOfSegment, {\n hintText: 'Proportion saying social media or online advertising inspired them to buy.',\n filters: [\n { variable_id: 691, answer_code: 1 }, // Yes\n ],\n }),\n kpiColumn('In-store trigger', QueryType.PercentOfSegment, {\n hintText:\n 'Proportion saying in-store staff, leaflets or display advertising inspired them to buy.',\n filters: [\n { variable_id: 692, answer_code: 1 }, // Yes\n ],\n }),\n kpiColumn('Price paid', QueryType.AveragePrice, {\n crossVar: 'globalPurchasePriceMidPoint',\n hintText: 'Average price paid (€).',\n }),\n kpiColumn(\n 'Price paid (Mobile)',\n QueryType.AveragePrice,\n {\n crossVar: 'mobileHandsetNSPMidPoint',\n hintText: 'Average price paid (€).',\n },\n [ITEM_GROUP.MOBILE_PHONE]\n ),\n kpiColumn('High price sensitivity', QueryType.PercentOfSegment, {\n filters: [\n { variable_id: 689, answer_code: 2 },\n { variable_id: 689, answer_code: 3 },\n { variable_id: 689, answer_code: 2920 },\n ],\n hintText:\n \"Price sensitivity is a typology derived from answers given across the survey. A scoring system is developed from mentions of 'Price' and 'Promotions' at key brand and retailer choice drivers questions as well as 'Price comparison site' usage. The more mentions of these, the higher the sensitivity score.\",\n }),\n kpiColumn('Retailers visited (2 or more)', QueryType.PercentOfSegment, {\n filters: [\n { variable_id: 695, answer_code: 2 }, // 2\n { variable_id: 695, answer_code: 3 }, // 3 or more\n ],\n hintText: 'Number of retailers visited in-store / online as part of purchase journey.',\n }),\n kpiColumn('Brands considered (3 or more)', QueryType.PercentOfSegment, {\n filters: [\n { variable_id: 683, answer_code: 3 }, // 3\n { variable_id: 683, answer_code: 4 }, // 4\n { variable_id: 683, answer_code: 2919 }, // 5 or more\n ],\n hintText: 'Number of brands considered during purchase journey.',\n }),\n kpiColumn('Brand is key', QueryType.PercentOfSegment, {\n hintText: \"Proportion mentioning 'Product brand' in their top 3 choice drivers.\",\n filters: [\n { variable_id: 697, answer_code: 1 }, // Yes\n ],\n }),\n kpiColumn('Features are key', QueryType.PercentOfSegment, {\n hintText: \"Proportion mentioning 'Product features' in their top 3 choice drivers.\",\n filters: [{ variable_id: 698, answer_code: 1 }], // Yes\n }),\n]\n\nexport const kpiTotalBase = kpiColumn('Total base', QueryType.PercentOfMarket)\n\nexport const productColumns = ['Price paid', 'Price paid (Mobile)']\n","import { useFilterSchema } from 'hooks/useFilterSchema'\nimport { useMemo } from 'react'\nimport { useSelector } from 'react-redux'\nimport { getAppliedFilters, Variables } from 'reducers/filtering/selectors'\nimport { RootState } from 'reducers/store'\nimport { CategoryGroupName } from 'typings/filters'\nimport { mapFiltersWithValues } from 'util/validateContext'\n\nexport const useAppliedBaseFilters = () => {\n const { filterSchema } = useFilterSchema()\n const appliedFilters = useSelector((state: RootState) => getAppliedFilters(state))\n\n const appliedFiltersBase = useMemo(\n () => (appliedFilters ?? {})[CategoryGroupName.General_Base],\n [appliedFilters]\n )\n\n const countryAnswers = useSelector(\n (state: RootState) => state.filters.filterValues[Variables.COUNTRY.toString() + filterSchema]\n )\n\n const productGroupsAnswers = useSelector(\n (state: RootState) =>\n state.filters.filterValues[Variables.PRODUCT_GROUP.toString() + filterSchema]\n )\n\n const productFilters = useMemo(() => {\n return mapFiltersWithValues(appliedFiltersBase, Variables.PRODUCT_GROUP, productGroupsAnswers)\n }, [appliedFiltersBase, productGroupsAnswers])\n const countryFilters = useMemo(() => {\n return mapFiltersWithValues(appliedFiltersBase, Variables.COUNTRY, countryAnswers)\n }, [appliedFiltersBase, countryAnswers])\n\n return {\n appliedFiltersBase,\n countryFilters,\n productGroupsAnswers,\n productFilters,\n }\n}\n","import {\n generalCategoryGroupLabelToName,\n generalCategoryGroupNames,\n productReviewCategoryGroupLabelToName,\n productReviewCategoryGroupNames,\n} from 'config/filters'\nimport { Location, Schema } from 'typings/filters'\nimport { useMemo } from 'react'\n\ntype FilterGroupNames = typeof generalCategoryGroupNames | typeof productReviewCategoryGroupNames\ntype FilterGroupLabels =\n | typeof generalCategoryGroupLabelToName\n | typeof productReviewCategoryGroupLabelToName\n\nconst keywordsToExclude = ['Product Sub Group 1', 'Product Sub Group 2', 'Product Sub Group 3']\nexport const useFilterSchema = (): {\n filterSchema: Schema\n filterGroupNames: FilterGroupNames\n filterGroupLabels: FilterGroupLabels\n invalidFilterGroupNames: FilterGroupNames\n invalidFilterSubGroupNames: string[] | string\n} => {\n const { pathname } = window.location\n const filterSchema = useMemo(\n () => (pathname === Location.PRODUCT_REVIEW ? Schema.CIE_REVIEW : Schema.CIE),\n [pathname]\n )\n\n const filterGroupNames = useMemo(\n () =>\n filterSchema === Schema.CIE ? generalCategoryGroupNames : productReviewCategoryGroupNames,\n [filterSchema]\n )\n\n const filterGroupLabels = useMemo(\n () =>\n filterSchema === Schema.CIE\n ? generalCategoryGroupLabelToName\n : productReviewCategoryGroupLabelToName,\n [filterSchema]\n )\n\n const invalidFilterGroupNames = useMemo(\n () =>\n filterSchema === Schema.CIE ? productReviewCategoryGroupNames : generalCategoryGroupNames,\n [filterSchema]\n )\n\n const invalidFilterSubGroupNames = useMemo(\n () => (pathname === Location.PRODUCT_REVIEW ? keywordsToExclude : ''),\n [pathname]\n )\n\n return {\n filterSchema,\n filterGroupNames,\n filterGroupLabels,\n invalidFilterGroupNames,\n invalidFilterSubGroupNames,\n }\n}\n","function _createForOfIteratorHelperLoose(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (it) return (it = it.call(o)).next.bind(it); if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; return function () { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }; } 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) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n// === Symbol Support ===\nvar hasSymbols = function () {\n return typeof Symbol === 'function';\n};\n\nvar hasSymbol = function (name) {\n return hasSymbols() && Boolean(Symbol[name]);\n};\n\nvar getSymbol = function (name) {\n return hasSymbol(name) ? Symbol[name] : '@@' + name;\n};\n\nif (hasSymbols() && !hasSymbol('observable')) {\n Symbol.observable = Symbol('observable');\n}\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}\n\nfunction getSpecies(obj) {\n var ctor = obj.constructor;\n\n if (ctor !== undefined) {\n ctor = ctor[SymbolSpecies];\n\n if (ctor === null) {\n ctor = undefined;\n }\n }\n\n return ctor !== undefined ? ctor : Observable;\n}\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}\n\nfunction enqueue(fn) {\n Promise.resolve().then(function () {\n try {\n fn();\n } catch (e) {\n hostReportError(e);\n }\n });\n}\n\nfunction cleanupSubscription(subscription) {\n var cleanup = subscription._cleanup;\n if (cleanup === undefined) return;\n subscription._cleanup = undefined;\n\n if (!cleanup) {\n return;\n }\n\n try {\n if (typeof cleanup === 'function') {\n cleanup();\n } else {\n var unsubscribe = getMethod(cleanup, 'unsubscribe');\n\n if (unsubscribe) {\n unsubscribe.call(cleanup);\n }\n }\n } catch (e) {\n hostReportError(e);\n }\n}\n\nfunction closeSubscription(subscription) {\n subscription._observer = undefined;\n subscription._queue = undefined;\n subscription._state = 'closed';\n}\n\nfunction flushSubscription(subscription) {\n var queue = subscription._queue;\n\n if (!queue) {\n return;\n }\n\n subscription._queue = undefined;\n subscription._state = 'ready';\n\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}\n\nfunction notifySubscription(subscription, type, value) {\n subscription._state = 'running';\n var observer = subscription._observer;\n\n try {\n var m = getMethod(observer, type);\n\n switch (type) {\n case 'next':\n if (m) m.call(observer, value);\n break;\n\n case 'error':\n closeSubscription(subscription);\n if (m) m.call(observer, value);else throw value;\n break;\n\n case 'complete':\n closeSubscription(subscription);\n if (m) m.call(observer);\n break;\n }\n } catch (e) {\n hostReportError(e);\n }\n\n if (subscription._state === 'closed') cleanupSubscription(subscription);else if (subscription._state === 'running') subscription._state = 'ready';\n}\n\nfunction onNotify(subscription, type, value) {\n if (subscription._state === 'closed') return;\n\n if (subscription._state === 'buffering') {\n subscription._queue.push({\n type: type,\n value: value\n });\n\n return;\n }\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\n notifySubscription(subscription, type, value);\n}\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\n try {\n this._cleanup = subscriber.call(undefined, subscriptionObserver);\n } catch (e) {\n subscriptionObserver.error(e);\n }\n\n if (this._state === 'initializing') this._state = 'ready';\n }\n\n var _proto = Subscription.prototype;\n\n _proto.unsubscribe = function unsubscribe() {\n if (this._state !== 'closed') {\n closeSubscription(this);\n cleanupSubscription(this);\n }\n };\n\n _createClass(Subscription, [{\n key: \"closed\",\n get: function () {\n return this._state === 'closed';\n }\n }]);\n\n return Subscription;\n}();\n\nvar SubscriptionObserver = /*#__PURE__*/function () {\n function SubscriptionObserver(subscription) {\n this._subscription = subscription;\n }\n\n var _proto2 = SubscriptionObserver.prototype;\n\n _proto2.next = function next(value) {\n onNotify(this._subscription, 'next', value);\n };\n\n _proto2.error = function error(value) {\n onNotify(this._subscription, 'error', value);\n };\n\n _proto2.complete = function complete() {\n onNotify(this._subscription, 'complete');\n };\n\n _createClass(SubscriptionObserver, [{\n key: \"closed\",\n get: function () {\n return this._subscription._state === 'closed';\n }\n }]);\n\n return SubscriptionObserver;\n}();\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\n var _proto3 = Observable.prototype;\n\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\n return new Subscription(observer, this._subscriber);\n };\n\n _proto3.forEach = function forEach(fn) {\n var _this = this;\n\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\n function done() {\n subscription.unsubscribe();\n resolve();\n }\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\n _proto3.map = function map(fn) {\n var _this2 = this;\n\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\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\n _proto3.filter = function filter(fn) {\n var _this3 = this;\n\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\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\n _proto3.reduce = function reduce(fn) {\n var _this4 = this;\n\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\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\n _proto3.concat = function concat() {\n var _this5 = this;\n\n for (var _len = arguments.length, sources = new Array(_len), _key = 0; _key < _len; _key++) {\n sources[_key] = arguments[_key];\n }\n\n var C = getSpecies(this);\n return new C(function (observer) {\n var subscription;\n var index = 0;\n\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\n startNext(_this5);\n return function () {\n if (subscription) {\n subscription.unsubscribe();\n subscription = undefined;\n }\n };\n });\n };\n\n _proto3.flatMap = function flatMap(fn) {\n var _this6 = this;\n\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\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\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\n function completeIfDone() {\n if (outer.closed && subscriptions.length === 0) observer.complete();\n }\n\n return function () {\n subscriptions.forEach(function (s) {\n return s.unsubscribe();\n });\n outer.unsubscribe();\n };\n });\n };\n\n _proto3[SymbolObservable] = function () {\n return this;\n };\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\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\n if (hasSymbol('iterator')) {\n method = getMethod(x, SymbolIterator);\n\n if (method) {\n return new C(function (observer) {\n enqueue(function () {\n if (observer.closed) return;\n\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\n observer.complete();\n });\n });\n }\n }\n\n if (Array.isArray(x)) {\n return new C(function (observer) {\n enqueue(function () {\n if (observer.closed) return;\n\n for (var i = 0; i < x.length; ++i) {\n observer.next(x[i]);\n if (observer.closed) return;\n }\n\n observer.complete();\n });\n });\n }\n\n throw new TypeError(x + ' is not observable');\n };\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\n var C = typeof this === 'function' ? this : Observable;\n return new C(function (observer) {\n enqueue(function () {\n if (observer.closed) return;\n\n for (var i = 0; i < items.length; ++i) {\n observer.next(items[i]);\n if (observer.closed) return;\n }\n\n observer.complete();\n });\n });\n };\n\n _createClass(Observable, null, [{\n key: SymbolSpecies,\n get: function () {\n return this;\n }\n }]);\n\n return Observable;\n}();\n\nif (hasSymbols()) {\n Object.defineProperty(Observable, Symbol('extensions'), {\n value: {\n symbol: SymbolObservable,\n hostReportError: hostReportError\n },\n configurable: true\n });\n}\n\nexport { Observable };\n","import { __assign, __spreadArray } from \"tslib\";\nimport { invariant, newInvariantError } from \"../globals/index.js\";\nexport function getFragmentQueryDocument(document, fragmentName) {\n var actualFragmentName = fragmentName;\n var fragments = [];\n document.definitions.forEach(function (definition) {\n if (definition.kind === \"OperationDefinition\") {\n throw newInvariantError(\n 70,\n definition.operation,\n definition.name ? \" named '\".concat(definition.name.value, \"'\") : \"\"\n );\n }\n if (definition.kind === \"FragmentDefinition\") {\n fragments.push(definition);\n }\n });\n if (typeof actualFragmentName === \"undefined\") {\n invariant(fragments.length === 1, 71, fragments.length);\n actualFragmentName = fragments[0].name.value;\n }\n var query = __assign(__assign({}, document), { definitions: __spreadArray([\n {\n kind: \"OperationDefinition\",\n operation: \"query\",\n selectionSet: {\n kind: \"SelectionSet\",\n selections: [\n {\n kind: \"FragmentSpread\",\n name: {\n kind: \"Name\",\n value: actualFragmentName,\n },\n },\n ],\n },\n }\n ], document.definitions, true) });\n return query;\n}\nexport function createFragmentMap(fragments) {\n if (fragments === void 0) { fragments = []; }\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 var fragmentName = selection.name.value;\n if (typeof fragmentMap === \"function\") {\n return fragmentMap(fragmentName);\n }\n var fragment = fragmentMap && fragmentMap[fragmentName];\n invariant(fragment, 72, fragmentName);\n return fragment || null;\n }\n default:\n return null;\n }\n}\n//# sourceMappingURL=fragments.js.map","import { newInvariantError } from \"../globals/index.js\";\nimport { isNonNullObject } from \"../common/objects.js\";\nimport { getFragmentFromSelection } from \"./fragments.js\";\nexport function makeReference(id) {\n return { __ref: String(id) };\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) &&\n value.kind === \"Document\" &&\n 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 }\n else if (isBooleanValue(value) || isStringValue(value)) {\n argObj[name.value] = value.value;\n }\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 }\n else if (isVariable(value)) {\n var variableValue = (variables || {})[value.name.value];\n argObj[name.value] = variableValue;\n }\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 }\n else if (isEnumValue(value)) {\n argObj[name.value] = value.value;\n }\n else if (isNullValue(value)) {\n argObj[name.value] = null;\n }\n else {\n throw newInvariantError(81, 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, 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, value = _a.value;\n return valueToObjectRepresentation(argObj, name, value, variables);\n });\n }\n return getStoreKeyName(field.name.value, argObj, directivesObj);\n}\nvar KNOWN_DIRECTIVES = [\n \"connection\",\n \"include\",\n \"skip\",\n \"client\",\n \"rest\",\n \"export\",\n \"nonreactive\",\n];\nexport var getStoreKeyName = Object.assign(function (fieldName, args, directives) {\n if (args &&\n directives &&\n directives[\"connection\"] &&\n directives[\"connection\"][\"key\"]) {\n if (directives[\"connection\"][\"filter\"] &&\n directives[\"connection\"][\"filter\"].length > 0) {\n var filterKeys = directives[\"connection\"][\"filter\"]\n ? directives[\"connection\"][\"filter\"]\n : [];\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(stringify(filteredArgs_1), \")\");\n }\n else {\n return directives[\"connection\"][\"key\"];\n }\n }\n var completeFieldName = fieldName;\n if (args) {\n var stringifiedArgs = stringify(args);\n completeFieldName += \"(\".concat(stringifiedArgs, \")\");\n }\n if (directives) {\n Object.keys(directives).forEach(function (key) {\n if (KNOWN_DIRECTIVES.indexOf(key) !== -1)\n return;\n if (directives[key] && Object.keys(directives[key]).length) {\n completeFieldName += \"@\".concat(key, \"(\").concat(stringify(directives[key]), \")\");\n }\n else {\n completeFieldName += \"@\".concat(key);\n }\n });\n }\n return completeFieldName;\n}, {\n setStringify: function (s) {\n var previous = stringify;\n stringify = s;\n return previous;\n },\n});\nvar stringify = function defaultStringify(value) {\n return JSON.stringify(value, stringifyReplacer);\n};\nfunction stringifyReplacer(_key, value) {\n if (isNonNullObject(value) && !Array.isArray(value)) {\n value = Object.keys(value)\n .sort()\n .reduce(function (copy, key) {\n copy[key] = value[key];\n return copy;\n }, {});\n }\n return value;\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, 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 }\n else if (fragments) {\n fragments.push(selection);\n }\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}\n//# sourceMappingURL=storeUtils.js.map","import { invariant, newInvariantError } from \"../globals/index.js\";\nimport { valueToObjectRepresentation } from \"./storeUtils.js\";\nexport function checkDocument(doc) {\n invariant(doc && doc.kind === \"Document\", 73);\n var operations = doc.definitions\n .filter(function (d) { return d.kind !== \"FragmentDefinition\"; })\n .map(function (definition) {\n if (definition.kind !== \"OperationDefinition\") {\n throw newInvariantError(74, definition.kind);\n }\n return definition;\n });\n invariant(operations.length <= 1, 75, 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\n .filter(function (definition) {\n return definition.kind === \"OperationDefinition\" && !!definition.name;\n })\n .map(function (x) { return x.name.value; })[0] || null);\n}\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\", 76);\n return queryDef;\n}\nexport function getFragmentDefinition(doc) {\n invariant(doc.kind === \"Document\", 77);\n invariant(doc.definitions.length <= 1, 78);\n var fragmentDef = doc.definitions[0];\n invariant(fragmentDef.kind === \"FragmentDefinition\", 79);\n return fragmentDef;\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\" ||\n operation === \"mutation\" ||\n operation === \"subscription\") {\n return definition;\n }\n }\n if (definition.kind === \"FragmentDefinition\" && !fragmentDefinition) {\n fragmentDefinition = definition;\n }\n }\n if (fragmentDefinition) {\n return fragmentDefinition;\n }\n throw newInvariantError(80);\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}\n//# sourceMappingURL=getFromAST.js.map","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 = (function () {\n function ApolloLink(request) {\n if (request)\n this.request = request;\n }\n ApolloLink.empty = function () {\n return new ApolloLink(function () { return Observable.of(); });\n };\n ApolloLink.from = function (links) {\n if (links.length === 0)\n return ApolloLink.empty();\n return links.map(toLink).reduce(function (x, y) { return x.concat(y); });\n };\n ApolloLink.split = function (test, left, right) {\n var leftLink = toLink(left);\n var rightLink = toLink(right || new ApolloLink(passthrough));\n if (isTerminating(leftLink) && isTerminating(rightLink)) {\n return new ApolloLink(function (operation) {\n return test(operation)\n ? leftLink.request(operation) || Observable.of()\n : rightLink.request(operation) || Observable.of();\n });\n }\n else {\n return new ApolloLink(function (operation, forward) {\n return test(operation)\n ? leftLink.request(operation, forward) || Observable.of()\n : rightLink.request(operation, forward) || Observable.of();\n });\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(35, firstLink);\n return firstLink;\n }\n var nextLink = toLink(second);\n if (isTerminating(nextLink)) {\n return new ApolloLink(function (operation) {\n return firstLink.request(operation, function (op) { return nextLink.request(op) || Observable.of(); }) || Observable.of();\n });\n }\n else {\n return 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 };\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(36);\n };\n ApolloLink.prototype.onError = function (error, observer) {\n if (observer && observer.error) {\n observer.error(error);\n return false;\n }\n throw error;\n };\n ApolloLink.prototype.setOnError = function (fn) {\n this.onError = fn;\n return this;\n };\n return ApolloLink;\n}());\nexport { ApolloLink };\n//# sourceMappingURL=ApolloLink.js.map","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 }\n else {\n context = __assign(__assign({}, context), next);\n }\n };\n var getContext = function () { return (__assign({}, context)); };\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}\n//# sourceMappingURL=createOperation.js.map","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 if (!transformedOperation.operationName) {\n transformedOperation.operationName =\n typeof transformedOperation.query !== \"string\"\n ? getOperationName(transformedOperation.query) || undefined\n : \"\";\n }\n return transformedOperation;\n}\n//# sourceMappingURL=transformOperation.js.map","import { newInvariantError } from \"../../utilities/globals/index.js\";\nexport function validateOperation(operation) {\n var OPERATION_FIELDS = [\n \"query\",\n \"operationName\",\n \"variables\",\n \"extensions\",\n \"context\",\n ];\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(43, key);\n }\n }\n return operation;\n}\n//# sourceMappingURL=validateOperation.js.map","import inspect from \"../jsutils/inspect.mjs\";\nimport { isNode } from \"./ast.mjs\";\n/**\n * A visitor is provided to visit, it contains the collection of\n * relevant functions to be called during the visitor's traversal.\n */\n\nexport var QueryDocumentKeys = {\n Name: [],\n Document: ['definitions'],\n OperationDefinition: ['name', 'variableDefinitions', 'directives', 'selectionSet'],\n VariableDefinition: ['variable', 'type', 'defaultValue', 'directives'],\n Variable: ['name'],\n SelectionSet: ['selections'],\n Field: ['alias', 'name', 'arguments', 'directives', 'selectionSet'],\n Argument: ['name', 'value'],\n FragmentSpread: ['name', 'directives'],\n InlineFragment: ['typeCondition', 'directives', 'selectionSet'],\n FragmentDefinition: ['name', // Note: fragment variable definitions are experimental and may be changed\n // or removed in the future.\n 'variableDefinitions', 'typeCondition', 'directives', 'selectionSet'],\n IntValue: [],\n FloatValue: [],\n StringValue: [],\n BooleanValue: [],\n NullValue: [],\n EnumValue: [],\n ListValue: ['values'],\n ObjectValue: ['fields'],\n ObjectField: ['name', 'value'],\n Directive: ['name', 'arguments'],\n NamedType: ['name'],\n ListType: ['type'],\n NonNullType: ['type'],\n SchemaDefinition: ['description', 'directives', 'operationTypes'],\n OperationTypeDefinition: ['type'],\n ScalarTypeDefinition: ['description', 'name', 'directives'],\n ObjectTypeDefinition: ['description', 'name', 'interfaces', 'directives', 'fields'],\n FieldDefinition: ['description', 'name', 'arguments', 'type', 'directives'],\n InputValueDefinition: ['description', 'name', 'type', 'defaultValue', 'directives'],\n InterfaceTypeDefinition: ['description', 'name', 'interfaces', 'directives', 'fields'],\n UnionTypeDefinition: ['description', 'name', 'directives', 'types'],\n EnumTypeDefinition: ['description', 'name', 'directives', 'values'],\n EnumValueDefinition: ['description', 'name', 'directives'],\n InputObjectTypeDefinition: ['description', 'name', 'directives', 'fields'],\n DirectiveDefinition: ['description', 'name', 'arguments', 'locations'],\n SchemaExtension: ['directives', 'operationTypes'],\n ScalarTypeExtension: ['name', 'directives'],\n ObjectTypeExtension: ['name', 'interfaces', 'directives', 'fields'],\n InterfaceTypeExtension: ['name', 'interfaces', 'directives', 'fields'],\n UnionTypeExtension: ['name', 'directives', 'types'],\n EnumTypeExtension: ['name', 'directives', 'values'],\n InputObjectTypeExtension: ['name', 'directives', 'fields']\n};\nexport var BREAK = Object.freeze({});\n/**\n * visit() will walk through an AST using a depth-first traversal, calling\n * the visitor's enter function at each node in the traversal, and calling the\n * leave function after visiting that node and all of its child nodes.\n *\n * By returning different values from the enter and leave functions, the\n * behavior of the visitor can be altered, including skipping over a sub-tree of\n * the AST (by returning false), editing the AST by returning a value or null\n * to remove the value, or to stop the whole traversal by returning BREAK.\n *\n * When using visit() to edit an AST, the original AST will not be modified, and\n * a new version of the AST with the changes applied will be returned from the\n * visit function.\n *\n * const editedAST = visit(ast, {\n * enter(node, key, parent, path, ancestors) {\n * // @return\n * // undefined: no action\n * // false: skip visiting this node\n * // visitor.BREAK: stop visiting altogether\n * // null: delete this node\n * // any value: replace this node with the returned value\n * },\n * leave(node, key, parent, path, ancestors) {\n * // @return\n * // undefined: no action\n * // false: no action\n * // visitor.BREAK: stop visiting altogether\n * // null: delete this node\n * // any value: replace this node with the returned value\n * }\n * });\n *\n * Alternatively to providing enter() and leave() functions, a visitor can\n * instead provide functions named the same as the kinds of AST nodes, or\n * enter/leave visitors at a named key, leading to four permutations of the\n * visitor API:\n *\n * 1) Named visitors triggered when entering a node of a specific kind.\n *\n * visit(ast, {\n * Kind(node) {\n * // enter the \"Kind\" node\n * }\n * })\n *\n * 2) Named visitors that trigger upon entering and leaving a node of\n * a specific kind.\n *\n * visit(ast, {\n * Kind: {\n * enter(node) {\n * // enter the \"Kind\" node\n * }\n * leave(node) {\n * // leave the \"Kind\" node\n * }\n * }\n * })\n *\n * 3) Generic visitors that trigger upon entering and leaving any node.\n *\n * visit(ast, {\n * enter(node) {\n * // enter any node\n * },\n * leave(node) {\n * // leave any node\n * }\n * })\n *\n * 4) Parallel visitors for entering and leaving nodes of a specific kind.\n *\n * visit(ast, {\n * enter: {\n * Kind(node) {\n * // enter the \"Kind\" node\n * }\n * },\n * leave: {\n * Kind(node) {\n * // leave the \"Kind\" node\n * }\n * }\n * })\n */\n\nexport function visit(root, visitor) {\n var visitorKeys = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : QueryDocumentKeys;\n\n /* eslint-disable no-undef-init */\n var stack = undefined;\n var inArray = Array.isArray(root);\n var keys = [root];\n var index = -1;\n var edits = [];\n var node = undefined;\n var key = undefined;\n var parent = undefined;\n var path = [];\n var ancestors = [];\n var newRoot = root;\n /* eslint-enable no-undef-init */\n\n do {\n index++;\n var isLeaving = index === keys.length;\n var isEdited = isLeaving && edits.length !== 0;\n\n if (isLeaving) {\n key = ancestors.length === 0 ? undefined : path[path.length - 1];\n node = parent;\n parent = ancestors.pop();\n\n if (isEdited) {\n if (inArray) {\n node = node.slice();\n } else {\n var clone = {};\n\n for (var _i2 = 0, _Object$keys2 = Object.keys(node); _i2 < _Object$keys2.length; _i2++) {\n var k = _Object$keys2[_i2];\n clone[k] = node[k];\n }\n\n node = clone;\n }\n\n var editOffset = 0;\n\n for (var ii = 0; ii < edits.length; ii++) {\n var editKey = edits[ii][0];\n var editValue = edits[ii][1];\n\n if (inArray) {\n editKey -= editOffset;\n }\n\n if (inArray && editValue === null) {\n node.splice(editKey, 1);\n editOffset++;\n } else {\n node[editKey] = editValue;\n }\n }\n }\n\n index = stack.index;\n keys = stack.keys;\n edits = stack.edits;\n inArray = stack.inArray;\n stack = stack.prev;\n } else {\n key = parent ? inArray ? index : keys[index] : undefined;\n node = parent ? parent[key] : newRoot;\n\n if (node === null || node === undefined) {\n continue;\n }\n\n if (parent) {\n path.push(key);\n }\n }\n\n var result = void 0;\n\n if (!Array.isArray(node)) {\n if (!isNode(node)) {\n throw new Error(\"Invalid AST Node: \".concat(inspect(node), \".\"));\n }\n\n var visitFn = getVisitFn(visitor, node.kind, isLeaving);\n\n if (visitFn) {\n result = visitFn.call(visitor, node, key, parent, path, ancestors);\n\n if (result === BREAK) {\n break;\n }\n\n if (result === false) {\n if (!isLeaving) {\n path.pop();\n continue;\n }\n } else if (result !== undefined) {\n edits.push([key, result]);\n\n if (!isLeaving) {\n if (isNode(result)) {\n node = result;\n } else {\n path.pop();\n continue;\n }\n }\n }\n }\n }\n\n if (result === undefined && isEdited) {\n edits.push([key, node]);\n }\n\n if (isLeaving) {\n path.pop();\n } else {\n var _visitorKeys$node$kin;\n\n stack = {\n inArray: inArray,\n index: index,\n keys: keys,\n edits: edits,\n prev: stack\n };\n inArray = Array.isArray(node);\n keys = inArray ? node : (_visitorKeys$node$kin = visitorKeys[node.kind]) !== null && _visitorKeys$node$kin !== void 0 ? _visitorKeys$node$kin : [];\n index = -1;\n edits = [];\n\n if (parent) {\n ancestors.push(parent);\n }\n\n parent = node;\n }\n } while (stack !== undefined);\n\n if (edits.length !== 0) {\n newRoot = edits[edits.length - 1][1];\n }\n\n return newRoot;\n}\n/**\n * Creates a new visitor instance which delegates to many visitors to run in\n * parallel. Each visitor will be visited for each node before moving on.\n *\n * If a prior visitor edits a node, no following visitors will see that node.\n */\n\nexport function visitInParallel(visitors) {\n var skipping = new Array(visitors.length);\n return {\n enter: function enter(node) {\n for (var i = 0; i < visitors.length; i++) {\n if (skipping[i] == null) {\n var fn = getVisitFn(visitors[i], node.kind,\n /* isLeaving */\n false);\n\n if (fn) {\n var result = fn.apply(visitors[i], arguments);\n\n if (result === false) {\n skipping[i] = node;\n } else if (result === BREAK) {\n skipping[i] = BREAK;\n } else if (result !== undefined) {\n return result;\n }\n }\n }\n }\n },\n leave: function leave(node) {\n for (var i = 0; i < visitors.length; i++) {\n if (skipping[i] == null) {\n var fn = getVisitFn(visitors[i], node.kind,\n /* isLeaving */\n true);\n\n if (fn) {\n var result = fn.apply(visitors[i], arguments);\n\n if (result === BREAK) {\n skipping[i] = BREAK;\n } else if (result !== undefined && result !== false) {\n return result;\n }\n }\n } else if (skipping[i] === node) {\n skipping[i] = null;\n }\n }\n }\n };\n}\n/**\n * Given a visitor instance, if it is leaving or not, and a node kind, return\n * the function the visitor runtime should call.\n */\n\nexport function getVisitFn(visitor, kind, isLeaving) {\n var kindVisitor = visitor[kind];\n\n if (kindVisitor) {\n if (!isLeaving && typeof kindVisitor === 'function') {\n // { Kind() {} }\n return kindVisitor;\n }\n\n var kindSpecificVisitor = isLeaving ? kindVisitor.leave : kindVisitor.enter;\n\n if (typeof kindSpecificVisitor === 'function') {\n // { Kind: { enter() {}, leave() {} } }\n return kindSpecificVisitor;\n }\n } else {\n var specificVisitor = isLeaving ? visitor.leave : visitor.enter;\n\n if (specificVisitor) {\n if (typeof specificVisitor === 'function') {\n // { enter() {}, leave() {} }\n return specificVisitor;\n }\n\n var specificKindVisitor = specificVisitor[kind];\n\n if (typeof specificKindVisitor === 'function') {\n // { enter: { Kind() {} }, leave: { Kind() {} } }\n return specificKindVisitor;\n }\n }\n }\n}\n","import { invariant } from \"../globals/index.js\";\nimport { visit, BREAK } 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, ifArgument = _a.ifArgument;\n var evaledValue = false;\n if (ifArgument.value.kind === \"Variable\") {\n evaledValue =\n variables && variables[ifArgument.value.name.value];\n invariant(evaledValue !== void 0, 66, directive.name.value);\n }\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 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))\n return;\n var directiveArguments = directive.arguments;\n var directiveName = directive.name.value;\n invariant(directiveArguments && directiveArguments.length === 1, 67, directiveName);\n var ifArgument = directiveArguments[0];\n invariant(ifArgument.name && ifArgument.name.value === \"if\", 68, directiveName);\n var ifValue = ifArgument.value;\n invariant(ifValue &&\n (ifValue.kind === \"Variable\" || ifValue.kind === \"BooleanValue\"), 69, directiveName);\n result.push({ directive: directive, ifArgument: ifArgument });\n });\n }\n return result;\n}\n//# sourceMappingURL=directives.js.map","import { newInvariantError } from \"../../utilities/globals/index.js\";\nexport var serializeFetchParameter = function (p, label) {\n var serialized;\n try {\n serialized = JSON.stringify(p);\n }\n catch (e) {\n var parseError = newInvariantError(39, label, e.message);\n parseError.parseError = e;\n throw parseError;\n }\n return serialized;\n};\n//# sourceMappingURL=serializeFetchParameter.js.map","import { 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//# sourceMappingURL=reader.js.map","import { 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 &&\n 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))\n body = response.body;\n if (isAsyncIterableIterator(body))\n return asyncIterator(body);\n if (isReadableStream(body))\n return readerIterator(body.getReader());\n if (isStreamableBlob(body)) {\n return readerIterator(body.stream().getReader());\n }\n if (isBlob(body))\n return promiseIterator(body.arrayBuffer());\n if (isNodeReadableStream(body))\n return nodeStreamIterator(body);\n throw new Error(\"Unknown body type for responseIterator. Please pass a streamable response.\");\n}\n//# sourceMappingURL=responseIterator.js.map","export 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 },\n _a[Symbol.asyncIterator] = function () {\n return this;\n },\n _a;\n}\n//# sourceMappingURL=async.js.map","import { canUseAsyncIteratorSymbol } from \"../../../utilities/index.js\";\nexport default function promiseIterator(promise) {\n var resolved = false;\n var iterator = {\n next: function () {\n if (resolved)\n return Promise.resolve({\n value: undefined,\n done: true,\n });\n resolved = true;\n return new Promise(function (resolve, reject) {\n promise\n .then(function (value) {\n resolve({ value: value, 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}\n//# sourceMappingURL=promise.js.map","import { 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)\n return;\n if (waiting.length) {\n var shiftedArr = waiting.shift();\n if (Array.isArray(shiftedArr) && shiftedArr[0]) {\n return shiftedArr[0]({ value: chunk, done: false });\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]({ value: undefined, done: true });\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)\n return reject(error);\n if (data.length)\n return resolve({ value: data.shift(), done: false });\n if (done)\n return resolve({ value: undefined, done: true });\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//# sourceMappingURL=nodeStream.js.map","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};\n//# sourceMappingURL=throwServerError.js.map","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}\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 = (function () {\n function DeepMerger(reconciler) {\n if (reconciler === void 0) { reconciler = defaultReconciler; }\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,\n source,\n sourceKey], context, false));\n if (result !== targetValue) {\n target = _this.shallowCopyForMerge(target);\n target[sourceKey] = result;\n }\n }\n }\n else {\n target = _this.shallowCopyForMerge(target);\n target[sourceKey] = source[sourceKey];\n }\n });\n return target;\n }\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 }\n else {\n value = __assign({ __proto__: Object.getPrototypeOf(value) }, value);\n }\n this.pastCopies.add(value);\n }\n }\n return value;\n };\n return DeepMerger;\n}());\nexport { DeepMerger };\n//# sourceMappingURL=mergeDeep.js.map","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) ||\n isExecutionPatchInitialResult(value));\n}\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) &&\n isNonEmptyArray(result.incremental)) {\n result.incremental.forEach(function (_a) {\n var data = _a.data, 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}\n//# sourceMappingURL=incrementalResult.js.map","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 var _a;\n return __awaiter(this, void 0, void 0, function () {\n var decoder, contentType, delimiter, boundaryVal, boundary, buffer, iterator, running, _b, value, done, chunk, searchFrom, bi, message, i, headers, contentType_1, body, result, next;\n var _c, _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 = (_a = response.headers) === null || _a === void 0 ? void 0 : _a.get(\"content-type\");\n delimiter = \"boundary=\";\n boundaryVal = (contentType === null || contentType === void 0 ? void 0 : contentType.includes(delimiter))\n ? 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 : \"-\";\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, 3];\n return [4, iterator.next()];\n case 2:\n _b = _e.sent(), value = _b.value, done = _b.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 _c = [\n buffer.slice(0, bi),\n buffer.slice(bi + boundary.length),\n ], message = _c[0], buffer = _c[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 &&\n 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 ||\n \"data\" in result ||\n \"incremental\" in result ||\n \"errors\" in result ||\n \"payload\" in result) {\n if (isApolloPayloadResult(result)) {\n next = {};\n if (\"payload\" in result) {\n next = __assign({}, result.payload);\n }\n if (\"errors\" in result) {\n next = __assign(__assign({}, next), { extensions: __assign(__assign({}, (\"extensions\" in next ? next.extensions : null)), (_d = {}, _d[PROTOCOL_ERRORS_SYMBOL] = result.errors, _d)) });\n }\n nextValue(next);\n }\n else {\n nextValue(result);\n }\n }\n else if (Object.keys(result).length === 1 &&\n \"hasNext\" in result &&\n !result.hasNext) {\n return [2];\n }\n }\n bi = buffer.indexOf(boundary);\n }\n return [3, 1];\n case 3: return [2];\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 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 var getResult = function () {\n try {\n return JSON.parse(bodyText);\n }\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 }\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 (err.result && err.result.errors && err.result.data) {\n observer.next(err.result);\n }\n observer.error(err);\n}\nexport function parseAndCheckHttpResponse(operations) {\n return function (response) {\n return response\n .text()\n .then(function (bodyText) { return parseJsonBody(response, bodyText); })\n .then(function (result) {\n if (response.status >= 300) {\n throwServerError(response, result, \"Response not successful: Received status code \".concat(response.status));\n }\n if (!Array.isArray(result) &&\n !hasOwnProperty.call(result, \"data\") &&\n !hasOwnProperty.call(result, \"errors\")) {\n throwServerError(response, result, \"Server response was missing for query '\".concat(Array.isArray(operations)\n ? operations.map(function (op) { return op.operationName; })\n : operations.operationName, \"'.\"));\n }\n return result;\n });\n };\n}\n//# sourceMappingURL=parseAndCheckHttpResponse.js.map","import { newInvariantError } from \"../../utilities/globals/index.js\";\nexport var checkFetcher = function (fetcher) {\n if (!fetcher && typeof fetch === \"undefined\") {\n throw newInvariantError(37);\n }\n};\n//# sourceMappingURL=checkFetcher.js.map","import { visit } from \"./visitor.mjs\";\nimport { printBlockString } from \"./blockString.mjs\";\n/**\n * Converts an AST into a string, using one set of reasonable\n * formatting rules.\n */\n\nexport function print(ast) {\n return visit(ast, {\n leave: printDocASTReducer\n });\n}\nvar MAX_LINE_LENGTH = 80; // TODO: provide better type coverage in future\n\nvar printDocASTReducer = {\n Name: function Name(node) {\n return node.value;\n },\n Variable: function Variable(node) {\n return '$' + node.name;\n },\n // Document\n Document: function Document(node) {\n return join(node.definitions, '\\n\\n') + '\\n';\n },\n OperationDefinition: function OperationDefinition(node) {\n var op = node.operation;\n var name = node.name;\n var varDefs = wrap('(', join(node.variableDefinitions, ', '), ')');\n var directives = join(node.directives, ' ');\n var selectionSet = node.selectionSet; // Anonymous queries with no directives or variable definitions can use\n // the query short form.\n\n return !name && !directives && !varDefs && op === 'query' ? selectionSet : join([op, join([name, varDefs]), directives, selectionSet], ' ');\n },\n VariableDefinition: function VariableDefinition(_ref) {\n var variable = _ref.variable,\n type = _ref.type,\n defaultValue = _ref.defaultValue,\n directives = _ref.directives;\n return variable + ': ' + type + wrap(' = ', defaultValue) + wrap(' ', join(directives, ' '));\n },\n SelectionSet: function SelectionSet(_ref2) {\n var selections = _ref2.selections;\n return block(selections);\n },\n Field: function Field(_ref3) {\n var alias = _ref3.alias,\n name = _ref3.name,\n args = _ref3.arguments,\n directives = _ref3.directives,\n selectionSet = _ref3.selectionSet;\n var prefix = wrap('', alias, ': ') + name;\n var argsLine = prefix + wrap('(', join(args, ', '), ')');\n\n if (argsLine.length > MAX_LINE_LENGTH) {\n argsLine = prefix + wrap('(\\n', indent(join(args, '\\n')), '\\n)');\n }\n\n return join([argsLine, join(directives, ' '), selectionSet], ' ');\n },\n Argument: function Argument(_ref4) {\n var name = _ref4.name,\n value = _ref4.value;\n return name + ': ' + value;\n },\n // Fragments\n FragmentSpread: function FragmentSpread(_ref5) {\n var name = _ref5.name,\n directives = _ref5.directives;\n return '...' + name + wrap(' ', join(directives, ' '));\n },\n InlineFragment: function InlineFragment(_ref6) {\n var typeCondition = _ref6.typeCondition,\n directives = _ref6.directives,\n selectionSet = _ref6.selectionSet;\n return join(['...', wrap('on ', typeCondition), join(directives, ' '), selectionSet], ' ');\n },\n FragmentDefinition: function FragmentDefinition(_ref7) {\n var name = _ref7.name,\n typeCondition = _ref7.typeCondition,\n variableDefinitions = _ref7.variableDefinitions,\n directives = _ref7.directives,\n selectionSet = _ref7.selectionSet;\n return (// Note: fragment variable definitions are experimental and may be changed\n // or removed in the future.\n \"fragment \".concat(name).concat(wrap('(', join(variableDefinitions, ', '), ')'), \" \") + \"on \".concat(typeCondition, \" \").concat(wrap('', join(directives, ' '), ' ')) + selectionSet\n );\n },\n // Value\n IntValue: function IntValue(_ref8) {\n var value = _ref8.value;\n return value;\n },\n FloatValue: function FloatValue(_ref9) {\n var value = _ref9.value;\n return value;\n },\n StringValue: function StringValue(_ref10, key) {\n var value = _ref10.value,\n isBlockString = _ref10.block;\n return isBlockString ? printBlockString(value, key === 'description' ? '' : ' ') : JSON.stringify(value);\n },\n BooleanValue: function BooleanValue(_ref11) {\n var value = _ref11.value;\n return value ? 'true' : 'false';\n },\n NullValue: function NullValue() {\n return 'null';\n },\n EnumValue: function EnumValue(_ref12) {\n var value = _ref12.value;\n return value;\n },\n ListValue: function ListValue(_ref13) {\n var values = _ref13.values;\n return '[' + join(values, ', ') + ']';\n },\n ObjectValue: function ObjectValue(_ref14) {\n var fields = _ref14.fields;\n return '{' + join(fields, ', ') + '}';\n },\n ObjectField: function ObjectField(_ref15) {\n var name = _ref15.name,\n value = _ref15.value;\n return name + ': ' + value;\n },\n // Directive\n Directive: function Directive(_ref16) {\n var name = _ref16.name,\n args = _ref16.arguments;\n return '@' + name + wrap('(', join(args, ', '), ')');\n },\n // Type\n NamedType: function NamedType(_ref17) {\n var name = _ref17.name;\n return name;\n },\n ListType: function ListType(_ref18) {\n var type = _ref18.type;\n return '[' + type + ']';\n },\n NonNullType: function NonNullType(_ref19) {\n var type = _ref19.type;\n return type + '!';\n },\n // Type System Definitions\n SchemaDefinition: addDescription(function (_ref20) {\n var directives = _ref20.directives,\n operationTypes = _ref20.operationTypes;\n return join(['schema', join(directives, ' '), block(operationTypes)], ' ');\n }),\n OperationTypeDefinition: function OperationTypeDefinition(_ref21) {\n var operation = _ref21.operation,\n type = _ref21.type;\n return operation + ': ' + type;\n },\n ScalarTypeDefinition: addDescription(function (_ref22) {\n var name = _ref22.name,\n directives = _ref22.directives;\n return join(['scalar', name, join(directives, ' ')], ' ');\n }),\n ObjectTypeDefinition: addDescription(function (_ref23) {\n var name = _ref23.name,\n interfaces = _ref23.interfaces,\n directives = _ref23.directives,\n fields = _ref23.fields;\n return join(['type', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n }),\n FieldDefinition: addDescription(function (_ref24) {\n var name = _ref24.name,\n args = _ref24.arguments,\n type = _ref24.type,\n directives = _ref24.directives;\n return name + (hasMultilineItems(args) ? wrap('(\\n', indent(join(args, '\\n')), '\\n)') : wrap('(', join(args, ', '), ')')) + ': ' + type + wrap(' ', join(directives, ' '));\n }),\n InputValueDefinition: addDescription(function (_ref25) {\n var name = _ref25.name,\n type = _ref25.type,\n defaultValue = _ref25.defaultValue,\n directives = _ref25.directives;\n return join([name + ': ' + type, wrap('= ', defaultValue), join(directives, ' ')], ' ');\n }),\n InterfaceTypeDefinition: addDescription(function (_ref26) {\n var name = _ref26.name,\n interfaces = _ref26.interfaces,\n directives = _ref26.directives,\n fields = _ref26.fields;\n return join(['interface', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n }),\n UnionTypeDefinition: addDescription(function (_ref27) {\n var name = _ref27.name,\n directives = _ref27.directives,\n types = _ref27.types;\n return join(['union', name, join(directives, ' '), types && types.length !== 0 ? '= ' + join(types, ' | ') : ''], ' ');\n }),\n EnumTypeDefinition: addDescription(function (_ref28) {\n var name = _ref28.name,\n directives = _ref28.directives,\n values = _ref28.values;\n return join(['enum', name, join(directives, ' '), block(values)], ' ');\n }),\n EnumValueDefinition: addDescription(function (_ref29) {\n var name = _ref29.name,\n directives = _ref29.directives;\n return join([name, join(directives, ' ')], ' ');\n }),\n InputObjectTypeDefinition: addDescription(function (_ref30) {\n var name = _ref30.name,\n directives = _ref30.directives,\n fields = _ref30.fields;\n return join(['input', name, join(directives, ' '), block(fields)], ' ');\n }),\n DirectiveDefinition: addDescription(function (_ref31) {\n var name = _ref31.name,\n args = _ref31.arguments,\n repeatable = _ref31.repeatable,\n locations = _ref31.locations;\n return 'directive @' + name + (hasMultilineItems(args) ? wrap('(\\n', indent(join(args, '\\n')), '\\n)') : wrap('(', join(args, ', '), ')')) + (repeatable ? ' repeatable' : '') + ' on ' + join(locations, ' | ');\n }),\n SchemaExtension: function SchemaExtension(_ref32) {\n var directives = _ref32.directives,\n operationTypes = _ref32.operationTypes;\n return join(['extend schema', join(directives, ' '), block(operationTypes)], ' ');\n },\n ScalarTypeExtension: function ScalarTypeExtension(_ref33) {\n var name = _ref33.name,\n directives = _ref33.directives;\n return join(['extend scalar', name, join(directives, ' ')], ' ');\n },\n ObjectTypeExtension: function ObjectTypeExtension(_ref34) {\n var name = _ref34.name,\n interfaces = _ref34.interfaces,\n directives = _ref34.directives,\n fields = _ref34.fields;\n return join(['extend type', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n },\n InterfaceTypeExtension: function InterfaceTypeExtension(_ref35) {\n var name = _ref35.name,\n interfaces = _ref35.interfaces,\n directives = _ref35.directives,\n fields = _ref35.fields;\n return join(['extend interface', name, wrap('implements ', join(interfaces, ' & ')), join(directives, ' '), block(fields)], ' ');\n },\n UnionTypeExtension: function UnionTypeExtension(_ref36) {\n var name = _ref36.name,\n directives = _ref36.directives,\n types = _ref36.types;\n return join(['extend union', name, join(directives, ' '), types && types.length !== 0 ? '= ' + join(types, ' | ') : ''], ' ');\n },\n EnumTypeExtension: function EnumTypeExtension(_ref37) {\n var name = _ref37.name,\n directives = _ref37.directives,\n values = _ref37.values;\n return join(['extend enum', name, join(directives, ' '), block(values)], ' ');\n },\n InputObjectTypeExtension: function InputObjectTypeExtension(_ref38) {\n var name = _ref38.name,\n directives = _ref38.directives,\n fields = _ref38.fields;\n return join(['extend input', name, join(directives, ' '), block(fields)], ' ');\n }\n};\n\nfunction addDescription(cb) {\n return function (node) {\n return join([node.description, cb(node)], '\\n');\n };\n}\n/**\n * Given maybeArray, print an empty string if it is null or empty, otherwise\n * print all items together separated by separator if provided\n */\n\n\nfunction join(maybeArray) {\n var _maybeArray$filter$jo;\n\n var separator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n return (_maybeArray$filter$jo = maybeArray === null || maybeArray === void 0 ? void 0 : maybeArray.filter(function (x) {\n return x;\n }).join(separator)) !== null && _maybeArray$filter$jo !== void 0 ? _maybeArray$filter$jo : '';\n}\n/**\n * Given array, print each item on its own line, wrapped in an\n * indented \"{ }\" block.\n */\n\n\nfunction block(array) {\n return wrap('{\\n', indent(join(array, '\\n')), '\\n}');\n}\n/**\n * If maybeString is not null or empty, then wrap with start and end, otherwise print an empty string.\n */\n\n\nfunction wrap(start, maybeString) {\n var end = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '';\n return maybeString != null && maybeString !== '' ? start + maybeString + end : '';\n}\n\nfunction indent(str) {\n return wrap(' ', str.replace(/\\n/g, '\\n '));\n}\n\nfunction isMultiline(str) {\n return str.indexOf('\\n') !== -1;\n}\n\nfunction hasMultilineItems(maybeArray) {\n return maybeArray != null && maybeArray.some(isMultiline);\n}\n","import { print as origPrint } from \"graphql\";\nimport { canUseWeakMap } from \"../common/canUse.js\";\nvar printCache = canUseWeakMap ? new WeakMap() : undefined;\nexport var print = function (ast) {\n var result;\n result = printCache === null || printCache === void 0 ? void 0 : printCache.get(ast);\n if (!result) {\n result = origPrint(ast);\n printCache === null || printCache === void 0 ? void 0 : printCache.set(ast, result);\n }\n return result;\n};\n//# sourceMappingURL=print.js.map","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 accept: \"*/*\",\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) { return printer(ast); };\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,\n 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), { headers: __assign(__assign({}, options.headers), config.headers) });\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 var operationName = operation.operationName, extensions = operation.extensions, variables = operation.variables, query = operation.query;\n var body = { operationName: operationName, variables: variables };\n if (http.includeExtensions)\n body.extensions = extensions;\n if (http.includeQuery)\n body.query = printer(query, print);\n return {\n options: options,\n body: body,\n };\n}\nfunction removeDuplicateHeaders(headers, preserveHeaderCase) {\n if (!preserveHeaderCase) {\n var normalizedHeaders_1 = Object.create(null);\n Object.keys(Object(headers)).forEach(function (name) {\n normalizedHeaders_1[name.toLowerCase()] = headers[name];\n });\n return normalizedHeaders_1;\n }\n var headerData = Object.create(null);\n Object.keys(Object(headers)).forEach(function (name) {\n headerData[name.toLowerCase()] = {\n originalName: name,\n value: headers[name],\n };\n });\n var normalizedHeaders = Object.create(null);\n Object.keys(headerData).forEach(function (name) {\n normalizedHeaders[headerData[name].originalName] = headerData[name].value;\n });\n return normalizedHeaders;\n}\n//# sourceMappingURL=selectHttpOptionsAndBody.js.map","import { Observable } from \"../../utilities/index.js\";\nexport function fromError(errorValue) {\n return new Observable(function (observer) {\n observer.error(errorValue);\n });\n}\n//# sourceMappingURL=fromError.js.map","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 ||\n op.selectionSet.selections.every(function (selection) {\n return selection.kind === Kind.FRAGMENT_SPREAD &&\n isEmpty(fragmentMap[selection.name.value], fragmentMap);\n }));\n}\nfunction nullIfDocIsEmpty(doc) {\n return isEmpty(getOperationDefinition(doc) || getFragmentDefinition(doc), createFragmentMap(getFragmentDefinitions(doc)))\n ? null\n : 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 }\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) { key = defaultKey; }\n var inUse = map.get(key);\n if (!inUse) {\n map.set(key, (inUse = {\n variables: new Set(),\n fragmentSpreads: new Set(),\n }));\n }\n return inUse;\n };\n}\nexport function removeDirectivesFromDocument(directives, doc) {\n checkDocument(doc);\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))\n continue;\n if (ancestor.kind === Kind.OPERATION_DEFINITION) {\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(82);\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) &&\n nodeDirectives\n .map(directiveMatcher)\n .some(function (config) { return config && config.remove; });\n };\n var originalFragmentDefsByPath = new Map();\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 Field: fieldOrInlineFragmentVisitor,\n InlineFragment: fieldOrInlineFragmentVisitor,\n VariableDefinition: {\n enter: function () {\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 },\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 return node;\n }\n if (operationCount > 0 &&\n node.selectionSet.selections.every(function (selection) {\n return selection.kind === Kind.FIELD &&\n selection.name.value === \"__typename\";\n })) {\n getInUseByFragmentName(node.name.value).removed = true;\n firstVisitMadeChanges = true;\n return null;\n }\n },\n },\n Directive: {\n leave: function (node) {\n if (directiveMatcher(node)) {\n firstVisitMadeChanges = true;\n return null;\n }\n },\n },\n });\n if (!firstVisitMadeChanges) {\n return doc;\n }\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 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 }\n else if (def.kind === Kind.FRAGMENT_DEFINITION &&\n operationCount === 0 &&\n !getInUseByFragmentName(def.name.value).removed) {\n allFragmentNamesUsed.add(def.name.value);\n }\n });\n allFragmentNamesUsed.forEach(function (fragmentName) {\n populateTransitiveVars(getInUseByFragmentName(fragmentName)).fragmentSpreads.forEach(function (childFragmentName) {\n allFragmentNamesUsed.add(childFragmentName);\n });\n });\n var fragmentWillBeRemoved = function (fragmentName) {\n return !!((!allFragmentNamesUsed.has(fragmentName) ||\n 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 FragmentSpread: enterVisitor,\n FragmentDefinition: enterVisitor,\n OperationDefinition: {\n leave: function (node) {\n if (node.variableDefinitions) {\n var usedVariableNames_1 = populateTransitiveVars(getInUseByOperationName(node.name && node.name.value)).transitiveVars;\n if (usedVariableNames_1.size < node.variableDefinitions.length) {\n return __assign(__assign({}, node), { variableDefinitions: node.variableDefinitions.filter(function (varDef) {\n return usedVariableNames_1.has(varDef.variable.name.value);\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 if (parent &&\n parent.kind ===\n Kind.OPERATION_DEFINITION) {\n return;\n }\n var selections = node.selections;\n if (!selections) {\n return;\n }\n var skip = selections.some(function (selection) {\n return (isField(selection) &&\n (selection.name.value === \"__typename\" ||\n selection.name.value.lastIndexOf(\"__\", 0) === 0));\n });\n if (skip) {\n return;\n }\n var field = parent;\n if (isField(field) &&\n field.directives &&\n field.directives.some(function (d) { return d.name.value === \"export\"; })) {\n return;\n }\n return __assign(__assign({}, node), { selections: __spreadArray(__spreadArray([], selections, true), [TYPENAME_FIELD], false) });\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 ||\n !directive.arguments.some(function (arg) { return arg.name.value === \"key\"; })) {\n globalThis.__DEV__ !== false && invariant.warn(83);\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) { nestedCheck = true; }\n return (!!selectionSet &&\n selectionSet.selections &&\n selectionSet.selections.some(function (selection) {\n return hasDirectivesInSelection(directives, selection, nestedCheck);\n }));\n}\nfunction hasDirectivesInSelection(directives, selection, nestedCheck) {\n if (nestedCheck === void 0) { nestedCheck = true; }\n if (!isField(selection)) {\n return true;\n }\n if (!selection.directives) {\n return false;\n }\n return (selection.directives.some(getDirectiveMatcher(directives)) ||\n (nestedCheck &&\n hasDirectivesInSelectionSet(directives, selection.selectionSet, nestedCheck)));\n}\nfunction getArgumentMatcher(config) {\n return function argumentMatcher(argument) {\n return config.some(function (aConfig) {\n return argument.value &&\n argument.value.kind === Kind.VARIABLE &&\n argument.value.name &&\n (aConfig.name === argument.value.name.value ||\n (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), { variableDefinitions: node.variableDefinitions\n ? node.variableDefinitions.filter(function (varDef) {\n return !config.some(function (arg) { return arg.name === varDef.variable.name.value; });\n })\n : [] });\n },\n },\n Field: {\n enter: function (node) {\n var shouldRemoveField = config.some(function (argConfig) { return argConfig.remove; });\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 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) { return def.name === node.name.value; })) {\n return null;\n }\n }\n return nullIfDocIsEmpty(visit(doc, {\n FragmentSpread: { enter: enter },\n FragmentDefinition: { enter: enter },\n }));\n}\nexport function buildQueryFromSelectionSet(document) {\n var definition = getMainDefinition(document);\n var definitionOperation = definition.operation;\n if (definitionOperation === \"query\") {\n return document;\n }\n var modifiedDoc = visit(document, {\n OperationDefinition: {\n enter: function (node) {\n return __assign(__assign({}, node), { operation: \"query\" });\n },\n },\n });\n return modifiedDoc;\n}\nexport function removeClientSetsFromDocument(document) {\n checkDocument(document);\n var modifiedDoc = removeDirectivesFromDocument([\n {\n test: function (directive) { return directive.name.value === \"client\"; },\n remove: true,\n },\n ], document);\n return modifiedDoc;\n}\n//# sourceMappingURL=transform.js.map","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 () { return fetch; });\nexport var createHttpLink = function (linkOptions) {\n if (linkOptions === void 0) { linkOptions = {}; }\n var _a = linkOptions.uri, uri = _a === void 0 ? \"/graphql\" : _a, preferredFetch = linkOptions.fetch, _b = linkOptions.print, print = _b === void 0 ? defaultPrinter : _b, includeExtensions = linkOptions.includeExtensions, preserveHeaderCase = linkOptions.preserveHeaderCase, useGETForQueries = linkOptions.useGETForQueries, _c = linkOptions.includeUnusedVariables, includeUnusedVariables = _c === void 0 ? false : _c, requestOptions = __rest(linkOptions, [\"uri\", \"fetch\", \"print\", \"includeExtensions\", \"preserveHeaderCase\", \"useGETForQueries\", \"includeUnusedVariables\"]);\n if (globalThis.__DEV__ !== false) {\n checkFetcher(preferredFetch || backupFetch);\n }\n var linkConfig = {\n http: { includeExtensions: includeExtensions, preserveHeaderCase: preserveHeaderCase },\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 var clientAwarenessHeaders = {};\n if (context.clientAwareness) {\n var _a = context.clientAwareness, name_1 = _a.name, 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 var _b = selectHttpOptionsAndBodyInternal(operation, print, fallbackHttpConfig, linkConfig, contextConfig), options = _b.options, 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 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 var hasDefer = hasDirectives([\"defer\"], operation.query);\n if (useGETForQueries &&\n !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 if (isSubscription && hasDefer) {\n globalThis.__DEV__ !== false && invariant.warn(38);\n }\n if (isSubscription) {\n acceptHeader +=\n \"boundary=graphql;subscriptionSpec=1.0,application/json\";\n }\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), newURI = _c.newURI, parseError = _c.parseError;\n if (parseError) {\n return fromError(parseError);\n }\n chosenURI = newURI;\n }\n else {\n try {\n options.body = serializeFetchParameter(body, \"Payload\");\n }\n catch (parseError) {\n return fromError(parseError);\n }\n }\n return new Observable(function (observer) {\n var currentFetch = preferredFetch || maybe(function () { return fetch; }) || backupFetch;\n var observerNext = observer.next.bind(observer);\n currentFetch(chosenURI, options)\n .then(function (response) {\n var _a;\n operation.setContext({ response: response });\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 }\n else {\n return parseAndCheckHttpResponse(operation)(response).then(observerNext);\n }\n })\n .then(function () {\n controller = undefined;\n observer.complete();\n })\n .catch(function (err) {\n controller = undefined;\n handleError(err, observer);\n });\n return function () {\n if (controller)\n controller.abort();\n };\n });\n });\n};\n//# sourceMappingURL=createHttpLink.js.map","export var selectURI = function (operation, fallbackURI) {\n var context = operation.getContext();\n var contextURI = context.uri;\n if (contextURI) {\n return contextURI;\n }\n else if (typeof fallbackURI === \"function\") {\n return fallbackURI(operation);\n }\n else {\n return fallbackURI || \"/graphql\";\n }\n};\n//# sourceMappingURL=selectURI.js.map","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 if (parent &&\n 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}\n//# sourceMappingURL=filterOperationVariables.js.map","import { serializeFetchParameter } from \"./serializeFetchParameter.js\";\nexport function rewriteURIForGET(chosenURI, body) {\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 }\n catch (parseError) {\n return { parseError: parseError };\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 }\n catch (parseError) {\n return { parseError: parseError };\n }\n addQueryParam(\"extensions\", serializedExtensions);\n }\n var fragment = \"\", 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 { newURI: newURI };\n}\n//# sourceMappingURL=rewriteURIForGET.js.map","import { __extends } from \"tslib\";\nimport { ApolloLink } from \"../core/index.js\";\nimport { createHttpLink } from \"./createHttpLink.js\";\nvar HttpLink = (function (_super) {\n __extends(HttpLink, _super);\n function HttpLink(options) {\n if (options === void 0) { options = {}; }\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 };\n//# sourceMappingURL=HttpLink.js.map","import { ApolloLink } from \"./ApolloLink.js\";\nexport var execute = ApolloLink.execute;\n//# sourceMappingURL=execute.js.map","// 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 { forEach, slice } = Array.prototype;\nconst { hasOwnProperty } = Object.prototype;\nexport class Trie {\n constructor(weakness = true, makeData = defaultMakeData) {\n this.weakness = weakness;\n this.makeData = makeData;\n }\n lookup(...array) {\n return this.lookupArray(array);\n }\n lookupArray(array) {\n let node = this;\n forEach.call(array, key => node = node.getChildTrie(key));\n return hasOwnProperty.call(node, \"data\")\n ? node.data\n : node.data = this.makeData(slice.call(array));\n }\n peek(...array) {\n return this.peekArray(array);\n }\n peekArray(array) {\n let node = this;\n for (let i = 0, len = array.length; node && i < len; ++i) {\n const map = this.weakness && isObjRef(array[i]) ? node.weak : node.strong;\n node = map && map.get(array[i]);\n }\n return node && node.data;\n }\n getChildTrie(key) {\n const map = this.weakness && isObjRef(key)\n ? this.weak || (this.weak = new WeakMap())\n : this.strong || (this.strong = new Map());\n let child = map.get(key);\n if (!child)\n map.set(key, child = new Trie(this.weakness, this.makeData));\n return child;\n }\n}\nfunction isObjRef(value) {\n switch (typeof value) {\n case \"object\":\n if (value === null)\n break;\n // Fall through to return true...\n case \"function\":\n return true;\n }\n return false;\n}\n//# sourceMappingURL=index.js.map","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)\n ? value.slice(0)\n : __assign({ __proto__: Object.getPrototypeOf(value) }, value);\n }\n return value;\n}\nvar ObjectCanon = (function () {\n function ObjectCanon() {\n this.known = new (canUseWeakSet ? WeakSet : Set)();\n this.pool = new Trie(canUseWeakMap);\n this.passes = new WeakMap();\n this.keysByJSON = new Map();\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)\n return original;\n var proto = Object.getPrototypeOf(value);\n switch (proto) {\n case Array.prototype: {\n if (this.known.has(value))\n return value;\n var array = value.map(this.admit, this);\n var node = this.pool.lookupArray(array);\n if (!node.array) {\n this.known.add((node.array = array));\n if (globalThis.__DEV__ !== false) {\n Object.freeze(array);\n }\n }\n return node.array;\n }\n case null:\n case Object.prototype: {\n if (this.known.has(value))\n 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 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 if (globalThis.__DEV__ !== false) {\n Object.freeze(obj_1);\n }\n }\n return node.object;\n }\n }\n }\n return value;\n };\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 = { sorted: keys, json: json }));\n }\n }\n return node.keys;\n };\n return ObjectCanon;\n}());\nexport { ObjectCanon };\nexport var canonicalStringify = Object.assign(function (value) {\n if (isObjectOrArray(value)) {\n if (stringifyCanon === void 0) {\n resetCanonicalStringify();\n }\n var canonical = stringifyCanon.admit(value);\n var json = stringifyCache.get(canonical);\n if (json === void 0) {\n stringifyCache.set(canonical, (json = JSON.stringify(canonical)));\n }\n return json;\n }\n return JSON.stringify(value);\n}, {\n reset: resetCanonicalStringify,\n});\nvar stringifyCanon;\nvar stringifyCache;\nfunction resetCanonicalStringify() {\n stringifyCanon = new ObjectCanon();\n stringifyCache = new (canUseWeakMap ? WeakMap : Map)();\n}\n//# sourceMappingURL=object-canon.js.map","import { Trie } from \"@wry/trie\";\nimport { canUseWeakMap, canUseWeakSet } from \"../common/canUse.js\";\nimport { checkDocument } from \"./getFromAST.js\";\nimport { invariant } from \"../globals/index.js\";\nfunction identity(document) {\n return document;\n}\nvar DocumentTransform = (function () {\n function DocumentTransform(transform, options) {\n if (options === void 0) { options = Object.create(null); }\n this.resultCache = canUseWeakSet\n ? new WeakSet()\n : new Set();\n this.transform = transform;\n if (options.getCacheKey) {\n this.getCacheKey = options.getCacheKey;\n }\n if (options.cache !== false) {\n this.stableCacheKeys = new Trie(canUseWeakMap, function (key) { return ({ key: key }); });\n }\n }\n DocumentTransform.prototype.getCacheKey = function (document) {\n return [document];\n };\n DocumentTransform.identity = function () {\n return new DocumentTransform(identity, { cache: false });\n };\n DocumentTransform.split = function (predicate, left, right) {\n if (right === void 0) { right = DocumentTransform.identity(); }\n return new DocumentTransform(function (document) {\n var documentTransform = predicate(document) ? left : right;\n return documentTransform.transformDocument(document);\n }, { cache: false });\n };\n DocumentTransform.prototype.transformDocument = function (document) {\n if (this.resultCache.has(document)) {\n return document;\n }\n var cacheEntry = this.getStableCacheEntry(document);\n if (cacheEntry && cacheEntry.value) {\n return cacheEntry.value;\n }\n checkDocument(document);\n var transformedDocument = this.transform(document);\n this.resultCache.add(transformedDocument);\n if (cacheEntry) {\n cacheEntry.value = transformedDocument;\n }\n return transformedDocument;\n };\n DocumentTransform.prototype.concat = function (otherTransform) {\n var _this = this;\n return new DocumentTransform(function (document) {\n return otherTransform.transformDocument(_this.transformDocument(document));\n }, { cache: false });\n };\n DocumentTransform.prototype.getStableCacheEntry = function (document) {\n if (!this.stableCacheKeys)\n return;\n var cacheKeys = this.getCacheKey(document);\n if (cacheKeys) {\n invariant(Array.isArray(cacheKeys), 65);\n return this.stableCacheKeys.lookupArray(cacheKeys);\n }\n };\n return DocumentTransform;\n}());\nexport { DocumentTransform };\n//# sourceMappingURL=DocumentTransform.js.map","import { Observable } from \"./Observable.js\";\nexport function asyncMap(observable, mapFn, catchFn) {\n return new Observable(function (observer) {\n var promiseQueue = {\n then: function (callback) {\n return new Promise(function (resolve) { return resolve(callback()); });\n },\n };\n function makeCallback(examiner, key) {\n return function (arg) {\n if (examiner) {\n var both = function () {\n return observer.closed\n ? 0\n : examiner(arg);\n };\n promiseQueue = promiseQueue.then(both, both).then(function (result) { return observer.next(result); }, function (error) { 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 promiseQueue.then(function () { return observer.complete(); });\n },\n };\n var sub = observable.subscribe(handler);\n return function () { return sub.unsubscribe(); };\n });\n}\n//# sourceMappingURL=asyncMap.js.map","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)\n ? result.errors.slice(0)\n : [];\n if (isExecutionPatchIncrementalResult(result) &&\n 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}\n//# sourceMappingURL=errorHandling.js.map","export function iterateObserversSafely(observers, method, argument) {\n var observersWithMethod = [];\n observers.forEach(function (obs) { return obs[method] && observersWithMethod.push(obs); });\n observersWithMethod.forEach(function (obs) { return obs[method](argument); });\n}\n//# sourceMappingURL=iteration.js.map","import { Observable } from \"./Observable.js\";\nimport { canUseSymbol } from \"../common/canUse.js\";\nexport function fixObservableSubclass(subclass) {\n function set(key) {\n Object.defineProperty(subclass, key, { value: Observable });\n }\n if (canUseSymbol && Symbol.species) {\n set(Symbol.species);\n }\n set(\"@@species\");\n return subclass;\n}\n//# sourceMappingURL=subclassing.js.map","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}\nvar Concast = (function (_super) {\n __extends(Concast, _super);\n function Concast(sources) {\n var _this = _super.call(this, function (observer) {\n _this.addObserver(observer);\n return function () { return _this.removeObserver(observer); };\n }) || this;\n _this.observers = new Set();\n _this.promise = new Promise(function (resolve, reject) {\n _this.resolve = resolve;\n _this.reject = reject;\n });\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 if (sub)\n setTimeout(function () { return sub.unsubscribe(); });\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, sub = _a.sub, _b = _a.sources, sources = _b === void 0 ? [] : _b;\n if (sub !== null) {\n var value = sources.shift();\n if (!value) {\n if (sub)\n setTimeout(function () { return sub.unsubscribe(); });\n _this.sub = null;\n if (_this.latest && _this.latest[0] === \"next\") {\n _this.resolve(_this.latest[1]);\n }\n else {\n _this.resolve();\n }\n _this.notify(\"complete\");\n iterateObserversSafely(_this.observers, \"complete\");\n }\n else if (isPromiseLike(value)) {\n value.then(function (obs) { return (_this.sub = obs.subscribe(_this.handlers)); });\n }\n else {\n _this.sub = value.subscribe(_this.handlers);\n }\n }\n },\n };\n _this.nextResultListeners = new Set();\n _this.cancel = function (reason) {\n _this.reject(reason);\n _this.sources = [];\n _this.handlers.complete();\n };\n _this.promise.catch(function (_) { });\n if (typeof sources === \"function\") {\n sources = [new Observable(sources)];\n }\n if (isPromiseLike(sources)) {\n sources.then(function (iterable) { return _this.start(iterable); }, _this.handlers.error);\n }\n else {\n _this.start(sources);\n }\n return _this;\n }\n Concast.prototype.start = function (sources) {\n if (this.sub !== void 0)\n return;\n this.sources = Array.from(sources);\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 (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 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 this.handlers.complete();\n }\n };\n Concast.prototype.notify = function (method, arg) {\n var nextResultListeners = this.nextResultListeners;\n if (nextResultListeners.size) {\n this.nextResultListeners = new Set();\n nextResultListeners.forEach(function (listener) { return listener(method, arg); });\n }\n };\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 };\nfixObservableSubclass(Concast);\n//# sourceMappingURL=Concast.js.map","var toString = Object.prototype.toString;\nexport function cloneDeep(value) {\n return cloneDeepHelper(value);\n}\nfunction cloneDeepHelper(val, seen) {\n switch (toString.call(val)) {\n case \"[object Array]\": {\n seen = seen || new Map();\n if (seen.has(val))\n 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 seen = seen || new Map();\n if (seen.has(val))\n return seen.get(val);\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}\n//# sourceMappingURL=cloneDeep.js.map","import { __rest } from \"tslib\";\nimport equal from \"@wry/equality\";\nimport { createFragmentMap, getFragmentDefinitions, getFragmentFromSelection, getMainDefinition, isField, resultKeyNameFromField, shouldInclude, } from \"../utilities/index.js\";\nexport function equalByQuery(query, _a, _b, variables) {\n var aData = _a.data, aRest = __rest(_a, [\"data\"]);\n var bData = _b.data, bRest = __rest(_b, [\"data\"]);\n return (equal(aRest, bRest) &&\n 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 return selectionSet.selections.every(function (selection) {\n if (seenSelections.has(selection))\n return true;\n seenSelections.add(selection);\n if (!shouldInclude(selection, context.variables))\n return true;\n if (selectionHasNonreactiveDirective(selection))\n 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 return equal(aResultChild, bResultChild);\n }\n var aChildIsArray = Array.isArray(aResultChild);\n var bChildIsArray = Array.isArray(bResultChild);\n if (aChildIsArray !== bChildIsArray)\n 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 }\n else {\n var fragment = getFragmentFromSelection(selection, context.fragmentMap);\n if (fragment) {\n if (selectionHasNonreactiveDirective(fragment))\n return true;\n return equalBySelectionSet(fragment.selectionSet, 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}\n//# sourceMappingURL=equalByQuery.js.map","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, } from \"../utilities/index.js\";\nimport { equalByQuery } from \"./equalByQuery.js\";\nvar assign = Object.assign, hasOwnProperty = Object.hasOwnProperty;\nvar ObservableQuery = (function (_super) {\n __extends(ObservableQuery, _super);\n function ObservableQuery(_a) {\n var queryManager = _a.queryManager, queryInfo = _a.queryInfo, options = _a.options;\n var _this = _super.call(this, function (observer) {\n try {\n var subObserver = observer._subscription._observer;\n if (subObserver && !subObserver.error) {\n subObserver.error = defaultSubscriptionObserverErrorCallback;\n }\n }\n catch (_a) { }\n var first = !_this.observers.size;\n _this.observers.add(observer);\n var last = _this.last;\n if (last && last.error) {\n observer.error && observer.error(last.error);\n }\n else if (last && last.result) {\n observer.next && observer.next(last.result);\n }\n if (first) {\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 _this.queryInfo = queryInfo;\n _this.queryManager = queryManager;\n _this.waitForOwnResult = skipCacheDataFor(options.fetchPolicy);\n _this.isTornDown = false;\n var _b = queryManager.defaultOptions.watchQuery, _c = _b === void 0 ? {} : _b, _d = _c.fetchPolicy, defaultFetchPolicy = _d === void 0 ? \"cache-first\" : _d;\n var _e = options.fetchPolicy, fetchPolicy = _e === void 0 ? defaultFetchPolicy : _e, _f = options.initialFetchPolicy, initialFetchPolicy = _f === void 0 ? fetchPolicy === \"standby\"\n ? defaultFetchPolicy\n : fetchPolicy : _f;\n _this.options = __assign(__assign({}, options), { initialFetchPolicy: initialFetchPolicy, fetchPolicy: fetchPolicy });\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 get: function () {\n return this.lastQuery || this.options.query;\n },\n enumerable: false,\n configurable: true\n });\n Object.defineProperty(ObservableQuery.prototype, \"variables\", {\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 var observer = {\n next: function (result) {\n resolve(result);\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 ObservableQuery.prototype.getCurrentResult = function (saveAsLastResult) {\n if (saveAsLastResult === void 0) { saveAsLastResult = true; }\n var lastResult = this.getLastResult(true);\n var networkStatus = this.queryInfo.networkStatus ||\n (lastResult && lastResult.networkStatus) ||\n NetworkStatus.ready;\n var result = __assign(__assign({}, lastResult), { loading: isNetworkRequestInFlight(networkStatus), networkStatus: networkStatus });\n var _a = this.options.fetchPolicy, fetchPolicy = _a === void 0 ? \"cache-first\" : _a;\n if (skipCacheDataFor(fetchPolicy) ||\n this.queryManager.getDocumentInfo(this.query).hasForcedResolvers) {\n }\n else if (this.waitForOwnResult) {\n this.queryInfo[\"updateWatch\"]();\n }\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 delete result.partial;\n if (diff.complete &&\n result.networkStatus === NetworkStatus.loading &&\n (fetchPolicy === \"cache-first\" || fetchPolicy === \"cache-only\")) {\n result.networkStatus = NetworkStatus.ready;\n result.loading = false;\n }\n }\n else {\n result.partial = true;\n }\n if (globalThis.__DEV__ !== false &&\n !diff.complete &&\n !this.options.partialRefetch &&\n !result.loading &&\n !result.data &&\n !result.error) {\n logMissingFieldErrors(diff.missing);\n }\n }\n if (saveAsLastResult) {\n this.updateLastResult(result);\n }\n return result;\n };\n ObservableQuery.prototype.isDifferentFromLastResult = function (newResult, variables) {\n if (!this.last) {\n return true;\n }\n var resultIsDifferent = this.queryManager.getDocumentInfo(this.query)\n .hasNonreactiveDirective\n ? !equalByQuery(this.query, this.last.result, newResult, this.variables)\n : !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 &&\n last[key] &&\n (!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 ObservableQuery.prototype.refetch = function (variables) {\n var _a;\n var reobserveOptions = {\n pollInterval: 0,\n };\n var fetchPolicy = this.options.fetchPolicy;\n if (fetchPolicy === \"cache-and-network\") {\n reobserveOptions.fetchPolicy = fetchPolicy;\n }\n else if (fetchPolicy === \"no-cache\") {\n reobserveOptions.fetchPolicy = \"no-cache\";\n }\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) { return v.variable.name.value === \"variables\"; })) {\n globalThis.__DEV__ !== false && invariant.warn(\n 20,\n variables,\n ((_a = queryDef.name) === null || _a === void 0 ? void 0 : _a.value) || queryDef\n );\n }\n }\n if (variables && !equal(this.options.variables, 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 ObservableQuery.prototype.fetchMore = function (fetchMoreOptions) {\n var _this = this;\n var combinedOptions = __assign(__assign({}, (fetchMoreOptions.query\n ? fetchMoreOptions\n : __assign(__assign(__assign(__assign({}, this.options), { query: this.options.query }), fetchMoreOptions), { variables: __assign(__assign({}, this.options.variables), fetchMoreOptions.variables) }))), { fetchPolicy: \"no-cache\" });\n combinedOptions.query = this.transformDocument(combinedOptions.query);\n var qid = this.queryManager.generateQueryId();\n this.lastQuery = fetchMoreOptions.query\n ? this.transformDocument(this.options.query)\n : combinedOptions.query;\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 return this.queryManager\n .fetchQuery(qid, combinedOptions, NetworkStatus.fetchMore)\n .then(function (fetchMoreResult) {\n _this.queryManager.removeQuery(qid);\n if (queryInfo.networkStatus === NetworkStatus.fetchMore) {\n queryInfo.networkStatus = originalNetworkStatus;\n }\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 }\n else {\n cache.writeQuery({\n query: combinedOptions.query,\n variables: combinedOptions.variables,\n data: fetchMoreResult.data,\n });\n }\n },\n onWatchUpdated: function (watch) {\n updatedQuerySet.add(watch.query);\n },\n });\n return fetchMoreResult;\n })\n .finally(function () {\n if (!updatedQuerySet.has(_this.query)) {\n reobserveCacheFirst(_this);\n }\n });\n };\n ObservableQuery.prototype.subscribeToMore = function (options) {\n var _this = this;\n var subscription = this.queryManager\n .startGraphQLSubscription({\n query: options.document,\n variables: options.variables,\n context: options.context,\n })\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(21, 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 ObservableQuery.prototype.setVariables = function (variables) {\n if (equal(this.variables, variables)) {\n return this.observers.size ? this.result() : Promise.resolve();\n }\n this.options.variables = variables;\n if (!this.observers.size) {\n return Promise.resolve();\n }\n return this.reobserve({\n fetchPolicy: this.options.initialFetchPolicy,\n variables: variables,\n }, NetworkStatus.setVariables);\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 ObservableQuery.prototype.startPolling = function (pollInterval) {\n this.options.pollInterval = pollInterval;\n this.updatePolling();\n };\n ObservableQuery.prototype.stopPolling = function () {\n this.options.pollInterval = 0;\n this.updatePolling();\n };\n ObservableQuery.prototype.applyNextFetchPolicy = function (reason, options) {\n if (options.nextFetchPolicy) {\n var _a = options.fetchPolicy, fetchPolicy = _a === void 0 ? \"cache-first\" : _a, _b = options.initialFetchPolicy, initialFetchPolicy = _b === void 0 ? fetchPolicy : _b;\n if (fetchPolicy === \"standby\") {\n }\n else if (typeof options.nextFetchPolicy === \"function\") {\n options.fetchPolicy = options.nextFetchPolicy(fetchPolicy, {\n reason: reason,\n options: options,\n observable: this,\n initialFetchPolicy: initialFetchPolicy,\n });\n }\n else if (reason === \"variables-changed\") {\n options.fetchPolicy = initialFetchPolicy;\n }\n else {\n options.fetchPolicy = options.nextFetchPolicy;\n }\n }\n return options.fetchPolicy;\n };\n ObservableQuery.prototype.fetch = function (options, newNetworkStatus, query) {\n this.queryManager.setObservableQuery(this);\n return this.queryManager[\"fetchConcastWithInfo\"](this.queryId, options, newNetworkStatus, query);\n };\n ObservableQuery.prototype.updatePolling = function () {\n var _this = this;\n if (this.queryManager.ssrMode) {\n return;\n }\n var _a = this, pollingInfo = _a.pollingInfo, pollInterval = _a.options.pollInterval;\n if (!pollInterval) {\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, 22);\n var info = pollingInfo || (this.pollingInfo = {});\n info.interval = pollInterval;\n var maybeFetch = function () {\n if (_this.pollingInfo) {\n if (!isNetworkRequestInFlight(_this.queryInfo.networkStatus)) {\n _this.reobserve({\n fetchPolicy: _this.options.initialFetchPolicy === \"no-cache\"\n ? \"no-cache\"\n : \"network-only\",\n }, NetworkStatus.poll).then(poll, poll);\n }\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) { variables = this.variables; }\n var error = this.getLastError();\n if (error && this.last && !equal(variables, this.last.variables)) {\n error = void 0;\n }\n return (this.last = __assign({ result: this.queryManager.assumeImmutableResults\n ? newResult\n : cloneDeep(newResult), variables: variables }, (error ? { error: error } : null)));\n };\n ObservableQuery.prototype.reobserveAsConcast = function (newOptions, newNetworkStatus) {\n var _this = this;\n this.isTornDown = false;\n var useDisposableConcast = newNetworkStatus === NetworkStatus.refetch ||\n newNetworkStatus === NetworkStatus.fetchMore ||\n newNetworkStatus === NetworkStatus.poll;\n var oldVariables = this.options.variables;\n var oldFetchPolicy = this.options.fetchPolicy;\n var mergedOptions = compact(this.options, newOptions || {});\n var options = useDisposableConcast\n ?\n mergedOptions\n : assign(this.options, mergedOptions);\n var query = this.transformDocument(options.query);\n this.lastQuery = query;\n if (!useDisposableConcast) {\n this.updatePolling();\n if (newOptions &&\n newOptions.variables &&\n !equal(newOptions.variables, oldVariables) &&\n options.fetchPolicy !== \"standby\" &&\n options.fetchPolicy === oldFetchPolicy) {\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), concast = _a.concast, fromLink = _a.fromLink;\n var observer = {\n next: function (result) {\n finishWaitingForOwnResult();\n _this.reportResult(result, variables);\n },\n error: function (error) {\n finishWaitingForOwnResult();\n _this.reportError(error, variables);\n },\n };\n if (!useDisposableConcast && (fromLink || !this.concast)) {\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 this.reobserveAsConcast(newOptions, newNetworkStatus).promise;\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 var last = this.last;\n this.resetLastResults();\n var subscription = this.subscribe.apply(this, args);\n this.last = last;\n return subscription;\n };\n ObservableQuery.prototype.observe = function () {\n this.reportResult(this.getCurrentResult(false), this.variables);\n };\n ObservableQuery.prototype.reportResult = function (result, variables) {\n var lastError = this.getLastError();\n var isDifferent = this.isDifferentFromLastResult(result, variables);\n if (lastError || !result.partial || this.options.returnPartialData) {\n this.updateLastResult(result, variables);\n }\n if (lastError || isDifferent) {\n iterateObserversSafely(this.observers, \"next\", result);\n }\n };\n ObservableQuery.prototype.reportError = function (error, variables) {\n var errorResult = __assign(__assign({}, this.getLastResult()), { error: error, errors: error.graphQLErrors, networkStatus: NetworkStatus.error, loading: false });\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)\n 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 this.subscriptions.forEach(function (sub) { return sub.unsubscribe(); });\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 return ObservableQuery;\n}(Observable));\nexport { ObservableQuery };\nfixObservableSubclass(ObservableQuery);\nexport function reobserveCacheFirst(obsQuery) {\n var _a = obsQuery.options, fetchPolicy = _a.fetchPolicy, nextFetchPolicy = _a.nextFetchPolicy;\n if (fetchPolicy === \"cache-and-network\" || fetchPolicy === \"network-only\") {\n return obsQuery.reobserve({\n fetchPolicy: \"cache-first\",\n nextFetchPolicy: function () {\n this.nextFetchPolicy = nextFetchPolicy;\n if (typeof nextFetchPolicy === \"function\") {\n return nextFetchPolicy.apply(this, arguments);\n }\n return fetchPolicy;\n },\n });\n }\n return obsQuery.reobserve();\n}\nfunction defaultSubscriptionObserverErrorCallback(error) {\n globalThis.__DEV__ !== false && invariant.error(23, error.message, error.stack);\n}\nexport function logMissingFieldErrors(missing) {\n if (globalThis.__DEV__ !== false && missing) {\n globalThis.__DEV__ !== false && invariant.debug(24, missing);\n }\n}\nfunction skipCacheDataFor(fetchPolicy) {\n return (fetchPolicy === \"network-only\" ||\n fetchPolicy === \"no-cache\" ||\n fetchPolicy === \"standby\");\n}\n//# sourceMappingURL=ObservableQuery.js.map","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}\n","function defaultDispose() { }\nexport class Cache {\n constructor(max = Infinity, dispose = 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 getNode(key) {\n const node = this.map.get(key);\n if (node && node !== this.newest) {\n const { older, newer } = 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}\n//# sourceMappingURL=cache.js.map","// 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 = [\n \"slot\",\n idCounter++,\n Date.now(),\n Math.random().toString(36).slice(2),\n ].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)\n 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 = { parent, slots };\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 }\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 }\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 }\n finally {\n currentContext = saved;\n }\n }\n else {\n return callback.apply(thisArg, args);\n }\n }\n};\nfunction maybe(fn) {\n try {\n return fn();\n }\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\n maybe(() => 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.\n Object.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.\n Array[globalKey] ||\n (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 }\n finally {\n return Slot;\n }\n })(makeSlotClass());\n//# sourceMappingURL=slot.js.map","import { Slot } from \"./slot.js\";\nexport { Slot };\nexport const { bind, noContext } = 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 }\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 }\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}\n//# sourceMappingURL=index.js.map","import { Slot } from \"@wry/context\";\nexport const parentEntrySlot = new Slot();\nexport function nonReactive(fn) {\n return parentEntrySlot.withValue(void 0, fn);\n}\nexport { bind as bindContext, noContext, setTimeout, asyncFromGen, } from \"@wry/context\";\n//# sourceMappingURL=context.js.map","export const { hasOwnProperty, } = Object.prototype;\nexport const arrayFromSet = Array.from ||\n function (set) {\n const array = [];\n set.forEach(item => array.push(item));\n return array;\n };\nexport function maybeUnsubscribe(entryOrDep) {\n const { unsubscribe } = entryOrDep;\n if (typeof unsubscribe === \"function\") {\n entryOrDep.unsubscribe = void 0;\n unsubscribe();\n }\n}\n//# sourceMappingURL=helpers.js.map","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}\nfunction valueGet(value) {\n switch (value.length) {\n case 0: throw new Error(\"unknown value\");\n case 1: return value[0];\n case 2: throw value[1];\n }\n}\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)\n ? reallyRecompute(this, args)\n : valueGet(this.value);\n }\n setDirty() {\n if (this.dirty)\n return;\n this.dirty = true;\n this.value.length = 0;\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 }\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 // Set entry.value as unknown.\n entry.value.length = 0;\n try {\n // If entry.fn succeeds, entry.value will become a normal Value.\n entry.value[0] = entry.fn.apply(null, args);\n }\n catch (e) {\n // If entry.fn throws, entry.value will become exceptional.\n entry.value[1] = e;\n }\n // Either way, this line is always reached.\n entry.recomputing = false;\n}\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 }\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 }\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 }\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}\n//# sourceMappingURL=entry.js.map","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};\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 &&\n 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}\n//# sourceMappingURL=dep.js.map","import { Trie } from \"@wry/trie\";\nimport { Cache } from \"./cache.js\";\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, } 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(...args) {\n const trie = defaultKeyTrie || (defaultKeyTrie = new Trie(typeof WeakMap === \"function\"));\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 };\nconst caches = new Set();\nexport function wrap(originalFunction, { max = Math.pow(2, 16), makeCacheKey = defaultMakeCacheKey, keyArgs, subscribe, } = Object.create(null)) {\n const cache = new Cache(max, entry => entry.dispose());\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.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() {\n return cache[\"map\"].size;\n },\n configurable: false,\n enumerable: false,\n });\n Object.freeze(optimistic.options = {\n max,\n makeCacheKey,\n keyArgs,\n subscribe,\n });\n function dirtyKey(key) {\n const entry = 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 = 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 cache.delete(key);\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}\n//# sourceMappingURL=index.js.map","import { dep } from \"optimism\";\nimport { Slot } from \"@wry/context\";\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) { return rv.forgetCache(cache); });\n}\nexport function recallCache(cache) {\n getCacheInfo(cache).vars.forEach(function (rv) { return rv.attachCache(cache); });\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 getCacheInfo(cache).dep.dirty(rv);\n broadcast(cache);\n });\n var oldListeners = Array.from(listeners);\n listeners.clear();\n oldListeners.forEach(function (listener) { return listener(value); });\n }\n }\n else {\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) { return caches.delete(cache); };\n return rv;\n}\nfunction broadcast(cache) {\n if (cache.broadcastWatches) {\n cache.broadcastWatches();\n }\n}\n//# sourceMappingURL=reactiveVars.js.map","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 = (function () {\n function LocalState(_a) {\n var cache = _a.cache, client = _a.client, resolvers = _a.resolvers, 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 }\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 LocalState.prototype.runResolvers = function (_a) {\n var document = _a.document, remoteResult = _a.remoteResult, context = _a.context, variables = _a.variables, _b = _a.onlyRunForcedResolvers, onlyRunForcedResolvers = _b === void 0 ? false : _b;\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_c) {\n if (document) {\n return [2, this.resolveDocument(document, remoteResult.data, context, variables, this.fragmentMatcher, onlyRunForcedResolvers).then(function (localResult) { return (__assign(__assign({}, remoteResult), { data: localResult.result })); })];\n }\n return [2, 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 LocalState.prototype.clientQuery = function (document) {\n if (hasDirectives([\"client\"], document)) {\n if (this.resolvers) {\n return document;\n }\n }\n return null;\n };\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), { cache: cache, getCacheKey: function (obj) {\n return cache.identify(obj);\n } });\n };\n LocalState.prototype.addExportedVariables = function (document, variables, context) {\n if (variables === void 0) { variables = {}; }\n if (context === void 0) { context = {}; }\n return __awaiter(this, void 0, void 0, function () {\n return __generator(this, function (_a) {\n if (document) {\n return [2, this.resolveDocument(document, this.buildRootValueFromCache(document, variables) || {}, this.prepareContext(context), variables).then(function (data) { return (__assign(__assign({}, variables), data.exportedVariables)); })];\n }\n return [2, __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\" &&\n arg.value.kind === \"BooleanValue\" &&\n arg.value.value === true;\n });\n if (forceResolvers) {\n return BREAK;\n }\n }\n },\n },\n });\n return forceResolvers;\n };\n 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, rootValue, context, variables, fragmentMatcher, onlyRunForcedResolvers) {\n if (context === void 0) { context = {}; }\n if (variables === void 0) { variables = {}; }\n if (fragmentMatcher === void 0) { fragmentMatcher = function () { return true; }; }\n if (onlyRunForcedResolvers === void 0) { onlyRunForcedResolvers = false; }\n return __awaiter(this, void 0, void 0, function () {\n var mainDefinition, fragments, fragmentMap, selectionsToResolve, definitionOperation, defaultOperationType, _a, cache, client, execContext, isClientFieldDescendant;\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\n ? definitionOperation.charAt(0).toUpperCase() +\n definitionOperation.slice(1)\n : \"Query\";\n _a = this, cache = _a.cache, client = _a.client;\n execContext = {\n fragmentMap: fragmentMap,\n context: __assign(__assign({}, context), { cache: cache, client: client }),\n variables: variables,\n fragmentMatcher: fragmentMatcher,\n defaultOperationType: defaultOperationType,\n exportedVariables: {},\n selectionsToResolve: selectionsToResolve,\n onlyRunForcedResolvers: onlyRunForcedResolvers,\n };\n isClientFieldDescendant = false;\n return [2, this.resolveSelectionSet(mainDefinition.selectionSet, isClientFieldDescendant, rootValue, execContext).then(function (result) { return ({\n result: result,\n exportedVariables: execContext.exportedVariables,\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) { return __awaiter(_this, void 0, void 0, function () {\n var fragment, typeCondition;\n return __generator(this, function (_a) {\n if (!isClientFieldDescendant &&\n !execContext.selectionsToResolve.has(selection)) {\n return [2];\n }\n if (!shouldInclude(selection, variables)) {\n return [2];\n }\n if (isField(selection)) {\n return [2, this.resolveField(selection, isClientFieldDescendant, rootValue, execContext).then(function (fieldResult) {\n var _a;\n if (typeof fieldResult !== \"undefined\") {\n resultsToMerge.push((_a = {},\n _a[resultKeyNameFromField(selection)] = fieldResult,\n _a));\n }\n })];\n }\n if (isInlineFragment(selection)) {\n fragment = selection;\n }\n else {\n fragment = fragmentMap[selection.name.value];\n invariant(fragment, 18, 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, this.resolveSelectionSet(fragment.selectionSet, isClientFieldDescendant, rootValue, execContext).then(function (fragmentResult) {\n resultsToMerge.push(fragmentResult);\n })];\n }\n }\n return [2];\n });\n }); };\n return [2, 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, 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 if (!execContext.onlyRunForcedResolvers ||\n 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(cacheSlot.withValue(this.cache, resolve, [\n rootValue,\n argumentsObjectFromField(field, variables),\n execContext.context,\n { field: field, fragmentMap: execContext.fragmentMap },\n ]));\n }\n }\n }\n return [2, resultPromise.then(function (result) {\n var _a, _b;\n if (result === void 0) { result = defaultResult; }\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 if (!field.selectionSet) {\n return result;\n }\n if (result == null) {\n return result;\n }\n var isClientField = (_b = (_a = field.directives) === null || _a === void 0 ? void 0 : _a.some(function (d) { return d.name.value === \"client\"; })) !== null && _b !== void 0 ? _b : false;\n if (Array.isArray(result)) {\n return _this.resolveSubSelectedArray(field, isClientFieldDescendant || isClientField, result, execContext);\n }\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 if (Array.isArray(item)) {\n return _this.resolveSubSelectedArray(field, isClientFieldDescendant, item, execContext);\n }\n if (field.selectionSet) {\n return _this.resolveSelectionSet(field.selectionSet, isClientFieldDescendant, item, execContext);\n }\n }));\n };\n LocalState.prototype.collectSelectionsToResolve = function (mainDefinition, fragmentMap) {\n var isSingleASTNode = function (node) { return !Array.isArray(node); };\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, 19, spread.name.value);\n var fragmentSelections = collectByDefinition(fragment);\n if (fragmentSelections.size > 0) {\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 };\n//# sourceMappingURL=LocalState.js.map","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 cache[methodName] = function () {\n destructiveMethodCounts.set(cache, (destructiveMethodCounts.get(cache) + 1) % 1e15);\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}\nvar QueryInfo = (function () {\n function QueryInfo(queryManager, queryId) {\n if (queryId === void 0) { queryId = queryManager.generateQueryId(); }\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 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 &&\n this.networkStatus !== NetworkStatus.loading &&\n !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.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 { complete: false };\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 ? {\n diff: diff,\n options: options || this.getDiffOptions(),\n }\n : void 0;\n };\n QueryInfo.prototype.getDiffOptions = function (variables) {\n var _a;\n if (variables === void 0) { variables = this.variables; }\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 oldDiff = this.lastDiff && this.lastDiff.diff;\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 () { return _this.notify(); }, 0);\n }\n }\n };\n QueryInfo.prototype.setObservableQuery = function (oq) {\n var _this = this;\n if (oq === this.observableQuery)\n 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 oq[\"observe\"]();\n }\n else {\n reobserveCacheFirst(oq);\n }\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) { return listener(_this); });\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 this.reset();\n this.cancel();\n this.cancel = QueryInfo.prototype.cancel;\n var oq = this.observableQuery;\n if (oq)\n oq.stopPolling();\n }\n };\n QueryInfo.prototype.cancel = function () { };\n QueryInfo.prototype.updateWatch = function (variables) {\n var _this = this;\n if (variables === void 0) { variables = this.variables; }\n var oq = this.observableQuery;\n if (oq && oq.options.fetchPolicy === \"no-cache\") {\n return;\n }\n var watchOptions = __assign(__assign({}, this.getDiffOptions(variables)), { watcher: this, callback: function (diff) { return _this.setDiff(diff); } });\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 lastWrite.dmCount === destructiveMethodCounts.get(this.cache) &&\n equal(variables, lastWrite.variables) &&\n 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)\n ? result.errors.slice(0)\n : [];\n this.reset();\n if (\"incremental\" in result && isNonEmptyArray(result.incremental)) {\n var mergedData = mergeIncrementalData(this.getDiff().result, result);\n result.data = mergedData;\n }\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({ result: result.data, complete: true }, this.getDiffOptions(options.variables));\n }\n else if (cacheWriteBehavior !== 0) {\n if (shouldWriteResult(result, options.errorPolicy)) {\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,\n });\n _this.lastWrite = {\n result: result,\n variables: options.variables,\n dmCount: destructiveMethodCounts.get(_this.cache),\n };\n }\n else {\n if (_this.lastDiff && _this.lastDiff.diff.complete) {\n result.data = _this.lastDiff.diff.result;\n return;\n }\n }\n var diffOptions = _this.getDiffOptions(options.variables);\n var diff = cache.diff(diffOptions);\n if (!_this.stopped && equal(_this.variables, options.variables)) {\n _this.updateWatch(options.variables);\n }\n _this.updateLastDiff(diff, diffOptions);\n if (diff.complete) {\n result.data = diff.result;\n }\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) { errorPolicy = \"none\"; }\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}\n//# sourceMappingURL=QueryInfo.js.map","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 { hasDirectives, isExecutionPatchIncrementalResult, isExecutionPatchResult, removeDirectivesFromDocument, } from \"../utilities/index.js\";\nimport { canonicalStringify } from \"../cache/index.js\";\nimport { getDefaultValues, getOperationDefinition, getOperationName, hasClientExports, graphQLResultHasError, getGraphQLErrorsFromResult, canUseWeakMap, 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 { LocalState } from \"./LocalState.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 QueryManager = (function () {\n function QueryManager(_a) {\n var _this = this;\n var cache = _a.cache, link = _a.link, defaultOptions = _a.defaultOptions, documentTransform = _a.documentTransform, _b = _a.queryDeduplication, queryDeduplication = _b === void 0 ? false : _b, onBroadcast = _a.onBroadcast, _c = _a.ssrMode, ssrMode = _c === void 0 ? false : _c, _d = _a.clientAwareness, clientAwareness = _d === void 0 ? {} : _d, localState = _a.localState, _e = _a.assumeImmutableResults, assumeImmutableResults = _e === void 0 ? !!cache.assumeImmutableResults : _e;\n this.clientAwareness = {};\n this.queries = new Map();\n this.fetchCancelFns = new Map();\n this.transformCache = new (canUseWeakMap ? WeakMap : Map)();\n this.queryIdCounter = 1;\n this.requestIdCounter = 1;\n this.mutationIdCounter = 1;\n this.inFlightLinkObservables = new Map();\n var defaultDocumentTransform = new DocumentTransform(function (document) { return _this.cache.transformDocument(document); }, { cache: false });\n this.cache = cache;\n this.link = link;\n this.defaultOptions = defaultOptions || Object.create(null);\n this.queryDeduplication = queryDeduplication;\n this.clientAwareness = clientAwareness;\n this.localState = localState || new LocalState({ cache: cache });\n this.ssrMode = ssrMode;\n this.assumeImmutableResults = assumeImmutableResults;\n this.documentTransform = documentTransform\n ? defaultDocumentTransform\n .concat(documentTransform)\n .concat(defaultDocumentTransform)\n : defaultDocumentTransform;\n if ((this.onBroadcast = onBroadcast)) {\n this.mutationStore = Object.create(null);\n }\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(25));\n };\n QueryManager.prototype.cancelPendingFetches = function (error) {\n this.fetchCancelFns.forEach(function (cancel) { return cancel(error); });\n this.fetchCancelFns.clear();\n };\n QueryManager.prototype.mutate = function (_a) {\n var _b, _c;\n var mutation = _a.mutation, variables = _a.variables, optimisticResponse = _a.optimisticResponse, updateQueries = _a.updateQueries, _d = _a.refetchQueries, refetchQueries = _d === void 0 ? [] : _d, _e = _a.awaitRefetchQueries, awaitRefetchQueries = _e === void 0 ? false : _e, updateWithProxyFn = _a.update, onQueryUpdated = _a.onQueryUpdated, _f = _a.fetchPolicy, fetchPolicy = _f === void 0 ? ((_b = this.defaultOptions.mutate) === null || _b === void 0 ? void 0 : _b.fetchPolicy) || \"network-only\" : _f, _g = _a.errorPolicy, errorPolicy = _g === void 0 ? ((_c = this.defaultOptions.mutate) === null || _c === void 0 ? void 0 : _c.errorPolicy) || \"none\" : _g, keepRootFields = _a.keepRootFields, context = _a.context;\n return __awaiter(this, void 0, void 0, function () {\n var mutationId, hasClientExports, mutationStoreValue, self;\n return __generator(this, function (_h) {\n switch (_h.label) {\n case 0:\n invariant(mutation, 26);\n invariant(fetchPolicy === \"network-only\" || fetchPolicy === \"no-cache\", 27);\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, 2];\n return [4, this.localState.addExportedVariables(mutation, variables, context)];\n case 1:\n variables = (_h.sent());\n _h.label = 2;\n case 2:\n mutationStoreValue = this.mutationStore &&\n (this.mutationStore[mutationId] = {\n mutation: mutation,\n variables: variables,\n loading: true,\n error: null,\n });\n if (optimisticResponse) {\n 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 }\n this.broadcastQueries();\n self = this;\n return [2, new Promise(function (resolve, reject) {\n return asyncMap(self.getObservableFromLink(mutation, __assign(__assign({}, context), { optimisticResponse: optimisticResponse }), 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: optimisticResponse ? mutationId : void 0,\n onQueryUpdated: onQueryUpdated,\n keepRootFields: keepRootFields,\n });\n }).subscribe({\n next: function (storeResult) {\n self.broadcastQueries();\n if (!(\"hasNext\" in storeResult) || storeResult.hasNext === false) {\n resolve(storeResult);\n }\n },\n error: function (err) {\n if (mutationStoreValue) {\n mutationStoreValue.loading = false;\n mutationStoreValue.error = err;\n }\n if (optimisticResponse) {\n self.cache.removeOptimistic(mutationId);\n }\n self.broadcastQueries();\n reject(err instanceof ApolloError\n ? err\n : 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) { cache = this.cache; }\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) &&\n isNonEmptyArray(result.incremental)) {\n var diff = cache.diff({\n id: \"ROOT_MUTATION\",\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 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), document = _b.document, variables = _b.variables;\n var _c = cache.diff({\n query: document,\n variables: variables,\n returnPartialData: true,\n optimistic: false,\n }), currentQueryResult = _c.result, complete = _c.complete;\n if (complete && currentQueryResult) {\n var nextQueryResult = updater(currentQueryResult, {\n mutationResult: result,\n queryName: (document && getOperationName(document)) || void 0,\n queryVariables: variables,\n });\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 ||\n mutation.refetchQueries ||\n mutation.update ||\n mutation.onQueryUpdated ||\n mutation.removeOptimistic) {\n var results_1 = [];\n this.refetchQueries({\n updateCache: function (cache) {\n if (!skipCache) {\n cacheWrites.forEach(function (write) { return cache.write(write); });\n }\n var update = mutation.update;\n var isFinalResult = !isExecutionPatchResult(result) ||\n (isExecutionPatchIncrementalResult(result) && !result.hasNext);\n if (update) {\n if (!skipCache) {\n var diff = cache.diff({\n id: \"ROOT_MUTATION\",\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), { data: diff.result });\n if (\"incremental\" in result) {\n delete result.incremental;\n }\n if (\"hasNext\" in result) {\n delete result.hasNext;\n }\n }\n }\n if (isFinalResult) {\n update(cache, result, {\n context: mutation.context,\n variables: mutation.variables,\n });\n }\n }\n if (!skipCache && !mutation.keepRootFields && isFinalResult) {\n cache.modify({\n id: \"ROOT_MUTATION\",\n fields: function (value, _a) {\n var fieldName = _a.fieldName, DELETE = _a.DELETE;\n return fieldName === \"__typename\" ? value : DELETE;\n },\n });\n }\n },\n include: mutation.refetchQueries,\n optimistic: false,\n removeOptimistic: mutation.removeOptimistic,\n onQueryUpdated: mutation.onQueryUpdated || null,\n }).forEach(function (result) { return results_1.push(result); });\n if (mutation.awaitRefetchQueries || mutation.onQueryUpdated) {\n return Promise.all(results_1).then(function () { return result; });\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\"\n ? optimisticResponse(mutation.variables)\n : optimisticResponse;\n return this.cache.recordOptimisticTransaction(function (cache) {\n try {\n _this.markMutationResult(__assign(__assign({}, mutation), { result: { data: data } }), cache);\n }\n catch (error) {\n globalThis.__DEV__ !== false && invariant.error(error);\n }\n }, mutation.mutationId);\n };\n QueryManager.prototype.fetchQuery = function (queryId, options, networkStatus) {\n return this.fetchConcastWithInfo(queryId, options, networkStatus).concast\n .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 hasClientExports: hasClientExports(document),\n hasForcedResolvers: this.localState.shouldForceResolvers(document),\n hasNonreactiveDirective: hasDirectives([\"nonreactive\"], document),\n clientQuery: this.localState.clientQuery(document),\n serverQuery: removeDirectivesFromDocument([\n { name: \"client\", remove: true },\n { name: \"connection\" },\n { name: \"nonreactive\" },\n ], document),\n defaultVars: getDefaultValues(getOperationDefinition(document)),\n asQuery: __assign(__assign({}, document), { definitions: document.definitions.map(function (def) {\n if (def.kind === \"OperationDefinition\" &&\n def.operation !== \"query\") {\n return __assign(__assign({}, def), { operation: \"query\" });\n }\n return def;\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 options = __assign(__assign({}, options), { variables: this.getVariables(query, options.variables) });\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 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) { queryId = this.generateQueryId(); }\n invariant(options.query, 28);\n invariant(options.query.kind === \"Document\", 29);\n invariant(!options.returnPartialData, 30);\n invariant(!options.pollInterval, 31);\n return this.fetchQuery(queryId, __assign(__assign({}, options), { query: this.transform(options.query) })).finally(function () { return _this.stopQuery(queryId); });\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)\n queryInfo.stop();\n };\n QueryManager.prototype.clearStore = function (options) {\n if (options === void 0) { options = {\n discardWatches: true,\n }; }\n this.cancelPendingFetches(newInvariantError(32));\n this.queries.forEach(function (queryInfo) {\n if (queryInfo.observableQuery) {\n queryInfo.networkStatus = NetworkStatus.loading;\n }\n else {\n queryInfo.stop();\n }\n });\n if (this.mutationStore) {\n this.mutationStore = Object.create(null);\n }\n return this.cache.reset(options);\n };\n QueryManager.prototype.getObservableQueries = function (include) {\n var _this = this;\n if (include === void 0) { include = \"active\"; }\n var queries = new Map();\n var queryNamesAndDocs = new Map();\n var legacyQueryOptions = new Set();\n if (Array.isArray(include)) {\n include.forEach(function (desc) {\n if (typeof desc === \"string\") {\n queryNamesAndDocs.set(desc, false);\n }\n else if (isDocumentNode(desc)) {\n queryNamesAndDocs.set(_this.transform(desc), false);\n }\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, document = _a.document;\n if (oq) {\n if (include === \"all\") {\n queries.set(queryId, oq);\n return;\n }\n var queryName = oq.queryName, fetchPolicy = oq.options.fetchPolicy;\n if (fetchPolicy === \"standby\" ||\n (include === \"active\" && !oq.hasObservers())) {\n return;\n }\n if (include === \"active\" ||\n (queryName && queryNamesAndDocs.has(queryName)) ||\n (document && queryNamesAndDocs.has(document))) {\n queries.set(queryId, oq);\n if (queryName)\n queryNamesAndDocs.set(queryName, true);\n if (document)\n queryNamesAndDocs.set(document, true);\n }\n }\n });\n if (legacyQueryOptions.size) {\n legacyQueryOptions.forEach(function (options) {\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), { fetchPolicy: \"network-only\" }),\n });\n invariant(oq.queryId === queryId);\n queryInfo.setObservableQuery(oq);\n queries.set(queryId, oq);\n });\n }\n if (globalThis.__DEV__ !== false && queryNamesAndDocs.size) {\n queryNamesAndDocs.forEach(function (included, nameOrDoc) {\n if (!included) {\n globalThis.__DEV__ !== false && invariant.warn(typeof nameOrDoc === \"string\" ? 33 : 34, nameOrDoc);\n }\n });\n }\n return queries;\n };\n QueryManager.prototype.reFetchObservableQueries = function (includeStandby) {\n var _this = this;\n if (includeStandby === void 0) { includeStandby = false; }\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 ||\n (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 (_a) {\n var _this = this;\n var query = _a.query, fetchPolicy = _a.fetchPolicy, _b = _a.errorPolicy, errorPolicy = _b === void 0 ? \"none\" : _b, variables = _a.variables, _c = _a.context, context = _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).map(function (result) {\n if (fetchPolicy !== \"no-cache\") {\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 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\n .addExportedVariables(query, variables, context)\n .then(makeObservable);\n return new Observable(function (observer) {\n var sub = null;\n observablePromise_1.then(function (observable) { return (sub = observable.subscribe(observer)); }, observer.error);\n return function () { return sub && sub.unsubscribe(); };\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 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)\n this.onBroadcast();\n this.queries.forEach(function (info) { return info.notify(); });\n };\n QueryManager.prototype.getLocalState = function () {\n return this.localState;\n };\n QueryManager.prototype.getObservableFromLink = function (query, context, variables, deduplication) {\n var _this = this;\n var _a;\n if (deduplication === void 0) { deduplication = (_a = context === null || context === void 0 ? void 0 : context.queryDeduplication) !== null && _a !== void 0 ? _a : this.queryDeduplication; }\n var observable;\n var _b = this.getDocumentInfo(query), serverQuery = _b.serverQuery, clientQuery = _b.clientQuery;\n if (serverQuery) {\n var _c = this, inFlightLinkObservables_1 = _c.inFlightLinkObservables, 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), { forceFetch: !deduplication })),\n };\n context = operation.context;\n if (deduplication) {\n var printedServerQuery_1 = print(serverQuery);\n var byVariables_1 = inFlightLinkObservables_1.get(printedServerQuery_1) || new Map();\n inFlightLinkObservables_1.set(printedServerQuery_1, byVariables_1);\n var varJson_1 = canonicalStringify(variables);\n observable = byVariables_1.get(varJson_1);\n if (!observable) {\n var concast = new Concast([\n execute(link, operation),\n ]);\n byVariables_1.set(varJson_1, (observable = concast));\n concast.beforeNext(function () {\n if (byVariables_1.delete(varJson_1) && byVariables_1.size < 1) {\n inFlightLinkObservables_1.delete(printedServerQuery_1);\n }\n });\n }\n }\n else {\n observable = new Concast([\n execute(link, operation),\n ]);\n }\n }\n else {\n observable = new Concast([Observable.of({ data: {} })]);\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 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 if (requestId >= queryInfo.lastRequestId) {\n if (hasErrors && options.errorPolicy === \"none\") {\n throw queryInfo.markError(new ApolloError({\n graphQLErrors: graphQLErrors,\n }));\n }\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 if (hasErrors && options.errorPolicy !== \"ignore\") {\n aqr.errors = graphQLErrors;\n aqr.networkStatus = NetworkStatus.error;\n }\n return aqr;\n }, function (networkError) {\n var error = isApolloError(networkError)\n ? networkError\n : new ApolloError({ networkError: networkError });\n if (requestId >= queryInfo.lastRequestId) {\n queryInfo.markError(error);\n }\n throw error;\n });\n };\n QueryManager.prototype.fetchConcastWithInfo = function (queryId, options, networkStatus, query) {\n var _this = this;\n if (networkStatus === void 0) { networkStatus = NetworkStatus.loading; }\n if (query === void 0) { query = options.query; }\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, fetchPolicy = _a === void 0 ? (defaults && defaults.fetchPolicy) || \"cache-first\" : _a, _b = options.errorPolicy, errorPolicy = _b === void 0 ? (defaults && defaults.errorPolicy) || \"none\" : _b, _c = options.returnPartialData, returnPartialData = _c === void 0 ? false : _c, _d = options.notifyOnNetworkStatusChange, notifyOnNetworkStatusChange = _d === void 0 ? false : _d, _e = options.context, 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 normalized.variables = variables;\n var sourcesWithInfo = _this.fetchQueryByPolicy(queryInfo, normalized, networkStatus);\n if (normalized.fetchPolicy !== \"standby\" &&\n sourcesWithInfo.sources.length > 0 &&\n queryInfo.observableQuery) {\n queryInfo.observableQuery[\"applyNextFetchPolicy\"](\"after-fetch\", options);\n }\n return sourcesWithInfo;\n };\n var cleanupCancelFn = function () { return _this.fetchCancelFns.delete(queryId); };\n this.fetchCancelFns.set(queryId, function (reason) {\n cleanupCancelFn();\n setTimeout(function () { return concast.cancel(reason); });\n });\n var concast, containsDataFromLink;\n if (this.getDocumentInfo(normalized.query).hasClientExports) {\n concast = new Concast(this.localState\n .addExportedVariables(normalized.query, normalized.variables, normalized.context)\n .then(fromVariables)\n .then(function (sourcesWithInfo) { return sourcesWithInfo.sources; }));\n containsDataFromLink = true;\n }\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, include = _a.include, _b = _a.optimistic, optimistic = _b === void 0 ? false : _b, _c = _a.removeOptimistic, removeOptimistic = _c === void 0 ? optimistic ? makeUniqueId(\"refetchQueries\") : void 0 : _c, 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 optimistic: (optimistic && removeOptimistic) || false,\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 includedQueriesById.delete(oq.queryId);\n var result = onQueryUpdated(oq, diff, lastDiff);\n if (result === true) {\n result = oq.refetch();\n }\n if (result !== false) {\n results.set(oq, result);\n }\n return result;\n }\n if (onQueryUpdated !== null) {\n includedQueriesById.set(oq.queryId, { oq: oq, lastDiff: lastDiff, diff: diff });\n }\n }\n },\n });\n }\n if (includedQueriesById.size) {\n includedQueriesById.forEach(function (_a, queryId) {\n var oq = _a.oq, lastDiff = _a.lastDiff, diff = _a.diff;\n var result;\n if (onQueryUpdated) {\n if (!diff) {\n var info = oq[\"queryInfo\"];\n info.reset();\n diff = info.getDiff();\n }\n result = onQueryUpdated(oq, diff, lastDiff);\n }\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 this.cache.removeOptimistic(removeOptimistic);\n }\n return results;\n };\n QueryManager.prototype.fetchQueryByPolicy = function (queryInfo, _a, networkStatus) {\n var _this = this;\n var query = _a.query, variables = _a.variables, fetchPolicy = _a.fetchPolicy, refetchWritePolicy = _a.refetchWritePolicy, errorPolicy = _a.errorPolicy, returnPartialData = _a.returnPartialData, context = _a.context, 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 () { return queryInfo.getDiff(); };\n var resultsFromCache = function (diff, networkStatus) {\n if (networkStatus === void 0) { networkStatus = queryInfo.networkStatus || NetworkStatus.loading; }\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({ data: data, loading: isNetworkRequestInFlight(networkStatus), networkStatus: networkStatus }, (diff.complete ? null : { partial: true })));\n };\n if (data && _this.getDocumentInfo(query).hasForcedResolvers) {\n return _this.localState\n .runResolvers({\n document: query,\n remoteResult: { data: data },\n context: context,\n variables: variables,\n onlyRunForcedResolvers: true,\n })\n .then(function (resolved) { return fromData(resolved.data || void 0); });\n }\n if (errorPolicy === \"none\" &&\n networkStatus === NetworkStatus.refetch &&\n Array.isArray(diff.missing)) {\n return fromData(void 0);\n }\n return fromData(data);\n };\n var cacheWriteBehavior = fetchPolicy === \"no-cache\"\n ? 0\n :\n networkStatus === NetworkStatus.refetch &&\n refetchWritePolicy !== \"merge\"\n ? 1\n : 2;\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 &&\n typeof oldNetworkStatus === \"number\" &&\n oldNetworkStatus !== networkStatus &&\n isNetworkRequestInFlight(networkStatus);\n switch (fetchPolicy) {\n default:\n case \"cache-first\": {\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 { fromLink: true, sources: [resultsFromLink()] };\n }\n case \"cache-and-network\": {\n var diff = readCache();\n if (diff.complete || returnPartialData || shouldNotify) {\n return {\n fromLink: true,\n sources: [resultsFromCache(diff), resultsFromLink()],\n };\n }\n return { fromLink: true, sources: [resultsFromLink()] };\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 { fromLink: true, sources: [resultsFromLink()] };\n case \"no-cache\":\n if (shouldNotify) {\n return {\n fromLink: true,\n sources: [resultsFromCache(queryInfo.getDiff()), resultsFromLink()],\n };\n }\n return { fromLink: true, sources: [resultsFromLink()] };\n case \"standby\":\n return { fromLink: false, sources: [] };\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) { context = {}; }\n var newContext = this.localState.prepareContext(context);\n return __assign(__assign({}, newContext), { clientAwareness: this.clientAwareness });\n };\n return QueryManager;\n}());\nexport { QueryManager };\n//# sourceMappingURL=QueryManager.js.map","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;\nimport { mergeOptions } from \"../utilities/index.js\";\nexport { mergeOptions };\nvar ApolloClient = (function () {\n function ApolloClient(options) {\n var _this = this;\n this.resetStoreCallbacks = [];\n this.clearStoreCallbacks = [];\n if (!options.cache) {\n throw newInvariantError(15);\n }\n var uri = options.uri, credentials = options.credentials, headers = options.headers, cache = options.cache, documentTransform = options.documentTransform, _a = options.ssrMode, ssrMode = _a === void 0 ? false : _a, _b = options.ssrForceFetchDelay, ssrForceFetchDelay = _b === void 0 ? 0 : _b, _c = options.connectToDevTools, connectToDevTools = _c === void 0 ? typeof window === \"object\" &&\n !window.__APOLLO_CLIENT__ &&\n globalThis.__DEV__ !== false : _c, _d = options.queryDeduplication, queryDeduplication = _d === void 0 ? true : _d, defaultOptions = options.defaultOptions, _e = options.assumeImmutableResults, assumeImmutableResults = _e === void 0 ? cache.assumeImmutableResults : _e, resolvers = options.resolvers, typeDefs = options.typeDefs, fragmentMatcher = options.fragmentMatcher, clientAwarenessName = options.name, clientAwarenessVersion = options.version;\n var link = options.link;\n if (!link) {\n link = uri\n ? new HttpLink({ uri: uri, credentials: credentials, 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 if (ssrForceFetchDelay) {\n setTimeout(function () { return (_this.disableNetworkFetches = false); }, 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.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 documentTransform: documentTransform,\n queryDeduplication: queryDeduplication,\n ssrMode: ssrMode,\n clientAwareness: {\n name: clientAwarenessName,\n version: clientAwarenessVersion,\n },\n localState: this.localState,\n assumeImmutableResults: assumeImmutableResults,\n onBroadcast: connectToDevTools\n ? 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 }\n : void 0,\n });\n if (connectToDevTools)\n this.connectToDevTools();\n }\n ApolloClient.prototype.connectToDevTools = function () {\n if (typeof window === \"object\") {\n var windowWithDevTools = window;\n var devtoolsSymbol = Symbol.for(\"apollo.devtools\");\n (windowWithDevTools[devtoolsSymbol] =\n windowWithDevTools[devtoolsSymbol] || []).push(this);\n windowWithDevTools.__APOLLO_CLIENT__ = this;\n }\n if (!hasSuggestedDevtools && globalThis.__DEV__ !== false) {\n hasSuggestedDevtools = true;\n setTimeout(function () {\n if (typeof window !== \"undefined\" &&\n window.document &&\n window.top === window.self &&\n !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 =\n \"https://chrome.google.com/webstore/detail/\" +\n \"apollo-client-developer-t/jdkknkkbebbapilgoeccciglkfbmbnfm\";\n }\n else if (ua.indexOf(\"Firefox/\") > -1) {\n url =\n \"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 \" +\n \"experience: %s\", url);\n }\n }\n }, 10000);\n }\n };\n Object.defineProperty(ApolloClient.prototype, \"documentTransform\", {\n get: function () {\n return this.queryManager.documentTransform;\n },\n enumerable: false,\n configurable: true\n });\n ApolloClient.prototype.stop = function () {\n this.queryManager.stop();\n };\n ApolloClient.prototype.watchQuery = function (options) {\n if (this.defaultOptions.watchQuery) {\n options = mergeOptions(this.defaultOptions.watchQuery, options);\n }\n if (this.disableNetworkFetches &&\n (options.fetchPolicy === \"network-only\" ||\n options.fetchPolicy === \"cache-and-network\")) {\n options = __assign(__assign({}, options), { fetchPolicy: \"cache-first\" });\n }\n return this.queryManager.watchQuery(options);\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\", 16);\n if (this.disableNetworkFetches && options.fetchPolicy === \"network-only\") {\n options = __assign(__assign({}, options), { fetchPolicy: \"cache-first\" });\n }\n return this.queryManager.query(options);\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 ApolloClient.prototype.subscribe = function (options) {\n return this.queryManager.startGraphQLSubscription(options);\n };\n ApolloClient.prototype.readQuery = function (options, optimistic) {\n if (optimistic === void 0) { optimistic = false; }\n return this.cache.readQuery(options, optimistic);\n };\n ApolloClient.prototype.readFragment = function (options, optimistic) {\n if (optimistic === void 0) { optimistic = false; }\n return this.cache.readFragment(options, optimistic);\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 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 ApolloClient.prototype.resetStore = function () {\n var _this = this;\n return Promise.resolve()\n .then(function () {\n return _this.queryManager.clearStore({\n discardWatches: false,\n });\n })\n .then(function () { return Promise.all(_this.resetStoreCallbacks.map(function (fn) { return fn(); })); })\n .then(function () { return _this.reFetchObservableQueries(); });\n };\n ApolloClient.prototype.clearStore = function () {\n var _this = this;\n return Promise.resolve()\n .then(function () {\n return _this.queryManager.clearStore({\n discardWatches: true,\n });\n })\n .then(function () { return Promise.all(_this.clearStoreCallbacks.map(function (fn) { return fn(); })); });\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) { return c !== cb; });\n };\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) { return c !== cb; });\n };\n };\n ApolloClient.prototype.reFetchObservableQueries = function (includeStandby) {\n return this.queryManager.reFetchObservableQueries(includeStandby);\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 result.queries = queries;\n result.results = results;\n result.catch(function (error) {\n globalThis.__DEV__ !== false && invariant.debug(17, error);\n });\n return result;\n };\n ApolloClient.prototype.getObservableQueries = function (include) {\n if (include === void 0) { include = \"active\"; }\n return this.queryManager.getObservableQueries(include);\n };\n ApolloClient.prototype.extract = function (optimistic) {\n return this.cache.extract(optimistic);\n };\n ApolloClient.prototype.restore = function (serializedState) {\n return this.cache.restore(serializedState);\n };\n ApolloClient.prototype.addResolvers = function (resolvers) {\n this.localState.addResolvers(resolvers);\n };\n ApolloClient.prototype.setResolvers = function (resolvers) {\n this.localState.setResolvers(resolvers);\n };\n ApolloClient.prototype.getResolvers = function () {\n return this.localState.getResolvers();\n };\n ApolloClient.prototype.setLocalStateFragmentMatcher = function (fragmentMatcher) {\n this.localState.setFragmentMatcher(fragmentMatcher);\n };\n ApolloClient.prototype.setLink = function (newLink) {\n this.link = this.queryManager.link = newLink;\n };\n return ApolloClient;\n}());\nexport { ApolloClient };\n//# sourceMappingURL=ApolloClient.js.map","import { __assign, __rest } from \"tslib\";\nimport { wrap } from \"optimism\";\nimport { getFragmentQueryDocument } from \"../../utilities/index.js\";\nvar ApolloCache = (function () {\n function ApolloCache() {\n this.assumeImmutableResults = false;\n this.getFragmentDoc = wrap(getFragmentQueryDocument);\n }\n ApolloCache.prototype.batch = function (options) {\n var _this = this;\n var optimisticId = typeof options.optimistic === \"string\"\n ? options.optimistic\n : options.optimistic === false\n ? null\n : void 0;\n var updateResult;\n this.performTransaction(function () { return (updateResult = options.update(_this)); }, optimisticId);\n return updateResult;\n };\n ApolloCache.prototype.recordOptimisticTransaction = function (transaction, optimisticId) {\n this.performTransaction(transaction, optimisticId);\n };\n ApolloCache.prototype.transformDocument = function (document) {\n return document;\n };\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 ApolloCache.prototype.readQuery = function (options, optimistic) {\n if (optimistic === void 0) { optimistic = !!options.optimistic; }\n return this.read(__assign(__assign({}, options), { rootId: options.id || \"ROOT_QUERY\", optimistic: optimistic }));\n };\n ApolloCache.prototype.readFragment = function (options, optimistic) {\n if (optimistic === void 0) { optimistic = !!options.optimistic; }\n return this.read(__assign(__assign({}, options), { query: this.getFragmentDoc(options.fragment, options.fragmentName), rootId: options.id, optimistic: optimistic }));\n };\n ApolloCache.prototype.writeQuery = function (_a) {\n var id = _a.id, data = _a.data, 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, data = _a.data, fragment = _a.fragment, fragmentName = _a.fragmentName, 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)\n return value;\n cache.writeQuery(__assign(__assign({}, options), { data: data }));\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)\n return value;\n cache.writeFragment(__assign(__assign({}, options), { data: data }));\n return data;\n },\n });\n };\n return ApolloCache;\n}());\nexport { ApolloCache };\n//# sourceMappingURL=cache.js.map","import { __extends } from \"tslib\";\nvar MissingFieldError = (function (_super) {\n __extends(MissingFieldError, _super);\n function MissingFieldError(message, path, query, variables) {\n var _a;\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 }\n else {\n _this.missing = _this.path;\n }\n _this.__proto__ = MissingFieldError.prototype;\n return _this;\n }\n return MissingFieldError;\n}(Error));\nexport { MissingFieldError };\n//# sourceMappingURL=common.js.map","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, id = _a.id, _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 (isNullish(id) && !isNullish(_id)) {\n id = _id;\n }\n if (!isNullish(id)) {\n return \"\".concat(__typename, \":\").concat(typeof id === \"number\" || typeof id === \"string\"\n ? id\n : JSON.stringify(id));\n }\n }\n}\nvar defaultConfig = {\n dataIdFromObject: defaultDataIdFromObject,\n addTypename: true,\n resultCaching: true,\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)\n ? store.get(objectOrReference.__ref, \"__typename\")\n : 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)\n ? result.every(function (item) {\n return selectionSetMatchesResult(selectionSet, item, variables);\n })\n : selectionSet.selections.every(function (field) {\n if (isField(field) && shouldInclude(field, variables)) {\n var key = resultKeyNameFromField(field);\n return (hasOwn.call(result, key) &&\n (!field.selectionSet ||\n selectionSetMatchesResult(field.selectionSet, result[key], variables)));\n }\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 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}\n//# sourceMappingURL=helpers.js.map","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 () { return DELETE; };\nvar INVALIDATE = Object.create(null);\nvar EntityStore = (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 this.rootIds = Object.create(null);\n this.refs = Object.create(null);\n this.getFieldValue = function (objectOrReference, storeFieldName) {\n return maybeDeepFreeze(isReference(objectOrReference)\n ? _this.get(objectOrReference.__ref, storeFieldName)\n : objectOrReference && objectOrReference[storeFieldName]);\n };\n this.canRead = function (objOrRef) {\n return isReference(objOrRef)\n ? _this.has(objOrRef.__ref)\n : typeof objOrRef === \"object\";\n };\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 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\" &&\n hasOwn.call(this.policies.rootTypenamesById, dataId)) {\n return this.policies.rootTypenamesById[dataId];\n }\n if (this instanceof Layer) {\n return this.parent.get(dataId, fieldName);\n }\n };\n EntityStore.prototype.lookup = function (dataId, dependOnExistence) {\n if (dependOnExistence)\n 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 if (isReference(older))\n older = older.__ref;\n if (isReference(newer))\n 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 (!incoming)\n return;\n invariant(typeof dataId === \"string\", 1);\n var merged = new DeepMerger(storeObjectReconciler).merge(existing, incoming);\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 (!existing)\n fieldsToDirty_1.__exists = 1;\n Object.keys(incoming).forEach(function (storeFieldName) {\n if (!existing ||\n existing[storeFieldName] !== merged[storeFieldName]) {\n fieldsToDirty_1[storeFieldName] = 1;\n var fieldName = fieldNameFromStoreName(storeFieldName);\n if (fieldName !== storeFieldName &&\n !_this.policies.hasKeyArgs(merged.__typename, fieldName)) {\n fieldsToDirty_1[fieldName] = 1;\n }\n if (merged[storeFieldName] === void 0 && !(_this instanceof Layer)) {\n delete merged[storeFieldName];\n }\n }\n });\n if (fieldsToDirty_1.__typename &&\n !(existing && existing.__typename) &&\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 ? {\n fieldName: fieldNameOrOptions,\n from: from || makeReference(dataId),\n }\n : fieldNameOrOptions, { store: _this });\n },\n };\n Object.keys(storeObject).forEach(function (storeFieldName) {\n var fieldName = fieldNameFromStoreName(storeFieldName);\n var fieldValue = storeObject[storeFieldName];\n if (fieldValue === void 0)\n return;\n var modify = typeof fields === \"function\"\n ? fields\n : fields[storeFieldName] || fields[fieldName];\n if (modify) {\n var newValue = modify === delModifier\n ? DELETE\n : modify(maybeDeepFreeze(fieldValue), __assign(__assign({}, sharedDetails_1), { fieldName: fieldName, storeFieldName: storeFieldName, storage: _this.getStorage(dataId, storeFieldName) }));\n if (newValue === INVALIDATE) {\n _this.group.dirty(dataId, storeFieldName);\n }\n else {\n if (newValue === DELETE)\n 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(2, ref);\n return true;\n }\n };\n if (isReference(newValue)) {\n checkReference(newValue);\n }\n else if (Array.isArray(newValue)) {\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))\n break;\n }\n else {\n if (typeof value === \"object\" && !!value) {\n var id = _this.policies.identify(value)[0];\n if (id) {\n someNonReference = value;\n }\n }\n }\n if (seenReference && someNonReference !== undefined) {\n globalThis.__DEV__ !== false && invariant.warn(3, 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 }\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 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\n ? this.policies.getStoreFieldName({ typename: typename, fieldName: fieldName, args: args })\n : fieldName;\n return this.modify(dataId, storeFieldName\n ? (_a = {},\n _a[storeFieldName] = delModifier,\n _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 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 = { extraRootIds: extraRootIds.sort() };\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, 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)\n delete this.rootIds[rootId];\n return count;\n }\n return 0;\n };\n EntityStore.prototype.getRootIdSet = function (ids) {\n if (ids === void 0) { ids = new Set(); }\n Object.keys(this.rootIds).forEach(ids.add, ids);\n if (this instanceof Layer) {\n this.parent.getRootIdSet(ids);\n }\n else {\n Object.keys(this.policies.rootTypenamesById).forEach(ids.add, ids);\n }\n return ids;\n };\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 Object.keys(_this.findChildRefIds(id)).forEach(ids.add, ids);\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)\n root_1 = root_1.parent;\n idsToRemove.forEach(function (id) { return root_1.delete(id); });\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)\n return found_1;\n var workSet_1 = new Set([root]);\n workSet_1.forEach(function (obj) {\n if (isReference(obj)) {\n found_1[obj.__ref] = true;\n }\n if (isNonNullObject(obj)) {\n Object.keys(obj).forEach(function (key) {\n var child = obj[key];\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 };\nvar CacheGroup = (function () {\n function CacheGroup(caching, parent) {\n if (parent === void 0) { parent = null; }\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 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), storeFieldName === \"__exists\" ? \"forget\" : \"setDirty\");\n }\n };\n return CacheGroup;\n}());\nfunction makeDepKey(dataId, storeFieldName) {\n return storeFieldName + \"#\" + dataId;\n}\nexport function maybeDependOnExistenceOfEntity(store, entityId) {\n if (supportsResultCaching(store)) {\n store.group.depend(entityId, \"__exists\");\n }\n}\n(function (EntityStore) {\n var Root = (function (_super) {\n __extends(Root, _super);\n function Root(_a) {\n var policies = _a.policies, _b = _a.resultCaching, resultCaching = _b === void 0 ? true : _b, 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)\n _this.replace(seed);\n return _this;\n }\n Root.prototype.addLayer = function (layerId, replay) {\n return this.stump.addLayer(layerId, replay);\n };\n Root.prototype.removeLayer = function () {\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 = {}));\nvar Layer = (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 var parent = this.parent.removeLayer(layerId);\n if (layerId === this.id) {\n if (this.group.caching) {\n Object.keys(this.data).forEach(function (dataId) {\n var ownStoreObject = _this.data[dataId];\n var parentStoreObject = parent[\"lookup\"](dataId);\n if (!parentStoreObject) {\n _this.delete(dataId);\n }\n else if (!ownStoreObject) {\n _this.group.dirty(dataId, \"__exists\");\n Object.keys(parentStoreObject).forEach(function (storeFieldName) {\n _this.group.dirty(dataId, storeFieldName);\n });\n }\n else if (ownStoreObject !== parentStoreObject) {\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 if (parent === this.parent)\n return this;\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)\n ? __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)\n p = p.parent;\n return p.getStorage.apply(p, arguments);\n };\n return Layer;\n}(EntityStore));\nvar Stump = (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 return this;\n };\n Stump.prototype.merge = function () {\n return this.parent.merge.apply(this.parent, arguments);\n };\n return Stump;\n}(Layer));\nfunction storeObjectReconciler(existingObject, incomingObject, property) {\n var existingValue = existingObject[property];\n var incomingValue = incomingObject[property];\n return equal(existingValue, incomingValue) ? existingValue : incomingValue;\n}\nexport function supportsResultCaching(store) {\n return !!(store instanceof EntityStore && store.group.caching);\n}\n//# sourceMappingURL=entityStore.js.map","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, } 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 { canonicalStringify, ObjectCanon } from \"./object-canon.js\";\nfunction execSelectionSetKeyArgs(options) {\n return [\n options.selectionSet,\n options.objectOrReference,\n options.context,\n options.context.canonizeResults,\n ];\n}\nvar StoreReader = (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 this.executeSelectionSet = wrap(function (options) {\n var _a;\n var canonizeResults = options.context.canonizeResults;\n var peekArgs = execSelectionSetKeyArgs(options);\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), { result: _this.canon.admit(other.result) });\n }\n return other;\n }\n maybeDependOnExistenceOfEntity(options.context.store, options.enclosingRef.__ref);\n return _this.execSelectionSetImpl(options);\n }, {\n max: this.config.resultCacheMaxSize,\n keyArgs: execSelectionSetKeyArgs,\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,\n makeCacheKey: function (_a) {\n var field = _a.field, array = _a.array, 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 StoreReader.prototype.diffQueryAgainstStore = function (_a) {\n var store = _a.store, query = _a.query, _b = _a.rootId, rootId = _b === void 0 ? \"ROOT_QUERY\" : _b, variables = _a.variables, _c = _a.returnPartialData, returnPartialData = _c === void 0 ? true : _c, _d = _a.canonizeResults, 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({ store: store, query: query, policies: policies, variables: variables, varString: canonicalStringify(variables), canonizeResults: canonizeResults }, extractFragmentContext(query, this.config.fragments)),\n });\n var missing;\n if (execResult.missing) {\n missing = [\n new MissingFieldError(firstMissing(execResult.missing), execResult.missing, query, variables),\n ];\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) &&\n this.knownResults.get(result) === selectionSet) {\n var latest = this.executeSelectionSet.peek(selectionSet, parent, context, this.canon.isKnown(result));\n if (latest && result === latest.result) {\n return true;\n }\n }\n return false;\n };\n StoreReader.prototype.execSelectionSetImpl = function (_a) {\n var _this = this;\n var selectionSet = _a.selectionSet, objectOrReference = _a.objectOrReference, enclosingRef = _a.enclosingRef, context = _a.context;\n if (isReference(objectOrReference) &&\n !context.policies.rootTypenamesById[objectOrReference.__ref] &&\n !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, policies = context.policies, 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 &&\n typeof typename === \"string\" &&\n !policies.rootIdsByTypename[typename]) {\n objectsToMerge.push({ __typename: typename });\n }\n function handleMissing(result, resultName) {\n var _a;\n if (result.missing) {\n missing = missingMerger.merge(missing, (_a = {},\n _a[resultName] = result.missing,\n _a));\n }\n return result.result;\n }\n var workSet = new Set(selectionSet.selections);\n workSet.forEach(function (selection) {\n var _a, _b;\n if (!shouldInclude(selection, variables))\n 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 = {},\n _a[resultName] = \"Can't find field '\".concat(selection.name.value, \"' on \").concat(isReference(objectOrReference)\n ? objectOrReference.__ref + \" object\"\n : \"object \" + JSON.stringify(objectOrReference, null, 2)),\n _a));\n }\n }\n else if (isArray(fieldValue)) {\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 (context.canonizeResults) {\n fieldValue = _this.canon.pass(fieldValue);\n }\n }\n else if (fieldValue != 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 }\n else {\n var fragment = getFragmentFromSelection(selection, context.lookupFragment);\n if (!fragment && selection.kind === Kind.FRAGMENT_SPREAD) {\n throw newInvariantError(9, 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 = { result: result, missing: missing };\n var frozen = context.canonizeResults\n ? this.canon.admit(finalResult)\n :\n maybeDeepFreeze(finalResult);\n if (frozen.result) {\n this.knownResults.set(frozen.result, selectionSet);\n }\n return frozen;\n };\n StoreReader.prototype.execSubSelectedArrayImpl = function (_a) {\n var _this = this;\n var field = _a.field, array = _a.array, enclosingRef = _a.enclosingRef, 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 if (item === null) {\n return null;\n }\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 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\")\n throw value;\n return value;\n });\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(\n !isReference(value),\n 10,\n getTypenameFromStoreObject(store, value),\n field.name.value\n );\n Object.values(value).forEach(workSet_1.add, workSet_1);\n }\n });\n }\n}\n//# sourceMappingURL=readFromStore.js.map","import { invariant } from \"../../utilities/globals/index.js\";\nimport { argumentsObjectFromField, DeepMerger, isNonEmptyArray, isNonNullObject, } from \"../../utilities/index.js\";\nimport { hasOwn, isArray } from \"./helpers.js\";\nvar specifierInfoCache = Object.create(null);\nfunction lookupSpecifierInfo(spec) {\n var cacheKey = JSON.stringify(spec);\n return (specifierInfoCache[cacheKey] ||\n (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, extract);\n if (extracted === void 0 &&\n object !== context.storeObject &&\n hasOwn.call(object, schemaKeyPath[0])) {\n extracted = extractKeyPath(object, schemaKeyPath, extractKey);\n }\n invariant(extracted !== void 0, 4, schemaKeyPath.join(\".\"), object);\n return extracted;\n }));\n return \"\".concat(context.typename, \":\").concat(JSON.stringify(keyObject));\n }));\n}\nexport function keyArgsFnFromSpecifier(specifier) {\n var info = lookupSpecifierInfo(specifier);\n return (info.keyArgsFn ||\n (info.keyArgsFn = function (args, _a) {\n var field = _a.field, variables = _a.variables, 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 var d = field.directives.find(function (d) { return d.name.value === directiveName_1; });\n var directiveArgs = d && argumentsObjectFromField(d, variables);\n return (directiveArgs &&\n extractKeyPath(directiveArgs, keyPath.slice(1)));\n }\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 return;\n }\n if (args) {\n return extractKeyPath(args, keyPath);\n }\n });\n var suffix = JSON.stringify(collected);\n if (args || suffix !== \"{}\") {\n fieldName += \":\" + suffix;\n }\n return fieldName;\n }));\n}\nexport function collectSpecifierPaths(specifier, extractor) {\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 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) { return paths_1.push(currentPath_1.concat(p)); });\n currentPath_1.length = 0;\n }\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 extract = extract || extractKey;\n return normalize(path.reduce(function reducer(obj, key) {\n return isArray(obj)\n ? obj.map(function (child) { return reducer(child, key); })\n : obj && extract(obj, key);\n }, object));\n}\nfunction normalize(value) {\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}\n//# sourceMappingURL=key-extractor.js.map","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 { canonicalStringify } from \"./object-canon.js\";\nimport { keyArgsFnFromSpecifier, keyFieldsFnFromSpecifier, } from \"./key-extractor.js\";\ngetStoreKeyName.setStringify(canonicalStringify);\nfunction argsFromFieldSpecifier(spec) {\n return spec.args !== void 0\n ? spec.args\n : spec.field\n ? argumentsObjectFromField(spec.field, spec.variables)\n : null;\n}\nvar nullKeyFieldsFn = function () { return void 0; };\nvar simpleKeyArgsFn = function (_args, context) { return context.fieldName; };\nvar mergeTrueFn = function (existing, incoming, _a) {\n var mergeObjects = _a.mergeObjects;\n return mergeObjects(existing, incoming);\n};\nvar mergeFalseFn = function (_, incoming) { return incoming; };\nvar Policies = (function () {\n function Policies(config) {\n this.config = config;\n this.typePolicies = Object.create(null);\n this.toBeAdded = Object.create(null);\n this.supertypeMap = new Map();\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({ dataIdFromObject: defaultDataIdFromObject }, 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 &&\n (partialContext.typename || ((_a = partialContext.storeObject) === null || _a === void 0 ? void 0 : _a.__typename))) ||\n object.__typename;\n if (typename === this.rootTypenamesById.ROOT_QUERY) {\n return [\"ROOT_QUERY\"];\n }\n var storeObject = (partialContext && partialContext.storeObject) || object;\n var context = __assign(__assign({}, partialContext), { typename: typename, storeObject: storeObject, readField: (partialContext && partialContext.readField) ||\n function () {\n var options = normalizeReadFieldOptions(arguments, storeObject);\n return policies.readField(options, {\n store: policies.cache[\"data\"],\n variables: options.variables,\n });\n } });\n var id;\n var policy = typename && this.getTypePolicy(typename);\n var keyFn = (policy && policy.keyFn) || this.config.dataIdFromObject;\n while (keyFn) {\n var specifierOrId = keyFn(__assign(__assign({}, object), storeObject), context);\n if (isArray(specifierOrId)) {\n keyFn = keyFieldsFnFromSpecifier(specifierOrId);\n }\n else {\n id = specifierOrId;\n break;\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], queryType = _a.queryType, mutationType = _a.mutationType, subscriptionType = _a.subscriptionType, incoming = __rest(_a, [\"queryType\", \"mutationType\", \"subscriptionType\"]);\n if (queryType)\n _this.setRootTypename(\"Query\", typename);\n if (mutationType)\n _this.setRootTypename(\"Mutation\", typename);\n if (subscriptionType)\n _this.setRootTypename(\"Subscription\", typename);\n if (hasOwn.call(_this.toBeAdded, typename)) {\n _this.toBeAdded[typename].push(incoming);\n }\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, fields = incoming.fields;\n function setMerge(existing, merge) {\n existing.merge =\n typeof merge === \"function\"\n ? merge\n :\n merge === true\n ? mergeTrueFn\n :\n merge === false\n ? mergeFalseFn\n : existing.merge;\n }\n setMerge(existing, incoming.merge);\n existing.keyFn =\n keyFields === false\n ? nullKeyFieldsFn\n :\n isArray(keyFields)\n ? keyFieldsFnFromSpecifier(keyFields)\n :\n typeof keyFields === \"function\"\n ? keyFields\n :\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 }\n else {\n var keyArgs = incoming.keyArgs, read = incoming.read, merge = incoming.merge;\n existing.keyFn =\n keyArgs === false\n ? simpleKeyArgsFn\n :\n isArray(keyArgs)\n ? keyArgsFnFromSpecifier(keyArgs)\n :\n typeof keyArgs === \"function\"\n ? keyArgs\n :\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 existing.keyFn = existing.keyFn || simpleKeyArgsFn;\n }\n });\n }\n };\n Policies.prototype.setRootTypename = function (which, typename) {\n if (typename === void 0) { typename = which; }\n var rootId = \"ROOT_\" + which.toUpperCase();\n var old = this.rootTypenamesById[rootId];\n if (typename !== old) {\n invariant(!old || old === which, 5, which);\n if (old)\n delete this.rootIdsByTypename[old];\n this.rootIdsByTypename[typename] = 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 _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 _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 var supertypes_1 = this.supertypeMap.get(typename);\n if (!supertypes_1 && this.fuzzySubtypes.size) {\n supertypes_1 = this.getSupertypeSet(typename, true);\n this.fuzzySubtypes.forEach(function (regExp, fuzzy) {\n if (regExp.test(typename)) {\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), fields = _a.fields, 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 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] ||\n (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)\n return true;\n if (!typename)\n return false;\n var supertype = fragment.typeCondition.name.value;\n if (typename === supertype)\n 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 &&\n supertypeSet.size &&\n workQueue_1.indexOf(supertypeSet) < 0) {\n workQueue_1.push(supertypeSet);\n }\n };\n var needToCheckFuzzySubtypes = !!(result && this.fuzzySubtypes.size);\n var checkingFuzzySubtypes = false;\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(6, typename, supertype);\n }\n typenameSupertypeSet.add(supertype);\n }\n return true;\n }\n supertypeSet.forEach(maybeEnqueue_1);\n if (needToCheckFuzzySubtypes &&\n i === workQueue_1.length - 1 &&\n selectionSetMatchesResult(fragment.selectionSet, result, variables)) {\n needToCheckFuzzySubtypes = false;\n checkingFuzzySubtypes = true;\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, 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 }\n else {\n storeFieldName = specifierOrString || fieldName;\n break;\n }\n }\n }\n if (storeFieldName === void 0) {\n storeFieldName = fieldSpec.field\n ? storeKeyNameFromField(fieldSpec.field, fieldSpec.variables)\n : getStoreKeyName(fieldName, argsFromFieldSpecifier(fieldSpec));\n }\n if (storeFieldName === false) {\n return fieldName;\n }\n return fieldName === fieldNameFromStoreName(storeFieldName)\n ? storeFieldName\n : fieldName + \":\" + storeFieldName;\n };\n Policies.prototype.readField = function (options, context) {\n var objectOrReference = options.from;\n if (!objectOrReference)\n return;\n var nameOrField = options.field || options.fieldName;\n if (!nameOrField)\n return;\n if (options.typename === void 0) {\n var typename = context.store.getFieldValue(objectOrReference, \"__typename\");\n if (typename)\n 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)\n ? objectOrReference.__ref\n : objectOrReference, storeFieldName));\n return cacheSlot.withValue(this.cache, read, [\n existing,\n readOptions,\n ]);\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, typename = _a.typename, merge = _a.merge;\n if (merge === mergeTrueFn) {\n return makeMergeObjectsFunction(context.store)(existing, incoming);\n }\n if (merge === mergeFalseFn) {\n return incoming;\n }\n if (context.overwrite) {\n existing = void 0;\n }\n return merge(existing, incoming, makeFieldFunctionOptions(this, 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, toReference = _a.toReference, 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], from = readFieldArgs[1], argc = readFieldArgs.length;\n var options;\n if (typeof fieldNameOrOptions === \"string\") {\n options = {\n fieldName: fieldNameOrOptions,\n from: argc > 1 ? from : objectOrReference,\n };\n }\n else {\n options = __assign({}, fieldNameOrOptions);\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(7, 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(8);\n }\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 store.merge(existing.__ref, incoming);\n return existing;\n }\n if (storeValueIsStoreObject(existing) && isReference(incoming)) {\n store.merge(existing, incoming.__ref);\n return incoming;\n }\n if (storeValueIsStoreObject(existing) &&\n storeValueIsStoreObject(incoming)) {\n return __assign(__assign({}, existing), incoming);\n }\n }\n return incoming;\n };\n}\n//# sourceMappingURL=policies.js.map","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, } from \"../../utilities/index.js\";\nimport { isArray, makeProcessedFieldsMerger, fieldNameFromStoreName, storeValueIsStoreObject, extractFragmentContext, } from \"./helpers.js\";\nimport { canonicalStringify } from \"./object-canon.js\";\nimport { normalizeReadFieldOptions } from \"./policies.js\";\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 =\n context.clientOnly === clientOnly && context.deferred === deferred\n ? context\n : __assign(__assign({}, context), { clientOnly: clientOnly, deferred: deferred })));\n }\n return flavored;\n}\nvar StoreWriter = (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, result = _a.result, dataId = _a.dataId, variables = _a.variables, overwrite = _a.overwrite;\n var operationDefinition = getOperationDefinition(query);\n var merger = makeProcessedFieldsMerger();\n variables = __assign(__assign({}, getDefaultValues(operationDefinition)), variables);\n var context = __assign(__assign({ store: store, written: Object.create(null), merge: function (existing, incoming) {\n return merger.merge(existing, incoming);\n }, variables: variables, varString: canonicalStringify(variables) }, extractFragmentContext(query, this.fragments)), { overwrite: !!overwrite, incomingById: new Map(), clientOnly: false, deferred: false, flavors: new Map() });\n var ref = this.processSelectionSet({\n result: result || Object.create(null),\n dataId: dataId,\n selectionSet: operationDefinition.selectionSet,\n mergeTree: { map: new Map() },\n context: context,\n });\n if (!isReference(ref)) {\n throw newInvariantError(11, result);\n }\n context.incomingById.forEach(function (_a, dataId) {\n var storeObject = _a.storeObject, mergeTree = _a.mergeTree, 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 return;\n }\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)] ===\n 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 (hasSelectionSet_1(storeFieldName) &&\n !hasMergeFunction_1(storeFieldName)) {\n warnAboutDataLoss(entityRef, storeObject, storeFieldName, context.store);\n }\n });\n }\n store.merge(dataId, storeObject);\n });\n store.retain(ref.__ref);\n return ref;\n };\n StoreWriter.prototype.processSelectionSet = function (_a) {\n var _this = this;\n var dataId = _a.dataId, result = _a.result, selectionSet = _a.selectionSet, context = _a.context, mergeTree = _a.mergeTree;\n var policies = this.cache.policies;\n var incoming = Object.create(null);\n var typename = (dataId && policies.rootTypenamesById[dataId]) ||\n getTypenameFromResult(result, selectionSet, context.fragmentMap) ||\n (dataId && context.store.get(dataId, \"__typename\"));\n if (\"string\" === typeof typename) {\n incoming.__typename = typename;\n }\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), { from: info.storeObject }), 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, 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, field.selectionSet\n ? getContextFlavor(context, false, false)\n : context, childTree);\n var childTypename = void 0;\n if (field.selectionSet &&\n (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 field: field,\n typename: typename,\n merge: merge,\n };\n }\n else {\n maybeRecycleChildMergeTree(mergeTree, storeFieldName);\n }\n incoming = context.merge(incoming, (_a = {},\n _a[storeFieldName] = incomingValue,\n _a));\n }\n else if (globalThis.__DEV__ !== false &&\n !context.clientOnly &&\n !context.deferred &&\n !addTypenameToDocument.added(field) &&\n !policies.getReadFunction(typename, field.name.value)) {\n globalThis.__DEV__ !== false && invariant.error(12, resultKeyNameFromField(field), result);\n }\n });\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 }), id = _b[0], keyObject = _b[1];\n dataId = dataId || id;\n if (keyObject) {\n incoming = context.merge(incoming, keyObject);\n }\n }\n catch (e) {\n if (!dataId)\n throw e;\n }\n if (\"string\" === typeof dataId) {\n var dataRef = makeReference(dataId);\n var sets = context.written[dataId] || (context.written[dataId] = []);\n if (sets.indexOf(selectionSet) >= 0)\n return dataRef;\n sets.push(selectionSet);\n if (this.reader &&\n 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) { return previous_1.fieldNodeSet.add(field); });\n }\n else {\n context.incomingById.set(dataId, {\n storeObject: incoming,\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 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 StoreWriter.prototype.flattenFields = function (selectionSet, result, context, typename) {\n if (typename === void 0) { typename = getTypenameFromResult(result, selectionSet, context.fragmentMap); }\n var fieldMap = new Map();\n var policies = this.cache.policies;\n var limitingTrie = new Trie(false);\n (function flatten(selectionSet, inheritedContext) {\n var visitedNode = limitingTrie.lookup(selectionSet, inheritedContext.clientOnly, inheritedContext.deferred);\n if (visitedNode.visited)\n return;\n visitedNode.visited = true;\n selectionSet.selections.forEach(function (selection) {\n if (!shouldInclude(selection, context.variables))\n return;\n var clientOnly = inheritedContext.clientOnly, deferred = inheritedContext.deferred;\n if (!(clientOnly && deferred) &&\n isNonEmptyArray(selection.directives)) {\n selection.directives.forEach(function (dir) {\n var name = dir.name.value;\n if (name === \"client\")\n clientOnly = true;\n if (name === \"defer\") {\n var args = argumentsObjectFromField(dir, context.variables);\n if (!args || args.if !== false) {\n deferred = true;\n }\n }\n });\n }\n if (isField(selection)) {\n var existing = fieldMap.get(selection);\n if (existing) {\n clientOnly = clientOnly && existing.clientOnly;\n deferred = deferred && existing.deferred;\n }\n fieldMap.set(selection, getContextFlavor(context, clientOnly, deferred));\n }\n else {\n var fragment = getFragmentFromSelection(selection, context.lookupFragment);\n if (!fragment && selection.kind === Kind.FRAGMENT_SPREAD) {\n throw newInvariantError(13, selection.name.value);\n }\n if (fragment &&\n 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 = !isArray(incoming) &&\n (isReference(existing) || storeValueIsStoreObject(existing))\n ? existing\n : void 0;\n var i_1 = incoming;\n if (e_1 && !getStorageArgs) {\n getStorageArgs = [isReference(e_1) ? e_1.__ref : e_1];\n }\n var changedFields_1;\n var getValue_1 = function (from, name) {\n return isArray(from)\n ? typeof name === \"number\"\n ? from[name]\n : void 0\n : 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 (void 0 === iVal)\n 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 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() || { map: new Map() });\n }\n return map.get(name);\n}\nfunction mergeMergeTrees(left, right) {\n if (left === right || !right || mergeTreeIsEmpty(right))\n return left;\n if (!left || mergeTreeIsEmpty(left))\n return right;\n var info = left.info && right.info\n ? __assign(__assign({}, left.info), right.info) : left.info || right.info;\n var needToMergeMaps = left.map.size && right.map.size;\n var map = needToMergeMaps\n ? new Map()\n : left.map.size\n ? left.map\n : right.map;\n var merged = { info: info, map: map };\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();\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)\n return;\n var incoming = getChild(incomingObj);\n if (!incoming)\n return;\n if (isReference(existing))\n return;\n if (equal(existing, incoming))\n return;\n if (Object.keys(existing).every(function (key) { return store.getFieldValue(incoming, key) !== void 0; })) {\n return;\n }\n var parentType = store.getFieldValue(existingRef, \"__typename\") ||\n store.getFieldValue(incomingObj, \"__typename\");\n var fieldName = fieldNameFromStoreName(storeFieldName);\n var typeDotName = \"\".concat(parentType, \".\").concat(fieldName);\n if (warnings.has(typeDotName))\n return;\n warnings.add(typeDotName);\n var childTypenames = [];\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(14, fieldName, parentType, childTypenames.length\n ? \"either ensure all objects of type \" +\n childTypenames.join(\" and \") +\n \" have an ID or a custom merge function, or \"\n : \"\", typeDotName, existing, incoming);\n}\n//# sourceMappingURL=writeToStore.js.map","import { __assign, __extends } from \"tslib\";\nimport { invariant } from \"../../utilities/globals/index.js\";\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, } 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 { canonicalStringify } from \"./object-canon.js\";\nvar InMemoryCache = (function (_super) {\n __extends(InMemoryCache, _super);\n function InMemoryCache(config) {\n if (config === void 0) { config = {}; }\n var _this = _super.call(this) || this;\n _this.watches = new Set();\n _this.addTypenameTransform = new DocumentTransform(addTypenameToDocument);\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 var rootStore = (this.data = new EntityStore.Root({\n policies: this.policies,\n resultCaching: this.config.resultCaching,\n }));\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 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\n ? void 0\n : 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,\n makeCacheKey: function (c) {\n var store = c.optimistic ? _this.optimisticData : _this.data;\n if (supportsResultCaching(store)) {\n var optimistic = c.optimistic, id = c.id, variables = c.variables;\n return store.makeCacheKey(c.query, c.callback, canonicalStringify({ optimistic: optimistic, id: id, variables: variables }));\n }\n },\n });\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 if (data)\n this.data.replace(data);\n return this;\n };\n InMemoryCache.prototype.extract = function (optimistic) {\n if (optimistic === void 0) { optimistic = false; }\n return (optimistic ? this.optimisticData : this.data).extract();\n };\n InMemoryCache.prototype.read = function (options) {\n var _a = options.returnPartialData, returnPartialData = _a === void 0 ? false : _a;\n try {\n return (this.storeReader.diffQueryAgainstStore(__assign(__assign({}, options), { store: options.optimistic ? this.optimisticData : this.data, config: this.config, returnPartialData: returnPartialData })).result || null);\n }\n catch (e) {\n if (e instanceof MissingFieldError) {\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 }\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 return false;\n }\n var store = options.optimistic\n ? this.optimisticData\n : this.data;\n try {\n ++this.txCount;\n return store.modify(options.id || \"ROOT_QUERY\", options.fields);\n }\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), { store: options.optimistic ? this.optimisticData : this.data, rootId: options.id || \"ROOT_QUERY\", config: this.config }));\n };\n InMemoryCache.prototype.watch = function (watch) {\n var _this = this;\n if (!this.watches.size) {\n recallCache(this);\n }\n this.watches.add(watch);\n if (watch.immediate) {\n this.maybeBroadcastWatch(watch);\n }\n return function () {\n if (_this.watches.delete(watch) && !_this.watches.size) {\n forgetCache(_this);\n }\n _this.maybeBroadcastWatch.forget(watch);\n };\n };\n InMemoryCache.prototype.gc = function (options) {\n canonicalStringify.reset();\n var ids = this.optimisticData.gc();\n if (options && !this.txCount) {\n if (options.resetResultCache) {\n this.resetResultCache(options.resetResultIdentities);\n }\n else if (options.resetResultIdentities) {\n this.storeReader.resetCanon();\n }\n }\n return ids;\n };\n InMemoryCache.prototype.retain = function (rootId, optimistic) {\n return (optimistic ? this.optimisticData : this.data).retain(rootId);\n };\n InMemoryCache.prototype.release = function (rootId, optimistic) {\n return (optimistic ? this.optimisticData : this.data).release(rootId);\n };\n InMemoryCache.prototype.identify = function (object) {\n if (isReference(object))\n return object.__ref;\n try {\n return this.policies.identify(object)[0];\n }\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 return false;\n }\n options = __assign(__assign({}, options), { id: \"ROOT_QUERY\" });\n }\n try {\n ++this.txCount;\n return this.optimisticData.evict(options, this.data);\n }\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 this.watches.forEach(function (watch) { return _this.maybeBroadcastWatch.forget(watch); });\n this.watches.clear();\n forgetCache(this);\n }\n else {\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, _a = options.optimistic, optimistic = _a === void 0 ? true : _a, removeOptimistic = options.removeOptimistic, onWatchUpdated = options.onWatchUpdated;\n var updateResult;\n var perform = function (layer) {\n var _a = _this, data = _a.data, optimisticData = _a.optimisticData;\n ++_this.txCount;\n if (layer) {\n _this.data = _this.optimisticData = layer;\n }\n try {\n return (updateResult = update(_this));\n }\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 this.broadcastWatches(__assign(__assign({}, options), { onWatchUpdated: function (watch) {\n alreadyDirty.add(watch);\n return false;\n } }));\n }\n if (typeof optimistic === \"string\") {\n this.optimisticData = this.optimisticData.addLayer(optimistic, perform);\n }\n else if (optimistic === false) {\n perform(this.data);\n }\n else {\n perform();\n }\n if (typeof removeOptimistic === \"string\") {\n this.optimisticData = this.optimisticData.removeLayer(removeOptimistic);\n }\n if (onWatchUpdated && alreadyDirty.size) {\n this.broadcastWatches(__assign(__assign({}, options), { onWatchUpdated: function (watch, diff) {\n var result = onWatchUpdated.call(this, watch, diff);\n if (result !== false) {\n alreadyDirty.delete(watch);\n }\n return result;\n } }));\n if (alreadyDirty.size) {\n alreadyDirty.forEach(function (watch) { return _this.maybeBroadcastWatch.dirty(watch); });\n }\n }\n else {\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.broadcastWatches = function (options) {\n var _this = this;\n if (!this.txCount) {\n this.watches.forEach(function (c) { return _this.maybeBroadcastWatch(c, options); });\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 InMemoryCache.prototype.broadcastWatch = function (c, options) {\n var lastDiff = c.lastDiff;\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 &&\n options.onWatchUpdated.call(this, c, diff, lastDiff) === false) {\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 };\n//# sourceMappingURL=inMemoryCache.js.map","export const CONFIG_KEY = 'NEWRON_PLATFORM_CONFIG'\n\nconst getConfig = (): Config => {\n const newronPlatformConfig = (window as any)[CONFIG_KEY] // This config values comes from host-app script variable NEWRON_PLATFORM_CONFIG\n\n return {\n ECOSYSTEM_BASEURL: process.env.ECOSYSTEM_BASEURL ?? '/graphql',\n API_PATH: process.env.API_PATH ?? '/cie/graphql',\n API_PREFERENCE_PATH: process.env.API_PREFERENCE_PATH ?? '/preference-filters',\n MFE_CIE_ENABLED: newronPlatformConfig?.MFE_CIE_ENABLED ?? '',\n }\n}\n\n// checks if the variables exist in process.env, if not, get it from NEWRON_PLATFORM_CONFIG\nexport const getValueFromKey = (key: string) => {\n const configEnv = getConfig() as any\n return configEnv[key.replace('REACT_APP_', '')]\n}\n\nexport const env = (key: string): string => {\n const value = getValueFromKey(key)\n if (!value) {\n throw new Error(`${key} is not set`)\n }\n return value\n}\n\nexport const envNoError = (key: string): string => {\n const value = getValueFromKey(key)\n if (!value) {\n return ''\n }\n return value\n}\n\nexport interface Config {\n ECOSYSTEM_BASEURL: string\n API_PATH: string\n API_PREFERENCE_PATH: string\n MFE_CIE_ENABLED: string\n}\n","import { ApolloClient, ApolloLink, HttpLink, InMemoryCache } from '@apollo/client'\nimport { memoize } from 'lodash'\nimport { envNoError } from 'util/env'\n\nconst customFetch: WindowOrWorkerGlobalScope['fetch'] = async (uri, options) => {\n return await fetch(uri, options)\n}\n\nexport const getApolloClientWithAuthentication = memoize((token: string) => {\n const httpLink = ApolloLink.from([\n new ApolloLink((operation, forward) => {\n if (token) {\n operation.setContext({ headers: { authorization: `Bearer ${token}` } })\n }\n return forward(operation)\n }),\n ApolloLink.split(\n (operation) => operation.getContext().name === 'ECOSYSTEM',\n new HttpLink({\n fetch: customFetch,\n uri: `${envNoError('ECOSYSTEM_BASEURL')}`,\n }),\n new HttpLink({\n fetch: customFetch,\n uri: envNoError('API_PATH'),\n })\n ),\n ])\n\n return new ApolloClient({\n connectToDevTools: process.env.NODE_ENV === 'development',\n cache: new InMemoryCache({\n typePolicies: {\n Answer: {\n keyFields: ['answer_id', 'answer_code'],\n },\n },\n }),\n link: httpLink,\n defaultOptions: { query: { fetchPolicy: 'no-cache' } },\n })\n})\n","import { gql } from '@apollo/client'\n\nexport const SERIES_SUMMARY = gql`\n fragment SeriesSummaryFragment on Series {\n primaryValue\n primaryCode\n seriesTotal\n seriesTotalUnweighted\n }\n`\nexport const SERIES_DETAILS_NO_LIMIT = gql`\n fragment SeriesDetailsFragmentNoLimit on Series {\n ...SeriesSummaryFragment\n aggregateDataPoint {\n percent\n unweighted\n secondaryValue\n secondaryCode\n weighted\n }\n dataPoints {\n percent\n unweighted\n secondaryValue\n secondaryCode\n weighted\n }\n }\n ${SERIES_SUMMARY}\n`\n\nexport const SERIES_DETAILS = gql`\n fragment SeriesDetailsFragment on Series {\n ...SeriesSummaryFragment\n aggregateDataPoint(limit: $limitDataPoints) {\n percent\n unweighted\n secondaryValue\n secondaryCode\n weighted\n }\n dataPoints(limit: $limitDataPoints) {\n percent\n marketShare\n unweighted\n secondaryValue\n secondaryCode\n weighted\n weightedTotal\n unweightedTotal\n average\n }\n }\n ${SERIES_SUMMARY}\n`\n\nexport const SERIES_RATING_DETAILS = gql`\n fragment SeriesRatingDetailsFragment on Series {\n ...SeriesSummaryFragment\n aggregateDataPoint(limit: $limitDataPoints) {\n percent\n unweighted\n secondaryValue\n secondaryCode\n weighted\n }\n dataPoints(limit: $limitDataPoints) {\n average\n unweighted\n secondaryValue\n secondaryCode\n weighted\n weightedTotal\n unweightedTotal\n }\n }\n ${SERIES_SUMMARY}\n`\nexport const SERIES_RATING_TREND_DETAILS = gql`\n fragment SeriesRatingTrendDetailsFragment on Series {\n ...SeriesSummaryFragment\n aggregateDataPoint(limit: $limitDataPoints) {\n percent\n average\n unweighted\n secondaryValue\n secondaryCode\n weighted\n }\n dataPoints(limit: $limitDataPoints) {\n percent\n average\n unweighted\n secondaryValue\n secondaryCode\n weighted\n weightedTotal\n unweightedTotal\n }\n }\n ${SERIES_SUMMARY}\n`\nexport const SERIES_DETAILS_AVERAGE = gql`\n fragment SeriesDetailsAverageFragment on Series {\n ...SeriesSummaryFragment\n aggregateDataPoint(limit: $limitDataPoints) {\n unweighted\n secondaryValue\n weighted\n }\n dataPoints(limit: $limitDataPoints) {\n unweighted\n secondaryValue\n average\n weighted\n }\n }\n ${SERIES_SUMMARY}\n`\nexport const AGGREGATE_DETAILS = gql`\n fragment AggregateDetailsFragment on Aggregate {\n totalCount\n totalCountUnweighted\n summarySeries {\n ...SeriesDetailsFragment\n }\n series(limit: $limitSeries, chartType: $chartType) {\n ...SeriesDetailsFragment\n }\n totalItems\n }\n ${SERIES_DETAILS}\n`\nexport const AGGREGATE_RATING_TREND_DETAILS = gql`\n fragment AggregateRatingTrendDetailsFragment on Aggregate {\n totalCount\n totalCountUnweighted\n summarySeries {\n ...SeriesRatingTrendDetailsFragment\n }\n series(limit: $limitSeries) {\n ...SeriesRatingTrendDetailsFragment\n }\n totalItems\n }\n ${SERIES_RATING_TREND_DETAILS}\n`\n\nexport const AGGREGATE_RATING_DETAILS = gql`\n fragment AggregateRatingDetailsFragment on Aggregate {\n totalCount\n totalCountUnweighted\n summarySeries {\n ...SeriesRatingDetailsFragment\n }\n series(limit: $limitSeries) {\n ...SeriesRatingDetailsFragment\n }\n totalItems\n }\n ${SERIES_RATING_DETAILS}\n`\nexport const AGGREGATE_DETAILS_AVERAGE = gql`\n fragment AggregateDetailsAverageFragment on Aggregate {\n totalCount\n totalCountUnweighted\n summarySeries {\n ...SeriesDetailsAverageFragment\n }\n series(limit: $limitSeries) {\n ...SeriesDetailsAverageFragment\n }\n totalItems\n }\n ${SERIES_DETAILS_AVERAGE}\n`\n\nexport const AGGREGATE_DETAILS_NO_SERIES_LIMIT = gql`\n fragment AggregateDetailsNoSeriesLimitFragment on Aggregate {\n totalCount\n totalCountUnweighted\n summarySeries {\n ...SeriesDetailsFragment\n }\n series {\n ...SeriesDetailsFragment\n }\n totalItems\n }\n ${SERIES_DETAILS}\n`\nexport const AGGREGATE_DETAILS_NO_SERIES_LIMIT_NO_SUMMARY = gql`\n fragment AggregateDetailsFragmentNoLimitNoSummary on AggregateWithoutSummary {\n totalCount\n totalCountUnweighted\n series {\n ...SeriesDetailsFragment\n }\n totalItems\n }\n ${SERIES_DETAILS}\n`\nexport const AGGREGATE_DETAILS_NO_DATA_LIMIT = gql`\n fragment AggregateDetailsNoLimitFragment on Aggregate {\n totalCount\n totalCountUnweighted\n summarySeries {\n ...SeriesDetailsFragmentNoLimit\n }\n series {\n ...SeriesDetailsFragmentNoLimit\n }\n }\n ${SERIES_DETAILS_NO_LIMIT}\n`\n\nexport const SUMMARY_SERIES_DETAILS = gql`\n fragment SummarySeriesDetailsFragment on Aggregate {\n totalCount\n totalCountUnweighted\n summarySeries {\n ...SeriesDetailsFragment\n }\n }\n ${SERIES_DETAILS}\n`\n\nexport const AGGREGATE_DETAILS_NO_SUMMARY = gql`\n fragment AggregateDetailsFragmentNoSummary on AggregateWithoutSummary {\n totalCount\n totalCountUnweighted\n series(limit: $limitSeries) {\n ...SeriesDetailsFragment\n }\n totalItems\n }\n ${SERIES_DETAILS}\n`\n","import { gql } from '@apollo/client'\nimport {\n AGGREGATE_DETAILS,\n AGGREGATE_DETAILS_AVERAGE,\n AGGREGATE_DETAILS_NO_DATA_LIMIT,\n AGGREGATE_DETAILS_NO_SERIES_LIMIT,\n AGGREGATE_DETAILS_NO_SERIES_LIMIT_NO_SUMMARY,\n AGGREGATE_DETAILS_NO_SUMMARY,\n AGGREGATE_RATING_DETAILS,\n AGGREGATE_RATING_TREND_DETAILS,\n SERIES_SUMMARY,\n SUMMARY_SERIES_DETAILS,\n} from './fragments'\n\nexport const GET_ALL_FILTERS = gql`\n query filters($schema: String, $context: [CellInput]!) {\n filters(schema: $schema, context: $context)\n }\n`\n\nexport const SINGLE_SUMMARY_QUERY = gql`\n ${SERIES_SUMMARY}\n query OverViewSummary(\n $primaryVar: SingleVariable!\n $filters: [Filter!]\n $context: [CellInput]!\n $localFilters: [Filter!] = []\n ) {\n cross: crossSingle(\n primary: $primaryVar\n secondary: $primaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n ) {\n totalCount\n totalCountUnweighted\n series {\n ...SeriesSummaryFragment\n }\n }\n }\n`\n\nexport const CROSS_SINGLE_QUERY = gql`\n ${AGGREGATE_DETAILS}\n\n query CrossSingleQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $tertiaryVar: SingleVariable\n $filters: [Filter!]\n $localFilters: [Filter!] = []\n $limitSeries: Int\n $limitDataPoints: Int\n $chartType: String\n $context: [CellInput]!\n $schema: String\n $removeDataPoints: [Int]\n $showDataPoints: [Int]\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $reviewAverage: Boolean\n ) {\n cross: crossSingle(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n schema: $schema\n removeDataPoints: $removeDataPoints\n showDataPoints: $showDataPoints\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n tertiary: $tertiaryVar\n reviewAverage: $reviewAverage\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\nexport const CROSS_SINGLE_EXPORT_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_DATA_LIMIT}\n\n query CrossSingleQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $tertiaryVar: SingleVariable\n $filters: [Filter!]\n $localFilters: [Filter!] = []\n $context: [CellInput]!\n $schema: String\n $removeDataPoints: [Int]\n $showDataPoints: [Int]\n $totalItems: Int\n $reviewAverage: Boolean\n ) {\n cross: crossSingle(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n schema: $schema\n removeDataPoints: $removeDataPoints\n showDataPoints: $showDataPoints\n totalItems: $totalItems\n tertiary: $tertiaryVar\n reviewAverage: $reviewAverage\n ) {\n ...AggregateDetailsNoLimitFragment\n }\n }\n`\n\nexport const CROSS_SINGLE_EXPORT_HEATMAP_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_SERIES_LIMIT}\n\n query CrossSingleQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $tertiaryVar: SingleVariable\n $filters: [Filter!]\n $localFilters: [Filter!] = []\n $context: [CellInput]!\n $schema: String\n $removeDataPoints: [Int]\n $showDataPoints: [Int]\n $totalItems: Int\n $reviewAverage: Boolean\n $limitDataPoints: Int\n ) {\n cross: crossSingle(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n schema: $schema\n removeDataPoints: $removeDataPoints\n showDataPoints: $showDataPoints\n totalItems: $totalItems\n tertiary: $tertiaryVar\n reviewAverage: $reviewAverage\n ) {\n ...AggregateDetailsNoSeriesLimitFragment\n }\n }\n`\n\nexport const CROSS_SINGLE_FACTOR_QUERY = gql`\n ${AGGREGATE_DETAILS_AVERAGE}\n\n query CrossSingleFactorQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n ) {\n cross: crossSingleFactor(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n ) {\n ...AggregateDetailsAverageFragment\n }\n }\n`\n\nexport const CROSS_SINGLE_AVERAGE_QUERY = gql`\n ${AGGREGATE_RATING_DETAILS}\n\n query CrossSingleAverageQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $filters: [Filter!]\n $localFilters: [Filter!] = []\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n $schema: String\n $removeDataPoints: [Int]\n $showDataPoints: [Int]\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n ) {\n cross: crossSingleAverage(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n schema: $schema\n removeDataPoints: $removeDataPoints\n showDataPoints: $showDataPoints\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n ) {\n ...AggregateRatingDetailsFragment\n }\n }\n`\n\nexport const CROSS_SINGLE_AND_MULTI_QUERY = gql`\n ${AGGREGATE_DETAILS}\n\n query CrossSingleAndMultiQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: MultiVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n $chartType: String\n $removeDataPoints: [Int]\n $showDataPoints: [Int]\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $paginationOn: String\n ) {\n cross: crossSingleAndMulti(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n removeDataPoints: $removeDataPoints\n showDataPoints: $showDataPoints\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n paginationOn: $paginationOn\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\n\nexport const CROSS_SINGLE_AND_MULTI_WITH_PARIMARY_BASE_QUERY = gql`\n ${AGGREGATE_DETAILS}\n\n query CrossSingleAndMultiWithPrimaryBaseQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: MultiVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n $chartType: String\n $removeDataPoints: [Int]\n $showDataPoints: [Int]\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $paginationOn: String\n ) {\n cross: crossSingleAndMultiWithPrimaryBase(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n removeDataPoints: $removeDataPoints\n showDataPoints: $showDataPoints\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n paginationOn: $paginationOn\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\n\nexport const CROSS_SINGLE_AND_MULTI_SUMMARY_QUERY = gql`\n ${SUMMARY_SERIES_DETAILS}\n\n query CrossSingleAndMultiQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: MultiVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitDataPoints: Int\n $context: [CellInput]!\n ) {\n cross: crossSingleAndMulti(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n ) {\n ...SummarySeriesDetailsFragment\n }\n }\n`\n\nexport const CROSS_TIME_AND_SINGLE_QUERY = gql`\n ${AGGREGATE_DETAILS}\n query CrossTimeAndSingleQuery(\n $secondaryVar: SingleVariable!\n $tertiaryVar: SingleVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n $chartType: String\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $schema: String\n ) {\n cross: crossTimeAndSingle(\n secondary: $secondaryVar\n tertiary: $tertiaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n schema: $schema\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\nexport const CROSS_SINGLE_AVERAGE_TREND_QUERY = gql`\n ${AGGREGATE_RATING_TREND_DETAILS}\n query CrossSingleAverageTrend(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $tertiaryVar: SingleVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $schema: String\n ) {\n cross: crossSingleAverageTrend(\n primary: $primaryVar\n secondary: $secondaryVar\n tertiary: $tertiaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n schema: $schema\n ) {\n ...AggregateRatingTrendDetailsFragment\n }\n }\n`\nexport const SOLITARY_MULTI_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_SERIES_LIMIT}\n query SolitaryMulti(\n $primaryVar: MultiVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitDataPoints: Int\n $context: [CellInput]!\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $showDataPoints: [Int]\n $removeDataPoints: [Int]\n ) {\n cross: solitaryMulti(\n primary: $primaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n removeDataPoints: $removeDataPoints\n ) {\n ...AggregateDetailsNoSeriesLimitFragment\n }\n }\n`\n\nexport const MULTI_CROSS_SINGLE_AVERAGE_PRICE_REVENUE_QUERY = gql`\n ${AGGREGATE_DETAILS_AVERAGE}\n query MultiCrossSingleAverageSeries(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $filters: [Filter!]\n $firstLocalFilters: [Filter!]\n $secondLocalFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n ) {\n cross: crossSingleNumericAvg(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n localFilters: $firstLocalFilters\n context: $context\n ) {\n ...AggregateDetailsAverageFragment\n }\n cross2: crossSingleNumericAvg(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n localFilters: $secondLocalFilters\n context: $context\n ) {\n ...AggregateDetailsAverageFragment\n }\n }\n`\n\nexport const CROSS_SINGLE_AVERAGE_PRICE_REVENUE_QUERY = gql`\n ${AGGREGATE_DETAILS_AVERAGE}\n query crossSingleNumericAvgQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n ) {\n cross: crossSingleNumericAvg(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n localFilters: $localFilters\n context: $context\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n ) {\n ...AggregateDetailsAverageFragment\n }\n }\n`\n\nexport const SOLITARY_SINGLE_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_SERIES_LIMIT}\n query SolitarySingle(\n $primaryVar: SingleVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitDataPoints: Int\n $context: [CellInput]!\n $schema: String\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $removeDataPoints: [Int]\n ) {\n cross: solitarySingle(\n primary: $primaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n schema: $schema\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n removeDataPoints: $removeDataPoints\n ) {\n ...AggregateDetailsNoSeriesLimitFragment\n }\n }\n`\n\nexport const SOLITARY_SINGLE_SEGMENTATION_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_SERIES_LIMIT}\n query SolitarySingleSegmentation(\n $primaryVar: SingleVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitDataPoints: Int\n $context: [CellInput]!\n $schema: String\n ) {\n cross: solitarySingleSegmentation(\n primary: $primaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n schema: $schema\n ) {\n ...AggregateDetailsNoSeriesLimitFragment\n }\n }\n`\n\nexport const GET_FILTER_VALUES = gql`\n query FilterValues(\n $variableId: Int!\n $filters: [Filter!]\n $context: [CellInput]!\n $schema: String\n ) {\n filterValues: filterValues(\n variableId: $variableId\n filters: $filters\n context: $context\n schema: $schema\n ) {\n answer_id\n answer_code\n label\n category_name\n }\n }\n`\n\nexport const GET_USER_SUBSCRIPTION = gql`\n query {\n context {\n country\n itemGroup\n waves\n }\n }\n`\n\nexport const CROSS_SINGLE_FACTOR_AVG_TRENDED_QUERY = gql`\n ${AGGREGATE_DETAILS_AVERAGE}\n\n query crossSingleFactorAvgTrendedQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $tertiaryVar: SingleVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n ) {\n cross: crossSingleFactorAvgTrended(\n primary: $primaryVar\n secondary: $secondaryVar\n tertiary: $tertiaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n ) {\n ...AggregateDetailsAverageFragment\n }\n }\n`\n\nexport const CROSS_TIME_SINGLE_NUMERIC_AVERAGE_QUERY = gql`\n ${AGGREGATE_DETAILS_AVERAGE}\n\n query crossTimeSingleNumericAverageQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $tertiaryVar: SingleVariable!\n $filters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n $localFilters: [Filter!]\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n ) {\n cross: crossTimeSingleNumericAverage(\n primary: $primaryVar\n secondary: $secondaryVar\n tertiary: $tertiaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n ) {\n ...AggregateDetailsAverageFragment\n }\n }\n`\n\nexport const COMBINED_FUNNEL_QUERY = gql`\n ${AGGREGATE_DETAILS}\n ${AGGREGATE_DETAILS_NO_DATA_LIMIT}\n query CombinedFunnel(\n $firstPrimaryVar: MultiVariable!\n $secondPrimaryVar: MultiVariable!\n $fourthPrimaryVar: SingleVariable!\n $fourthSecondaryVar: SingleVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n $chartType: String\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n ) {\n cross: solitaryMulti(\n primary: $firstPrimaryVar\n filters: $filters\n localFilters: $localFilters\n context: $context\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n ) {\n ...AggregateDetailsFragment\n }\n cross2: solitaryMulti(\n primary: $secondPrimaryVar\n filters: $filters\n localFilters: $localFilters\n context: $context\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n ) {\n ...AggregateDetailsNoLimitFragment\n }\n cross3: crossSingle(\n primary: $fourthPrimaryVar\n secondary: $fourthSecondaryVar\n filters: $filters\n localFilters: $localFilters\n context: $context\n chartType: $chartType\n ) {\n ...AggregateDetailsNoLimitFragment\n }\n }\n`\nexport const COMBINED_OS_FUNNEL_QUERY = gql`\n ${AGGREGATE_DETAILS}\n ${AGGREGATE_DETAILS_NO_DATA_LIMIT}\n query CombinedFunnel(\n $primaryVar: MultiVariable!\n $secondPrimaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $context: [CellInput]!\n $chartType: String\n $limitSeries: Int\n $limitDataPoints: Int\n ) {\n cross: solitaryMulti(\n primary: $primaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n ) {\n ...AggregateDetailsFragment\n }\n cross2: solitarySingle(\n primary: $secondPrimaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n ) {\n ...AggregateDetailsNoLimitFragment\n }\n cross3: crossSingle(\n primary: $secondaryVar\n secondary: $secondPrimaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n chartType: $chartType\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\n\nexport const MULTI_SOLITARY_SERIES_QUERY = gql`\n ${AGGREGATE_DETAILS}\n query MultiSolitarySeries(\n $primaryVar: SingleVariable!\n $filters: [Filter!]\n $firstLocalFilters: [Filter!]\n $secondLocalFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $context: [CellInput]!\n $chartType: String\n $showDataPoints: [Int]\n ) {\n cross: solitarySingle(\n primary: $primaryVar\n filters: $filters\n localFilters: $firstLocalFilters\n context: $context\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n cross2: solitarySingle(\n primary: $primaryVar\n filters: $filters\n localFilters: $secondLocalFilters\n context: $context\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\nexport const MULTI_SOLITARY_MULTI_SERIES_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_SERIES_LIMIT}\n ${AGGREGATE_DETAILS_NO_DATA_LIMIT}\n\n query SolitaryMulti(\n $primaryVar: MultiVariable!\n $filters: [Filter!]\n $limitDataPoints: Int\n $firstLocalFilters: [Filter!]\n $secondLocalFilters: [Filter!]\n $context: [CellInput]!\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $removeDataPoints: [Int]\n ) {\n cross: solitaryMulti(\n primary: $primaryVar\n filters: $filters\n context: $context\n localFilters: $firstLocalFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n removeDataPoints: $removeDataPoints\n ) {\n ...AggregateDetailsNoSeriesLimitFragment\n }\n cross2: solitaryMulti(\n primary: $primaryVar\n filters: $filters\n context: $context\n localFilters: $secondLocalFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n removeDataPoints: $removeDataPoints\n ) {\n ...AggregateDetailsNoLimitFragment\n }\n }\n`\nexport const MULTI_SOLITARY_SERIES_NO_LIMIT_QUERY = gql`\n ${AGGREGATE_DETAILS}\n ${AGGREGATE_DETAILS_NO_DATA_LIMIT}\n query MultiSolitarySeries(\n $primaryVar: SingleVariable!\n $filters: [Filter!]\n $firstLocalFilters: [Filter!]\n $secondLocalFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $context: [CellInput]!\n $chartType: String\n $removeDataPoints: [Int]\n ) {\n cross: solitarySingle(\n primary: $primaryVar\n filters: $filters\n localFilters: $firstLocalFilters\n context: $context\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n removeDataPoints: $removeDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n cross2: solitarySingle(\n primary: $primaryVar\n filters: $filters\n localFilters: $secondLocalFilters\n context: $context\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n removeDataPoints: $removeDataPoints\n ) {\n ...AggregateDetailsNoLimitFragment\n }\n }\n`\nexport const MULTI_CONVERSION_QUERY = gql`\n ${AGGREGATE_DETAILS}\n query MultiConversionSeries(\n $primaryVar: SingleVariable!\n $secondaryVar: MultiVariable!\n $secondPrimaryVar: MultiVariable!\n $filters: [Filter!]\n $localFilters: [Filter!]\n $limitSeries: Int\n $chartType: String\n $limitDataPoints: Int\n $context: [CellInput]!\n $removeDataPoints: [Int]\n $showDataPoints: [Int]\n ) {\n cross: crossSingleAndMulti(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n removeDataPoints: $removeDataPoints\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n cross2: crossSingleAndMulti(\n primary: $primaryVar\n secondary: $secondPrimaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n removeDataPoints: $removeDataPoints\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\n\nexport const CROSS_AVERAGE_SOLITARY_SERIES_QUERY = gql`\n ${AGGREGATE_DETAILS_AVERAGE}\n ${AGGREGATE_DETAILS}\n query CrossAverageSolitarySeries(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $filters: [Filter!]\n $firstLocalFilters: [Filter!]\n $limitSeries: Int\n $chartType: String\n $limitDataPoints: Int\n $context: [CellInput]!\n ) {\n cross: crossSingleNumericAvg(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n localFilters: []\n context: $context\n ) {\n ...AggregateDetailsAverageFragment\n }\n cross2: solitarySingle(\n primary: $primaryVar\n filters: $filters\n localFilters: $firstLocalFilters\n context: $context\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\n\nexport const SOLITARY_CONVERSION_RATE_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_SERIES_LIMIT_NO_SUMMARY}\n query solitaryConversionRate(\n $primaryVar: MultiVariable!\n $secondaryVar: MultiOrSingleVariable!\n $filters: [Filter]\n $localFilters: [Filter] = []\n $context: [CellInput]\n $totalVariableSelectionOverride: MultiVariable\n $limitDataPoints: Int\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n ) {\n cross: solitaryConversionRate(\n totalVariable: $primaryVar\n conversionVariable: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n totalVariableSelectionOverride: $totalVariableSelectionOverride\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n ) {\n ...AggregateDetailsFragmentNoLimitNoSummary\n }\n }\n`\n\nexport const MULTI_SOLITARY_CONVERSION_RATE_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_SERIES_LIMIT_NO_SUMMARY}\n query solitaryConversionRate(\n $firstPrimaryVar: MultiVariable!\n $secondPrimaryVar: MultiOrSingleVariable!\n $primaryVar: MultiVariable!\n $secondaryVar: MultiOrSingleVariable!\n $filters: [Filter]\n $localFilters: [Filter] = []\n $context: [CellInput]\n $totalVariableSelectionOverride: MultiVariable\n $limitDataPoints: Int\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $showDataPoints: [Int]\n ) {\n cross: solitaryConversionRate(\n totalVariable: $primaryVar\n conversionVariable: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n totalVariableSelectionOverride: $totalVariableSelectionOverride\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragmentNoLimitNoSummary\n }\n cross2: solitaryConversionRate(\n totalVariable: $firstPrimaryVar\n conversionVariable: $secondPrimaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n totalVariableSelectionOverride: $totalVariableSelectionOverride\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragmentNoLimitNoSummary\n }\n }\n`\nexport const MULTI_FILTER_SOLITARY_CONVERSION_RATE_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_SERIES_LIMIT_NO_SUMMARY}\n query solitaryConversionRate(\n $firstPrimaryVar: MultiVariable!\n $secondPrimaryVar: MultiOrSingleVariable!\n $primaryVar: MultiVariable!\n $secondaryVar: MultiOrSingleVariable!\n $filters: [Filter]\n $convertedFilter1: [Filter] = []\n $convertedFilter2: [Filter] = []\n $convertedFilter3: [Filter] = []\n $context: [CellInput]\n $totalVariableSelectionOverride: MultiVariable\n $limitDataPoints: Int\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $showDataPoints: [Int]\n ) {\n cross: solitaryConversionRate(\n totalVariable: $primaryVar\n conversionVariable: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $convertedFilter1\n totalVariableSelectionOverride: $totalVariableSelectionOverride\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragmentNoLimitNoSummary\n }\n cross2: solitaryConversionRate(\n totalVariable: $primaryVar\n conversionVariable: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $convertedFilter2\n totalVariableSelectionOverride: $totalVariableSelectionOverride\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragmentNoLimitNoSummary\n }\n cross3: solitaryConversionRate(\n totalVariable: $primaryVar\n conversionVariable: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $convertedFilter3\n totalVariableSelectionOverride: $totalVariableSelectionOverride\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragmentNoLimitNoSummary\n }\n cross4: solitaryConversionRate(\n totalVariable: $firstPrimaryVar\n conversionVariable: $secondPrimaryVar\n filters: $filters\n context: $context\n totalVariableSelectionOverride: $totalVariableSelectionOverride\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragmentNoLimitNoSummary\n }\n }\n`\n\nexport const MULTI_SOLITARY_CONVERSION_RATE_TRENDED_QUERY = gql`\n ${AGGREGATE_DETAILS}\n query solitaryConversionRateTrended(\n $primaryVar: SingleVariable!\n $firstPrimaryVar: MultiVariable!\n $secondaryVar: MultiOrSingleVariable!\n $secondPrimaryVar: MultiOrSingleVariable\n $filters: [Filter]\n $localFilters: [Filter] = []\n $context: [CellInput]\n $limitDataPoints: Int\n $limitSeries: Int\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $showDataPoints: [Int]\n $chartType: String\n ) {\n cross: solitaryConversionRateTrended(\n primary: $primaryVar\n secondary: $firstPrimaryVar\n tertiary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n cross2: solitaryConversionRateTrended(\n primary: $primaryVar\n secondary: $firstPrimaryVar\n tertiary: $secondPrimaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\n\nexport const MULTI_FILLTER_SOLITARY_CONVERSION_RATE_TRENDED_QUERY = gql`\n ${AGGREGATE_DETAILS}\n query solitaryConversionRateTrended(\n $primaryVar: SingleVariable!\n $firstPrimaryVar: MultiVariable!\n $secondaryVar: MultiOrSingleVariable!\n $secondPrimaryVar: MultiOrSingleVariable\n $filters: [Filter]\n $convertedFilter1: [Filter] = []\n $convertedFilter2: [Filter] = []\n $convertedFilter3: [Filter] = []\n $context: [CellInput]\n $limitDataPoints: Int\n $limitSeries: Int\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $showDataPoints: [Int]\n $chartType: String\n ) {\n cross: solitaryConversionRateTrended(\n primary: $primaryVar\n secondary: $firstPrimaryVar\n tertiary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $convertedFilter1\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n cross2: solitaryConversionRateTrended(\n primary: $primaryVar\n secondary: $firstPrimaryVar\n tertiary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $convertedFilter2\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n cross3: solitaryConversionRateTrended(\n primary: $primaryVar\n secondary: $firstPrimaryVar\n tertiary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $convertedFilter3\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n cross4: solitaryConversionRateTrended(\n primary: $primaryVar\n secondary: $firstPrimaryVar\n tertiary: $secondPrimaryVar\n filters: $filters\n context: $context\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\n\nexport const MULTI_CROSS_SINGLE_QUERY = gql`\n ${AGGREGATE_DETAILS}\n query CrossSingleQuery(\n $primaryVar: SingleVariable!\n $secondaryVar: SingleVariable!\n $tertiaryVar: SingleVariable\n $filters: [Filter!]\n $firstLocalFilters: [Filter!]\n $secondLocalFilters: [Filter!]\n $limitSeries: Int\n $limitDataPoints: Int\n $chartType: String\n $context: [CellInput]!\n $schema: String\n $removeDataPoints: [Int]\n $showDataPoints: [Int]\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n ) {\n cross: crossSingle(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $firstLocalFilters\n schema: $schema\n removeDataPoints: $removeDataPoints\n showDataPoints: $showDataPoints\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n tertiary: $tertiaryVar\n ) {\n ...AggregateDetailsFragment\n }\n cross2: crossSingle(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $secondLocalFilters\n schema: $schema\n removeDataPoints: $removeDataPoints\n showDataPoints: $showDataPoints\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n tertiary: $tertiaryVar\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\nexport const GET_SUMMARY_VALUES = gql`\n query summaryValues(\n $primaryVar: SingleVariable!\n $filters: [Filter]\n $localFilters: [Filter] = []\n $context: [CellInput]\n $schema: String\n ) {\n cross: summaryValues(\n primary: $primaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n schema: $schema\n ) {\n totalCountUnweighted\n }\n }\n`\n\nexport const CROSS_MULTI_SINGLE_QUERY = gql`\n ${AGGREGATE_DETAILS}\n\n query CrossMultiSingleQuery(\n $primaryVar: MultiVariable!\n $secondaryVar: SingleVariable!\n $filters: [Filter!]\n $localFilters: [Filter!] = []\n $limitSeries: Int\n $chartType: String\n $limitDataPoints: Int\n $context: [CellInput]!\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n ) {\n cross: crossMultiSingle(\n primary: $primaryVar\n secondary: $secondaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\n\nexport const SOLITARY_MULTI_DISTRIBUTION_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_SUMMARY}\n\n query SolitaryMultiDistributionQuery(\n $primaryVars: [MultiVariable!]\n $primaryValues: [String!]\n $filters: [Filter!]\n $localFilters: [Filter!]\n $context: [CellInput]!\n $transposeAxis: Boolean\n $limitSeries: Int\n $limitDataPoints: Int\n $removeDataPoints: [Int]\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n ) {\n cross: solitaryMultiDistribution(\n primary: $primaryVars\n primaryValues: $primaryValues\n filters: $filters\n context: $context\n localFilters: $localFilters\n transposeAxis: $transposeAxis\n removeDataPoints: $removeDataPoints\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n ) {\n ...AggregateDetailsFragmentNoSummary\n }\n }\n`\nexport const MULTI_SOLITARY_MULTI_DISTRIBUTION_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_SUMMARY}\n ${AGGREGATE_DETAILS_NO_SERIES_LIMIT_NO_SUMMARY}\n\n query SolitaryMultiDistributionQuery(\n $primaryVars: [MultiVariable!]\n $primaryValues: [String!]\n $filters: [Filter!]\n $firstLocalFilters: [Filter!]\n $secondLocalFilters: [Filter!]\n $context: [CellInput]!\n $transposeAxis: Boolean\n $limitSeries: Int\n $limitDataPoints: Int\n $removeDataPoints: [Int]\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $sortedSeries: Boolean\n $selectValue: String\n ) {\n cross: solitaryMultiDistribution(\n primary: $primaryVars\n primaryValues: $primaryValues\n filters: $filters\n context: $context\n localFilters: $firstLocalFilters\n transposeAxis: $transposeAxis\n removeDataPoints: $removeDataPoints\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n sortedSeries: $sortedSeries\n selectValue: $selectValue\n ) {\n ...AggregateDetailsFragmentNoSummary\n }\n cross2: solitaryMultiDistribution(\n primary: $primaryVars\n primaryValues: $primaryValues\n filters: $filters\n context: $context\n localFilters: $secondLocalFilters\n transposeAxis: $transposeAxis\n removeDataPoints: $removeDataPoints\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n sortedSeries: $sortedSeries\n selectValue: $selectValue\n ) {\n ...AggregateDetailsFragmentNoLimitNoSummary\n }\n }\n`\nexport const SOLITARY_MULTI_FEATURE_DISTRIBUTION_QUERY = gql`\n ${AGGREGATE_DETAILS_NO_SUMMARY}\n\n query solitaryMultiFeatureDistributionQuery(\n $primaryVars: [MultiVariable!]\n $primaryValues: [String!]\n $filters: [Filter!]\n $localFilters: [Filter!]\n $context: [CellInput]!\n $featureDesign: Boolean\n $limitSeries: Int\n $limitDataPoints: Int\n $removeDataPoints: [Int]\n ) {\n cross: solitaryMultiFeatureDistribution(\n primary: $primaryVars\n primaryValues: $primaryValues\n filters: $filters\n context: $context\n localFilters: $localFilters\n removeDataPoints: $removeDataPoints\n featureDesign: $featureDesign\n ) {\n ...AggregateDetailsFragmentNoSummary\n }\n }\n`\nexport const CROSS_MULTI_OR_SINGLE_TRENDED_QUERY = gql`\n ${AGGREGATE_DETAILS}\n query solitaryConversionRateTrended(\n $primaryVar: SingleVariable!\n $secondaryVar: MultiVariable!\n $tertiaryVar: MultiOrSingleVariable\n $filters: [Filter]\n $localFilters: [Filter] = []\n $context: [CellInput]\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $showDataPoints: [Int]\n $limitSeries: Int\n $limitDataPoints: Int\n $chartType: String\n ) {\n cross: solitaryConversionRateTrended(\n primary: $primaryVar\n secondary: $secondaryVar\n tertiary: $tertiaryVar\n filters: $filters\n context: $context\n localFilters: $localFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\nexport const MULTI_CROSS_MULTI_OR_SINGLE_TRENDED_QUERY = gql`\n ${AGGREGATE_DETAILS}\n\n query MultiCrossMultiSingleTrended(\n $primaryVar: SingleVariable!\n $secondaryVar: MultiVariable!\n $tertiaryVar: MultiOrSingleVariable!\n $totalVariable: MultiOrSingleVariable\n $filters: [Filter]\n $localFilters: [Filter] = []\n $context: [CellInput]\n $limitDataPoints: Int\n $pageNumber: Int\n $itemsPerPage: Int\n $totalItems: Int\n $showDataPoints: [Int]\n $limitSeries: Int\n $chartType: String\n ) {\n cross: solitaryConversionRateTrended(\n primary: $primaryVar\n secondary: $secondaryVar\n tertiary: $tertiaryVar\n totalVariable: $totalVariable\n filters: $filters\n context: $context\n localFilters: $localFilters\n pageNumber: $pageNumber\n itemsPerPage: $itemsPerPage\n totalItems: $totalItems\n showDataPoints: $showDataPoints\n ) {\n ...AggregateDetailsFragment\n }\n }\n`\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { PanelState } from 'components/KBQSelect'\n\nconst initialState: PanelState[] = []\n\nconst KBQPanelStateSlices = createSlice({\n name: 'accrodionPanels',\n initialState,\n reducers: {\n setKBQPanelState(state, action: PayloadAction) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n },\n})\n\nexport const { setKBQPanelState } = KBQPanelStateSlices.actions\n\nexport default KBQPanelStateSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { KBQSelectedOptions } from 'components/KBQSelect'\n\nconst initialState: KBQSelectedOptions[] = []\n\nconst defaultSelectedLostShopperKBQOptionsSlices = createSlice({\n name: 'DefaultSelectedKBQOptions',\n initialState,\n reducers: {\n setDefaultKBQOption(state, action: PayloadAction) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n clearDefaultKBQOptions(state) {\n return initialState\n },\n },\n})\n\nexport const { setDefaultKBQOption, clearDefaultKBQOptions } =\n defaultSelectedLostShopperKBQOptionsSlices.actions\n\nexport default defaultSelectedLostShopperKBQOptionsSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { KBQShoppersData } from 'components/KBQSelect'\n\nconst initialState: KBQShoppersData[] = []\n\nconst kbqChartDataSlices = createSlice({\n name: 'KBQChartData',\n initialState,\n reducers: {\n setKBQChartData(state, action: PayloadAction) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n },\n})\n\nexport const { setKBQChartData } = kbqChartDataSlices.actions\n\nexport default kbqChartDataSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { TopPurchasedData } from 'components/KBQSelect'\n\nconst initialState: TopPurchasedData[] = []\n\nconst kbqTopPurchasedDataSlices = createSlice({\n name: 'KBQTopPurchasedData',\n initialState,\n reducers: {\n setKBQTopPurchasedData(state, action: PayloadAction) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n },\n})\n\nexport const { setKBQTopPurchasedData } = kbqTopPurchasedDataSlices.actions\n\nexport default kbqTopPurchasedDataSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { KBQSelectedOptions } from 'components/KBQSelect'\n\nconst initialState: KBQSelectedOptions[] = []\n\nconst selectedLostShopperKBQOptionsSlices = createSlice({\n name: 'SelectedKBQOptions',\n initialState,\n reducers: {\n setSelectKBQOption(state, action: PayloadAction) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n clearSelectKBQOptions(state) {\n return initialState\n },\n },\n})\n\nexport const { setSelectKBQOption, clearSelectKBQOptions } =\n selectedLostShopperKBQOptionsSlices.actions\n\nexport default selectedLostShopperKBQOptionsSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { SelectedDefaultBrand } from 'components/KBQSelect'\n\nconst initialState: SelectedDefaultBrand[] = []\nconst selectedDefaultKBQOptionsSlices = createSlice({\n name: 'SelectedDefaultKBQOptions',\n initialState,\n reducers: {\n setSelectedDefaultPurchasedBrand(state, action: PayloadAction) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n },\n})\n\nexport const { setSelectedDefaultPurchasedBrand } = selectedDefaultKBQOptionsSlices.actions\n\nexport default selectedDefaultKBQOptionsSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { KBQSelectOption } from 'components/KBQSelect'\n\nconst initialState: KBQSelectOption[] = []\nconst selectedDefaultChannelVisitedKBQOptionsSlices = createSlice({\n name: 'selectedDefaultChannelVisitedKBQOptions',\n initialState,\n reducers: {\n setSelectedDefaultChannelVisited(state, action: PayloadAction) {\n return initialState.concat(action.payload)\n },\n },\n})\n\nexport const { setSelectedDefaultChannelVisited } =\n selectedDefaultChannelVisitedKBQOptionsSlices.actions\n\nexport default selectedDefaultChannelVisitedKBQOptionsSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { DonutViewByOption } from 'typings/viewBy'\n\nconst initialState: DonutViewByOption[] = []\n\nconst selectedDonutViewBySlices = createSlice({\n name: 'selectedDonutViewBy',\n initialState,\n reducers: {\n selectDonutViewBy(state, action: PayloadAction) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n setDonutViewBy(state, action: PayloadAction) {\n return action.payload ?? initialState\n },\n },\n})\n\nexport const { selectDonutViewBy, setDonutViewBy } = selectedDonutViewBySlices.actions\n\nexport default selectedDonutViewBySlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { KBQSelectOption } from 'components/KBQSelect'\n\nconst initialState: KBQSelectOption[] = []\nconst defaultSelectedRetailerKBQOptionsSlices = createSlice({\n name: 'defaultSelectedRetailerKBQOptions',\n initialState,\n reducers: {\n setDefaultSelectedPurchasedRetailer(state, action: PayloadAction) {\n return initialState.concat(action.payload)\n },\n },\n})\n\nexport const { setDefaultSelectedPurchasedRetailer } =\n defaultSelectedRetailerKBQOptionsSlices.actions\n\nexport default defaultSelectedRetailerKBQOptionsSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nconst initialState = {\n hasError: false,\n hasForbiddenError: false,\n}\n\nconst storiesSummaryErrorSlices = createSlice({\n name: 'brandLostShopperSummaryError',\n initialState,\n reducers: {\n setStoriesSummaryError(\n state,\n action: PayloadAction<{ hasError: boolean; hasForbiddenError: boolean }>\n ) {\n state.hasError = action.payload.hasError\n state.hasForbiddenError = action.payload.hasForbiddenError\n },\n },\n})\n\nexport const { setStoriesSummaryError } = storiesSummaryErrorSlices.actions\n\nexport default storiesSummaryErrorSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { KBQTopLostShoppers } from 'components/KBQSelect'\n\nconst initialState: KBQTopLostShoppers[] = []\n\nconst topLostShopperSlices = createSlice({\n name: 'TopLostShoppers',\n initialState,\n reducers: {\n setTopLostShoppers(state, action: PayloadAction) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n },\n})\n\nexport const { setTopLostShoppers } = topLostShopperSlices.actions\n\nexport default topLostShopperSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nconst initialState = ''\n\nconst topPurchasedBrandDonutSlices = createSlice({\n name: 'topPurchasedBrandDonut',\n initialState,\n reducers: {\n setTopPurchasedBrandDonut(_state, action: PayloadAction<{ topPurchasedBrandLabel: string }>) {\n return action.payload.topPurchasedBrandLabel\n },\n },\n})\n\nexport const { setTopPurchasedBrandDonut } = topPurchasedBrandDonutSlices.actions\n\nexport default topPurchasedBrandDonutSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nconst initialState = false\n\nconst bubbleExportVisible = createSlice({\n name: 'bubbleExportVisible',\n initialState,\n reducers: {\n togglebubbleExport(_state, action: PayloadAction<{ loading: boolean }>) {\n return action.payload.loading\n },\n },\n})\n\nexport const { togglebubbleExport } = bubbleExportVisible.actions\n\nexport default bubbleExportVisible.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nconst initialState = {\n visible: false,\n fromPage: '',\n}\n\nconst navigateBackBarVisible = createSlice({\n name: 'navigateBackBarVisible',\n initialState,\n reducers: {\n toggleNavigateBackBar(state, action: PayloadAction<{ visible: boolean; fromPage: string }>) {\n state.visible = action.payload.visible\n state.fromPage = action.payload.fromPage\n },\n },\n})\n\nexport const { toggleNavigateBackBar } = navigateBackBarVisible.actions\n\nexport default navigateBackBarVisible.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { Segment } from 'typings/segments'\n\nexport type SegmentVisibility = Record\n\nconst initialState: SegmentVisibility = {\n 58285: true,\n 58280: true,\n 58286: true,\n 58283: true,\n 58282: true,\n 58284: true,\n 58281: true,\n}\n\nconst segmentVisibility = createSlice({\n name: 'selectAudienceProfilerKPI',\n initialState,\n reducers: {\n loadSegmentVisibility(_state, { payload }: PayloadAction) {\n return payload\n },\n setSegmentVisibility(\n state,\n { payload: { segment, visible } }: PayloadAction<{ segment: Segment; visible: boolean }>\n ) {\n state[segment] = visible\n return state\n },\n },\n})\n\nexport const { loadSegmentVisibility, setSegmentVisibility } = segmentVisibility.actions\n\nexport default segmentVisibility.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { AudienceProfilerKPI } from 'components/Segmentation/SegmentationBubble/AudienceProfilerChartHeader'\nimport { AudienceProfilerKPIOptions } from 'config/audienceProfilerKPI'\n\nconst initialState: AudienceProfilerKPI = AudienceProfilerKPIOptions[0]\n\nconst selectedAudienceProfilerKPI = createSlice({\n name: 'selectAudienceProfilerKPI',\n initialState,\n reducers: {\n selectAudienceProfilerKPI(state, action: PayloadAction) {\n return action.payload\n },\n },\n})\n\nexport const { selectAudienceProfilerKPI } = selectedAudienceProfilerKPI.actions\n\nexport default selectedAudienceProfilerKPI.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { CompareByOption } from 'components/Segmentation/CompareBy'\nimport { OptionTypeBase } from 'react-select/src/types'\n\nexport interface AppliedCompareBy {\n compareById: string\n activeRadio: CompareByOption\n appliedComparators: OptionTypeBase[]\n isOtherUnclassifiedPresent?: boolean\n}\n\nconst initialState: AppliedCompareBy[] = []\n\nconst compareBySlice = createSlice({\n name: 'appliedCompareBy',\n initialState,\n reducers: {\n setAppliedCompareBy(state, action: PayloadAction) {\n return state\n .filter(({ compareById }) => compareById !== action.payload.compareById)\n .concat(action.payload)\n },\n setAllAppliedCompareBy(state, action: PayloadAction) {\n return action.payload ?? initialState\n },\n },\n})\nexport const { setAppliedCompareBy, setAllAppliedCompareBy } = compareBySlice.actions\nexport default compareBySlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { CurrencyOption } from 'typings/currency'\n\nconst initialState: Omit[] = []\n\nconst selectedCurrencySlices = createSlice({\n name: 'selectCurrency',\n initialState,\n reducers: {\n selectCurrency(state, action: PayloadAction>) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n },\n})\n\nexport const { selectCurrency } = selectedCurrencySlices.actions\n\nexport default selectedCurrencySlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nexport type WarningPayload = {\n id: string\n showCurrencyWarning: boolean\n}\n\nconst initialState: WarningPayload[] = []\n\nconst showCurrencyWarningSlice = createSlice({\n name: 'showCurrencyWarning',\n initialState,\n reducers: {\n toggleCurrencyWarning(state, action: PayloadAction) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n },\n})\n\nexport const { toggleCurrencyWarning } = showCurrencyWarningSlice.actions\nexport default showCurrencyWarningSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\ninterface SubscriptionError {\n error: string | null\n}\n\ninterface SubscriptionErrorState {\n value: SubscriptionError | null\n}\n\nconst initialState: SubscriptionErrorState = { value: null }\n\nconst subscriptionErrorSlice = createSlice({\n name: 'subscriptionError',\n initialState,\n reducers: {\n saveSubscriptionError(state, action: PayloadAction) {\n state.value = {\n error: action.payload,\n }\n },\n resetSubscriptionError(state) {\n if (state.value) {\n state.value = {\n error: null,\n }\n }\n },\n },\n})\n\nexport const { saveSubscriptionError, resetSubscriptionError } = subscriptionErrorSlice.actions\nexport default subscriptionErrorSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nconst initialState: {\n consumer: any\n} = { consumer: {} }\n\nconst consumerFeatureFlag = createSlice({\n name: 'cieFeatureFlag',\n initialState,\n reducers: {\n setCieFeatureFlags(state, action: PayloadAction) {\n state.consumer = action.payload\n return state\n },\n },\n})\n\nexport const { setCieFeatureFlags } = consumerFeatureFlag.actions\n\nexport default consumerFeatureFlag.reducer\n","import { createNextState, createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { allCategoryGroupNames } from 'config/filters'\nimport { CategoryGroupName, Filter } from 'typings/filters'\nimport { FilterSet } from '../saved'\n\ntype AppliedFilters = {\n value: Record\n}\n\nconst initialState: AppliedFilters = {\n value: allCategoryGroupNames.reduce(\n (acc, groupName) => ({ ...acc, [groupName]: [] }),\n {} as Record\n ),\n}\n\nconst appliedFiltersSlice = createSlice({\n name: 'applied',\n initialState,\n reducers: {\n applyFilters(state, action: PayloadAction) {\n const nextState = action.payload.reduce(\n (acc, curr) => {\n acc[curr.categoryGroup].push(curr)\n return acc\n },\n allCategoryGroupNames.reduce(\n (acc, groupName) => ({ ...acc, [groupName]: [] }),\n {} as Record\n )\n )\n state.value = nextState\n },\n removeFilter(state, action: PayloadAction) {\n state.value = createNextState(state.value, (draft) => {\n const key = action.payload.categoryGroup\n draft[key] = state.value[key].filter(\n ({ variable_id, answer_code }) =>\n !(\n variable_id === action.payload.variable_id &&\n answer_code === action.payload.answer_code\n )\n )\n })\n },\n applyImportedFilters(state, action: PayloadAction) {\n const filterSetToApply = action.payload?.find((filter) => filter.isApplied)\n\n if (filterSetToApply) {\n return { value: filterSetToApply.filters }\n }\n\n return state\n },\n },\n})\n\nexport const { applyFilters, removeFilter, applyImportedFilters } = appliedFiltersSlice.actions\n\nexport default appliedFiltersSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { Filter } from 'typings/filters'\nconst initialState: Filter[] = []\nconst defaultFiltersSlice = createSlice({\n name: 'applied',\n initialState,\n reducers: {\n defaultFilters(state, action: PayloadAction) {\n return action.payload\n },\n clearAllFilters(state) {\n return initialState\n },\n },\n})\n\nexport const { defaultFilters, clearAllFilters } = defaultFiltersSlice.actions\n\nexport default defaultFiltersSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\ntype DisabledFilters = {\n value: Record\n}\n\nconst initialState: DisabledFilters = {\n value: {},\n}\n\nconst disabledSlice = createSlice({\n name: 'values',\n initialState,\n reducers: {\n setDisabledFilter(\n state,\n action: PayloadAction<{\n variable_id: number\n disabled: boolean\n }>\n ) {\n const { variable_id, disabled } = action.payload\n\n state.value[variable_id] = disabled\n },\n resetDisabledFilters(state) {\n state.value = {}\n },\n },\n})\n\nexport const { setDisabledFilter, resetDisabledFilters } = disabledSlice.actions\n\nexport default disabledSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { Answer } from 'typings/filters'\n\ntype FilterValuesState = Record\n\nconst initialState: FilterValuesState = {}\n\nconst filterValuesSlice = createSlice({\n name: 'filterValues',\n initialState,\n reducers: {\n setFilterValues(state, action: PayloadAction<{ variableId: string; values: Answer[] }>) {\n const { variableId, values } = action.payload\n state[variableId] = values\n },\n },\n})\n\nexport const { setFilterValues } = filterValuesSlice.actions\n\nexport default filterValuesSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nconst initialState: number[] = []\n\nconst lostShoppers = createSlice({\n name: 'lostShoppers',\n initialState,\n reducers: {\n addRetailerLostShoppers(state, action: PayloadAction) {\n if (state.indexOf(action.payload) === -1) state.push(action.payload)\n return state\n },\n },\n})\n\nexport const { addRetailerLostShoppers } = lostShoppers.actions\n\nexport default lostShoppers.reducer\n","import { allCategoryGroupNames } from 'config/filters'\nimport { SavedFilters } from 'reducers/filtering/saved'\nimport { CategoryGroupName, Filter } from 'typings/filters'\n\nexport enum DeprecatedCategoryGroupName {\n Base = 'Base',\n Audience = 'Audience',\n Product = 'Product Specification',\n}\n\nexport type ImportedFilter = Omit & {\n categoryGroup: CategoryGroupName | DeprecatedCategoryGroupName\n}\n\nexport type ImportedFilterSet = {\n id?: string\n name: string\n filters: Partial>\n isApplied?: boolean\n isDisabled?: boolean\n}\n\nconst shopperFilterVariableIDs = [\n // Demographics\n 6, 8, 37, 9, 34, 32, 33, 11, 10, 59, 121,\n\n // Influential Shoppers\n 52, 53,\n]\nconst isDeprecatedAudienceGroup = (\n hasDeprecatedAudienceFilters: boolean,\n groupName: CategoryGroupName,\n predicate: (groupName: CategoryGroupName) => boolean\n): boolean => {\n return hasDeprecatedAudienceFilters && predicate(groupName)\n}\nconst finalFilters = (filtersToSave: ImportedFilterSet, groupName: CategoryGroupName) => {\n return filtersToSave.filters[groupName] ?? []\n}\nconst hasDeprecatedFilters = (deprecatedAudienceFilters: ImportedFilter[] | undefined) => {\n return deprecatedAudienceFilters && deprecatedAudienceFilters.length > 0\n}\nexport const formatSavedFilters = (importedFilterSet: ImportedFilterSet[]): SavedFilters => {\n if (!importedFilterSet) return []\n\n return importedFilterSet.map((filtersToSave) => {\n const deprecatedAudienceFilters = filtersToSave.filters[DeprecatedCategoryGroupName.Audience]\n const hasDeprecatedAudienceFilters = hasDeprecatedFilters(deprecatedAudienceFilters)\n\n const deprecatedBaseFilters = filtersToSave.filters[DeprecatedCategoryGroupName.Base]\n const deprecatedProductFilters = filtersToSave.filters[DeprecatedCategoryGroupName.Product]\n\n return {\n name: filtersToSave.name,\n isApplied: filtersToSave.isApplied,\n isDisabled: filtersToSave.isDisabled,\n id: filtersToSave.id,\n filters: allCategoryGroupNames.reduce(\n (acc, groupName) => {\n // Deprecated Category Group: Audience\n const isGeneralShopper = (groupName: CategoryGroupName): boolean => {\n return groupName === CategoryGroupName.General_Shopper\n }\n\n const isGeneralPurchase = (groupName: CategoryGroupName): boolean => {\n return groupName === CategoryGroupName.General_Purchase\n }\n if (\n isDeprecatedAudienceGroup(\n hasDeprecatedAudienceFilters as boolean,\n groupName,\n isGeneralShopper\n )\n ) {\n const shopperFilters = (deprecatedAudienceFilters as ImportedFilter[])\n .filter((filter) => shopperFilterVariableIDs.includes(filter.variable_id))\n .map((filter) => ({ ...filter, categoryGroup: groupName }))\n return {\n ...acc,\n [groupName]: shopperFilters,\n }\n }\n if (\n isDeprecatedAudienceGroup(\n hasDeprecatedAudienceFilters as boolean,\n groupName,\n isGeneralPurchase\n )\n ) {\n const purchaseFilters = (deprecatedAudienceFilters as ImportedFilter[])\n .filter((filter) => !shopperFilterVariableIDs.includes(filter.variable_id))\n .map((filter) => ({ ...filter, categoryGroup: groupName }))\n return {\n ...acc,\n [groupName]: purchaseFilters,\n }\n }\n\n // Deprecated Category Group: Base\n if (deprecatedBaseFilters && groupName === CategoryGroupName.General_Base) {\n return {\n ...acc,\n [groupName]: deprecatedBaseFilters.map((filter) => ({\n ...filter,\n categoryGroup: groupName,\n })),\n }\n }\n\n // Deprecated Category Group: Product Specification\n if (deprecatedProductFilters && groupName === CategoryGroupName.General_Product) {\n return {\n ...acc,\n [groupName]: deprecatedProductFilters.map((filter) => ({\n ...filter,\n categoryGroup: groupName,\n })),\n }\n }\n\n return {\n ...acc,\n [groupName]: finalFilters(filtersToSave, groupName),\n }\n },\n {} as Record\n ),\n }\n })\n}\n","import { createAsyncThunk, createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { allCategoryGroupNames } from 'config/filters'\nimport { RootState } from 'reducers/store'\nimport { CategoryGroupName, Filter } from 'typings/filters'\nimport { Configuration, FiltersControllerApiFactory, Filters } from '@ecosystem/preference-nest-api'\nimport { selectAppliedSavedFilters } from 'reducers/filtering/selectors'\nimport { formatSavedFilters } from 'util/migration'\nimport { loadFromLocalStorage, saveToLocalStorage } from 'util/localStorage'\n\nexport type FilterSet = {\n id?: string\n name: string\n filters: Record\n isApplied?: boolean\n isDisabled?: boolean\n}\nexport type SavedFilters = FilterSet[]\nexport type PartialFilter = Partial & Pick\n\nconst initialState: SavedFilters = []\n\nconst getPrefService = (accessToken: string) => {\n const config = new Configuration({\n accessToken,\n basePath: `${window.origin}/preference-filters`,\n })\n return FiltersControllerApiFactory(config)\n}\n\nexport const createFilter = async (prefService: any, oldFilter: any) => {\n try {\n await prefService.filtersControllerCreate({\n context: { product: 'CIE' },\n name: oldFilter.name,\n data: oldFilter,\n })\n return { success: true, filter: oldFilter }\n } catch (err: any) {\n if (err?.response?.status !== 422 || err?.response?.data?.message !== 'Name already exists') {\n return { success: false, filter: oldFilter }\n }\n return { success: true, filter: null }\n }\n}\n\nexport const updateLocalStorageOnMigration = (\n storageKey: string | undefined,\n failed: any[],\n migratedFilters: any[]\n) => {\n if (failed.length === 0) {\n localStorage.removeItem(`${storageKey}_filters.saved`)\n } else {\n saveToLocalStorage({ storageKey, key: 'filters.saved', data: failed })\n }\n\n if (migratedFilters.length > 0) {\n saveToLocalStorage({ storageKey, key: 'filters.migrated', data: migratedFilters })\n }\n}\n\nexport const migrateFilters = async (state: RootState) => {\n const storageKey = state.user.hash\n const savedFilters = loadFromLocalStorage({ storageKey, key: 'filters.saved' })\n const migratedFilters = loadFromLocalStorage({ storageKey, key: 'filters.migrated' }) || []\n const failed = []\n const token = state.user.jwt\n const prefService = getPrefService(token as string)\n\n if (savedFilters?.length > 0) {\n for (const oldFilter of savedFilters) {\n const result = await createFilter(prefService, oldFilter)\n if (result.success) {\n if (result.filter) migratedFilters.push(result.filter)\n } else {\n failed.push(result.filter)\n }\n }\n updateLocalStorageOnMigration(storageKey, failed, migratedFilters)\n }\n}\n\nexport const saveFilters = createAsyncThunk(\n 'saved/saveFilters',\n async (payload: FilterSet, { getState }) => {\n const token = (getState() as RootState).user.jwt\n const prefService = getPrefService(token as string)\n const {\n data: { id },\n } = await prefService.filtersControllerCreate({\n context: {\n product: 'CIE',\n },\n name: payload.name,\n data: payload,\n })\n const d: FilterSet = {\n ...payload,\n id,\n }\n return d\n }\n)\n\nexport const applySavedFilter = createAsyncThunk(\n 'saved/applySavedFilter',\n async (payload: string, { getState }) => {\n const state = getState() as RootState\n const token = state.user.jwt\n const prefService = getPrefService(token!)\n\n const toApply = state.filters.saved.find((sf: FilterSet) => sf.name === payload)\n if (!toApply || toApply?.isApplied === true) return\n\n const currentlyApplied: FilterSet | undefined = selectAppliedSavedFilters(state)\n\n if (currentlyApplied?.id) {\n await prefService.filtersControllerUpdateById(currentlyApplied.id, {\n data: { ...currentlyApplied, isApplied: false },\n })\n }\n\n if (toApply.id) {\n await prefService.filtersControllerUpdateById(toApply?.id, {\n data: { ...toApply, isApplied: true },\n })\n }\n return payload\n }\n)\n\nexport const unapplySavedFilters = createAsyncThunk(\n 'saved/unapplySavedFilters',\n async (_payload: undefined, { getState }) => {\n const state = getState() as RootState\n const token = state.user.jwt\n const prefService = getPrefService(token!)\n const currentlyApplied: FilterSet | undefined = selectAppliedSavedFilters(state)\n\n if (currentlyApplied?.id) {\n prefService.filtersControllerUpdateById(currentlyApplied.id, {\n data: { ...currentlyApplied, isApplied: false },\n })\n }\n }\n)\nexport const disableSavedFilters = createAsyncThunk(\n 'saved/disableSavedFilters',\n async (payload: string, { getState }) => {\n const state = getState() as RootState\n\n const token = state.user.jwt\n const prefService = getPrefService(token!)\n\n const toDisable = state.filters.saved.find((sf: FilterSet) => sf.name === payload)\n if (!toDisable || toDisable?.isDisabled === true) return\n\n if (toDisable.id) {\n await prefService.filtersControllerUpdateById(toDisable?.id, {\n data: { ...toDisable, isDisabled: true },\n })\n }\n\n return payload\n }\n)\n\nexport const removeSavedFilter = createAsyncThunk(\n 'saved/removeSavedFilter',\n async (payload: { id: string | undefined; name: string }, { getState }) => {\n if (!payload.id) throw new Error('id not defined')\n const state = getState() as RootState\n const token = state.user.jwt\n const prefService = getPrefService(token!)\n await prefService.filtersControllerDeleteById(payload.id)\n return payload\n }\n)\n\nexport const savedFiltersToFilterSet = (result: Filters[]): FilterSet[] => {\n const sanitisedResponse = (result || []).map(\n ({\n id,\n data: { name, filters, isApplied, isDisabled },\n }: {\n id: string\n name: string\n data: any\n }) => {\n return {\n id,\n name,\n filters,\n isApplied,\n isDisabled,\n }\n }\n )\n\n return formatSavedFilters(sanitisedResponse)\n}\n\nexport const checkApplied = async (\n result: Filters[],\n prefService: ReturnType\n) => {\n const applied = result.filter((res) => {\n return (res.data as FilterSet).isApplied\n })\n if (applied.length > 1) {\n for (const filterSet of applied) {\n await prefService.filtersControllerUpdateById(filterSet.id, {\n data: {\n ...filterSet.data,\n isApplied: false,\n isDisabled: false,\n },\n })\n }\n\n const refetchedFilters = await prefService.filtersControllerFindAll('CIE')\n return refetchedFilters.data\n }\n return result\n}\n\nexport const getPreferenceFilters = createAsyncThunk(\n 'saved/getPreferenceFilters',\n async (_payload: undefined, { getState }) => {\n const state = getState() as RootState\n // Migrate from local storage to preference filters API\n // START\n migrateFilters(state)\n // END\n const token = state.user.jwt\n const prefService = getPrefService(token!)\n const result = await prefService.filtersControllerFindAll('CIE')\n const resultData = await checkApplied(result.data, prefService)\n return savedFiltersToFilterSet(resultData)\n }\n)\n\nexport const IsFilterType = (categoryGroupName: string) => (itemToCheck: any) =>\n typeof itemToCheck === 'object' &&\n typeof itemToCheck.answer_code === 'number' &&\n typeof itemToCheck.variable_id === 'number' &&\n itemToCheck.categoryGroup === categoryGroupName &&\n typeof itemToCheck.desc === 'string' &&\n typeof itemToCheck.label === 'string'\n\nexport const isSavedFiltersType = (itemToCheck: any) =>\n Array.isArray(itemToCheck) &&\n itemToCheck.every(\n (arrayItem) =>\n typeof arrayItem === 'object' &&\n typeof arrayItem.name === 'string' &&\n arrayItem.name.length > 0 &&\n typeof arrayItem.filters === 'object' &&\n allCategoryGroupNames.every((name) => {\n const categoryGroup = arrayItem.filters[name]\n\n return Array.isArray(categoryGroup) && categoryGroup.every(IsFilterType(name))\n })\n )\n\nconst savedFiltersSlice = createSlice({\n name: 'saved',\n initialState,\n reducers: {\n saveImportedFilters(state, action: PayloadAction) {\n if (isSavedFiltersType(action.payload)) {\n return action.payload\n }\n return initialState\n },\n },\n extraReducers: (builder) => {\n builder.addCase(saveFilters.fulfilled, (state, action) => {\n return [...state, action.payload]\n })\n builder.addCase(applySavedFilter.fulfilled, (state, action) => {\n return state.map((filter) => ({\n ...filter,\n isApplied: filter.name === action.payload,\n }))\n })\n builder.addCase(unapplySavedFilters.fulfilled, (state, action) => {\n return state.map((filter) => ({\n ...filter,\n isApplied: false,\n }))\n })\n builder.addCase(disableSavedFilters.fulfilled, (state) => {\n return state.map((filter) => ({\n ...filter,\n isDisabled: false,\n }))\n })\n builder.addCase(removeSavedFilter.fulfilled, (state, action) => {\n return state.filter((filter) => filter.name !== action.payload.name)\n })\n builder.addCase(getPreferenceFilters.fulfilled, (state, action) => {\n return action.payload\n })\n },\n})\n\nexport const { saveImportedFilters } = savedFiltersSlice.actions\n\nexport default savedFiltersSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nconst initialState = false\n\nconst savedModalOpenSlice = createSlice({\n name: 'savedModalOpen',\n initialState,\n reducers: {\n toggleSavedModal(state, _action: PayloadAction<{ open: boolean }>) {\n return !state\n },\n },\n})\n\nexport const { toggleSavedModal } = savedModalOpenSlice.actions\nexport default savedModalOpenSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { Filter } from 'typings/filters'\nimport { FilterSet } from '../saved'\n\ntype SelectedFilters = Filter[]\n\nconst initialState: SelectedFilters = []\n\nconst selectedFiltersSlice = createSlice({\n name: 'selectedFilters',\n initialState,\n reducers: {\n selectFilter(state, action: PayloadAction) {\n state.push(action.payload)\n },\n deselectFilter(state, action: PayloadAction) {\n return state.filter(\n ({ variable_id, answer_code }) =>\n !(\n variable_id === action.payload.variable_id && answer_code === action.payload.answer_code\n )\n )\n },\n selectFilters(state, action: PayloadAction) {\n return action.payload\n },\n clearVariableFilters(state, action: PayloadAction) {\n return state.filter(({ variable_id }) => variable_id !== action.payload)\n },\n clearAllFilters(state) {\n return initialState\n },\n replaceVariableFilters(\n state,\n action: PayloadAction<{ filters: Filter[]; variableId: number }>\n ) {\n return state\n .filter(({ variable_id }) => variable_id !== action.payload.variableId)\n .concat(action.payload.filters)\n },\n\n selectImportedFilters(state, action: PayloadAction) {\n const filterSetToApply = action.payload?.find((filter) => filter.isApplied)\n\n if (filterSetToApply) {\n return Object.values(filterSetToApply.filters).flat()\n }\n\n return state\n },\n },\n})\n\nexport const {\n selectFilter,\n deselectFilter,\n selectFilters,\n clearVariableFilters,\n clearAllFilters,\n replaceVariableFilters,\n selectImportedFilters,\n} = selectedFiltersSlice.actions\n\nexport default selectedFiltersSlice.reducer\n","import { createSelector } from '@reduxjs/toolkit'\nimport { findIndex, groupBy, some, transform, flatten, pick } from 'lodash'\nimport { Answer, CategoryGroupName, Filter, Schema } from 'typings/filters'\nimport { RootState } from 'reducers/store'\nimport {\n allCategoryGroupNames,\n generalCategoryGroupNames,\n productReviewCategoryGroupNames,\n} from 'config/filters'\n\nexport enum Variables {\n TIME_FRAME = 3,\n TIME_FRAME_YEARLY = 706,\n TIME_FRAME_LIVE = 999,\n COUNTRY = 35,\n PRODUCT_GROUP = 12,\n BRAND_ECOSYSTEM = 790,\n BRAND_PURCHASED = 14,\n FEATURE_IMPORTANCE = 162,\n}\n\nconst getCategoryGroupNames = (schema: Schema) =>\n schema === Schema.CIE ? generalCategoryGroupNames : productReviewCategoryGroupNames\n\nconst unMemoizedGetSelectedFiltersWithSchema = (schema: Schema, selected: Filter[]) =>\n selected.filter((filter) => getCategoryGroupNames(schema).includes(filter.categoryGroup))\n\nconst unMemoizedGetAppliedFiltersWithSchema = (\n schema: Schema,\n applied: Record\n) => pick(applied, getCategoryGroupNames(schema))\n\nconst unMemoizedGetAppliedFiltersWithoutSchema = (applied: Record) =>\n pick(applied, allCategoryGroupNames)\nexport const getFilterValues = (state: Pick) => {\n return state.filters.values\n}\n\nexport const getSelectedFilters = (state: Pick) => {\n return state.filters.selected\n}\n\nexport const getDisabledFilter = (state: Pick) => {\n return state.filters.disabled.value\n}\n\nexport const getAppliedFilters = (state: Pick) => {\n return state.filters.applied.value\n}\n\nexport const getSavedFilters = (state: Pick) => {\n return state.filters.saved\n}\n\nexport const getRetailerLostShopperFilters = (state: Pick) => {\n return state.filters.lostShoppers\n}\nexport const getDefaultFilters = (state: Pick) => {\n return state.filters.defaultFilters\n}\n\nexport const selectAppliedSavedFilters = createSelector([getSavedFilters], (saved) => {\n return saved.find(({ isApplied }) => !!isApplied)\n})\n\nexport const selectAppliedFiltersArray = createSelector([getAppliedFilters], (applied) => {\n return flatten(Object.values(applied)).map(({ categoryGroup, desc, label, ...rest }) => rest)\n})\nconst getSelectedVariable = (_: RootState, props: { variableId: number }) => {\n return props.variableId\n}\n\nconst getSchema = (_: RootState, props: { schema: Schema }) => props.schema\n\nexport const selectSelectedFilters = createSelector(\n [getSchema, getSelectedFilters],\n (schema, selected) => {\n return unMemoizedGetSelectedFiltersWithSchema(schema, selected)\n }\n)\n\nexport const selectAllAppliedFilters = createSelector([getAppliedFilters], (applied) => {\n return flatten(Object.values(unMemoizedGetAppliedFiltersWithoutSchema(applied))).map(\n ({ categoryGroup, desc, label, answer_id, ...rest }) => rest\n )\n})\n\nexport const selectAppliedFilters = createSelector(\n [getSchema, getAppliedFilters],\n (schema, applied) => {\n return unMemoizedGetAppliedFiltersWithSchema(schema, applied)\n }\n)\n\nexport const selectSanitizedAppliedFiltersArray = createSelector(\n [getSchema, getAppliedFilters],\n (schema, applied) => {\n return flatten(Object.values(unMemoizedGetAppliedFiltersWithSchema(schema, applied))).map(\n ({ categoryGroup, desc, label, answer_id, ...rest }) => rest\n )\n }\n)\n\nexport const selectSanitizedAppliedFilters = createSelector(\n [getSchema, getAppliedFilters],\n (schema, applied) => {\n return flatten(Object.values(unMemoizedGetAppliedFiltersWithSchema(schema, applied))).map(\n ({ categoryGroup, desc, label, answer_id, ...rest }) => rest\n )\n }\n)\n\nexport const selectSanitizedFilters = createSelector(\n [getSchema, getSelectedFilters],\n (schema, selected) =>\n unMemoizedGetSelectedFiltersWithSchema(schema, selected).map((filter) => {\n const { categoryGroup, desc, label, answer_id, ...rest } = filter ?? {}\n\n return rest\n })\n)\n\nexport const getVariableSelectedFilterValues = createSelector(\n [getSchema, getSelectedFilters, getSelectedVariable],\n (schema, selected, variableId) => {\n return unMemoizedGetSelectedFiltersWithSchema(schema, selected).filter(\n (filter) => filter.variable_id === variableId\n )\n }\n)\n\nexport const selectFiltersForTracking = createSelector(\n [getSchema, getSelectedFilters],\n (schema, selected) => {\n return transform(\n unMemoizedGetSelectedFiltersWithSchema(schema, selected),\n (acc: { categoryName: string; optionChosen: string[] }[], curr) => {\n const [categoryName, value] = curr.desc.split(': ')\n const categoryInUse = findIndex(acc, (obj) => obj.categoryName === categoryName)\n categoryInUse < 0\n ? acc.push({ categoryName, optionChosen: [value] })\n : acc[categoryInUse].optionChosen.push(value)\n },\n []\n )\n }\n)\n\nexport const selectVariableSelectedLabels = createSelector(\n [getSchema, getSelectedFilters],\n (schema, selected) => {\n return new Set(\n unMemoizedGetSelectedFiltersWithSchema(schema, selected).map(\n (filter) => filter.desc.split(':')[0]\n )\n )\n }\n)\n\nexport const selectVariableCount = createSelector(\n [getSchema, getSelectedFilters],\n (schema, selected) => {\n return new Set(\n unMemoizedGetSelectedFiltersWithSchema(schema, selected).map((filter) => filter.variable_id)\n ).size\n }\n)\n\nexport const selectFiltersChanged = createSelector(\n [getSchema, getSelectedFilters, selectSanitizedAppliedFiltersArray],\n (schema, selected, applied) => {\n const selectedFiltersWithSchema = unMemoizedGetSelectedFiltersWithSchema(schema, selected)\n if (selectedFiltersWithSchema.length !== applied.length) {\n return true\n }\n let hasChanged = false\n selectedFiltersWithSchema.forEach((selectedFilter) => {\n if (!hasChanged) {\n const isApplied = some(applied, {\n variable_id: selectedFilter.variable_id,\n answer_code: selectedFilter.answer_code,\n })\n if (!isApplied) {\n hasChanged = true\n }\n }\n })\n return hasChanged\n }\n)\n\nexport const selectVariableValues = createSelector(\n [getFilterValues, getSelectedVariable],\n (values, variableId) => {\n return {\n values: values[variableId] || [],\n variableId,\n }\n }\n)\n\nexport const selectValuesWithSelected = createSelector(\n [selectVariableValues, getVariableSelectedFilterValues],\n ({ values, variableId }, selected) => {\n const byId = groupBy(values, 'answer_code')\n\n const selectedData = selected\n .reduce<(Filter | Answer)[]>((pv, cv) => {\n if (!byId[cv.answer_code]) {\n return [...pv, cv]\n }\n return pv\n }, values)\n .slice()\n\n return variableId === Variables.TIME_FRAME || variableId === Variables.TIME_FRAME_YEARLY\n ? selectedData.sort((a, b) => b.answer_code - a.answer_code)\n : selectedData\n }\n)\n\nexport const selectDisabledFilter = createSelector(\n [getDisabledFilter, getSelectedVariable],\n (disabled, selected) => {\n return !!disabled[selected]\n }\n)\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nconst initialState = {\n quarterly: false,\n yearly: false,\n live: true,\n}\n\nconst timeFrameTabOpenSlice = createSlice({\n name: 'timeframeTabOpen',\n initialState,\n reducers: {\n setActiveTimeFrameTab(\n state,\n action: PayloadAction<{\n quarterly: boolean\n yearly: boolean\n live: boolean\n }>\n ) {\n const { quarterly, yearly, live } = action.payload\n\n state.quarterly = quarterly\n state.yearly = yearly\n state.live = live\n\n return state\n },\n resetTimeFrameTab(state) {\n return initialState\n },\n },\n})\n\nexport const { setActiveTimeFrameTab, resetTimeFrameTab } = timeFrameTabOpenSlice.actions\nexport default timeFrameTabOpenSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nconst initialState = false\n\nconst topBarOpenSlice = createSlice({\n name: 'topBarOpen',\n initialState,\n reducers: {\n toggleFilterTopBar(state, _action: PayloadAction<{ open: boolean }>) {\n return !state\n },\n },\n})\n\nexport const { toggleFilterTopBar } = topBarOpenSlice.actions\nexport default topBarOpenSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { Answer } from 'typings/filters'\n\ntype AppliedFilters = Record\n\nconst initialState: AppliedFilters = {}\n\ntype ValueCacheRecord = {\n variable_id: number\n values: Answer[]\n}\n\nconst valuesSlice = createSlice({\n name: 'values',\n initialState,\n reducers: {\n setFilterValues(state, action: PayloadAction) {\n const { variable_id, values } = action.payload\n\n state[variable_id] = values\n },\n },\n})\n\nexport const { setFilterValues } = valuesSlice.actions\n\nexport default valuesSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { PageOptions } from 'typings/pagination'\n\nconst initialState: PageOptions[] = []\n\nconst selectedPageSlices = createSlice({\n name: 'selectedPageNumber',\n initialState,\n reducers: {\n selectPageNumber(state, action: PayloadAction) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n },\n})\n\nexport const { selectPageNumber } = selectedPageSlices.actions\n\nexport default selectedPageSlices.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nconst initialState = false\n\nconst firstApplySlice = createSlice({\n name: 'savedModalOpen',\n initialState,\n reducers: {\n setFirstApply(_state, action: PayloadAction) {\n if (action.payload) {\n return action.payload\n }\n return initialState\n },\n },\n})\n\nexport const { setFirstApply } = firstApplySlice.actions\nexport default firstApplySlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { Answer } from 'typings/filters'\n\ntype Values = Answer[]\n\nconst initialState: Values = []\n\nconst reviewFilterValuesSlice = createSlice({\n name: 'reviewFilterValues',\n initialState,\n reducers: {\n setReviewFilterValues(state, action: PayloadAction) {\n return [...action.payload]\n },\n },\n})\n\nexport const { setReviewFilterValues } = reviewFilterValuesSlice.actions\n\nexport default reviewFilterValuesSlice.reducer\n","import { combineReducers } from '@reduxjs/toolkit'\nimport topBarOpen from './topBarOpen'\nimport savedModalOpen from './savedModalOpen'\nimport selected from './selected'\nimport applied from './applied'\nimport saved from './saved'\nimport values from './values'\nimport disabled from './disabled'\nimport firstApply from './firstApply'\nimport lostShoppers from './lostShoppers'\nimport reviewFilterValues from './reviewFilterValues'\nimport timeFrameTab from './timeFrameTab'\nimport defaultFilters from './defaultFilters'\nimport filterValues from './filterValues'\n\nconst filters = combineReducers({\n topBarOpen,\n timeFrameTab,\n savedModalOpen,\n selected,\n applied,\n saved,\n values,\n disabled,\n firstApply,\n lostShoppers,\n reviewFilterValues,\n defaultFilters,\n filterValues,\n})\n\nexport type FilterState = ReturnType\n\nexport default filters\n","import { combineReducers } from '@reduxjs/toolkit'\nimport page from './page'\nimport section from './section'\nimport activepage from './activepage'\n\nconst tracking = combineReducers({\n page,\n section,\n activepage,\n})\n\nexport type TrackingState = ReturnType\n\nexport default tracking\n","import { combineReducers } from '@reduxjs/toolkit'\nimport user from './user'\n\nconst subscription = combineReducers({\n user,\n})\n\nexport type SubscriptionState = ReturnType\n\nexport default subscription\n","import { combineReducers } from '@reduxjs/toolkit'\nimport selected from './selected'\n\nconst viewBy = combineReducers({\n selected,\n})\n\nexport type ViewBy = ReturnType\n\nexport default viewBy\n","import { combineReducers } from '@reduxjs/toolkit'\nimport subscriptionError from './subscription'\n\nconst error = combineReducers({\n subscriptionError,\n})\n\nexport type ErrorState = ReturnType\n\nexport default error\n","import { combineReducers } from '@reduxjs/toolkit'\nimport selected from './selected'\nimport showCurrencyWarning from './showCurrencyWarning'\n\nconst currency = combineReducers({\n selected,\n showCurrencyWarning,\n})\n\nexport type Currency = ReturnType\n\nexport default currency\n","import { combineReducers } from '@reduxjs/toolkit'\nimport navigateBackBarVisible from './navigateBackBarVisible'\nimport selectedKPI from './selectedKPI'\nimport segmentVisibility from './segmentVisibility'\nimport bubbleExportVisible from './bubbleExportVisible'\n\nconst audienceProfiler = combineReducers({\n navigateBackBarVisible,\n segmentVisibility,\n selectedKPI,\n bubbleExportVisible,\n})\n\nexport type AudienceProfiler = ReturnType\n\nexport default audienceProfiler\n","import { combineReducers } from '@reduxjs/toolkit'\nimport selectedPage from './selectedPage'\n\nconst page = combineReducers({\n selectedPage,\n})\n\nexport type Page = ReturnType\n\nexport default page\n","import { combineReducers } from '@reduxjs/toolkit'\nimport applied from './applied'\n\nconst compareBy = combineReducers({\n applied,\n})\n\nexport type CompareBy = ReturnType\n\nexport default compareBy\n","import { combineReducers } from '@reduxjs/toolkit'\nimport consumerFeatureFlags from './consumerFeatureFlags'\n\nconst featureFlag = combineReducers({\n consumerFeatureFlags,\n})\n\nexport type FeatureFlags = ReturnType\n\nexport default featureFlag\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nconst initialState: any[] = []\n\nconst donutViewByItemsSlices = createSlice({\n name: 'DonutViewByItems',\n initialState,\n reducers: {\n setDonutViewByItems(state, action: PayloadAction) {\n return action.payload ?? initialState\n },\n },\n})\n\nexport const { setDonutViewByItems } = donutViewByItemsSlices.actions\n\nexport default donutViewByItemsSlices.reducer\n","import { combineReducers } from '@reduxjs/toolkit'\nimport selectedBrand from './selectedBrand'\nimport storiesSummaryError from './storiesSummaryError'\nimport selectLostShoppers from './selectLostShoppers'\nimport defaultSelectedLostShopper from './defaultSelectedLostShopper'\nimport topLostShoppers from './topLostShoppers'\nimport kbqTopPurchasedData from './kbqTopPurchasedData'\nimport kbqChartData from './kbqChartData'\nimport accordionPanels from './accordionPanels'\nimport selectedPurchaseDriversList from './selectedPurchaseDriversList'\nimport selectedRetailer from './selectedRetailer'\nimport selectedChannelVisited from './selectedChannelVisited'\nimport topPurchasedBrandDonut from './topPurchasedBrandDonut'\nimport donutViewByItems from './donutViewByItems'\nconst KBQBrands = combineReducers({\n donutViewByItems,\n selectedBrand,\n storiesSummaryError,\n selectLostShoppers,\n defaultSelectedLostShopper,\n topLostShoppers,\n kbqTopPurchasedData,\n kbqChartData,\n accordionPanels,\n selectedPurchaseDriversList,\n selectedRetailer,\n selectedChannelVisited,\n topPurchasedBrandDonut,\n})\n\nexport type KBQ = ReturnType\n\nexport default KBQBrands\n","import { combineReducers } from '@reduxjs/toolkit'\nimport filters from './filtering'\nimport tracking from './tracking'\nimport subscription from './subscription'\nimport viewBy from './viewBy'\nimport user from './user'\nimport error from './error'\nimport currency from './currency'\nimport audienceProfiler from './audienceProfiler'\nimport pagination from './pagination'\nimport compareBy from './compareBy'\nimport featureFlag from './featureFlag'\nimport KBQ from './KBQ'\n\nconst rootReducer = combineReducers({\n filters,\n tracking,\n subscription,\n viewBy,\n audienceProfiler,\n user,\n error,\n currency,\n pagination,\n compareBy,\n featureFlag,\n KBQ,\n})\n\nexport default rootReducer\n","import { configureStore } from '@reduxjs/toolkit'\nimport watch from 'redux-watch'\nimport { at, Many } from 'lodash'\nimport { loadFromLocalStorage, saveToLocalStorage } from 'util/localStorage/index'\nimport rootReducer from './rootReducer'\nimport { setFirstApply } from './filtering/firstApply'\nimport { getPreferenceFilters } from './filtering/saved'\n\nexport const store = configureStore({\n reducer: rootReducer,\n})\n\nif (process.env.NODE_ENV === 'development' && module.hot) {\n module.hot.accept('./rootReducer', () => {\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const newRootReducer = require('./rootReducer').default\n store.replaceReducer(newRootReducer)\n })\n}\nconst persistingSessionFilters = [{ key: 'filters.applied', loadActions: [] }]\nconst persistingStates = [{ key: 'filters.firstApply', loadActions: [setFirstApply] }]\n\npersistingSessionFilters.forEach(({ key }) => {\n const watcher = watch(store.getState, key)\n store.subscribe(\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n watcher((newVal, oldVal, objectPath) => {\n const storageKey = store.getState().user.hash\n saveToLocalStorage({\n storageKey,\n key,\n data: at(store.getState(), [key] as Many)[0],\n session: true,\n })\n })\n )\n})\n\npersistingStates.forEach(({ key }) => {\n const watcher = watch(store.getState, key)\n store.subscribe(\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n watcher((newVal, oldVal, objectPath) => {\n const storageKey = store.getState().user.hash\n\n saveToLocalStorage({\n storageKey,\n key,\n data: at(store.getState(), [key] as Many)[0],\n })\n })\n )\n})\n\n// Update with saved states in local storage, after user logs in\nconst userHashWatch = watch(store.getState, 'user.hash')\nstore.subscribe(\n userHashWatch(() => {\n const storageKey = store.getState().user.hash\n\n persistingStates.forEach(({ key, loadActions }) => {\n const state = loadFromLocalStorage({ storageKey, key })\n\n if (loadActions) {\n loadActions.forEach((loadAction) => store.dispatch(loadAction(state)))\n }\n })\n })\n)\n\nconst userJwtWatch = watch(store.getState, 'user.jwt')\nstore.subscribe(\n userJwtWatch(() => {\n // pull saved filters from preference API\n store.dispatch(getPreferenceFilters())\n })\n)\n\nexport type RootState = ReturnType\nexport type AppDispatch = typeof store.dispatch\n\nexport default store\n","import { RootState } from 'reducers/store'\n\nexport const selectUserSubscription = (state: Pick) => {\n return state.subscription.user.value\n}\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\nexport type Cell = {\n country: string\n itemGroup: string\n waves: string[]\n}\n\ninterface SubscriptionState {\n value: Cell[] | null\n}\n\nconst initialState: SubscriptionState = { value: null }\n\nconst subscriptionSlice = createSlice({\n name: 'user',\n initialState,\n reducers: {\n setSubscription(state, action: PayloadAction) {\n state.value = action.payload\n },\n },\n})\n\nexport const { setSubscription } = subscriptionSlice.actions\nexport default subscriptionSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\ninterface ActivePageTracking {\n activePageName: string\n}\n\ninterface ActivePageState {\n value: ActivePageTracking\n}\n\nconst initialState: ActivePageState = { value: { activePageName: '' } }\n\nconst activePageSlice = createSlice({\n name: 'activepage',\n initialState,\n reducers: {\n updateActivePage(\n state,\n action: PayloadAction<{\n activePageName: string\n }>\n ) {\n state.value = {\n ...state.value,\n ...action.payload,\n }\n },\n },\n})\n\nexport const { updateActivePage } = activePageSlice.actions\nexport default activePageSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\ninterface PageTracking {\n page: string\n chartDepthViewed?: number\n chartName?: string\n totalCharts?: number\n}\n\ninterface PageState {\n value: PageTracking | null\n}\n\nconst initialState: PageState = { value: null }\n\nconst pageSlice = createSlice({\n name: 'page',\n initialState,\n reducers: {\n createPageTracking(state, action: PayloadAction) {\n state.value = {\n page: action.payload,\n }\n },\n updateChartViewed(\n state,\n action: PayloadAction<{\n chartDepthViewed: number\n chartName: string\n }>\n ) {\n if (state.value) {\n const currentDepth = state.value.chartDepthViewed || 0\n if (action.payload.chartDepthViewed > currentDepth) {\n state.value = {\n ...state.value,\n ...action.payload,\n }\n }\n }\n },\n updateTotalCharts(\n state,\n action: PayloadAction<{\n totalCharts: number\n }>\n ) {\n if (state.value) {\n state.value = {\n ...state.value,\n ...action.payload,\n }\n }\n },\n },\n})\n\nexport const { createPageTracking, updateChartViewed, updateTotalCharts } = pageSlice.actions\nexport default pageSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\ninterface SectionTracking {\n section: string\n subSection: string\n pageName: string\n}\n\ninterface SectionState {\n value: SectionTracking\n}\n\nconst initialState: SectionState = { value: { section: '', subSection: '', pageName: '' } }\n\nconst sectionSlice = createSlice({\n name: 'section',\n initialState,\n reducers: {\n updateSection(\n state,\n action: PayloadAction<{\n section: string\n subSection: string\n pageName: string\n }>\n ) {\n state.value = {\n ...state.value,\n ...action.payload,\n }\n },\n },\n})\n\nexport const { updateSection } = sectionSlice.actions\nexport default sectionSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\n\ninterface UserState {\n hash?: string\n jwt?: string\n email?: string\n firstName?: string\n lastName?: string\n userId?: string\n}\n\nconst initialState: UserState = {}\n\nconst userSlice = createSlice({\n name: 'hash',\n initialState,\n reducers: {\n setUserData(state, action: PayloadAction) {\n return {\n ...state,\n hash: action.payload.hash,\n email: action.payload.email,\n firstName: action.payload.firstName,\n lastName: action.payload.lastName,\n userId: action.payload.userId,\n }\n },\n setUserJwt(state, action: PayloadAction) {\n return { ...state, jwt: action.payload }\n },\n },\n})\n\nexport const { setUserData, setUserJwt } = userSlice.actions\nexport default userSlice.reducer\n","import { createSlice, PayloadAction } from '@reduxjs/toolkit'\nimport { ViewByOption } from 'typings/viewBy'\n\nconst initialState: ViewByOption[] = []\n\nconst selectedViewBySlices = createSlice({\n name: 'selectedViewBy',\n initialState,\n reducers: {\n selectViewBy(state, action: PayloadAction) {\n return state.filter(({ id }) => id !== action.payload.id).concat(action.payload)\n },\n setAllSelectedViewBy(state, action: PayloadAction) {\n return action.payload ?? initialState\n },\n },\n})\n\nexport const { selectViewBy, setAllSelectedViewBy } = selectedViewBySlices.actions\n\nexport default selectedViewBySlices.reducer\n","export enum CategoryGroupName {\n General_Base = 'General_Base',\n General_Shopper = 'General_Shopper',\n General_Purchase = 'General_Purchase',\n General_Product = 'General_Product',\n General_Archive = 'General_Archive',\n\n ProductReview_Base = 'ProductReview_Base',\n ProductReview_Purchase = 'ProductReview_Purchase',\n ProductReview_Review = 'ProductReview_Review',\n}\n\nexport interface FilterData {\n variable_id: number\n answer_id: number\n answer_code: number\n}\n\nexport interface FilterMeta {\n label: string\n desc: string\n categoryGroup: CategoryGroupName\n operator?: string\n categoryName?: string\n}\n\nexport type Filter = FilterData & FilterMeta\n\n// e.g. Audience Definition\nexport interface CategoryGroup {\n id: number\n label: CategoryGroupName | string\n categories: Category[]\n}\n\n// e.g. Demographics\nexport interface Category {\n id: number\n label: string\n variables: Variable[]\n subSection?: string\n}\n\n// e.g. Age\nexport interface Variable {\n variable_id: number\n label: string\n values: Answer[]\n categoryGroup?: CategoryGroupName\n tooltip_content?: string\n placeholder?: string\n show_separator_top?: boolean\n show_separator_bottom?: boolean\n disable_on_select?: boolean\n}\n\n// e.g. 18-24\nexport interface Answer {\n answer_id: number\n answer_code: number\n label: string\n category_name?: string\n}\n\nexport enum Operator {\n NOT_IN = 'not_in',\n}\n\nexport enum Schema {\n CIE = 'cie',\n CIE_REVIEW = 'cie_review',\n}\n\nexport interface FooterProps {\n linkText: string\n pageName: string\n toLocation: string\n locationTitle: string\n}\n\nexport enum Location {\n PRODUCT_REVIEW = '/cie/brand/productReviews',\n PRODUCT_REVIEWS = 'Product Reviews',\n AUDIENCE_PROFILER = '/audience-profiler',\n AUDIENCE_PROFILER_TITLE = 'Audience Profiler',\n STORIES = 'Stories',\n OVERVIEW = 'Overview',\n}\n\nexport enum SubCategories {\n General = 'General',\n Features = 'Features',\n}\nexport interface RowSpec {\n header: {\n hint?: string\n title: string\n secondaryTitle: string\n }\n hide?: {\n codes: number[]\n }\n}\n\nexport enum CategoryLabels {\n Product = 'Product Specification',\n}\n\nexport const TIME_FRAME = 'Time Frame: '\n","import { useAnalytics } from '@ecosystem/newron-client-lib'\nimport store from 'reducers/store'\nimport { Location } from 'typings/filters'\n\ninterface NavClickMessage {\n linkName: string\n pageName: string\n section: string\n subsection?: string\n navigationSource?: string\n}\n\ninterface FiltersApplied {\n access: string\n categoryCombination: string\n filterName: string\n optionChosen: string[]\n pageName: string\n subsection: string\n section: string\n}\n\ninterface FiltersAppliedDetails {\n access: string\n categoryChosen: string\n categoryCombination: string\n filterName: string\n optionChosen: string[]\n pageName: string\n subsection?: string\n section: string\n}\n\ninterface ChartInteractions {\n access: string\n chartName: string\n dataSource: string\n elementName: string\n elementType: string\n optionChosen?: string | string[]\n pageName: string\n subsection?: string\n section: string\n}\n\ninterface SearchClicked {\n access: string\n actionType: string\n keyword: string\n keywordOrigin: string\n pageName: string\n subsection: string\n section: string\n}\n\ninterface FilterTrayButtonClick {\n page: string\n action: string\n buttonName: string\n}\n\ninterface PageElementClick {\n access: string\n elementCategory: string\n elementName: string\n pageName: string\n subsection: string\n section: string\n optionChosen?: string[]\n}\n\ninterface TableClicked {\n access: string\n column?: string\n elementName: string\n elementType?: string\n optionChosen?: string | string[]\n pageName: string\n subsection?: string\n section: string\n tableName?: string\n}\ninterface PageElementViewed {\n access: string\n elementCategory: string\n elementName: string\n pageName: string\n subsection: string\n section: string\n dataAvailability: string\n}\n\ninterface PageScrolled {\n // access: string\n deepestChartViewed?: string\n referrer: string\n scroll?: number\n}\n\ninterface PageViewed {\n pageName: string\n subsection: string\n section: string\n}\n\nexport enum AnalyticsEvent {\n NavigationClick = 'Navigation Clicked',\n FiltersApplied = 'Filter Applied',\n FiltersAppliedDetails = 'Filter Applied Details',\n SearchClicked = 'Search Clicked',\n ChartInteractions = 'Chart Interactions',\n PageElementClick = 'Page Element Clicked',\n PageElementViewed = 'Page Element Viewed',\n PageScrolled = 'Page Scrolled',\n PageViewed = 'Page Viewed',\n TableClicked = 'Table Clicked',\n DataExported = 'Data Exported',\n DataExportInitiated = 'Data Export Initiated',\n}\n\nexport enum TRACKING {\n ACCESS = 'consumer',\n FILTER_NAME = 'Consumer Filter',\n ELEMENT_NAME = 'View By',\n ELEMENT_TYPE = 'Dropdown',\n DATA_SOURCE = 'Survey',\n HINT = 'Hint',\n REVIEW_DATA_SOURCE = 'Consumer Reviews',\n FILTER_BAR = 'Filter Bar',\n CLEAR_FILTERS = 'Clear Filters',\n EXPAND_FILTER_BAR = 'Expand Filter Bar',\n EXPORT = 'Export',\n SAVE_FILTER = 'Save Filter',\n SAMPLE_SIZE_LABEL = 'Low sample size label',\n LOW_SAMPLE_SIZE = 'Low sample size',\n YES = 'yes',\n NO = 'no (low sample size)',\n YES_LOW_SAMPLE_SIZE = 'yes (low sample size)',\n NO_DATA = 'no (no data)',\n LEGEND = 'Legend',\n CHART_ENGAGEMENT = 'Chart Engagement',\n FILTER_TRAY = 'Filter Tray',\n EXPAND_FILTER_TRAY = 'Expand Filter Tray',\n SEARCH_CLICKED = 'Search clicked(keyword entered)',\n MANUAL_ENTRY = 'Manual Entry',\n DROPDOWN = 'Dropdown',\n CONTENT_LINK = 'Content Link',\n LINK = 'link',\n Chart = 'chart',\n JUMP_POINT = 'Jump Point',\n Chart_Tooltip = 'Chart Tooltip',\n SELECT_AUDIENCES = 'Select Audiences',\n AUDIENCE_SELECTOR = 'Audience Selector',\n COMPARE_BY = 'Compare By',\n TABLE_OVERLAY = 'Table Overlay',\n OVERLAY = 'Overlay',\n BUBBLE_OVERLAY = 'Bubble Overlay',\n SORT = 'Sort',\n TRELLIS_SORT = 'Trellis Sort',\n YES_NO_DATA = 'yes (no data)',\n YES_LOW_SAMPLE_NO_DATA = 'yes(low sample size, no data)',\n COLLAPSE_FILTER = 'Collapse Filter',\n GO_BACKTO_PROFILER = 'Go Back to Profiler',\n PAGINATION = 'Pagination',\n LEFT_CLICK = 'Left Click',\n RIGHT_CLICK = 'Right Click',\n HINT_HYPERLINK = 'Hint Hyperlink',\n PLATFORM = 'Platform',\n EVENT_DESCRIPTION = 'User downloads the export file',\n EXPORT_DATA = 'Export Data',\n CURRENCY = 'Currency',\n BANNER_EXPAND = 'Banner Expand',\n BANNER_COLLAPSED = 'Banner Collapsed',\n FORMAT_TOGGLE = 'Format Toggle',\n CAROUSEL = 'Carousel',\n READ_MORE = 'Read more',\n SAVED_FILTERS = 'Saved filters',\n SAVED_FILTER_OPTION = 'Saved filter options',\n SAVED_FILTER_NAVIGATION = 'Saved filters navigation',\n DELETE = 'Delete',\n SELECT_COMPETITORS = 'Select competitors',\n GO_BACKTO_STORIES = 'Go Back to Stories',\n SELECT_SHOPPERS = 'Select shoppers for comparison',\n SELECT_BRAND = 'Select Brand',\n CHART_PANEL = 'Chart Panel',\n SELECT_RETAILER = 'Select Retailer',\n SELECT_CHANNEL_VISISTED = 'Select Channel Visited',\n}\n\ninterface TrackProps {\n id: AnalyticsEvent\n message:\n | NavClickMessage\n | FiltersApplied\n | SearchClicked\n | FilterTrayButtonClick\n | FiltersAppliedDetails\n | ChartInteractions\n | PageElementClick\n | PageElementViewed\n | PageScrolled\n | PageViewed\n | TableClicked\n}\n\ninterface PageProps {\n location: string\n}\n\nconst Analytics = () => {\n const { page, identify, track, group } = useAnalytics()\n return {\n page,\n identify,\n track,\n group,\n }\n}\n\nexport const trackNavigationEvent = (props: TrackProps) => {\n const { id, message } = props\n\n Analytics().track(id, message)\n}\nexport const trackEvent = (props: TrackProps) => {\n const { id, message } = props\n Analytics().track(id, { ...message, access: TRACKING.ACCESS })\n}\n\nexport const trackPageScrollEvent = (props: TrackProps) => {\n const { section, pageName, subSection } = store.getState().tracking.section.value\n const { id, message } = props\n Analytics().track(id, {\n ...message,\n access: TRACKING.ACCESS,\n pageName,\n section,\n subsection: subSection,\n })\n}\n\nexport const trackPageViewedEvent = (id: string) => {\n const { section, pageName, subSection } = store.getState().tracking.section.value\n const location = store.getState().tracking.page.value\n const overview = 'overview'\n if (!location?.page.includes(Location.AUDIENCE_PROFILER)) {\n Analytics().track(id, {\n access: TRACKING.ACCESS,\n pageName: pageName ? pageName : overview,\n section: section ? section : overview,\n subsection: subSection ? subSection : overview,\n })\n }\n}\n\nexport const trackPage = (props: PageProps) => {\n const { location } = props\n Analytics().page(location, { access: TRACKING.ACCESS })\n}\n","import { envNoError } from 'util/env'\n\nexport const addDelimiter = (num: number, delimiter = ',') => {\n return Math.floor(num)\n .toString()\n .replace(/(\\d)(?=(\\d{3})+(?!\\d))/g, `$1${delimiter}`) // NOSONAR\n}\n\nexport const formatRedirectUri = (redirectUri: string) => {\n const publicUrl = envNoError('PUBLIC_URL')\n if (publicUrl) {\n return `${publicUrl}/${redirectUri}`\n }\n return `${redirectUri}`\n}\n\nexport const stringToNumericalHashCode = (s: string) => {\n let hash = 0\n let i\n let chr\n\n if (s.length === 0) return `${hash}`\n for (i = 0; i < s.length; i++) {\n chr = s.charCodeAt(i)\n // tslint:disable-next-line:no-bitwise\n hash = (hash << 5) - hash + chr\n // tslint:disable-next-line:no-bitwise\n hash |= 0\n }\n return `${hash}`\n}\n\nexport const removePrefixNumbering = (str: string): string => str.replace(/^\\d+\\.\\s+(.+)$/, '$1') // NOSONAR\n\nexport const prependEuro = (value: number | string) => `€${value}`\nexport const appendPercent = (value: number | string) => `${value}%`\n","export const loadFromLocalStorage = ({\n storageKey = '',\n key,\n}: {\n storageKey?: string\n key: string\n}) => {\n try {\n const unserialised = localStorage.getItem(`${storageKey}_${key}`)\n\n if (unserialised === null) {\n return undefined\n }\n return JSON.parse(unserialised)\n } catch (error) {\n return undefined\n }\n}\n\nexport const saveToLocalStorage = ({\n storageKey = '',\n key,\n data,\n session,\n}: {\n storageKey?: string\n key: string\n data: any\n session?: boolean\n}) => {\n try {\n const serialisedState = JSON.stringify(data)\n session\n ? sessionStorage.setItem(`${storageKey}_${key}`, serialisedState)\n : localStorage.setItem(`${storageKey}_${key}`, serialisedState)\n } catch (error) {\n // add log\n }\n}\n","export const BASE_CIE_PATH = 'cie'\n\nexport enum CIE_ALLOWED_PATH {\n CALLBACK = 'callback',\n CIE_OVERVIEW = 'overview',\n AUDIENCE_PROFILER = 'audience-profiler',\n STORIES = 'stories',\n STORIES_OVERVIEW = 'stories/overview',\n}\n\nexport const isAllowedCiePath = (ciePath: string) => {\n return ciePath.includes(BASE_CIE_PATH)\n}\n\nexport const getBaseCiePathDefinition = (): string => {\n return `/`\n}\n\nexport const getCiePathDefinition = (ciePath: CIE_ALLOWED_PATH | string): string => {\n return `/${ciePath}`\n}\n\nexport const getRetailPathForHistory = (ciePath: CIE_ALLOWED_PATH): string => {\n return ciePath\n}\n\nexport const getWildcardCiePath = (): string => {\n return '/:page'\n}\n\nexport const getNewronLogoutPath = (): string => {\n return '/logout'\n}\n\nexport const isCIERoute = (): boolean => {\n return window.location.pathname.includes(BASE_CIE_PATH) && window.location.pathname !== '/cie/'\n}\n","import { Cell } from 'reducers/subscription/user'\nimport { Answer, Filter } from 'typings/filters'\n\ntype FilterCombination = Filter & { categoryName?: string }\n\nexport const generateCombinationSet = (\n productArray: FilterCombination[],\n marketArray: FilterCombination[]\n) => {\n const combinationSet = []\n\n for (const productItem of productArray) {\n for (const marketItem of marketArray) {\n combinationSet.push({\n product_code: productItem.categoryName,\n market_code: marketItem.categoryName,\n })\n }\n }\n\n return combinationSet\n}\n\nexport const filterContext = (\n sharedContextArray: Cell[],\n combArray: {\n product_code?: string\n market_code?: string\n }[]\n) => {\n if (!sharedContextArray.length) {\n return combArray.map(({ product_code, market_code }) => ({\n itemGroup: product_code,\n country: market_code,\n }))\n }\n const filteredSharedContext = sharedContextArray.filter((contextItem) => {\n return combArray.some((combItem) => {\n return (\n contextItem.country === combItem.market_code &&\n contextItem.itemGroup === combItem.product_code\n )\n })\n })\n\n const filteredSharedContextWithoutWaves = filteredSharedContext.map(\n ({ waves, ...rest }: Cell) => rest\n )\n\n return filteredSharedContextWithoutWaves\n}\n\nexport const mapFiltersWithValues = (\n filters: Filter[],\n variableId: number,\n valuesData: Answer[]\n) => {\n return filters\n .filter((filter) => filter.variable_id === variableId)\n .map((filter) => {\n return {\n ...filter,\n categoryName: valuesData.find((answer) => filter.answer_code === answer.answer_code)\n ?.category_name,\n }\n })\n}\n\nexport const isValidContext = (\n sharedContextArray: Omit[],\n loggedInUserContext: Omit[]\n) => {\n if (loggedInUserContext?.length === 0) {\n return true\n }\n if (!sharedContextArray.length) {\n return false\n }\n return sharedContextArray.every((sharedContext) => {\n return loggedInUserContext.some((contextItem) => {\n return (\n sharedContext.country === contextItem.country &&\n sharedContext.itemGroup === contextItem.itemGroup\n )\n })\n })\n}\n\nexport const hasMatch = (\n combArray: {\n product_code?: string\n market_code?: string\n }[],\n context: Cell[]\n) => {\n if (context && context.length === 0) return true\n return combArray.every((combItem) =>\n context.some(\n (contextItem) =>\n contextItem.itemGroup === combItem.product_code &&\n contextItem.country === combItem.market_code\n )\n )\n}\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Lato:wght@400;700&display=swap);\"]);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.index-module__Wrapper--vZBrx{color:#414752;font-size:20px;display:flex;justify-content:center;align-items:center;grid-area:content;height:100vh}.index-module__Wrapper--vZBrx .index-module__Content--ZB20L{flex-direction:column}`, \"\",{\"version\":3,\"sources\":[\"webpack://./src/components/LoadingContent/index.module.scss\",\"webpack://./node_modules/@ecosystem/ui-lib/core/styles/themes/ecosystem-default/_colors.scss\",\"webpack://./node_modules/@ecosystem/ui-lib/core/styles/base/_fonts.scss\"],\"names\":[],\"mappings\":\"AAGA,8BACE,aCKS,CDJT,cEaG,CFZH,YAAA,CACA,sBAAA,CACA,kBAAA,CACA,iBAAA,CACA,YAAA,CAEA,4DACE,qBAAA\",\"sourcesContent\":[\"@import '~@ecosystem/ui-lib/core/styles/base/fonts';\\n@import '~@ecosystem/ui-lib/core/styles/themes/ecosystem-default/colors';\\n\\n.Wrapper {\\n color: $text-default;\\n font-size: $h4;\\n display: flex;\\n justify-content: center;\\n align-items: center;\\n grid-area: content;\\n height: 100vh;\\n\\n .Content {\\n flex-direction: column;\\n }\\n}\\n\",\"/* stylelint-disable color-no-hex */\\n\\n/* new pallete from march 2021*/\\n/* ui colors */\\n$brand-darkorange: #cf4800;\\n$brand-brightorange: #e55a00;\\n$brand-lightorange: #fdefe6;\\n$brand-superlightorange: #fdf6f2;\\n$grey-900: #323842;\\n$grey-800: #414752;\\n$grey-700: #5c626e;\\n$grey-600: #6f7582;\\n$grey-500: #9499a3;\\n$grey-400: #bbc0c9;\\n$grey-300: #dadde3;\\n$grey-200: #ebecf0;\\n$grey-100: #f5f6f7;\\n$ui-white: #fff;\\n$ui-green: #167922;\\n$ui-red: #bc1c0e;\\n\\n/* data vis colours */\\n$blue-800: #2b4c9b;\\n$blue-700: #3456a6;\\n$blue-600: #3c60b3;\\n$blue-500: #4368bd;\\n$blue-400: #6480c3;\\n$blue-300: #879bcc;\\n$blue-200: #afbbdb;\\n$blue-100: #dbe0eb;\\n$petrol-800: #428a81;\\n$petrol-700: #4b9a91;\\n$petrol-600: #4da9a1;\\n$petrol-500: #54b9b1;\\n$petrol-400: #63c8c2;\\n$petrol-300: #81d7d3;\\n$petrol-200: #b2edeb;\\n$petrol-100: #e2ffff;\\n$magenta-800: #97254f;\\n$magenta-700: #ac2b55;\\n$magenta-600: #c02d58;\\n$magenta-500: #d2335f;\\n$magenta-400: #d44a73;\\n$magenta-300: #d76789;\\n$magenta-200: #da91a7;\\n$magenta-100: #ddbbc5;\\n$yellow-800: #ee7c24;\\n$yellow-700: #f58a27;\\n$yellow-600: #fa9a2a;\\n$yellow-500: #ffa52f;\\n$yellow-400: #fdb244;\\n$yellow-300: #fdc166;\\n$yellow-200: #fed79a;\\n$yellow-100: #ffebcc;\\n$purple-800: #5c399b;\\n$purple-700: #673fa2;\\n$purple-600: #7249ad;\\n$purple-500: #7b4db3;\\n$purple-400: #8d69bb;\\n$purple-300: #a387c8;\\n$purple-200: #bfb0d4;\\n$purple-100: #ddd8e4;\\n$ext-grey-100: #d6d9dc;\\n$ext-grey-200: #c0c5c8;\\n$ext-grey-300: #9fa7ad;\\n$ext-grey-400: #7f888e;\\n$ext-grey-500: #6a757c;\\n$ext-grey-600: #535d63;\\n$ext-grey-700: #3b4145;\\n$ext-grey-800: #171a1c;\\n$red-100: #cba6a8;\\n$red-200: #bb7471;\\n$red-300: #b0504c;\\n$red-400: #ba302a;\\n$red-500: #bc1c0e;\\n$red-600: #ad0e0e;\\n$red-700: #9b0009;\\n$red-800: #8f0001;\\n$green-100: #bde5bd;\\n$green-200: #98d299;\\n$green-300: #73c375;\\n$green-400: #59b75b;\\n$green-500: #3dad42;\\n$green-600: #329d38;\\n$green-700: #24892c;\\n$green-800: #167922;\\n\\n/* descriptive tokens */\\n$text-heading: $grey-900;\\n$text-default: $grey-800;\\n$text-secondary-interactive: $grey-700;\\n$text-lighter: $grey-600;\\n$text-inactive: $grey-500;\\n$stroke: $grey-400;\\n$stroke-light: $grey-300;\\n$background-darkest: $grey-600;\\n$background-dark: $grey-300;\\n$background-medium: $grey-200;\\n$background-light: $grey-100;\\n$color-focus: $yellow-200;\\n\\n/* end colours from design system */\\n\\n/* need to address these two */\\n$modal-background: rgba(0, 10, 20, 0.5);\\n$brand-brightorange-200: #ffd07c;\\n\\n/* stylelint-enable */\\n\\n$colors: 'brand-darkorange' $brand-darkorange, 'brand-brightorange' $brand-brightorange,\\n 'brand-superlightorange' $brand-superlightorange, 'grey-800' $grey-800, 'grey-700' $grey-700, 'grey-600' $grey-600,\\n 'grey-500' $grey-500, 'grey-400' $grey-400, 'grey-300' $grey-300, 'grey-200' $grey-200, 'grey-100' $grey-100,\\n 'ext-grey-800' $ext-grey-800, 'ext-grey-700' $ext-grey-700, 'ext-grey-600' $ext-grey-600, 'ext-grey-500' $ext-grey-500,\\n 'ext-grey-400' ext-$grey-400, 'ext-grey-300' $ext-grey-300, 'ext-grey-200' $ext-grey-200, 'ext-grey-100' ext-$grey-100,\\n 'white' $ui-white, 'green' $ui-green, 'red' $ui-red, 'blue-800' $blue-800, 'blue-700' $blue-700, 'blue-600' $blue-600,\\n 'blue-500' $blue-500, 'blue-400' $blue-400, 'blue-300' $blue-300, 'blue-200' $blue-200, 'blue-100' $blue-100,\\n 'petrol-800' $petrol-800, 'petrol-700' $petrol-700, 'petrol-600' $petrol-600, 'petrol-500' $petrol-500,\\n 'petrol-400' $petrol-400, 'petrol-300' $petrol-300, 'petrol-200' $petrol-200, 'petrol-100' $petrol-100,\\n 'magenta-800' $magenta-800, 'magenta-700' $magenta-700, 'magenta-600' $magenta-600, 'magenta-500' $magenta-500,\\n 'magenta-400' $magenta-400, 'magenta-300' $magenta-300, 'magenta-200' $magenta-200, 'magenta-100' $magenta-100,\\n 'yellow-800' $yellow-800, 'yellow-700' $yellow-700, 'yellow-600' $yellow-600, 'yellow-500' $yellow-500,\\n 'yellow-400' $yellow-400, 'yellow-300' $yellow-300, 'yellow-200' $yellow-200, 'yellow-100' $yellow-100,\\n 'purple-800' $purple-800, 'purple-700' $purple-700, 'purple-600' $purple-600, 'purple-500' $purple-500,\\n 'purple-400' $purple-400, 'purple-300' $purple-300, 'purple-200' $purple-200, 'purple-100' $purple-100,\\n 'red-800' $red-800, 'red-700' $red-700, 'red-600' $red-600, 'red-500' $red-500, 'red-400' $red-400, 'red-300' $red-300,\\n 'red-200' $red-200, 'red-100' $red-100, 'green-800' $green-800, 'green-700' $green-700, 'green-600' $green-600,\\n 'green-500' $green-500, 'green-400' $green-400, 'green-300' $green-300, 'green-200' $green-200, 'green-100' $green-100,\\n 'ui-green' $ui-green, 'ui-red' $ui-red, 'text-heading' $text-heading, 'text-default' $text-default,\\n 'text-secondary-interactive' $text-secondary-interactive, 'text-lighter' $text-lighter, 'text-inactive' $text-inactive,\\n 'stroke' $stroke, 'stroke-light' $stroke-light, 'background-darkest' $background-darkest,\\n 'background-dark' $background-dark, 'background-medium' $background-medium, 'background-light' $background-light,\\n 'color-focus' $color-focus;\\n\\n/* stylelint-disable */\\n:export {\\n brand-darkorange: $brand-darkorange;\\n brand-brightorange: $brand-brightorange;\\n brand-superlightorange: $brand-superlightorange;\\n grey-800: $grey-800;\\n grey-700: $grey-700;\\n grey-600: $grey-600;\\n grey-500: $grey-500;\\n grey-400: $grey-400;\\n grey-300: $grey-300;\\n grey-200: $grey-200;\\n grey-100: $grey-100;\\n white: $ui-white;\\n green: $ui-green;\\n red: $ui-red;\\n blue-800: $blue-800;\\n blue-700: $blue-700;\\n blue-600: $blue-600;\\n blue-500: $blue-500;\\n blue-400: $blue-400;\\n blue-300: $blue-300;\\n blue-200: $blue-200;\\n blue-100: $blue-100;\\n petrol-800: $petrol-800;\\n petrol-700: $petrol-700;\\n petrol-600: $petrol-600;\\n petrol-500: $petrol-500;\\n petrol-400: $petrol-400;\\n petrol-300: $petrol-300;\\n petrol-200: $petrol-200;\\n petrol-100: $petrol-100;\\n magenta-800: $magenta-800;\\n magenta-700: $magenta-700;\\n magenta-600: $magenta-600;\\n magenta-500: $magenta-500;\\n magenta-400: $magenta-400;\\n magenta-300: $magenta-300;\\n magenta-200: $magenta-200;\\n magenta-100: $magenta-100;\\n yellow-800: $yellow-800;\\n yellow-700: $yellow-700;\\n yellow-600: $yellow-600;\\n yellow-500: $yellow-500;\\n yellow-400: $yellow-400;\\n yellow-300: $yellow-300;\\n yellow-200: $yellow-200;\\n yellow-100: $yellow-100;\\n green-800: $green-800;\\n green-700: $green-700;\\n green-600: $green-600;\\n green-500: $green-500;\\n green-400: $green-400;\\n green-300: $green-300;\\n green-200: $green-200;\\n green-100: $green-100;\\n red-800: $red-800;\\n red-700: $red-700;\\n red-600: $red-600;\\n red-500: $red-500;\\n red-400: $red-400;\\n red-300: $red-300;\\n red-200: $red-200;\\n red-100: $red-100;\\n purple-800: $purple-800;\\n purple-700: $purple-700;\\n purple-600: $purple-600;\\n purple-500: $purple-500;\\n purple-400: $purple-400;\\n purple-300: $purple-300;\\n purple-200: $purple-200;\\n purple-100: $purple-100;\\n ext-grey-800: $ext-grey-800;\\n ext-grey-700: $ext-grey-700;\\n ext-grey-600: $ext-grey-600;\\n ext-grey-500: $ext-grey-500;\\n ext-grey-400: $ext-grey-400;\\n ext-grey-300: $ext-grey-300;\\n ext-grey-200: $ext-grey-200;\\n ext-grey-100: $ext-grey-100;\\n ui-green: $ui-green;\\n ui-red: $ui-red;\\n text-heading: $text-heading;\\n text-default: $text-default;\\n text-secondary-interactive: $text-secondary-interactive;\\n text-lighter: $text-lighter;\\n text-inactive: $text-inactive;\\n stroke: $stroke;\\n stroke-light: $stroke-light;\\n background-darkest: $background-darkest;\\n background-dark: $background-dark;\\n background-medium: $background-medium;\\n background-light: $background-light;\\n color-focus: $color-focus;\\n colors-0: $blue-500;\\n colors-1: $petrol-500;\\n colors-2: $yellow-500;\\n colors-3: $magenta-500;\\n colors-4: $purple-500;\\n colors-5: $blue-300;\\n colors-6: $purple-200;\\n colors-7: $magenta-800;\\n colors-8: $petrol-600;\\n colors-9: $yellow-100;\\n colors-10: $yellow-400;\\n colors-11: $purple-400;\\n colors-12: $blue-200;\\n colors-13: $magenta-200;\\n colors-14: $petrol-300;\\n colors-15: $magenta-400;\\n colors-16: $purple-800;\\n colors-17: $yellow-700;\\n colors-18: $purple-300;\\n colors-19: $petrol-800;\\n colors-20: $yellow-200;\\n colors-21: $blue-400;\\n colors-22: $magenta-100;\\n colors-23: $petrol-700;\\n colors-24: $purple-100;\\n colors-25: $magenta-600;\\n colors-26: $petrol-100;\\n colors-27: $yellow-300;\\n colors-28: $blue-100;\\n colors-29: $purple-700;\\n}\\n\\n/* stylelint-enable */\\n\",\"@import url('https://fonts.googleapis.com/css2?family=Lato:wght@400;700&display=swap');\\n\\n$font-primary: 'Lato', sans-serif;\\n$font-weight-heavy: 700;\\n\\n/* Design System Jan 2020 */\\n\\n$body-baseline: 16px;\\n$intro-text: 18px;\\n$micro: 12px;\\n$caption: 14px;\\n$giant: 48px;\\n$h1: 32px;\\n$h1-tablet: 28px;\\n$h2: 28px;\\n$h2-tablet: 24px;\\n$h3: 24px;\\n$h3-tablet: 20px;\\n$h4: 20px;\\n\\n/* stylelint-disable */\\n:export {\\n font-primary: $font-primary;\\n micro: $micro;\\n caption: $caption;\\n}\\n/* stylelint-enable */\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nvar _1 = `\"Lato\",sans-serif`;\nexport { _1 as \"font-primary\" };\nexport var micro = `12px`;\nexport var caption = `14px`;\nvar _2 = `#cf4800`;\nexport { _2 as \"brand-darkorange\" };\nvar _3 = `#e55a00`;\nexport { _3 as \"brand-brightorange\" };\nvar _4 = `#fdf6f2`;\nexport { _4 as \"brand-superlightorange\" };\nvar _5 = `#414752`;\nexport { _5 as \"grey-800\" };\nvar _6 = `#5c626e`;\nexport { _6 as \"grey-700\" };\nvar _7 = `#6f7582`;\nexport { _7 as \"grey-600\" };\nvar _8 = `#9499a3`;\nexport { _8 as \"grey-500\" };\nvar _9 = `#bbc0c9`;\nexport { _9 as \"grey-400\" };\nvar _a = `#dadde3`;\nexport { _a as \"grey-300\" };\nvar _b = `#ebecf0`;\nexport { _b as \"grey-200\" };\nvar _c = `#f5f6f7`;\nexport { _c as \"grey-100\" };\nexport var white = `#fff`;\nexport var green = `#167922`;\nexport var red = `#bc1c0e`;\nvar _d = `#2b4c9b`;\nexport { _d as \"blue-800\" };\nvar _e = `#3456a6`;\nexport { _e as \"blue-700\" };\nvar _f = `#3c60b3`;\nexport { _f as \"blue-600\" };\nvar _10 = `#4368bd`;\nexport { _10 as \"blue-500\" };\nvar _11 = `#6480c3`;\nexport { _11 as \"blue-400\" };\nvar _12 = `#879bcc`;\nexport { _12 as \"blue-300\" };\nvar _13 = `#afbbdb`;\nexport { _13 as \"blue-200\" };\nvar _14 = `#dbe0eb`;\nexport { _14 as \"blue-100\" };\nvar _15 = `#428a81`;\nexport { _15 as \"petrol-800\" };\nvar _16 = `#4b9a91`;\nexport { _16 as \"petrol-700\" };\nvar _17 = `#4da9a1`;\nexport { _17 as \"petrol-600\" };\nvar _18 = `#54b9b1`;\nexport { _18 as \"petrol-500\" };\nvar _19 = `#63c8c2`;\nexport { _19 as \"petrol-400\" };\nvar _1a = `#81d7d3`;\nexport { _1a as \"petrol-300\" };\nvar _1b = `#b2edeb`;\nexport { _1b as \"petrol-200\" };\nvar _1c = `#e2ffff`;\nexport { _1c as \"petrol-100\" };\nvar _1d = `#97254f`;\nexport { _1d as \"magenta-800\" };\nvar _1e = `#ac2b55`;\nexport { _1e as \"magenta-700\" };\nvar _1f = `#c02d58`;\nexport { _1f as \"magenta-600\" };\nvar _20 = `#d2335f`;\nexport { _20 as \"magenta-500\" };\nvar _21 = `#d44a73`;\nexport { _21 as \"magenta-400\" };\nvar _22 = `#d76789`;\nexport { _22 as \"magenta-300\" };\nvar _23 = `#da91a7`;\nexport { _23 as \"magenta-200\" };\nvar _24 = `#ddbbc5`;\nexport { _24 as \"magenta-100\" };\nvar _25 = `#ee7c24`;\nexport { _25 as \"yellow-800\" };\nvar _26 = `#f58a27`;\nexport { _26 as \"yellow-700\" };\nvar _27 = `#fa9a2a`;\nexport { _27 as \"yellow-600\" };\nvar _28 = `#ffa52f`;\nexport { _28 as \"yellow-500\" };\nvar _29 = `#fdb244`;\nexport { _29 as \"yellow-400\" };\nvar _2a = `#fdc166`;\nexport { _2a as \"yellow-300\" };\nvar _2b = `#fed79a`;\nexport { _2b as \"yellow-200\" };\nvar _2c = `#ffebcc`;\nexport { _2c as \"yellow-100\" };\nvar _2d = `#167922`;\nexport { _2d as \"green-800\" };\nvar _2e = `#24892c`;\nexport { _2e as \"green-700\" };\nvar _2f = `#329d38`;\nexport { _2f as \"green-600\" };\nvar _30 = `#3dad42`;\nexport { _30 as \"green-500\" };\nvar _31 = `#59b75b`;\nexport { _31 as \"green-400\" };\nvar _32 = `#73c375`;\nexport { _32 as \"green-300\" };\nvar _33 = `#98d299`;\nexport { _33 as \"green-200\" };\nvar _34 = `#bde5bd`;\nexport { _34 as \"green-100\" };\nvar _35 = `#8f0001`;\nexport { _35 as \"red-800\" };\nvar _36 = `#9b0009`;\nexport { _36 as \"red-700\" };\nvar _37 = `#ad0e0e`;\nexport { _37 as \"red-600\" };\nvar _38 = `#bc1c0e`;\nexport { _38 as \"red-500\" };\nvar _39 = `#ba302a`;\nexport { _39 as \"red-400\" };\nvar _3a = `#b0504c`;\nexport { _3a as \"red-300\" };\nvar _3b = `#bb7471`;\nexport { _3b as \"red-200\" };\nvar _3c = `#cba6a8`;\nexport { _3c as \"red-100\" };\nvar _3d = `#5c399b`;\nexport { _3d as \"purple-800\" };\nvar _3e = `#673fa2`;\nexport { _3e as \"purple-700\" };\nvar _3f = `#7249ad`;\nexport { _3f as \"purple-600\" };\nvar _40 = `#7b4db3`;\nexport { _40 as \"purple-500\" };\nvar _41 = `#8d69bb`;\nexport { _41 as \"purple-400\" };\nvar _42 = `#a387c8`;\nexport { _42 as \"purple-300\" };\nvar _43 = `#bfb0d4`;\nexport { _43 as \"purple-200\" };\nvar _44 = `#ddd8e4`;\nexport { _44 as \"purple-100\" };\nvar _45 = `#171a1c`;\nexport { _45 as \"ext-grey-800\" };\nvar _46 = `#3b4145`;\nexport { _46 as \"ext-grey-700\" };\nvar _47 = `#535d63`;\nexport { _47 as \"ext-grey-600\" };\nvar _48 = `#6a757c`;\nexport { _48 as \"ext-grey-500\" };\nvar _49 = `#7f888e`;\nexport { _49 as \"ext-grey-400\" };\nvar _4a = `#9fa7ad`;\nexport { _4a as \"ext-grey-300\" };\nvar _4b = `#c0c5c8`;\nexport { _4b as \"ext-grey-200\" };\nvar _4c = `#d6d9dc`;\nexport { _4c as \"ext-grey-100\" };\nvar _4d = `#167922`;\nexport { _4d as \"ui-green\" };\nvar _4e = `#bc1c0e`;\nexport { _4e as \"ui-red\" };\nvar _4f = `#323842`;\nexport { _4f as \"text-heading\" };\nvar _50 = `#414752`;\nexport { _50 as \"text-default\" };\nvar _51 = `#5c626e`;\nexport { _51 as \"text-secondary-interactive\" };\nvar _52 = `#6f7582`;\nexport { _52 as \"text-lighter\" };\nvar _53 = `#9499a3`;\nexport { _53 as \"text-inactive\" };\nexport var stroke = `#bbc0c9`;\nvar _54 = `#dadde3`;\nexport { _54 as \"stroke-light\" };\nvar _55 = `#6f7582`;\nexport { _55 as \"background-darkest\" };\nvar _56 = `#dadde3`;\nexport { _56 as \"background-dark\" };\nvar _57 = `#ebecf0`;\nexport { _57 as \"background-medium\" };\nvar _58 = `#f5f6f7`;\nexport { _58 as \"background-light\" };\nvar _59 = `#fed79a`;\nexport { _59 as \"color-focus\" };\nvar _5a = `#4368bd`;\nexport { _5a as \"colors-0\" };\nvar _5b = `#54b9b1`;\nexport { _5b as \"colors-1\" };\nvar _5c = `#ffa52f`;\nexport { _5c as \"colors-2\" };\nvar _5d = `#d2335f`;\nexport { _5d as \"colors-3\" };\nvar _5e = `#7b4db3`;\nexport { _5e as \"colors-4\" };\nvar _5f = `#879bcc`;\nexport { _5f as \"colors-5\" };\nvar _60 = `#bfb0d4`;\nexport { _60 as \"colors-6\" };\nvar _61 = `#97254f`;\nexport { _61 as \"colors-7\" };\nvar _62 = `#4da9a1`;\nexport { _62 as \"colors-8\" };\nvar _63 = `#ffebcc`;\nexport { _63 as \"colors-9\" };\nvar _64 = `#fdb244`;\nexport { _64 as \"colors-10\" };\nvar _65 = `#8d69bb`;\nexport { _65 as \"colors-11\" };\nvar _66 = `#afbbdb`;\nexport { _66 as \"colors-12\" };\nvar _67 = `#da91a7`;\nexport { _67 as \"colors-13\" };\nvar _68 = `#81d7d3`;\nexport { _68 as \"colors-14\" };\nvar _69 = `#d44a73`;\nexport { _69 as \"colors-15\" };\nvar _6a = `#5c399b`;\nexport { _6a as \"colors-16\" };\nvar _6b = `#f58a27`;\nexport { _6b as \"colors-17\" };\nvar _6c = `#a387c8`;\nexport { _6c as \"colors-18\" };\nvar _6d = `#428a81`;\nexport { _6d as \"colors-19\" };\nvar _6e = `#fed79a`;\nexport { _6e as \"colors-20\" };\nvar _6f = `#6480c3`;\nexport { _6f as \"colors-21\" };\nvar _70 = `#ddbbc5`;\nexport { _70 as \"colors-22\" };\nvar _71 = `#4b9a91`;\nexport { _71 as \"colors-23\" };\nvar _72 = `#ddd8e4`;\nexport { _72 as \"colors-24\" };\nvar _73 = `#c02d58`;\nexport { _73 as \"colors-25\" };\nvar _74 = `#e2ffff`;\nexport { _74 as \"colors-26\" };\nvar _75 = `#fdc166`;\nexport { _75 as \"colors-27\" };\nvar _76 = `#dbe0eb`;\nexport { _76 as \"colors-28\" };\nvar _77 = `#673fa2`;\nexport { _77 as \"colors-29\" };\nexport var Wrapper = `index-module__Wrapper--vZBrx`;\nexport var Content = `index-module__Content--ZB20L`;\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"./slide-consumer-4.jpg\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.slide-container{text-align:center;width:100%}.consumerImage-4{background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-position:center;background-size:cover;width:100%;height:300px;position:relative;top:-8px}.header-actionable{font-size:18px;font-weight:bold}.subheader-consumer-4{overflow:hidden;text-overflow:initial;white-space:normal;padding:0 24px;height:3em}.productConsumer{margin-top:8px}`, \"\",{\"version\":3,\"sources\":[\"webpack://./src/components/OnboardingGuide/actionable-data-slide/ActionableDataSlide.scss\"],\"names\":[],\"mappings\":\"AAAA,iBACE,iBAAA,CACA,UAAA,CAGF,iBACE,wDAAA,CACA,0BAAA,CACA,qBAAA,CACA,UAAA,CACA,YAAA,CACA,iBAAA,CACA,QAAA,CAGF,mBACE,cAAA,CACA,gBAAA,CAGF,sBACE,eAAA,CACA,qBAAA,CACA,kBAAA,CACA,cAAA,CACA,UAAA,CAGF,iBACE,cAAA\",\"sourcesContent\":[\".slide-container {\\n text-align: center;\\n width: 100%;\\n}\\n\\n.consumerImage-4 {\\n background-image: url('./slide-consumer-4.jpg');\\n background-position: center;\\n background-size: cover;\\n width: 100%;\\n height: 300px;\\n position: relative;\\n top: -8px;\\n}\\n\\n.header-actionable {\\n font-size: 18px;\\n font-weight: bold;\\n}\\n\\n.subheader-consumer-4 {\\n overflow: hidden;\\n text-overflow: initial;\\n white-space: normal;\\n padding: 0 24px;\\n height: 3em;\\n}\\n\\n.productConsumer {\\n margin-top: 8px;\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"./slide-consumer-3.jpg\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.slide-container{text-align:center;width:100%}.consumerImage-3{background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-position:center;background-size:cover;width:100%;height:300px;position:relative;top:-8px}.header-consumer-3{font-size:18px;font-weight:bold}.subheader-consumer-3{overflow:hidden;text-overflow:initial;white-space:normal;padding:0 24px}.productConsumer{margin-top:8px}`, \"\",{\"version\":3,\"sources\":[\"webpack://./src/components/OnboardingGuide/focus-matters-slide/FocusMattersSlide.scss\"],\"names\":[],\"mappings\":\"AAAA,iBACE,iBAAA,CACA,UAAA,CAGF,iBACE,wDAAA,CACA,0BAAA,CACA,qBAAA,CACA,UAAA,CACA,YAAA,CACA,iBAAA,CACA,QAAA,CAGF,mBACE,cAAA,CACA,gBAAA,CAGF,sBACE,eAAA,CACA,qBAAA,CACA,kBAAA,CACA,cAAA,CAGF,iBACE,cAAA\",\"sourcesContent\":[\".slide-container {\\n text-align: center;\\n width: 100%;\\n}\\n\\n.consumerImage-3 {\\n background-image: url('./slide-consumer-3.jpg');\\n background-position: center;\\n background-size: cover;\\n width: 100%;\\n height: 300px;\\n position: relative;\\n top: -8px;\\n}\\n\\n.header-consumer-3 {\\n font-size: 18px;\\n font-weight: bold;\\n}\\n\\n.subheader-consumer-3 {\\n overflow: hidden;\\n text-overflow: initial;\\n white-space: normal;\\n padding: 0 24px;\\n}\\n\\n.productConsumer {\\n margin-top: 8px;\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"./slide-consumer-2.jpg\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.slide-container{text-align:center;width:100%}.consumerImage-2{background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-position:center;background-size:cover;width:100%;height:300px;position:relative;top:-8px}.header-consumer-2{font-size:18px;font-weight:bold}.subheader-consumer-2{overflow:hidden;text-overflow:initial;white-space:normal;padding:0 24px}.productConsumer{margin-top:8px}`, \"\",{\"version\":3,\"sources\":[\"webpack://./src/components/OnboardingGuide/millions-shoppers-slide/MillionsShoppersSlide.scss\"],\"names\":[],\"mappings\":\"AAAA,iBACE,iBAAA,CACA,UAAA,CAGF,iBACE,wDAAA,CACA,0BAAA,CACA,qBAAA,CACA,UAAA,CACA,YAAA,CACA,iBAAA,CACA,QAAA,CAGF,mBACE,cAAA,CACA,gBAAA,CAGF,sBACE,eAAA,CACA,qBAAA,CACA,kBAAA,CACA,cAAA,CAGF,iBACE,cAAA\",\"sourcesContent\":[\".slide-container {\\n text-align: center;\\n width: 100%;\\n}\\n\\n.consumerImage-2 {\\n background-image: url('./slide-consumer-2.jpg');\\n background-position: center;\\n background-size: cover;\\n width: 100%;\\n height: 300px;\\n position: relative;\\n top: -8px;\\n}\\n\\n.header-consumer-2 {\\n font-size: 18px;\\n font-weight: bold;\\n}\\n\\n.subheader-consumer-2 {\\n overflow: hidden;\\n text-overflow: initial;\\n white-space: normal;\\n padding: 0 24px;\\n}\\n\\n.productConsumer {\\n margin-top: 8px;\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"./slide-consumer-1.jpg\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.slide-container{text-align:center;width:100%}.consumerImage{background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-position:center;background-size:cover;width:100%;height:300px;position:relative;top:-8px}.header-consumer-1{font-size:18px;font-weight:bold}.subheader-consumer-1{overflow:hidden;text-overflow:initial;white-space:normal;padding:0 24px}.productConsumer{margin-top:8px}`, \"\",{\"version\":3,\"sources\":[\"webpack://./src/components/OnboardingGuide/selling-starts-slide/SellingStartsSlide.scss\"],\"names\":[],\"mappings\":\"AAAA,iBACE,iBAAA,CACA,UAAA,CAGF,eACE,wDAAA,CACA,0BAAA,CACA,qBAAA,CACA,UAAA,CACA,YAAA,CACA,iBAAA,CACA,QAAA,CAGF,mBACE,cAAA,CACA,gBAAA,CAGF,sBACE,eAAA,CACA,qBAAA,CACA,kBAAA,CACA,cAAA,CAGF,iBACE,cAAA\",\"sourcesContent\":[\".slide-container {\\n text-align: center;\\n width: 100%;\\n}\\n\\n.consumerImage {\\n background-image: url('./slide-consumer-1.jpg');\\n background-position: center;\\n background-size: cover;\\n width: 100%;\\n height: 300px;\\n position: relative;\\n top: -8px;\\n}\\n\\n.header-consumer-1 {\\n font-size: 18px;\\n font-weight: bold;\\n}\\n\\n.subheader-consumer-1 {\\n overflow: hidden;\\n text-overflow: initial;\\n white-space: normal;\\n padding: 0 24px;\\n}\\n\\n.productConsumer {\\n margin-top: 8px;\\n}\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_SOURCEMAP_IMPORT___ from \"../../../node_modules/css-loader/dist/runtime/sourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_SOURCEMAP_IMPORT___);\n___CSS_LOADER_EXPORT___.push([module.id, \"@import url(https://fonts.googleapis.com/css2?family=Lato:wght@400;700&display=swap);\"]);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.index-module__ConfirmationModal__Criteria--l2XfU{margin-bottom:48px}.index-module__ConfirmationModal__Criteria__Title--zWQm2{font-size:12px;font-weight:700;margin-right:8px;margin-bottom:4px}.index-module__ConfirmationModal__Criteria__Filters--odqi9{margin-top:8px}.index-module__ConfirmationModal__Icon--AbovX{display:flex !important;align-items:center;margin-right:10px}.index-module__ConfirmationModal__Content--nZaYU{border:1px solid #dadde3;border-radius:8px;padding:16px 24px;max-height:150px;overflow-y:auto;margin-top:16px}.index-module__ConfirmationModal__Filters--L3sKy{font-family:\"Lato\",sans-serif;font-style:normal;font-weight:bold;font-size:12px;color:#5c626e;margin-top:10px}`, \"\",{\"version\":3,\"sources\":[\"webpack://./src/util/confirmation/index.module.scss\",\"webpack://./node_modules/@ecosystem/ui-lib/core/styles/base/_fonts.scss\",\"webpack://./node_modules/@ecosystem/ui-lib/core/styles/base/_spacing.scss\",\"webpack://./node_modules/@ecosystem/ui-lib/core/styles/base/_sizes.scss\",\"webpack://./node_modules/@ecosystem/ui-lib/core/styles/themes/ecosystem-default/_colors.scss\"],\"names\":[],\"mappings\":\"AAME,kDACE,kBAAA,CAEA,yDACE,cCDE,CDEF,eCRc,CDSd,gBEVS,CFWT,iBEZU,CFeZ,2DACE,cEfS,CFkBb,8CACE,uBAAA,CACA,kBAAA,CACA,iBAAA,CAEF,iDACE,wBAAA,CACA,iBG1BkB,CH2BlB,iBAAA,CACA,gBAAA,CACA,eAAA,CACA,eE3BY,CF6Bd,iDACE,6BChCW,CDiCX,iBAAA,CACA,gBAAA,CACA,cAAA,CACA,aI5BO,CJ6BP,eAAA\",\"sourcesContent\":[\"@import '~@ecosystem/ui-lib/core/styles/base/fonts';\\n@import '~@ecosystem/ui-lib/core/styles/base/spacing';\\n@import '~@ecosystem/ui-lib/core/styles/base/sizes';\\n@import '~@ecosystem/ui-lib/core/styles/themes/ecosystem-default/colors';\\n\\n.ConfirmationModal {\\n &__Criteria {\\n margin-bottom: $spacing-large;\\n\\n &__Title {\\n font-size: $micro;\\n font-weight: $font-weight-heavy;\\n margin-right: $spacing-tiny;\\n margin-bottom: $spacing-micro;\\n }\\n\\n &__Filters {\\n margin-top: $spacing-tiny;\\n }\\n }\\n &__Icon {\\n display: flex !important;\\n align-items: center;\\n margin-right: 10px;\\n }\\n &__Content {\\n border: 1px solid $stroke-light;\\n border-radius: $border-radius-large;\\n padding: 16px 24px;\\n max-height: 150px;\\n overflow-y: auto;\\n margin-top: $spacing-small;\\n }\\n &__Filters {\\n font-family: $font-primary;\\n font-style: normal;\\n font-weight: bold;\\n font-size: 12px;\\n color: $grey-700;\\n margin-top: 10px;\\n }\\n}\\n\",\"@import url('https://fonts.googleapis.com/css2?family=Lato:wght@400;700&display=swap');\\n\\n$font-primary: 'Lato', sans-serif;\\n$font-weight-heavy: 700;\\n\\n/* Design System Jan 2020 */\\n\\n$body-baseline: 16px;\\n$intro-text: 18px;\\n$micro: 12px;\\n$caption: 14px;\\n$giant: 48px;\\n$h1: 32px;\\n$h1-tablet: 28px;\\n$h2: 28px;\\n$h2-tablet: 24px;\\n$h3: 24px;\\n$h3-tablet: 20px;\\n$h4: 20px;\\n\\n/* stylelint-disable */\\n:export {\\n font-primary: $font-primary;\\n micro: $micro;\\n caption: $caption;\\n}\\n/* stylelint-enable */\\n\",\"$spacing-nano: 2px;\\n$spacing-micro: 4px;\\n$spacing-tiny: 8px;\\n$spacing-smallest: 12px;\\n$spacing-small: 16px;\\n$spacing-standard: 24px;\\n$spacing-semi: 32px;\\n$spacing-large: 48px;\\n$spacing-xlarge: 64px;\\n\",\"$border-radius: 4px;\\n$border-radius-large: 8px;\\n\\n$widget-height: 30vh;\\n$widget-width: 100%;\\n\\n$context-bar-height: 62px;\\n$context-bar-width: 100%;\\n\\n$ecosystem-header-height: 78px;\\n$ecosystem-footer-height: 76px;\\n\\n$desktop-width: 1366px;\\n$desktop-width-medium: 1440px;\\n$desktop-width-large: 1680px;\\n$desktop-width-extra-large: 1920px;\\n$tablet-portrait-width: 768px;\\n\\n$media-desktop: 'only screen and (min-width: #{$desktop-width})';\\n$media-desktop-medium: 'only screen and (min-width: #{$desktop-width-medium})';\\n$media-desktop-large: 'only screen and (min-width: #{$desktop-width-large})';\\n$media-desktop-extra-large: 'only screen and (min-width: #{$desktop-width-extra-large})';\\n\",\"/* stylelint-disable color-no-hex */\\n\\n/* new pallete from march 2021*/\\n/* ui colors */\\n$brand-darkorange: #cf4800;\\n$brand-brightorange: #e55a00;\\n$brand-lightorange: #fdefe6;\\n$brand-superlightorange: #fdf6f2;\\n$grey-900: #323842;\\n$grey-800: #414752;\\n$grey-700: #5c626e;\\n$grey-600: #6f7582;\\n$grey-500: #9499a3;\\n$grey-400: #bbc0c9;\\n$grey-300: #dadde3;\\n$grey-200: #ebecf0;\\n$grey-100: #f5f6f7;\\n$ui-white: #fff;\\n$ui-green: #167922;\\n$ui-red: #bc1c0e;\\n\\n/* data vis colours */\\n$blue-800: #2b4c9b;\\n$blue-700: #3456a6;\\n$blue-600: #3c60b3;\\n$blue-500: #4368bd;\\n$blue-400: #6480c3;\\n$blue-300: #879bcc;\\n$blue-200: #afbbdb;\\n$blue-100: #dbe0eb;\\n$petrol-800: #428a81;\\n$petrol-700: #4b9a91;\\n$petrol-600: #4da9a1;\\n$petrol-500: #54b9b1;\\n$petrol-400: #63c8c2;\\n$petrol-300: #81d7d3;\\n$petrol-200: #b2edeb;\\n$petrol-100: #e2ffff;\\n$magenta-800: #97254f;\\n$magenta-700: #ac2b55;\\n$magenta-600: #c02d58;\\n$magenta-500: #d2335f;\\n$magenta-400: #d44a73;\\n$magenta-300: #d76789;\\n$magenta-200: #da91a7;\\n$magenta-100: #ddbbc5;\\n$yellow-800: #ee7c24;\\n$yellow-700: #f58a27;\\n$yellow-600: #fa9a2a;\\n$yellow-500: #ffa52f;\\n$yellow-400: #fdb244;\\n$yellow-300: #fdc166;\\n$yellow-200: #fed79a;\\n$yellow-100: #ffebcc;\\n$purple-800: #5c399b;\\n$purple-700: #673fa2;\\n$purple-600: #7249ad;\\n$purple-500: #7b4db3;\\n$purple-400: #8d69bb;\\n$purple-300: #a387c8;\\n$purple-200: #bfb0d4;\\n$purple-100: #ddd8e4;\\n$ext-grey-100: #d6d9dc;\\n$ext-grey-200: #c0c5c8;\\n$ext-grey-300: #9fa7ad;\\n$ext-grey-400: #7f888e;\\n$ext-grey-500: #6a757c;\\n$ext-grey-600: #535d63;\\n$ext-grey-700: #3b4145;\\n$ext-grey-800: #171a1c;\\n$red-100: #cba6a8;\\n$red-200: #bb7471;\\n$red-300: #b0504c;\\n$red-400: #ba302a;\\n$red-500: #bc1c0e;\\n$red-600: #ad0e0e;\\n$red-700: #9b0009;\\n$red-800: #8f0001;\\n$green-100: #bde5bd;\\n$green-200: #98d299;\\n$green-300: #73c375;\\n$green-400: #59b75b;\\n$green-500: #3dad42;\\n$green-600: #329d38;\\n$green-700: #24892c;\\n$green-800: #167922;\\n\\n/* descriptive tokens */\\n$text-heading: $grey-900;\\n$text-default: $grey-800;\\n$text-secondary-interactive: $grey-700;\\n$text-lighter: $grey-600;\\n$text-inactive: $grey-500;\\n$stroke: $grey-400;\\n$stroke-light: $grey-300;\\n$background-darkest: $grey-600;\\n$background-dark: $grey-300;\\n$background-medium: $grey-200;\\n$background-light: $grey-100;\\n$color-focus: $yellow-200;\\n\\n/* end colours from design system */\\n\\n/* need to address these two */\\n$modal-background: rgba(0, 10, 20, 0.5);\\n$brand-brightorange-200: #ffd07c;\\n\\n/* stylelint-enable */\\n\\n$colors: 'brand-darkorange' $brand-darkorange, 'brand-brightorange' $brand-brightorange,\\n 'brand-superlightorange' $brand-superlightorange, 'grey-800' $grey-800, 'grey-700' $grey-700, 'grey-600' $grey-600,\\n 'grey-500' $grey-500, 'grey-400' $grey-400, 'grey-300' $grey-300, 'grey-200' $grey-200, 'grey-100' $grey-100,\\n 'ext-grey-800' $ext-grey-800, 'ext-grey-700' $ext-grey-700, 'ext-grey-600' $ext-grey-600, 'ext-grey-500' $ext-grey-500,\\n 'ext-grey-400' ext-$grey-400, 'ext-grey-300' $ext-grey-300, 'ext-grey-200' $ext-grey-200, 'ext-grey-100' ext-$grey-100,\\n 'white' $ui-white, 'green' $ui-green, 'red' $ui-red, 'blue-800' $blue-800, 'blue-700' $blue-700, 'blue-600' $blue-600,\\n 'blue-500' $blue-500, 'blue-400' $blue-400, 'blue-300' $blue-300, 'blue-200' $blue-200, 'blue-100' $blue-100,\\n 'petrol-800' $petrol-800, 'petrol-700' $petrol-700, 'petrol-600' $petrol-600, 'petrol-500' $petrol-500,\\n 'petrol-400' $petrol-400, 'petrol-300' $petrol-300, 'petrol-200' $petrol-200, 'petrol-100' $petrol-100,\\n 'magenta-800' $magenta-800, 'magenta-700' $magenta-700, 'magenta-600' $magenta-600, 'magenta-500' $magenta-500,\\n 'magenta-400' $magenta-400, 'magenta-300' $magenta-300, 'magenta-200' $magenta-200, 'magenta-100' $magenta-100,\\n 'yellow-800' $yellow-800, 'yellow-700' $yellow-700, 'yellow-600' $yellow-600, 'yellow-500' $yellow-500,\\n 'yellow-400' $yellow-400, 'yellow-300' $yellow-300, 'yellow-200' $yellow-200, 'yellow-100' $yellow-100,\\n 'purple-800' $purple-800, 'purple-700' $purple-700, 'purple-600' $purple-600, 'purple-500' $purple-500,\\n 'purple-400' $purple-400, 'purple-300' $purple-300, 'purple-200' $purple-200, 'purple-100' $purple-100,\\n 'red-800' $red-800, 'red-700' $red-700, 'red-600' $red-600, 'red-500' $red-500, 'red-400' $red-400, 'red-300' $red-300,\\n 'red-200' $red-200, 'red-100' $red-100, 'green-800' $green-800, 'green-700' $green-700, 'green-600' $green-600,\\n 'green-500' $green-500, 'green-400' $green-400, 'green-300' $green-300, 'green-200' $green-200, 'green-100' $green-100,\\n 'ui-green' $ui-green, 'ui-red' $ui-red, 'text-heading' $text-heading, 'text-default' $text-default,\\n 'text-secondary-interactive' $text-secondary-interactive, 'text-lighter' $text-lighter, 'text-inactive' $text-inactive,\\n 'stroke' $stroke, 'stroke-light' $stroke-light, 'background-darkest' $background-darkest,\\n 'background-dark' $background-dark, 'background-medium' $background-medium, 'background-light' $background-light,\\n 'color-focus' $color-focus;\\n\\n/* stylelint-disable */\\n:export {\\n brand-darkorange: $brand-darkorange;\\n brand-brightorange: $brand-brightorange;\\n brand-superlightorange: $brand-superlightorange;\\n grey-800: $grey-800;\\n grey-700: $grey-700;\\n grey-600: $grey-600;\\n grey-500: $grey-500;\\n grey-400: $grey-400;\\n grey-300: $grey-300;\\n grey-200: $grey-200;\\n grey-100: $grey-100;\\n white: $ui-white;\\n green: $ui-green;\\n red: $ui-red;\\n blue-800: $blue-800;\\n blue-700: $blue-700;\\n blue-600: $blue-600;\\n blue-500: $blue-500;\\n blue-400: $blue-400;\\n blue-300: $blue-300;\\n blue-200: $blue-200;\\n blue-100: $blue-100;\\n petrol-800: $petrol-800;\\n petrol-700: $petrol-700;\\n petrol-600: $petrol-600;\\n petrol-500: $petrol-500;\\n petrol-400: $petrol-400;\\n petrol-300: $petrol-300;\\n petrol-200: $petrol-200;\\n petrol-100: $petrol-100;\\n magenta-800: $magenta-800;\\n magenta-700: $magenta-700;\\n magenta-600: $magenta-600;\\n magenta-500: $magenta-500;\\n magenta-400: $magenta-400;\\n magenta-300: $magenta-300;\\n magenta-200: $magenta-200;\\n magenta-100: $magenta-100;\\n yellow-800: $yellow-800;\\n yellow-700: $yellow-700;\\n yellow-600: $yellow-600;\\n yellow-500: $yellow-500;\\n yellow-400: $yellow-400;\\n yellow-300: $yellow-300;\\n yellow-200: $yellow-200;\\n yellow-100: $yellow-100;\\n green-800: $green-800;\\n green-700: $green-700;\\n green-600: $green-600;\\n green-500: $green-500;\\n green-400: $green-400;\\n green-300: $green-300;\\n green-200: $green-200;\\n green-100: $green-100;\\n red-800: $red-800;\\n red-700: $red-700;\\n red-600: $red-600;\\n red-500: $red-500;\\n red-400: $red-400;\\n red-300: $red-300;\\n red-200: $red-200;\\n red-100: $red-100;\\n purple-800: $purple-800;\\n purple-700: $purple-700;\\n purple-600: $purple-600;\\n purple-500: $purple-500;\\n purple-400: $purple-400;\\n purple-300: $purple-300;\\n purple-200: $purple-200;\\n purple-100: $purple-100;\\n ext-grey-800: $ext-grey-800;\\n ext-grey-700: $ext-grey-700;\\n ext-grey-600: $ext-grey-600;\\n ext-grey-500: $ext-grey-500;\\n ext-grey-400: $ext-grey-400;\\n ext-grey-300: $ext-grey-300;\\n ext-grey-200: $ext-grey-200;\\n ext-grey-100: $ext-grey-100;\\n ui-green: $ui-green;\\n ui-red: $ui-red;\\n text-heading: $text-heading;\\n text-default: $text-default;\\n text-secondary-interactive: $text-secondary-interactive;\\n text-lighter: $text-lighter;\\n text-inactive: $text-inactive;\\n stroke: $stroke;\\n stroke-light: $stroke-light;\\n background-darkest: $background-darkest;\\n background-dark: $background-dark;\\n background-medium: $background-medium;\\n background-light: $background-light;\\n color-focus: $color-focus;\\n colors-0: $blue-500;\\n colors-1: $petrol-500;\\n colors-2: $yellow-500;\\n colors-3: $magenta-500;\\n colors-4: $purple-500;\\n colors-5: $blue-300;\\n colors-6: $purple-200;\\n colors-7: $magenta-800;\\n colors-8: $petrol-600;\\n colors-9: $yellow-100;\\n colors-10: $yellow-400;\\n colors-11: $purple-400;\\n colors-12: $blue-200;\\n colors-13: $magenta-200;\\n colors-14: $petrol-300;\\n colors-15: $magenta-400;\\n colors-16: $purple-800;\\n colors-17: $yellow-700;\\n colors-18: $purple-300;\\n colors-19: $petrol-800;\\n colors-20: $yellow-200;\\n colors-21: $blue-400;\\n colors-22: $magenta-100;\\n colors-23: $petrol-700;\\n colors-24: $purple-100;\\n colors-25: $magenta-600;\\n colors-26: $petrol-100;\\n colors-27: $yellow-300;\\n colors-28: $blue-100;\\n colors-29: $purple-700;\\n}\\n\\n/* stylelint-enable */\\n\"],\"sourceRoot\":\"\"}]);\n// Exports\nvar _1 = `\"Lato\",sans-serif`;\nexport { _1 as \"font-primary\" };\nexport var micro = `12px`;\nexport var caption = `14px`;\nvar _2 = `#cf4800`;\nexport { _2 as \"brand-darkorange\" };\nvar _3 = `#e55a00`;\nexport { _3 as \"brand-brightorange\" };\nvar _4 = `#fdf6f2`;\nexport { _4 as \"brand-superlightorange\" };\nvar _5 = `#414752`;\nexport { _5 as \"grey-800\" };\nvar _6 = `#5c626e`;\nexport { _6 as \"grey-700\" };\nvar _7 = `#6f7582`;\nexport { _7 as \"grey-600\" };\nvar _8 = `#9499a3`;\nexport { _8 as \"grey-500\" };\nvar _9 = `#bbc0c9`;\nexport { _9 as \"grey-400\" };\nvar _a = `#dadde3`;\nexport { _a as \"grey-300\" };\nvar _b = `#ebecf0`;\nexport { _b as \"grey-200\" };\nvar _c = `#f5f6f7`;\nexport { _c as \"grey-100\" };\nexport var white = `#fff`;\nexport var green = `#167922`;\nexport var red = `#bc1c0e`;\nvar _d = `#2b4c9b`;\nexport { _d as \"blue-800\" };\nvar _e = `#3456a6`;\nexport { _e as \"blue-700\" };\nvar _f = `#3c60b3`;\nexport { _f as \"blue-600\" };\nvar _10 = `#4368bd`;\nexport { _10 as \"blue-500\" };\nvar _11 = `#6480c3`;\nexport { _11 as \"blue-400\" };\nvar _12 = `#879bcc`;\nexport { _12 as \"blue-300\" };\nvar _13 = `#afbbdb`;\nexport { _13 as \"blue-200\" };\nvar _14 = `#dbe0eb`;\nexport { _14 as \"blue-100\" };\nvar _15 = `#428a81`;\nexport { _15 as \"petrol-800\" };\nvar _16 = `#4b9a91`;\nexport { _16 as \"petrol-700\" };\nvar _17 = `#4da9a1`;\nexport { _17 as \"petrol-600\" };\nvar _18 = `#54b9b1`;\nexport { _18 as \"petrol-500\" };\nvar _19 = `#63c8c2`;\nexport { _19 as \"petrol-400\" };\nvar _1a = `#81d7d3`;\nexport { _1a as \"petrol-300\" };\nvar _1b = `#b2edeb`;\nexport { _1b as \"petrol-200\" };\nvar _1c = `#e2ffff`;\nexport { _1c as \"petrol-100\" };\nvar _1d = `#97254f`;\nexport { _1d as \"magenta-800\" };\nvar _1e = `#ac2b55`;\nexport { _1e as \"magenta-700\" };\nvar _1f = `#c02d58`;\nexport { _1f as \"magenta-600\" };\nvar _20 = `#d2335f`;\nexport { _20 as \"magenta-500\" };\nvar _21 = `#d44a73`;\nexport { _21 as \"magenta-400\" };\nvar _22 = `#d76789`;\nexport { _22 as \"magenta-300\" };\nvar _23 = `#da91a7`;\nexport { _23 as \"magenta-200\" };\nvar _24 = `#ddbbc5`;\nexport { _24 as \"magenta-100\" };\nvar _25 = `#ee7c24`;\nexport { _25 as \"yellow-800\" };\nvar _26 = `#f58a27`;\nexport { _26 as \"yellow-700\" };\nvar _27 = `#fa9a2a`;\nexport { _27 as \"yellow-600\" };\nvar _28 = `#ffa52f`;\nexport { _28 as \"yellow-500\" };\nvar _29 = `#fdb244`;\nexport { _29 as \"yellow-400\" };\nvar _2a = `#fdc166`;\nexport { _2a as \"yellow-300\" };\nvar _2b = `#fed79a`;\nexport { _2b as \"yellow-200\" };\nvar _2c = `#ffebcc`;\nexport { _2c as \"yellow-100\" };\nvar _2d = `#167922`;\nexport { _2d as \"green-800\" };\nvar _2e = `#24892c`;\nexport { _2e as \"green-700\" };\nvar _2f = `#329d38`;\nexport { _2f as \"green-600\" };\nvar _30 = `#3dad42`;\nexport { _30 as \"green-500\" };\nvar _31 = `#59b75b`;\nexport { _31 as \"green-400\" };\nvar _32 = `#73c375`;\nexport { _32 as \"green-300\" };\nvar _33 = `#98d299`;\nexport { _33 as \"green-200\" };\nvar _34 = `#bde5bd`;\nexport { _34 as \"green-100\" };\nvar _35 = `#8f0001`;\nexport { _35 as \"red-800\" };\nvar _36 = `#9b0009`;\nexport { _36 as \"red-700\" };\nvar _37 = `#ad0e0e`;\nexport { _37 as \"red-600\" };\nvar _38 = `#bc1c0e`;\nexport { _38 as \"red-500\" };\nvar _39 = `#ba302a`;\nexport { _39 as \"red-400\" };\nvar _3a = `#b0504c`;\nexport { _3a as \"red-300\" };\nvar _3b = `#bb7471`;\nexport { _3b as \"red-200\" };\nvar _3c = `#cba6a8`;\nexport { _3c as \"red-100\" };\nvar _3d = `#5c399b`;\nexport { _3d as \"purple-800\" };\nvar _3e = `#673fa2`;\nexport { _3e as \"purple-700\" };\nvar _3f = `#7249ad`;\nexport { _3f as \"purple-600\" };\nvar _40 = `#7b4db3`;\nexport { _40 as \"purple-500\" };\nvar _41 = `#8d69bb`;\nexport { _41 as \"purple-400\" };\nvar _42 = `#a387c8`;\nexport { _42 as \"purple-300\" };\nvar _43 = `#bfb0d4`;\nexport { _43 as \"purple-200\" };\nvar _44 = `#ddd8e4`;\nexport { _44 as \"purple-100\" };\nvar _45 = `#171a1c`;\nexport { _45 as \"ext-grey-800\" };\nvar _46 = `#3b4145`;\nexport { _46 as \"ext-grey-700\" };\nvar _47 = `#535d63`;\nexport { _47 as \"ext-grey-600\" };\nvar _48 = `#6a757c`;\nexport { _48 as \"ext-grey-500\" };\nvar _49 = `#7f888e`;\nexport { _49 as \"ext-grey-400\" };\nvar _4a = `#9fa7ad`;\nexport { _4a as \"ext-grey-300\" };\nvar _4b = `#c0c5c8`;\nexport { _4b as \"ext-grey-200\" };\nvar _4c = `#d6d9dc`;\nexport { _4c as \"ext-grey-100\" };\nvar _4d = `#167922`;\nexport { _4d as \"ui-green\" };\nvar _4e = `#bc1c0e`;\nexport { _4e as \"ui-red\" };\nvar _4f = `#323842`;\nexport { _4f as \"text-heading\" };\nvar _50 = `#414752`;\nexport { _50 as \"text-default\" };\nvar _51 = `#5c626e`;\nexport { _51 as \"text-secondary-interactive\" };\nvar _52 = `#6f7582`;\nexport { _52 as \"text-lighter\" };\nvar _53 = `#9499a3`;\nexport { _53 as \"text-inactive\" };\nexport var stroke = `#bbc0c9`;\nvar _54 = `#dadde3`;\nexport { _54 as \"stroke-light\" };\nvar _55 = `#6f7582`;\nexport { _55 as \"background-darkest\" };\nvar _56 = `#dadde3`;\nexport { _56 as \"background-dark\" };\nvar _57 = `#ebecf0`;\nexport { _57 as \"background-medium\" };\nvar _58 = `#f5f6f7`;\nexport { _58 as \"background-light\" };\nvar _59 = `#fed79a`;\nexport { _59 as \"color-focus\" };\nvar _5a = `#4368bd`;\nexport { _5a as \"colors-0\" };\nvar _5b = `#54b9b1`;\nexport { _5b as \"colors-1\" };\nvar _5c = `#ffa52f`;\nexport { _5c as \"colors-2\" };\nvar _5d = `#d2335f`;\nexport { _5d as \"colors-3\" };\nvar _5e = `#7b4db3`;\nexport { _5e as \"colors-4\" };\nvar _5f = `#879bcc`;\nexport { _5f as \"colors-5\" };\nvar _60 = `#bfb0d4`;\nexport { _60 as \"colors-6\" };\nvar _61 = `#97254f`;\nexport { _61 as \"colors-7\" };\nvar _62 = `#4da9a1`;\nexport { _62 as \"colors-8\" };\nvar _63 = `#ffebcc`;\nexport { _63 as \"colors-9\" };\nvar _64 = `#fdb244`;\nexport { _64 as \"colors-10\" };\nvar _65 = `#8d69bb`;\nexport { _65 as \"colors-11\" };\nvar _66 = `#afbbdb`;\nexport { _66 as \"colors-12\" };\nvar _67 = `#da91a7`;\nexport { _67 as \"colors-13\" };\nvar _68 = `#81d7d3`;\nexport { _68 as \"colors-14\" };\nvar _69 = `#d44a73`;\nexport { _69 as \"colors-15\" };\nvar _6a = `#5c399b`;\nexport { _6a as \"colors-16\" };\nvar _6b = `#f58a27`;\nexport { _6b as \"colors-17\" };\nvar _6c = `#a387c8`;\nexport { _6c as \"colors-18\" };\nvar _6d = `#428a81`;\nexport { _6d as \"colors-19\" };\nvar _6e = `#fed79a`;\nexport { _6e as \"colors-20\" };\nvar _6f = `#6480c3`;\nexport { _6f as \"colors-21\" };\nvar _70 = `#ddbbc5`;\nexport { _70 as \"colors-22\" };\nvar _71 = `#4b9a91`;\nexport { _71 as \"colors-23\" };\nvar _72 = `#ddd8e4`;\nexport { _72 as \"colors-24\" };\nvar _73 = `#c02d58`;\nexport { _73 as \"colors-25\" };\nvar _74 = `#e2ffff`;\nexport { _74 as \"colors-26\" };\nvar _75 = `#fdc166`;\nexport { _75 as \"colors-27\" };\nvar _76 = `#dbe0eb`;\nexport { _76 as \"colors-28\" };\nvar _77 = `#673fa2`;\nexport { _77 as \"colors-29\" };\nexport var ConfirmationModal__Criteria = `index-module__ConfirmationModal__Criteria--l2XfU`;\nexport var ConfirmationModal__Criteria__Title = `index-module__ConfirmationModal__Criteria__Title--zWQm2`;\nexport var ConfirmationModal__Criteria__Filters = `index-module__ConfirmationModal__Criteria__Filters--odqi9`;\nexport var ConfirmationModal__Icon = `index-module__ConfirmationModal__Icon--AbovX`;\nexport var ConfirmationModal__Content = `index-module__ConfirmationModal__Content--nZaYU`;\nexport var ConfirmationModal__Filters = `index-module__ConfirmationModal__Filters--L3sKy`;\nexport default ___CSS_LOADER_EXPORT___;\n","\"use strict\";\n\n/*\n MIT License http://www.opensource.org/licenses/mit-license.php\n Author Tobias Koppers @sokra\n*/\nmodule.exports = function (cssWithMappingToString) {\n var list = [];\n\n // return the list of modules as css string\n list.toString = function toString() {\n return this.map(function (item) {\n var content = \"\";\n var needLayer = typeof item[5] !== \"undefined\";\n if (item[4]) {\n content += \"@supports (\".concat(item[4], \") {\");\n }\n if (item[2]) {\n content += \"@media \".concat(item[2], \" {\");\n }\n if (needLayer) {\n content += \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\");\n }\n content += cssWithMappingToString(item);\n if (needLayer) {\n content += \"}\";\n }\n if (item[2]) {\n content += \"}\";\n }\n if (item[4]) {\n content += \"}\";\n }\n return content;\n }).join(\"\");\n };\n\n // import a list of modules into the list\n list.i = function i(modules, media, dedupe, supports, layer) {\n if (typeof modules === \"string\") {\n modules = [[null, modules, undefined]];\n }\n var alreadyImportedModules = {};\n if (dedupe) {\n for (var k = 0; k < this.length; k++) {\n var id = this[k][0];\n if (id != null) {\n alreadyImportedModules[id] = true;\n }\n }\n }\n for (var _k = 0; _k < modules.length; _k++) {\n var item = [].concat(modules[_k]);\n if (dedupe && alreadyImportedModules[item[0]]) {\n continue;\n }\n if (typeof layer !== \"undefined\") {\n if (typeof item[5] === \"undefined\") {\n item[5] = layer;\n } else {\n item[1] = \"@layer\".concat(item[5].length > 0 ? \" \".concat(item[5]) : \"\", \" {\").concat(item[1], \"}\");\n item[5] = layer;\n }\n }\n if (media) {\n if (!item[2]) {\n item[2] = media;\n } else {\n item[1] = \"@media \".concat(item[2], \" {\").concat(item[1], \"}\");\n item[2] = media;\n }\n }\n if (supports) {\n if (!item[4]) {\n item[4] = \"\".concat(supports);\n } else {\n item[1] = \"@supports (\".concat(item[4], \") {\").concat(item[1], \"}\");\n item[4] = supports;\n }\n }\n list.push(item);\n }\n };\n return list;\n};","\"use strict\";\n\nmodule.exports = function (url, options) {\n if (!options) {\n options = {};\n }\n if (!url) {\n return url;\n }\n url = String(url.__esModule ? url.default : url);\n\n // If url is already wrapped in quotes, remove them\n if (/^['\"].*['\"]$/.test(url)) {\n url = url.slice(1, -1);\n }\n if (options.hash) {\n url += options.hash;\n }\n\n // Should url be wrapped?\n // See https://drafts.csswg.org/css-values-3/#urls\n if (/[\"'() \\t\\n]|(%20)/.test(url) || options.needQuotes) {\n return \"\\\"\".concat(url.replace(/\"/g, '\\\\\"').replace(/\\n/g, \"\\\\n\"), \"\\\"\");\n }\n return url;\n};","\"use strict\";\n\nmodule.exports = function (item) {\n var content = item[1];\n var cssMapping = item[3];\n if (!cssMapping) {\n return content;\n }\n if (typeof btoa === \"function\") {\n var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(cssMapping))));\n var data = \"sourceMappingURL=data:application/json;charset=utf-8;base64,\".concat(base64);\n var sourceMapping = \"/*# \".concat(data, \" */\");\n return [content].concat([sourceMapping]).join(\"\\n\");\n }\n return [content].join(\"\\n\");\n};","function _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/**\n * Return true if `value` is object-like. A value is object-like if it's not\n * `null` and has a `typeof` result of \"object\".\n */\nexport default function isObjectLike(value) {\n return _typeof(value) == 'object' && value !== null;\n}\n","// In ES2015 (or a polyfilled) environment, this will be Symbol.iterator\n// istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2317')\nexport var SYMBOL_ITERATOR = typeof Symbol === 'function' && Symbol.iterator != null ? Symbol.iterator : '@@iterator'; // In ES2017 (or a polyfilled) environment, this will be Symbol.asyncIterator\n// istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2317')\n\nexport var SYMBOL_ASYNC_ITERATOR = typeof Symbol === 'function' && Symbol.asyncIterator != null ? Symbol.asyncIterator : '@@asyncIterator'; // istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2317')\n\nexport var SYMBOL_TO_STRING_TAG = typeof Symbol === 'function' && Symbol.toStringTag != null ? Symbol.toStringTag : '@@toStringTag';\n","/**\n * Represents a location in a Source.\n */\n\n/**\n * Takes a Source and a UTF-8 character offset, and returns the corresponding\n * line and column as a SourceLocation.\n */\nexport function getLocation(source, position) {\n var lineRegexp = /\\r\\n|[\\n\\r]/g;\n var line = 1;\n var column = position + 1;\n var match;\n\n while ((match = lineRegexp.exec(source.body)) && match.index < position) {\n line += 1;\n column = position + 1 - (match.index + match[0].length);\n }\n\n return {\n line: line,\n column: column\n };\n}\n","import { getLocation } from \"./location.mjs\";\n/**\n * Render a helpful description of the location in the GraphQL Source document.\n */\n\nexport function printLocation(location) {\n return printSourceLocation(location.source, getLocation(location.source, location.start));\n}\n/**\n * Render a helpful description of the location in the GraphQL Source document.\n */\n\nexport function printSourceLocation(source, sourceLocation) {\n var firstLineColumnOffset = source.locationOffset.column - 1;\n var body = whitespace(firstLineColumnOffset) + source.body;\n var lineIndex = sourceLocation.line - 1;\n var lineOffset = source.locationOffset.line - 1;\n var lineNum = sourceLocation.line + lineOffset;\n var columnOffset = sourceLocation.line === 1 ? firstLineColumnOffset : 0;\n var columnNum = sourceLocation.column + columnOffset;\n var locationStr = \"\".concat(source.name, \":\").concat(lineNum, \":\").concat(columnNum, \"\\n\");\n var lines = body.split(/\\r\\n|[\\n\\r]/g);\n var locationLine = lines[lineIndex]; // Special case for minified documents\n\n if (locationLine.length > 120) {\n var subLineIndex = Math.floor(columnNum / 80);\n var subLineColumnNum = columnNum % 80;\n var subLines = [];\n\n for (var i = 0; i < locationLine.length; i += 80) {\n subLines.push(locationLine.slice(i, i + 80));\n }\n\n return locationStr + printPrefixedLines([[\"\".concat(lineNum), subLines[0]]].concat(subLines.slice(1, subLineIndex + 1).map(function (subLine) {\n return ['', subLine];\n }), [[' ', whitespace(subLineColumnNum - 1) + '^'], ['', subLines[subLineIndex + 1]]]));\n }\n\n return locationStr + printPrefixedLines([// Lines specified like this: [\"prefix\", \"string\"],\n [\"\".concat(lineNum - 1), lines[lineIndex - 1]], [\"\".concat(lineNum), locationLine], ['', whitespace(columnNum - 1) + '^'], [\"\".concat(lineNum + 1), lines[lineIndex + 1]]]);\n}\n\nfunction printPrefixedLines(lines) {\n var existingLines = lines.filter(function (_ref) {\n var _ = _ref[0],\n line = _ref[1];\n return line !== undefined;\n });\n var padLen = Math.max.apply(Math, existingLines.map(function (_ref2) {\n var prefix = _ref2[0];\n return prefix.length;\n }));\n return existingLines.map(function (_ref3) {\n var prefix = _ref3[0],\n line = _ref3[1];\n return leftPad(padLen, prefix) + (line ? ' | ' + line : ' |');\n }).join('\\n');\n}\n\nfunction whitespace(len) {\n return Array(len + 1).join(' ');\n}\n\nfunction leftPad(len, str) {\n return whitespace(len - str.length) + str;\n}\n","function _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _wrapNativeSuper(Class) { var _cache = typeof Map === \"function\" ? new Map() : undefined; _wrapNativeSuper = function _wrapNativeSuper(Class) { if (Class === null || !_isNativeFunction(Class)) return Class; if (typeof Class !== \"function\") { throw new TypeError(\"Super expression must either be null or a function\"); } if (typeof _cache !== \"undefined\") { if (_cache.has(Class)) return _cache.get(Class); _cache.set(Class, Wrapper); } function Wrapper() { return _construct(Class, arguments, _getPrototypeOf(this).constructor); } Wrapper.prototype = Object.create(Class.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return _setPrototypeOf(Wrapper, Class); }; return _wrapNativeSuper(Class); }\n\nfunction _construct(Parent, args, Class) { if (_isNativeReflectConstruct()) { _construct = Reflect.construct; } else { _construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) _setPrototypeOf(instance, Class.prototype); return instance; }; } return _construct.apply(null, arguments); }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction _isNativeFunction(fn) { return Function.toString.call(fn).indexOf(\"[native code]\") !== -1; }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\n// FIXME:\n// flowlint uninitialized-instance-property:off\nimport isObjectLike from \"../jsutils/isObjectLike.mjs\";\nimport { SYMBOL_TO_STRING_TAG } from \"../polyfills/symbols.mjs\";\nimport { getLocation } from \"../language/location.mjs\";\nimport { printLocation, printSourceLocation } from \"../language/printLocation.mjs\";\n/**\n * A GraphQLError describes an Error found during the parse, validate, or\n * execute phases of performing a GraphQL operation. In addition to a message\n * and stack trace, it also includes information about the locations in a\n * GraphQL document and/or execution result that correspond to the Error.\n */\n\nexport var GraphQLError = /*#__PURE__*/function (_Error) {\n _inherits(GraphQLError, _Error);\n\n var _super = _createSuper(GraphQLError);\n\n /**\n * A message describing the Error for debugging purposes.\n *\n * Enumerable, and appears in the result of JSON.stringify().\n *\n * Note: should be treated as readonly, despite invariant usage.\n */\n\n /**\n * An array of { line, column } locations within the source GraphQL document\n * which correspond to this error.\n *\n * Errors during validation often contain multiple locations, for example to\n * point out two things with the same name. Errors during execution include a\n * single location, the field which produced the error.\n *\n * Enumerable, and appears in the result of JSON.stringify().\n */\n\n /**\n * An array describing the JSON-path into the execution response which\n * corresponds to this error. Only included for errors during execution.\n *\n * Enumerable, and appears in the result of JSON.stringify().\n */\n\n /**\n * An array of GraphQL AST Nodes corresponding to this error.\n */\n\n /**\n * The source GraphQL document for the first location of this error.\n *\n * Note that if this Error represents more than one node, the source may not\n * represent nodes after the first node.\n */\n\n /**\n * An array of character offsets within the source GraphQL document\n * which correspond to this error.\n */\n\n /**\n * The original error thrown from a field resolver during execution.\n */\n\n /**\n * Extension fields to add to the formatted error.\n */\n function GraphQLError(message, nodes, source, positions, path, originalError, extensions) {\n var _locations2, _source2, _positions2, _extensions2;\n\n var _this;\n\n _classCallCheck(this, GraphQLError);\n\n _this = _super.call(this, message); // Compute list of blame nodes.\n\n var _nodes = Array.isArray(nodes) ? nodes.length !== 0 ? nodes : undefined : nodes ? [nodes] : undefined; // Compute locations in the source for the given nodes/positions.\n\n\n var _source = source;\n\n if (!_source && _nodes) {\n var _nodes$0$loc;\n\n _source = (_nodes$0$loc = _nodes[0].loc) === null || _nodes$0$loc === void 0 ? void 0 : _nodes$0$loc.source;\n }\n\n var _positions = positions;\n\n if (!_positions && _nodes) {\n _positions = _nodes.reduce(function (list, node) {\n if (node.loc) {\n list.push(node.loc.start);\n }\n\n return list;\n }, []);\n }\n\n if (_positions && _positions.length === 0) {\n _positions = undefined;\n }\n\n var _locations;\n\n if (positions && source) {\n _locations = positions.map(function (pos) {\n return getLocation(source, pos);\n });\n } else if (_nodes) {\n _locations = _nodes.reduce(function (list, node) {\n if (node.loc) {\n list.push(getLocation(node.loc.source, node.loc.start));\n }\n\n return list;\n }, []);\n }\n\n var _extensions = extensions;\n\n if (_extensions == null && originalError != null) {\n var originalExtensions = originalError.extensions;\n\n if (isObjectLike(originalExtensions)) {\n _extensions = originalExtensions;\n }\n }\n\n Object.defineProperties(_assertThisInitialized(_this), {\n name: {\n value: 'GraphQLError'\n },\n message: {\n value: message,\n // By being enumerable, JSON.stringify will include `message` in the\n // resulting output. This ensures that the simplest possible GraphQL\n // service adheres to the spec.\n enumerable: true,\n writable: true\n },\n locations: {\n // Coercing falsy values to undefined ensures they will not be included\n // in JSON.stringify() when not provided.\n value: (_locations2 = _locations) !== null && _locations2 !== void 0 ? _locations2 : undefined,\n // By being enumerable, JSON.stringify will include `locations` in the\n // resulting output. This ensures that the simplest possible GraphQL\n // service adheres to the spec.\n enumerable: _locations != null\n },\n path: {\n // Coercing falsy values to undefined ensures they will not be included\n // in JSON.stringify() when not provided.\n value: path !== null && path !== void 0 ? path : undefined,\n // By being enumerable, JSON.stringify will include `path` in the\n // resulting output. This ensures that the simplest possible GraphQL\n // service adheres to the spec.\n enumerable: path != null\n },\n nodes: {\n value: _nodes !== null && _nodes !== void 0 ? _nodes : undefined\n },\n source: {\n value: (_source2 = _source) !== null && _source2 !== void 0 ? _source2 : undefined\n },\n positions: {\n value: (_positions2 = _positions) !== null && _positions2 !== void 0 ? _positions2 : undefined\n },\n originalError: {\n value: originalError\n },\n extensions: {\n // Coercing falsy values to undefined ensures they will not be included\n // in JSON.stringify() when not provided.\n value: (_extensions2 = _extensions) !== null && _extensions2 !== void 0 ? _extensions2 : undefined,\n // By being enumerable, JSON.stringify will include `path` in the\n // resulting output. This ensures that the simplest possible GraphQL\n // service adheres to the spec.\n enumerable: _extensions != null\n }\n }); // Include (non-enumerable) stack trace.\n\n if (originalError !== null && originalError !== void 0 && originalError.stack) {\n Object.defineProperty(_assertThisInitialized(_this), 'stack', {\n value: originalError.stack,\n writable: true,\n configurable: true\n });\n return _possibleConstructorReturn(_this);\n } // istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2317')\n\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(_assertThisInitialized(_this), GraphQLError);\n } else {\n Object.defineProperty(_assertThisInitialized(_this), 'stack', {\n value: Error().stack,\n writable: true,\n configurable: true\n });\n }\n\n return _this;\n }\n\n _createClass(GraphQLError, [{\n key: \"toString\",\n value: function toString() {\n return printError(this);\n } // FIXME: workaround to not break chai comparisons, should be remove in v16\n // $FlowFixMe[unsupported-syntax] Flow doesn't support computed properties yet\n\n }, {\n key: SYMBOL_TO_STRING_TAG,\n get: function get() {\n return 'Object';\n }\n }]);\n\n return GraphQLError;\n}( /*#__PURE__*/_wrapNativeSuper(Error));\n/**\n * Prints a GraphQLError to a string, representing useful location information\n * about the error's position in the source.\n */\n\nexport function printError(error) {\n var output = error.message;\n\n if (error.nodes) {\n for (var _i2 = 0, _error$nodes2 = error.nodes; _i2 < _error$nodes2.length; _i2++) {\n var node = _error$nodes2[_i2];\n\n if (node.loc) {\n output += '\\n\\n' + printLocation(node.loc);\n }\n }\n } else if (error.source && error.locations) {\n for (var _i4 = 0, _error$locations2 = error.locations; _i4 < _error$locations2.length; _i4++) {\n var location = _error$locations2[_i4];\n output += '\\n\\n' + printSourceLocation(error.source, location);\n }\n }\n\n return output;\n}\n","import { GraphQLError } from \"./GraphQLError.mjs\";\n/**\n * Produces a GraphQLError representing a syntax error, containing useful\n * descriptive information about the syntax error's position in the source.\n */\n\nexport function syntaxError(source, position, description) {\n return new GraphQLError(\"Syntax Error: \".concat(description), undefined, source, [position]);\n}\n","/**\n * An exported enum describing the different kinds of tokens that the\n * lexer emits.\n */\nexport var TokenKind = Object.freeze({\n SOF: '',\n EOF: '',\n BANG: '!',\n DOLLAR: '$',\n AMP: '&',\n PAREN_L: '(',\n PAREN_R: ')',\n SPREAD: '...',\n COLON: ':',\n EQUALS: '=',\n AT: '@',\n BRACKET_L: '[',\n BRACKET_R: ']',\n BRACE_L: '{',\n PIPE: '|',\n BRACE_R: '}',\n NAME: 'Name',\n INT: 'Int',\n FLOAT: 'Float',\n STRING: 'String',\n BLOCK_STRING: 'BlockString',\n COMMENT: 'Comment'\n});\n/**\n * The enum type representing the token kinds values.\n */\n","export default function devAssert(condition, message) {\n var booleanCondition = Boolean(condition); // istanbul ignore else (See transformation done in './resources/inlineInvariant.js')\n\n if (!booleanCondition) {\n throw new Error(message);\n }\n}\n","function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nimport { SYMBOL_TO_STRING_TAG } from \"../polyfills/symbols.mjs\";\nimport inspect from \"../jsutils/inspect.mjs\";\nimport devAssert from \"../jsutils/devAssert.mjs\";\nimport instanceOf from \"../jsutils/instanceOf.mjs\";\n\n/**\n * A representation of source input to GraphQL. The `name` and `locationOffset` parameters are\n * optional, but they are useful for clients who store GraphQL documents in source files.\n * For example, if the GraphQL input starts at line 40 in a file named `Foo.graphql`, it might\n * be useful for `name` to be `\"Foo.graphql\"` and location to be `{ line: 40, column: 1 }`.\n * The `line` and `column` properties in `locationOffset` are 1-indexed.\n */\nexport var Source = /*#__PURE__*/function () {\n function Source(body) {\n var name = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'GraphQL request';\n var locationOffset = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {\n line: 1,\n column: 1\n };\n typeof body === 'string' || devAssert(0, \"Body must be a string. Received: \".concat(inspect(body), \".\"));\n this.body = body;\n this.name = name;\n this.locationOffset = locationOffset;\n this.locationOffset.line > 0 || devAssert(0, 'line in locationOffset is 1-indexed and must be positive.');\n this.locationOffset.column > 0 || devAssert(0, 'column in locationOffset is 1-indexed and must be positive.');\n } // $FlowFixMe[unsupported-syntax] Flow doesn't support computed properties yet\n\n\n _createClass(Source, [{\n key: SYMBOL_TO_STRING_TAG,\n get: function get() {\n return 'Source';\n }\n }]);\n\n return Source;\n}();\n/**\n * Test if the given value is a Source object.\n *\n * @internal\n */\n\n// eslint-disable-next-line no-redeclare\nexport function isSource(source) {\n return instanceOf(source, Source);\n}\n","/**\n * The set of allowed directive location values.\n */\nexport var DirectiveLocation = Object.freeze({\n // Request Definitions\n QUERY: 'QUERY',\n MUTATION: 'MUTATION',\n SUBSCRIPTION: 'SUBSCRIPTION',\n FIELD: 'FIELD',\n FRAGMENT_DEFINITION: 'FRAGMENT_DEFINITION',\n FRAGMENT_SPREAD: 'FRAGMENT_SPREAD',\n INLINE_FRAGMENT: 'INLINE_FRAGMENT',\n VARIABLE_DEFINITION: 'VARIABLE_DEFINITION',\n // Type System Definitions\n SCHEMA: 'SCHEMA',\n SCALAR: 'SCALAR',\n OBJECT: 'OBJECT',\n FIELD_DEFINITION: 'FIELD_DEFINITION',\n ARGUMENT_DEFINITION: 'ARGUMENT_DEFINITION',\n INTERFACE: 'INTERFACE',\n UNION: 'UNION',\n ENUM: 'ENUM',\n ENUM_VALUE: 'ENUM_VALUE',\n INPUT_OBJECT: 'INPUT_OBJECT',\n INPUT_FIELD_DEFINITION: 'INPUT_FIELD_DEFINITION'\n});\n/**\n * The enum type representing the directive location values.\n */\n","import { syntaxError } from \"../error/syntaxError.mjs\";\nimport { Token } from \"./ast.mjs\";\nimport { TokenKind } from \"./tokenKind.mjs\";\nimport { dedentBlockStringValue } from \"./blockString.mjs\";\n/**\n * Given a Source object, creates a Lexer for that source.\n * A Lexer is a stateful stream generator in that every time\n * it is advanced, it returns the next token in the Source. Assuming the\n * source lexes, the final Token emitted by the lexer will be of kind\n * EOF, after which the lexer will repeatedly return the same EOF token\n * whenever called.\n */\n\nexport var Lexer = /*#__PURE__*/function () {\n /**\n * The previously focused non-ignored token.\n */\n\n /**\n * The currently focused non-ignored token.\n */\n\n /**\n * The (1-indexed) line containing the current token.\n */\n\n /**\n * The character offset at which the current line begins.\n */\n function Lexer(source) {\n var startOfFileToken = new Token(TokenKind.SOF, 0, 0, 0, 0, null);\n this.source = source;\n this.lastToken = startOfFileToken;\n this.token = startOfFileToken;\n this.line = 1;\n this.lineStart = 0;\n }\n /**\n * Advances the token stream to the next non-ignored token.\n */\n\n\n var _proto = Lexer.prototype;\n\n _proto.advance = function advance() {\n this.lastToken = this.token;\n var token = this.token = this.lookahead();\n return token;\n }\n /**\n * Looks ahead and returns the next non-ignored token, but does not change\n * the state of Lexer.\n */\n ;\n\n _proto.lookahead = function lookahead() {\n var token = this.token;\n\n if (token.kind !== TokenKind.EOF) {\n do {\n var _token$next;\n\n // Note: next is only mutable during parsing, so we cast to allow this.\n token = (_token$next = token.next) !== null && _token$next !== void 0 ? _token$next : token.next = readToken(this, token);\n } while (token.kind === TokenKind.COMMENT);\n }\n\n return token;\n };\n\n return Lexer;\n}();\n/**\n * @internal\n */\n\nexport function isPunctuatorTokenKind(kind) {\n return kind === TokenKind.BANG || kind === TokenKind.DOLLAR || kind === TokenKind.AMP || kind === TokenKind.PAREN_L || kind === TokenKind.PAREN_R || kind === TokenKind.SPREAD || kind === TokenKind.COLON || kind === TokenKind.EQUALS || kind === TokenKind.AT || kind === TokenKind.BRACKET_L || kind === TokenKind.BRACKET_R || kind === TokenKind.BRACE_L || kind === TokenKind.PIPE || kind === TokenKind.BRACE_R;\n}\n\nfunction printCharCode(code) {\n return (// NaN/undefined represents access beyond the end of the file.\n isNaN(code) ? TokenKind.EOF : // Trust JSON for ASCII.\n code < 0x007f ? JSON.stringify(String.fromCharCode(code)) : // Otherwise print the escaped form.\n \"\\\"\\\\u\".concat(('00' + code.toString(16).toUpperCase()).slice(-4), \"\\\"\")\n );\n}\n/**\n * Gets the next token from the source starting at the given position.\n *\n * This skips over whitespace until it finds the next lexable token, then lexes\n * punctuators immediately or calls the appropriate helper function for more\n * complicated tokens.\n */\n\n\nfunction readToken(lexer, prev) {\n var source = lexer.source;\n var body = source.body;\n var bodyLength = body.length;\n var pos = prev.end;\n\n while (pos < bodyLength) {\n var code = body.charCodeAt(pos);\n var _line = lexer.line;\n\n var _col = 1 + pos - lexer.lineStart; // SourceCharacter\n\n\n switch (code) {\n case 0xfeff: // \n\n case 9: // \\t\n\n case 32: // \n\n case 44:\n // ,\n ++pos;\n continue;\n\n case 10:\n // \\n\n ++pos;\n ++lexer.line;\n lexer.lineStart = pos;\n continue;\n\n case 13:\n // \\r\n if (body.charCodeAt(pos + 1) === 10) {\n pos += 2;\n } else {\n ++pos;\n }\n\n ++lexer.line;\n lexer.lineStart = pos;\n continue;\n\n case 33:\n // !\n return new Token(TokenKind.BANG, pos, pos + 1, _line, _col, prev);\n\n case 35:\n // #\n return readComment(source, pos, _line, _col, prev);\n\n case 36:\n // $\n return new Token(TokenKind.DOLLAR, pos, pos + 1, _line, _col, prev);\n\n case 38:\n // &\n return new Token(TokenKind.AMP, pos, pos + 1, _line, _col, prev);\n\n case 40:\n // (\n return new Token(TokenKind.PAREN_L, pos, pos + 1, _line, _col, prev);\n\n case 41:\n // )\n return new Token(TokenKind.PAREN_R, pos, pos + 1, _line, _col, prev);\n\n case 46:\n // .\n if (body.charCodeAt(pos + 1) === 46 && body.charCodeAt(pos + 2) === 46) {\n return new Token(TokenKind.SPREAD, pos, pos + 3, _line, _col, prev);\n }\n\n break;\n\n case 58:\n // :\n return new Token(TokenKind.COLON, pos, pos + 1, _line, _col, prev);\n\n case 61:\n // =\n return new Token(TokenKind.EQUALS, pos, pos + 1, _line, _col, prev);\n\n case 64:\n // @\n return new Token(TokenKind.AT, pos, pos + 1, _line, _col, prev);\n\n case 91:\n // [\n return new Token(TokenKind.BRACKET_L, pos, pos + 1, _line, _col, prev);\n\n case 93:\n // ]\n return new Token(TokenKind.BRACKET_R, pos, pos + 1, _line, _col, prev);\n\n case 123:\n // {\n return new Token(TokenKind.BRACE_L, pos, pos + 1, _line, _col, prev);\n\n case 124:\n // |\n return new Token(TokenKind.PIPE, pos, pos + 1, _line, _col, prev);\n\n case 125:\n // }\n return new Token(TokenKind.BRACE_R, pos, pos + 1, _line, _col, prev);\n\n case 34:\n // \"\n if (body.charCodeAt(pos + 1) === 34 && body.charCodeAt(pos + 2) === 34) {\n return readBlockString(source, pos, _line, _col, prev, lexer);\n }\n\n return readString(source, pos, _line, _col, prev);\n\n case 45: // -\n\n case 48: // 0\n\n case 49: // 1\n\n case 50: // 2\n\n case 51: // 3\n\n case 52: // 4\n\n case 53: // 5\n\n case 54: // 6\n\n case 55: // 7\n\n case 56: // 8\n\n case 57:\n // 9\n return readNumber(source, pos, code, _line, _col, prev);\n\n case 65: // A\n\n case 66: // B\n\n case 67: // C\n\n case 68: // D\n\n case 69: // E\n\n case 70: // F\n\n case 71: // G\n\n case 72: // H\n\n case 73: // I\n\n case 74: // J\n\n case 75: // K\n\n case 76: // L\n\n case 77: // M\n\n case 78: // N\n\n case 79: // O\n\n case 80: // P\n\n case 81: // Q\n\n case 82: // R\n\n case 83: // S\n\n case 84: // T\n\n case 85: // U\n\n case 86: // V\n\n case 87: // W\n\n case 88: // X\n\n case 89: // Y\n\n case 90: // Z\n\n case 95: // _\n\n case 97: // a\n\n case 98: // b\n\n case 99: // c\n\n case 100: // d\n\n case 101: // e\n\n case 102: // f\n\n case 103: // g\n\n case 104: // h\n\n case 105: // i\n\n case 106: // j\n\n case 107: // k\n\n case 108: // l\n\n case 109: // m\n\n case 110: // n\n\n case 111: // o\n\n case 112: // p\n\n case 113: // q\n\n case 114: // r\n\n case 115: // s\n\n case 116: // t\n\n case 117: // u\n\n case 118: // v\n\n case 119: // w\n\n case 120: // x\n\n case 121: // y\n\n case 122:\n // z\n return readName(source, pos, _line, _col, prev);\n }\n\n throw syntaxError(source, pos, unexpectedCharacterMessage(code));\n }\n\n var line = lexer.line;\n var col = 1 + pos - lexer.lineStart;\n return new Token(TokenKind.EOF, bodyLength, bodyLength, line, col, prev);\n}\n/**\n * Report a message that an unexpected character was encountered.\n */\n\n\nfunction unexpectedCharacterMessage(code) {\n if (code < 0x0020 && code !== 0x0009 && code !== 0x000a && code !== 0x000d) {\n return \"Cannot contain the invalid character \".concat(printCharCode(code), \".\");\n }\n\n if (code === 39) {\n // '\n return 'Unexpected single quote character (\\'), did you mean to use a double quote (\")?';\n }\n\n return \"Cannot parse the unexpected character \".concat(printCharCode(code), \".\");\n}\n/**\n * Reads a comment token from the source file.\n *\n * #[\\u0009\\u0020-\\uFFFF]*\n */\n\n\nfunction readComment(source, start, line, col, prev) {\n var body = source.body;\n var code;\n var position = start;\n\n do {\n code = body.charCodeAt(++position);\n } while (!isNaN(code) && ( // SourceCharacter but not LineTerminator\n code > 0x001f || code === 0x0009));\n\n return new Token(TokenKind.COMMENT, start, position, line, col, prev, body.slice(start + 1, position));\n}\n/**\n * Reads a number token from the source file, either a float\n * or an int depending on whether a decimal point appears.\n *\n * Int: -?(0|[1-9][0-9]*)\n * Float: -?(0|[1-9][0-9]*)(\\.[0-9]+)?((E|e)(+|-)?[0-9]+)?\n */\n\n\nfunction readNumber(source, start, firstCode, line, col, prev) {\n var body = source.body;\n var code = firstCode;\n var position = start;\n var isFloat = false;\n\n if (code === 45) {\n // -\n code = body.charCodeAt(++position);\n }\n\n if (code === 48) {\n // 0\n code = body.charCodeAt(++position);\n\n if (code >= 48 && code <= 57) {\n throw syntaxError(source, position, \"Invalid number, unexpected digit after 0: \".concat(printCharCode(code), \".\"));\n }\n } else {\n position = readDigits(source, position, code);\n code = body.charCodeAt(position);\n }\n\n if (code === 46) {\n // .\n isFloat = true;\n code = body.charCodeAt(++position);\n position = readDigits(source, position, code);\n code = body.charCodeAt(position);\n }\n\n if (code === 69 || code === 101) {\n // E e\n isFloat = true;\n code = body.charCodeAt(++position);\n\n if (code === 43 || code === 45) {\n // + -\n code = body.charCodeAt(++position);\n }\n\n position = readDigits(source, position, code);\n code = body.charCodeAt(position);\n } // Numbers cannot be followed by . or NameStart\n\n\n if (code === 46 || isNameStart(code)) {\n throw syntaxError(source, position, \"Invalid number, expected digit but got: \".concat(printCharCode(code), \".\"));\n }\n\n return new Token(isFloat ? TokenKind.FLOAT : TokenKind.INT, start, position, line, col, prev, body.slice(start, position));\n}\n/**\n * Returns the new position in the source after reading digits.\n */\n\n\nfunction readDigits(source, start, firstCode) {\n var body = source.body;\n var position = start;\n var code = firstCode;\n\n if (code >= 48 && code <= 57) {\n // 0 - 9\n do {\n code = body.charCodeAt(++position);\n } while (code >= 48 && code <= 57); // 0 - 9\n\n\n return position;\n }\n\n throw syntaxError(source, position, \"Invalid number, expected digit but got: \".concat(printCharCode(code), \".\"));\n}\n/**\n * Reads a string token from the source file.\n *\n * \"([^\"\\\\\\u000A\\u000D]|(\\\\(u[0-9a-fA-F]{4}|[\"\\\\/bfnrt])))*\"\n */\n\n\nfunction readString(source, start, line, col, prev) {\n var body = source.body;\n var position = start + 1;\n var chunkStart = position;\n var code = 0;\n var value = '';\n\n while (position < body.length && !isNaN(code = body.charCodeAt(position)) && // not LineTerminator\n code !== 0x000a && code !== 0x000d) {\n // Closing Quote (\")\n if (code === 34) {\n value += body.slice(chunkStart, position);\n return new Token(TokenKind.STRING, start, position + 1, line, col, prev, value);\n } // SourceCharacter\n\n\n if (code < 0x0020 && code !== 0x0009) {\n throw syntaxError(source, position, \"Invalid character within String: \".concat(printCharCode(code), \".\"));\n }\n\n ++position;\n\n if (code === 92) {\n // \\\n value += body.slice(chunkStart, position - 1);\n code = body.charCodeAt(position);\n\n switch (code) {\n case 34:\n value += '\"';\n break;\n\n case 47:\n value += '/';\n break;\n\n case 92:\n value += '\\\\';\n break;\n\n case 98:\n value += '\\b';\n break;\n\n case 102:\n value += '\\f';\n break;\n\n case 110:\n value += '\\n';\n break;\n\n case 114:\n value += '\\r';\n break;\n\n case 116:\n value += '\\t';\n break;\n\n case 117:\n {\n // uXXXX\n var charCode = uniCharCode(body.charCodeAt(position + 1), body.charCodeAt(position + 2), body.charCodeAt(position + 3), body.charCodeAt(position + 4));\n\n if (charCode < 0) {\n var invalidSequence = body.slice(position + 1, position + 5);\n throw syntaxError(source, position, \"Invalid character escape sequence: \\\\u\".concat(invalidSequence, \".\"));\n }\n\n value += String.fromCharCode(charCode);\n position += 4;\n break;\n }\n\n default:\n throw syntaxError(source, position, \"Invalid character escape sequence: \\\\\".concat(String.fromCharCode(code), \".\"));\n }\n\n ++position;\n chunkStart = position;\n }\n }\n\n throw syntaxError(source, position, 'Unterminated string.');\n}\n/**\n * Reads a block string token from the source file.\n *\n * \"\"\"(\"?\"?(\\\\\"\"\"|\\\\(?!=\"\"\")|[^\"\\\\]))*\"\"\"\n */\n\n\nfunction readBlockString(source, start, line, col, prev, lexer) {\n var body = source.body;\n var position = start + 3;\n var chunkStart = position;\n var code = 0;\n var rawValue = '';\n\n while (position < body.length && !isNaN(code = body.charCodeAt(position))) {\n // Closing Triple-Quote (\"\"\")\n if (code === 34 && body.charCodeAt(position + 1) === 34 && body.charCodeAt(position + 2) === 34) {\n rawValue += body.slice(chunkStart, position);\n return new Token(TokenKind.BLOCK_STRING, start, position + 3, line, col, prev, dedentBlockStringValue(rawValue));\n } // SourceCharacter\n\n\n if (code < 0x0020 && code !== 0x0009 && code !== 0x000a && code !== 0x000d) {\n throw syntaxError(source, position, \"Invalid character within String: \".concat(printCharCode(code), \".\"));\n }\n\n if (code === 10) {\n // new line\n ++position;\n ++lexer.line;\n lexer.lineStart = position;\n } else if (code === 13) {\n // carriage return\n if (body.charCodeAt(position + 1) === 10) {\n position += 2;\n } else {\n ++position;\n }\n\n ++lexer.line;\n lexer.lineStart = position;\n } else if ( // Escape Triple-Quote (\\\"\"\")\n code === 92 && body.charCodeAt(position + 1) === 34 && body.charCodeAt(position + 2) === 34 && body.charCodeAt(position + 3) === 34) {\n rawValue += body.slice(chunkStart, position) + '\"\"\"';\n position += 4;\n chunkStart = position;\n } else {\n ++position;\n }\n }\n\n throw syntaxError(source, position, 'Unterminated string.');\n}\n/**\n * Converts four hexadecimal chars to the integer that the\n * string represents. For example, uniCharCode('0','0','0','f')\n * will return 15, and uniCharCode('0','0','f','f') returns 255.\n *\n * Returns a negative number on error, if a char was invalid.\n *\n * This is implemented by noting that char2hex() returns -1 on error,\n * which means the result of ORing the char2hex() will also be negative.\n */\n\n\nfunction uniCharCode(a, b, c, d) {\n return char2hex(a) << 12 | char2hex(b) << 8 | char2hex(c) << 4 | char2hex(d);\n}\n/**\n * Converts a hex character to its integer value.\n * '0' becomes 0, '9' becomes 9\n * 'A' becomes 10, 'F' becomes 15\n * 'a' becomes 10, 'f' becomes 15\n *\n * Returns -1 on error.\n */\n\n\nfunction char2hex(a) {\n return a >= 48 && a <= 57 ? a - 48 // 0-9\n : a >= 65 && a <= 70 ? a - 55 // A-F\n : a >= 97 && a <= 102 ? a - 87 // a-f\n : -1;\n}\n/**\n * Reads an alphanumeric + underscore name from the source.\n *\n * [_A-Za-z][_0-9A-Za-z]*\n */\n\n\nfunction readName(source, start, line, col, prev) {\n var body = source.body;\n var bodyLength = body.length;\n var position = start + 1;\n var code = 0;\n\n while (position !== bodyLength && !isNaN(code = body.charCodeAt(position)) && (code === 95 || // _\n code >= 48 && code <= 57 || // 0-9\n code >= 65 && code <= 90 || // A-Z\n code >= 97 && code <= 122) // a-z\n ) {\n ++position;\n }\n\n return new Token(TokenKind.NAME, start, position, line, col, prev, body.slice(start, position));\n} // _ A-Z a-z\n\n\nfunction isNameStart(code) {\n return code === 95 || code >= 65 && code <= 90 || code >= 97 && code <= 122;\n}\n","import { syntaxError } from \"../error/syntaxError.mjs\";\nimport { Kind } from \"./kinds.mjs\";\nimport { Location } from \"./ast.mjs\";\nimport { TokenKind } from \"./tokenKind.mjs\";\nimport { Source, isSource } from \"./source.mjs\";\nimport { DirectiveLocation } from \"./directiveLocation.mjs\";\nimport { Lexer, isPunctuatorTokenKind } from \"./lexer.mjs\";\n/**\n * Configuration options to control parser behavior\n */\n\n/**\n * Given a GraphQL source, parses it into a Document.\n * Throws GraphQLError if a syntax error is encountered.\n */\nexport function parse(source, options) {\n var parser = new Parser(source, options);\n return parser.parseDocument();\n}\n/**\n * Given a string containing a GraphQL value (ex. `[42]`), parse the AST for\n * that value.\n * Throws GraphQLError if a syntax error is encountered.\n *\n * This is useful within tools that operate upon GraphQL Values directly and\n * in isolation of complete GraphQL documents.\n *\n * Consider providing the results to the utility function: valueFromAST().\n */\n\nexport function parseValue(source, options) {\n var parser = new Parser(source, options);\n parser.expectToken(TokenKind.SOF);\n var value = parser.parseValueLiteral(false);\n parser.expectToken(TokenKind.EOF);\n return value;\n}\n/**\n * Given a string containing a GraphQL Type (ex. `[Int!]`), parse the AST for\n * that type.\n * Throws GraphQLError if a syntax error is encountered.\n *\n * This is useful within tools that operate upon GraphQL Types directly and\n * in isolation of complete GraphQL documents.\n *\n * Consider providing the results to the utility function: typeFromAST().\n */\n\nexport function parseType(source, options) {\n var parser = new Parser(source, options);\n parser.expectToken(TokenKind.SOF);\n var type = parser.parseTypeReference();\n parser.expectToken(TokenKind.EOF);\n return type;\n}\n/**\n * This class is exported only to assist people in implementing their own parsers\n * without duplicating too much code and should be used only as last resort for cases\n * such as experimental syntax or if certain features could not be contributed upstream.\n *\n * It is still part of the internal API and is versioned, so any changes to it are never\n * considered breaking changes. If you still need to support multiple versions of the\n * library, please use the `versionInfo` variable for version detection.\n *\n * @internal\n */\n\nexport var Parser = /*#__PURE__*/function () {\n function Parser(source, options) {\n var sourceObj = isSource(source) ? source : new Source(source);\n this._lexer = new Lexer(sourceObj);\n this._options = options;\n }\n /**\n * Converts a name lex token into a name parse node.\n */\n\n\n var _proto = Parser.prototype;\n\n _proto.parseName = function parseName() {\n var token = this.expectToken(TokenKind.NAME);\n return {\n kind: Kind.NAME,\n value: token.value,\n loc: this.loc(token)\n };\n } // Implements the parsing rules in the Document section.\n\n /**\n * Document : Definition+\n */\n ;\n\n _proto.parseDocument = function parseDocument() {\n var start = this._lexer.token;\n return {\n kind: Kind.DOCUMENT,\n definitions: this.many(TokenKind.SOF, this.parseDefinition, TokenKind.EOF),\n loc: this.loc(start)\n };\n }\n /**\n * Definition :\n * - ExecutableDefinition\n * - TypeSystemDefinition\n * - TypeSystemExtension\n *\n * ExecutableDefinition :\n * - OperationDefinition\n * - FragmentDefinition\n */\n ;\n\n _proto.parseDefinition = function parseDefinition() {\n if (this.peek(TokenKind.NAME)) {\n switch (this._lexer.token.value) {\n case 'query':\n case 'mutation':\n case 'subscription':\n return this.parseOperationDefinition();\n\n case 'fragment':\n return this.parseFragmentDefinition();\n\n case 'schema':\n case 'scalar':\n case 'type':\n case 'interface':\n case 'union':\n case 'enum':\n case 'input':\n case 'directive':\n return this.parseTypeSystemDefinition();\n\n case 'extend':\n return this.parseTypeSystemExtension();\n }\n } else if (this.peek(TokenKind.BRACE_L)) {\n return this.parseOperationDefinition();\n } else if (this.peekDescription()) {\n return this.parseTypeSystemDefinition();\n }\n\n throw this.unexpected();\n } // Implements the parsing rules in the Operations section.\n\n /**\n * OperationDefinition :\n * - SelectionSet\n * - OperationType Name? VariableDefinitions? Directives? SelectionSet\n */\n ;\n\n _proto.parseOperationDefinition = function parseOperationDefinition() {\n var start = this._lexer.token;\n\n if (this.peek(TokenKind.BRACE_L)) {\n return {\n kind: Kind.OPERATION_DEFINITION,\n operation: 'query',\n name: undefined,\n variableDefinitions: [],\n directives: [],\n selectionSet: this.parseSelectionSet(),\n loc: this.loc(start)\n };\n }\n\n var operation = this.parseOperationType();\n var name;\n\n if (this.peek(TokenKind.NAME)) {\n name = this.parseName();\n }\n\n return {\n kind: Kind.OPERATION_DEFINITION,\n operation: operation,\n name: name,\n variableDefinitions: this.parseVariableDefinitions(),\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n loc: this.loc(start)\n };\n }\n /**\n * OperationType : one of query mutation subscription\n */\n ;\n\n _proto.parseOperationType = function parseOperationType() {\n var operationToken = this.expectToken(TokenKind.NAME);\n\n switch (operationToken.value) {\n case 'query':\n return 'query';\n\n case 'mutation':\n return 'mutation';\n\n case 'subscription':\n return 'subscription';\n }\n\n throw this.unexpected(operationToken);\n }\n /**\n * VariableDefinitions : ( VariableDefinition+ )\n */\n ;\n\n _proto.parseVariableDefinitions = function parseVariableDefinitions() {\n return this.optionalMany(TokenKind.PAREN_L, this.parseVariableDefinition, TokenKind.PAREN_R);\n }\n /**\n * VariableDefinition : Variable : Type DefaultValue? Directives[Const]?\n */\n ;\n\n _proto.parseVariableDefinition = function parseVariableDefinition() {\n var start = this._lexer.token;\n return {\n kind: Kind.VARIABLE_DEFINITION,\n variable: this.parseVariable(),\n type: (this.expectToken(TokenKind.COLON), this.parseTypeReference()),\n defaultValue: this.expectOptionalToken(TokenKind.EQUALS) ? this.parseValueLiteral(true) : undefined,\n directives: this.parseDirectives(true),\n loc: this.loc(start)\n };\n }\n /**\n * Variable : $ Name\n */\n ;\n\n _proto.parseVariable = function parseVariable() {\n var start = this._lexer.token;\n this.expectToken(TokenKind.DOLLAR);\n return {\n kind: Kind.VARIABLE,\n name: this.parseName(),\n loc: this.loc(start)\n };\n }\n /**\n * SelectionSet : { Selection+ }\n */\n ;\n\n _proto.parseSelectionSet = function parseSelectionSet() {\n var start = this._lexer.token;\n return {\n kind: Kind.SELECTION_SET,\n selections: this.many(TokenKind.BRACE_L, this.parseSelection, TokenKind.BRACE_R),\n loc: this.loc(start)\n };\n }\n /**\n * Selection :\n * - Field\n * - FragmentSpread\n * - InlineFragment\n */\n ;\n\n _proto.parseSelection = function parseSelection() {\n return this.peek(TokenKind.SPREAD) ? this.parseFragment() : this.parseField();\n }\n /**\n * Field : Alias? Name Arguments? Directives? SelectionSet?\n *\n * Alias : Name :\n */\n ;\n\n _proto.parseField = function parseField() {\n var start = this._lexer.token;\n var nameOrAlias = this.parseName();\n var alias;\n var name;\n\n if (this.expectOptionalToken(TokenKind.COLON)) {\n alias = nameOrAlias;\n name = this.parseName();\n } else {\n name = nameOrAlias;\n }\n\n return {\n kind: Kind.FIELD,\n alias: alias,\n name: name,\n arguments: this.parseArguments(false),\n directives: this.parseDirectives(false),\n selectionSet: this.peek(TokenKind.BRACE_L) ? this.parseSelectionSet() : undefined,\n loc: this.loc(start)\n };\n }\n /**\n * Arguments[Const] : ( Argument[?Const]+ )\n */\n ;\n\n _proto.parseArguments = function parseArguments(isConst) {\n var item = isConst ? this.parseConstArgument : this.parseArgument;\n return this.optionalMany(TokenKind.PAREN_L, item, TokenKind.PAREN_R);\n }\n /**\n * Argument[Const] : Name : Value[?Const]\n */\n ;\n\n _proto.parseArgument = function parseArgument() {\n var start = this._lexer.token;\n var name = this.parseName();\n this.expectToken(TokenKind.COLON);\n return {\n kind: Kind.ARGUMENT,\n name: name,\n value: this.parseValueLiteral(false),\n loc: this.loc(start)\n };\n };\n\n _proto.parseConstArgument = function parseConstArgument() {\n var start = this._lexer.token;\n return {\n kind: Kind.ARGUMENT,\n name: this.parseName(),\n value: (this.expectToken(TokenKind.COLON), this.parseValueLiteral(true)),\n loc: this.loc(start)\n };\n } // Implements the parsing rules in the Fragments section.\n\n /**\n * Corresponds to both FragmentSpread and InlineFragment in the spec.\n *\n * FragmentSpread : ... FragmentName Directives?\n *\n * InlineFragment : ... TypeCondition? Directives? SelectionSet\n */\n ;\n\n _proto.parseFragment = function parseFragment() {\n var start = this._lexer.token;\n this.expectToken(TokenKind.SPREAD);\n var hasTypeCondition = this.expectOptionalKeyword('on');\n\n if (!hasTypeCondition && this.peek(TokenKind.NAME)) {\n return {\n kind: Kind.FRAGMENT_SPREAD,\n name: this.parseFragmentName(),\n directives: this.parseDirectives(false),\n loc: this.loc(start)\n };\n }\n\n return {\n kind: Kind.INLINE_FRAGMENT,\n typeCondition: hasTypeCondition ? this.parseNamedType() : undefined,\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n loc: this.loc(start)\n };\n }\n /**\n * FragmentDefinition :\n * - fragment FragmentName on TypeCondition Directives? SelectionSet\n *\n * TypeCondition : NamedType\n */\n ;\n\n _proto.parseFragmentDefinition = function parseFragmentDefinition() {\n var _this$_options;\n\n var start = this._lexer.token;\n this.expectKeyword('fragment'); // Experimental support for defining variables within fragments changes\n // the grammar of FragmentDefinition:\n // - fragment FragmentName VariableDefinitions? on TypeCondition Directives? SelectionSet\n\n if (((_this$_options = this._options) === null || _this$_options === void 0 ? void 0 : _this$_options.experimentalFragmentVariables) === true) {\n return {\n kind: Kind.FRAGMENT_DEFINITION,\n name: this.parseFragmentName(),\n variableDefinitions: this.parseVariableDefinitions(),\n typeCondition: (this.expectKeyword('on'), this.parseNamedType()),\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n loc: this.loc(start)\n };\n }\n\n return {\n kind: Kind.FRAGMENT_DEFINITION,\n name: this.parseFragmentName(),\n typeCondition: (this.expectKeyword('on'), this.parseNamedType()),\n directives: this.parseDirectives(false),\n selectionSet: this.parseSelectionSet(),\n loc: this.loc(start)\n };\n }\n /**\n * FragmentName : Name but not `on`\n */\n ;\n\n _proto.parseFragmentName = function parseFragmentName() {\n if (this._lexer.token.value === 'on') {\n throw this.unexpected();\n }\n\n return this.parseName();\n } // Implements the parsing rules in the Values section.\n\n /**\n * Value[Const] :\n * - [~Const] Variable\n * - IntValue\n * - FloatValue\n * - StringValue\n * - BooleanValue\n * - NullValue\n * - EnumValue\n * - ListValue[?Const]\n * - ObjectValue[?Const]\n *\n * BooleanValue : one of `true` `false`\n *\n * NullValue : `null`\n *\n * EnumValue : Name but not `true`, `false` or `null`\n */\n ;\n\n _proto.parseValueLiteral = function parseValueLiteral(isConst) {\n var token = this._lexer.token;\n\n switch (token.kind) {\n case TokenKind.BRACKET_L:\n return this.parseList(isConst);\n\n case TokenKind.BRACE_L:\n return this.parseObject(isConst);\n\n case TokenKind.INT:\n this._lexer.advance();\n\n return {\n kind: Kind.INT,\n value: token.value,\n loc: this.loc(token)\n };\n\n case TokenKind.FLOAT:\n this._lexer.advance();\n\n return {\n kind: Kind.FLOAT,\n value: token.value,\n loc: this.loc(token)\n };\n\n case TokenKind.STRING:\n case TokenKind.BLOCK_STRING:\n return this.parseStringLiteral();\n\n case TokenKind.NAME:\n this._lexer.advance();\n\n switch (token.value) {\n case 'true':\n return {\n kind: Kind.BOOLEAN,\n value: true,\n loc: this.loc(token)\n };\n\n case 'false':\n return {\n kind: Kind.BOOLEAN,\n value: false,\n loc: this.loc(token)\n };\n\n case 'null':\n return {\n kind: Kind.NULL,\n loc: this.loc(token)\n };\n\n default:\n return {\n kind: Kind.ENUM,\n value: token.value,\n loc: this.loc(token)\n };\n }\n\n case TokenKind.DOLLAR:\n if (!isConst) {\n return this.parseVariable();\n }\n\n break;\n }\n\n throw this.unexpected();\n };\n\n _proto.parseStringLiteral = function parseStringLiteral() {\n var token = this._lexer.token;\n\n this._lexer.advance();\n\n return {\n kind: Kind.STRING,\n value: token.value,\n block: token.kind === TokenKind.BLOCK_STRING,\n loc: this.loc(token)\n };\n }\n /**\n * ListValue[Const] :\n * - [ ]\n * - [ Value[?Const]+ ]\n */\n ;\n\n _proto.parseList = function parseList(isConst) {\n var _this = this;\n\n var start = this._lexer.token;\n\n var item = function item() {\n return _this.parseValueLiteral(isConst);\n };\n\n return {\n kind: Kind.LIST,\n values: this.any(TokenKind.BRACKET_L, item, TokenKind.BRACKET_R),\n loc: this.loc(start)\n };\n }\n /**\n * ObjectValue[Const] :\n * - { }\n * - { ObjectField[?Const]+ }\n */\n ;\n\n _proto.parseObject = function parseObject(isConst) {\n var _this2 = this;\n\n var start = this._lexer.token;\n\n var item = function item() {\n return _this2.parseObjectField(isConst);\n };\n\n return {\n kind: Kind.OBJECT,\n fields: this.any(TokenKind.BRACE_L, item, TokenKind.BRACE_R),\n loc: this.loc(start)\n };\n }\n /**\n * ObjectField[Const] : Name : Value[?Const]\n */\n ;\n\n _proto.parseObjectField = function parseObjectField(isConst) {\n var start = this._lexer.token;\n var name = this.parseName();\n this.expectToken(TokenKind.COLON);\n return {\n kind: Kind.OBJECT_FIELD,\n name: name,\n value: this.parseValueLiteral(isConst),\n loc: this.loc(start)\n };\n } // Implements the parsing rules in the Directives section.\n\n /**\n * Directives[Const] : Directive[?Const]+\n */\n ;\n\n _proto.parseDirectives = function parseDirectives(isConst) {\n var directives = [];\n\n while (this.peek(TokenKind.AT)) {\n directives.push(this.parseDirective(isConst));\n }\n\n return directives;\n }\n /**\n * Directive[Const] : @ Name Arguments[?Const]?\n */\n ;\n\n _proto.parseDirective = function parseDirective(isConst) {\n var start = this._lexer.token;\n this.expectToken(TokenKind.AT);\n return {\n kind: Kind.DIRECTIVE,\n name: this.parseName(),\n arguments: this.parseArguments(isConst),\n loc: this.loc(start)\n };\n } // Implements the parsing rules in the Types section.\n\n /**\n * Type :\n * - NamedType\n * - ListType\n * - NonNullType\n */\n ;\n\n _proto.parseTypeReference = function parseTypeReference() {\n var start = this._lexer.token;\n var type;\n\n if (this.expectOptionalToken(TokenKind.BRACKET_L)) {\n type = this.parseTypeReference();\n this.expectToken(TokenKind.BRACKET_R);\n type = {\n kind: Kind.LIST_TYPE,\n type: type,\n loc: this.loc(start)\n };\n } else {\n type = this.parseNamedType();\n }\n\n if (this.expectOptionalToken(TokenKind.BANG)) {\n return {\n kind: Kind.NON_NULL_TYPE,\n type: type,\n loc: this.loc(start)\n };\n }\n\n return type;\n }\n /**\n * NamedType : Name\n */\n ;\n\n _proto.parseNamedType = function parseNamedType() {\n var start = this._lexer.token;\n return {\n kind: Kind.NAMED_TYPE,\n name: this.parseName(),\n loc: this.loc(start)\n };\n } // Implements the parsing rules in the Type Definition section.\n\n /**\n * TypeSystemDefinition :\n * - SchemaDefinition\n * - TypeDefinition\n * - DirectiveDefinition\n *\n * TypeDefinition :\n * - ScalarTypeDefinition\n * - ObjectTypeDefinition\n * - InterfaceTypeDefinition\n * - UnionTypeDefinition\n * - EnumTypeDefinition\n * - InputObjectTypeDefinition\n */\n ;\n\n _proto.parseTypeSystemDefinition = function parseTypeSystemDefinition() {\n // Many definitions begin with a description and require a lookahead.\n var keywordToken = this.peekDescription() ? this._lexer.lookahead() : this._lexer.token;\n\n if (keywordToken.kind === TokenKind.NAME) {\n switch (keywordToken.value) {\n case 'schema':\n return this.parseSchemaDefinition();\n\n case 'scalar':\n return this.parseScalarTypeDefinition();\n\n case 'type':\n return this.parseObjectTypeDefinition();\n\n case 'interface':\n return this.parseInterfaceTypeDefinition();\n\n case 'union':\n return this.parseUnionTypeDefinition();\n\n case 'enum':\n return this.parseEnumTypeDefinition();\n\n case 'input':\n return this.parseInputObjectTypeDefinition();\n\n case 'directive':\n return this.parseDirectiveDefinition();\n }\n }\n\n throw this.unexpected(keywordToken);\n };\n\n _proto.peekDescription = function peekDescription() {\n return this.peek(TokenKind.STRING) || this.peek(TokenKind.BLOCK_STRING);\n }\n /**\n * Description : StringValue\n */\n ;\n\n _proto.parseDescription = function parseDescription() {\n if (this.peekDescription()) {\n return this.parseStringLiteral();\n }\n }\n /**\n * SchemaDefinition : Description? schema Directives[Const]? { OperationTypeDefinition+ }\n */\n ;\n\n _proto.parseSchemaDefinition = function parseSchemaDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('schema');\n var directives = this.parseDirectives(true);\n var operationTypes = this.many(TokenKind.BRACE_L, this.parseOperationTypeDefinition, TokenKind.BRACE_R);\n return {\n kind: Kind.SCHEMA_DEFINITION,\n description: description,\n directives: directives,\n operationTypes: operationTypes,\n loc: this.loc(start)\n };\n }\n /**\n * OperationTypeDefinition : OperationType : NamedType\n */\n ;\n\n _proto.parseOperationTypeDefinition = function parseOperationTypeDefinition() {\n var start = this._lexer.token;\n var operation = this.parseOperationType();\n this.expectToken(TokenKind.COLON);\n var type = this.parseNamedType();\n return {\n kind: Kind.OPERATION_TYPE_DEFINITION,\n operation: operation,\n type: type,\n loc: this.loc(start)\n };\n }\n /**\n * ScalarTypeDefinition : Description? scalar Name Directives[Const]?\n */\n ;\n\n _proto.parseScalarTypeDefinition = function parseScalarTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('scalar');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n return {\n kind: Kind.SCALAR_TYPE_DEFINITION,\n description: description,\n name: name,\n directives: directives,\n loc: this.loc(start)\n };\n }\n /**\n * ObjectTypeDefinition :\n * Description?\n * type Name ImplementsInterfaces? Directives[Const]? FieldsDefinition?\n */\n ;\n\n _proto.parseObjectTypeDefinition = function parseObjectTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('type');\n var name = this.parseName();\n var interfaces = this.parseImplementsInterfaces();\n var directives = this.parseDirectives(true);\n var fields = this.parseFieldsDefinition();\n return {\n kind: Kind.OBJECT_TYPE_DEFINITION,\n description: description,\n name: name,\n interfaces: interfaces,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * ImplementsInterfaces :\n * - implements `&`? NamedType\n * - ImplementsInterfaces & NamedType\n */\n ;\n\n _proto.parseImplementsInterfaces = function parseImplementsInterfaces() {\n var _this$_options2;\n\n if (!this.expectOptionalKeyword('implements')) {\n return [];\n }\n\n if (((_this$_options2 = this._options) === null || _this$_options2 === void 0 ? void 0 : _this$_options2.allowLegacySDLImplementsInterfaces) === true) {\n var types = []; // Optional leading ampersand\n\n this.expectOptionalToken(TokenKind.AMP);\n\n do {\n types.push(this.parseNamedType());\n } while (this.expectOptionalToken(TokenKind.AMP) || this.peek(TokenKind.NAME));\n\n return types;\n }\n\n return this.delimitedMany(TokenKind.AMP, this.parseNamedType);\n }\n /**\n * FieldsDefinition : { FieldDefinition+ }\n */\n ;\n\n _proto.parseFieldsDefinition = function parseFieldsDefinition() {\n var _this$_options3;\n\n // Legacy support for the SDL?\n if (((_this$_options3 = this._options) === null || _this$_options3 === void 0 ? void 0 : _this$_options3.allowLegacySDLEmptyFields) === true && this.peek(TokenKind.BRACE_L) && this._lexer.lookahead().kind === TokenKind.BRACE_R) {\n this._lexer.advance();\n\n this._lexer.advance();\n\n return [];\n }\n\n return this.optionalMany(TokenKind.BRACE_L, this.parseFieldDefinition, TokenKind.BRACE_R);\n }\n /**\n * FieldDefinition :\n * - Description? Name ArgumentsDefinition? : Type Directives[Const]?\n */\n ;\n\n _proto.parseFieldDefinition = function parseFieldDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n var name = this.parseName();\n var args = this.parseArgumentDefs();\n this.expectToken(TokenKind.COLON);\n var type = this.parseTypeReference();\n var directives = this.parseDirectives(true);\n return {\n kind: Kind.FIELD_DEFINITION,\n description: description,\n name: name,\n arguments: args,\n type: type,\n directives: directives,\n loc: this.loc(start)\n };\n }\n /**\n * ArgumentsDefinition : ( InputValueDefinition+ )\n */\n ;\n\n _proto.parseArgumentDefs = function parseArgumentDefs() {\n return this.optionalMany(TokenKind.PAREN_L, this.parseInputValueDef, TokenKind.PAREN_R);\n }\n /**\n * InputValueDefinition :\n * - Description? Name : Type DefaultValue? Directives[Const]?\n */\n ;\n\n _proto.parseInputValueDef = function parseInputValueDef() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n var name = this.parseName();\n this.expectToken(TokenKind.COLON);\n var type = this.parseTypeReference();\n var defaultValue;\n\n if (this.expectOptionalToken(TokenKind.EQUALS)) {\n defaultValue = this.parseValueLiteral(true);\n }\n\n var directives = this.parseDirectives(true);\n return {\n kind: Kind.INPUT_VALUE_DEFINITION,\n description: description,\n name: name,\n type: type,\n defaultValue: defaultValue,\n directives: directives,\n loc: this.loc(start)\n };\n }\n /**\n * InterfaceTypeDefinition :\n * - Description? interface Name Directives[Const]? FieldsDefinition?\n */\n ;\n\n _proto.parseInterfaceTypeDefinition = function parseInterfaceTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('interface');\n var name = this.parseName();\n var interfaces = this.parseImplementsInterfaces();\n var directives = this.parseDirectives(true);\n var fields = this.parseFieldsDefinition();\n return {\n kind: Kind.INTERFACE_TYPE_DEFINITION,\n description: description,\n name: name,\n interfaces: interfaces,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * UnionTypeDefinition :\n * - Description? union Name Directives[Const]? UnionMemberTypes?\n */\n ;\n\n _proto.parseUnionTypeDefinition = function parseUnionTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('union');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var types = this.parseUnionMemberTypes();\n return {\n kind: Kind.UNION_TYPE_DEFINITION,\n description: description,\n name: name,\n directives: directives,\n types: types,\n loc: this.loc(start)\n };\n }\n /**\n * UnionMemberTypes :\n * - = `|`? NamedType\n * - UnionMemberTypes | NamedType\n */\n ;\n\n _proto.parseUnionMemberTypes = function parseUnionMemberTypes() {\n return this.expectOptionalToken(TokenKind.EQUALS) ? this.delimitedMany(TokenKind.PIPE, this.parseNamedType) : [];\n }\n /**\n * EnumTypeDefinition :\n * - Description? enum Name Directives[Const]? EnumValuesDefinition?\n */\n ;\n\n _proto.parseEnumTypeDefinition = function parseEnumTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('enum');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var values = this.parseEnumValuesDefinition();\n return {\n kind: Kind.ENUM_TYPE_DEFINITION,\n description: description,\n name: name,\n directives: directives,\n values: values,\n loc: this.loc(start)\n };\n }\n /**\n * EnumValuesDefinition : { EnumValueDefinition+ }\n */\n ;\n\n _proto.parseEnumValuesDefinition = function parseEnumValuesDefinition() {\n return this.optionalMany(TokenKind.BRACE_L, this.parseEnumValueDefinition, TokenKind.BRACE_R);\n }\n /**\n * EnumValueDefinition : Description? EnumValue Directives[Const]?\n *\n * EnumValue : Name\n */\n ;\n\n _proto.parseEnumValueDefinition = function parseEnumValueDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n return {\n kind: Kind.ENUM_VALUE_DEFINITION,\n description: description,\n name: name,\n directives: directives,\n loc: this.loc(start)\n };\n }\n /**\n * InputObjectTypeDefinition :\n * - Description? input Name Directives[Const]? InputFieldsDefinition?\n */\n ;\n\n _proto.parseInputObjectTypeDefinition = function parseInputObjectTypeDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('input');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var fields = this.parseInputFieldsDefinition();\n return {\n kind: Kind.INPUT_OBJECT_TYPE_DEFINITION,\n description: description,\n name: name,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * InputFieldsDefinition : { InputValueDefinition+ }\n */\n ;\n\n _proto.parseInputFieldsDefinition = function parseInputFieldsDefinition() {\n return this.optionalMany(TokenKind.BRACE_L, this.parseInputValueDef, TokenKind.BRACE_R);\n }\n /**\n * TypeSystemExtension :\n * - SchemaExtension\n * - TypeExtension\n *\n * TypeExtension :\n * - ScalarTypeExtension\n * - ObjectTypeExtension\n * - InterfaceTypeExtension\n * - UnionTypeExtension\n * - EnumTypeExtension\n * - InputObjectTypeDefinition\n */\n ;\n\n _proto.parseTypeSystemExtension = function parseTypeSystemExtension() {\n var keywordToken = this._lexer.lookahead();\n\n if (keywordToken.kind === TokenKind.NAME) {\n switch (keywordToken.value) {\n case 'schema':\n return this.parseSchemaExtension();\n\n case 'scalar':\n return this.parseScalarTypeExtension();\n\n case 'type':\n return this.parseObjectTypeExtension();\n\n case 'interface':\n return this.parseInterfaceTypeExtension();\n\n case 'union':\n return this.parseUnionTypeExtension();\n\n case 'enum':\n return this.parseEnumTypeExtension();\n\n case 'input':\n return this.parseInputObjectTypeExtension();\n }\n }\n\n throw this.unexpected(keywordToken);\n }\n /**\n * SchemaExtension :\n * - extend schema Directives[Const]? { OperationTypeDefinition+ }\n * - extend schema Directives[Const]\n */\n ;\n\n _proto.parseSchemaExtension = function parseSchemaExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('schema');\n var directives = this.parseDirectives(true);\n var operationTypes = this.optionalMany(TokenKind.BRACE_L, this.parseOperationTypeDefinition, TokenKind.BRACE_R);\n\n if (directives.length === 0 && operationTypes.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.SCHEMA_EXTENSION,\n directives: directives,\n operationTypes: operationTypes,\n loc: this.loc(start)\n };\n }\n /**\n * ScalarTypeExtension :\n * - extend scalar Name Directives[Const]\n */\n ;\n\n _proto.parseScalarTypeExtension = function parseScalarTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('scalar');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n\n if (directives.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.SCALAR_TYPE_EXTENSION,\n name: name,\n directives: directives,\n loc: this.loc(start)\n };\n }\n /**\n * ObjectTypeExtension :\n * - extend type Name ImplementsInterfaces? Directives[Const]? FieldsDefinition\n * - extend type Name ImplementsInterfaces? Directives[Const]\n * - extend type Name ImplementsInterfaces\n */\n ;\n\n _proto.parseObjectTypeExtension = function parseObjectTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('type');\n var name = this.parseName();\n var interfaces = this.parseImplementsInterfaces();\n var directives = this.parseDirectives(true);\n var fields = this.parseFieldsDefinition();\n\n if (interfaces.length === 0 && directives.length === 0 && fields.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.OBJECT_TYPE_EXTENSION,\n name: name,\n interfaces: interfaces,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * InterfaceTypeExtension :\n * - extend interface Name ImplementsInterfaces? Directives[Const]? FieldsDefinition\n * - extend interface Name ImplementsInterfaces? Directives[Const]\n * - extend interface Name ImplementsInterfaces\n */\n ;\n\n _proto.parseInterfaceTypeExtension = function parseInterfaceTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('interface');\n var name = this.parseName();\n var interfaces = this.parseImplementsInterfaces();\n var directives = this.parseDirectives(true);\n var fields = this.parseFieldsDefinition();\n\n if (interfaces.length === 0 && directives.length === 0 && fields.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.INTERFACE_TYPE_EXTENSION,\n name: name,\n interfaces: interfaces,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * UnionTypeExtension :\n * - extend union Name Directives[Const]? UnionMemberTypes\n * - extend union Name Directives[Const]\n */\n ;\n\n _proto.parseUnionTypeExtension = function parseUnionTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('union');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var types = this.parseUnionMemberTypes();\n\n if (directives.length === 0 && types.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.UNION_TYPE_EXTENSION,\n name: name,\n directives: directives,\n types: types,\n loc: this.loc(start)\n };\n }\n /**\n * EnumTypeExtension :\n * - extend enum Name Directives[Const]? EnumValuesDefinition\n * - extend enum Name Directives[Const]\n */\n ;\n\n _proto.parseEnumTypeExtension = function parseEnumTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('enum');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var values = this.parseEnumValuesDefinition();\n\n if (directives.length === 0 && values.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.ENUM_TYPE_EXTENSION,\n name: name,\n directives: directives,\n values: values,\n loc: this.loc(start)\n };\n }\n /**\n * InputObjectTypeExtension :\n * - extend input Name Directives[Const]? InputFieldsDefinition\n * - extend input Name Directives[Const]\n */\n ;\n\n _proto.parseInputObjectTypeExtension = function parseInputObjectTypeExtension() {\n var start = this._lexer.token;\n this.expectKeyword('extend');\n this.expectKeyword('input');\n var name = this.parseName();\n var directives = this.parseDirectives(true);\n var fields = this.parseInputFieldsDefinition();\n\n if (directives.length === 0 && fields.length === 0) {\n throw this.unexpected();\n }\n\n return {\n kind: Kind.INPUT_OBJECT_TYPE_EXTENSION,\n name: name,\n directives: directives,\n fields: fields,\n loc: this.loc(start)\n };\n }\n /**\n * DirectiveDefinition :\n * - Description? directive @ Name ArgumentsDefinition? `repeatable`? on DirectiveLocations\n */\n ;\n\n _proto.parseDirectiveDefinition = function parseDirectiveDefinition() {\n var start = this._lexer.token;\n var description = this.parseDescription();\n this.expectKeyword('directive');\n this.expectToken(TokenKind.AT);\n var name = this.parseName();\n var args = this.parseArgumentDefs();\n var repeatable = this.expectOptionalKeyword('repeatable');\n this.expectKeyword('on');\n var locations = this.parseDirectiveLocations();\n return {\n kind: Kind.DIRECTIVE_DEFINITION,\n description: description,\n name: name,\n arguments: args,\n repeatable: repeatable,\n locations: locations,\n loc: this.loc(start)\n };\n }\n /**\n * DirectiveLocations :\n * - `|`? DirectiveLocation\n * - DirectiveLocations | DirectiveLocation\n */\n ;\n\n _proto.parseDirectiveLocations = function parseDirectiveLocations() {\n return this.delimitedMany(TokenKind.PIPE, this.parseDirectiveLocation);\n }\n /*\n * DirectiveLocation :\n * - ExecutableDirectiveLocation\n * - TypeSystemDirectiveLocation\n *\n * ExecutableDirectiveLocation : one of\n * `QUERY`\n * `MUTATION`\n * `SUBSCRIPTION`\n * `FIELD`\n * `FRAGMENT_DEFINITION`\n * `FRAGMENT_SPREAD`\n * `INLINE_FRAGMENT`\n *\n * TypeSystemDirectiveLocation : one of\n * `SCHEMA`\n * `SCALAR`\n * `OBJECT`\n * `FIELD_DEFINITION`\n * `ARGUMENT_DEFINITION`\n * `INTERFACE`\n * `UNION`\n * `ENUM`\n * `ENUM_VALUE`\n * `INPUT_OBJECT`\n * `INPUT_FIELD_DEFINITION`\n */\n ;\n\n _proto.parseDirectiveLocation = function parseDirectiveLocation() {\n var start = this._lexer.token;\n var name = this.parseName();\n\n if (DirectiveLocation[name.value] !== undefined) {\n return name;\n }\n\n throw this.unexpected(start);\n } // Core parsing utility functions\n\n /**\n * Returns a location object, used to identify the place in the source that created a given parsed object.\n */\n ;\n\n _proto.loc = function loc(startToken) {\n var _this$_options4;\n\n if (((_this$_options4 = this._options) === null || _this$_options4 === void 0 ? void 0 : _this$_options4.noLocation) !== true) {\n return new Location(startToken, this._lexer.lastToken, this._lexer.source);\n }\n }\n /**\n * Determines if the next token is of a given kind\n */\n ;\n\n _proto.peek = function peek(kind) {\n return this._lexer.token.kind === kind;\n }\n /**\n * If the next token is of the given kind, return that token after advancing the lexer.\n * Otherwise, do not change the parser state and throw an error.\n */\n ;\n\n _proto.expectToken = function expectToken(kind) {\n var token = this._lexer.token;\n\n if (token.kind === kind) {\n this._lexer.advance();\n\n return token;\n }\n\n throw syntaxError(this._lexer.source, token.start, \"Expected \".concat(getTokenKindDesc(kind), \", found \").concat(getTokenDesc(token), \".\"));\n }\n /**\n * If the next token is of the given kind, return that token after advancing the lexer.\n * Otherwise, do not change the parser state and return undefined.\n */\n ;\n\n _proto.expectOptionalToken = function expectOptionalToken(kind) {\n var token = this._lexer.token;\n\n if (token.kind === kind) {\n this._lexer.advance();\n\n return token;\n }\n\n return undefined;\n }\n /**\n * If the next token is a given keyword, advance the lexer.\n * Otherwise, do not change the parser state and throw an error.\n */\n ;\n\n _proto.expectKeyword = function expectKeyword(value) {\n var token = this._lexer.token;\n\n if (token.kind === TokenKind.NAME && token.value === value) {\n this._lexer.advance();\n } else {\n throw syntaxError(this._lexer.source, token.start, \"Expected \\\"\".concat(value, \"\\\", found \").concat(getTokenDesc(token), \".\"));\n }\n }\n /**\n * If the next token is a given keyword, return \"true\" after advancing the lexer.\n * Otherwise, do not change the parser state and return \"false\".\n */\n ;\n\n _proto.expectOptionalKeyword = function expectOptionalKeyword(value) {\n var token = this._lexer.token;\n\n if (token.kind === TokenKind.NAME && token.value === value) {\n this._lexer.advance();\n\n return true;\n }\n\n return false;\n }\n /**\n * Helper function for creating an error when an unexpected lexed token is encountered.\n */\n ;\n\n _proto.unexpected = function unexpected(atToken) {\n var token = atToken !== null && atToken !== void 0 ? atToken : this._lexer.token;\n return syntaxError(this._lexer.source, token.start, \"Unexpected \".concat(getTokenDesc(token), \".\"));\n }\n /**\n * Returns a possibly empty list of parse nodes, determined by the parseFn.\n * This list begins with a lex token of openKind and ends with a lex token of closeKind.\n * Advances the parser to the next lex token after the closing token.\n */\n ;\n\n _proto.any = function any(openKind, parseFn, closeKind) {\n this.expectToken(openKind);\n var nodes = [];\n\n while (!this.expectOptionalToken(closeKind)) {\n nodes.push(parseFn.call(this));\n }\n\n return nodes;\n }\n /**\n * Returns a list of parse nodes, determined by the parseFn.\n * It can be empty only if open token is missing otherwise it will always return non-empty list\n * that begins with a lex token of openKind and ends with a lex token of closeKind.\n * Advances the parser to the next lex token after the closing token.\n */\n ;\n\n _proto.optionalMany = function optionalMany(openKind, parseFn, closeKind) {\n if (this.expectOptionalToken(openKind)) {\n var nodes = [];\n\n do {\n nodes.push(parseFn.call(this));\n } while (!this.expectOptionalToken(closeKind));\n\n return nodes;\n }\n\n return [];\n }\n /**\n * Returns a non-empty list of parse nodes, determined by the parseFn.\n * This list begins with a lex token of openKind and ends with a lex token of closeKind.\n * Advances the parser to the next lex token after the closing token.\n */\n ;\n\n _proto.many = function many(openKind, parseFn, closeKind) {\n this.expectToken(openKind);\n var nodes = [];\n\n do {\n nodes.push(parseFn.call(this));\n } while (!this.expectOptionalToken(closeKind));\n\n return nodes;\n }\n /**\n * Returns a non-empty list of parse nodes, determined by the parseFn.\n * This list may begin with a lex token of delimiterKind followed by items separated by lex tokens of tokenKind.\n * Advances the parser to the next lex token after last item in the list.\n */\n ;\n\n _proto.delimitedMany = function delimitedMany(delimiterKind, parseFn) {\n this.expectOptionalToken(delimiterKind);\n var nodes = [];\n\n do {\n nodes.push(parseFn.call(this));\n } while (this.expectOptionalToken(delimiterKind));\n\n return nodes;\n };\n\n return Parser;\n}();\n/**\n * A helper function to describe a token as a string for debugging.\n */\n\nfunction getTokenDesc(token) {\n var value = token.value;\n return getTokenKindDesc(token.kind) + (value != null ? \" \\\"\".concat(value, \"\\\"\") : '');\n}\n/**\n * A helper function to describe a token kind as a string for debugging.\n */\n\n\nfunction getTokenKindDesc(kind) {\n return isPunctuatorTokenKind(kind) ? \"\\\"\".concat(kind, \"\\\"\") : kind;\n}\n","import { __assign } from \"tslib\";\nimport { parse } from 'graphql';\nvar docCache = new Map();\nvar fragmentSourceMap = new Map();\nvar printFragmentWarnings = true;\nvar experimentalFragmentVariables = false;\nfunction normalize(string) {\n return string.replace(/[\\s,]+/g, ' ').trim();\n}\nfunction cacheKeyFromLoc(loc) {\n return normalize(loc.source.body.substring(loc.start, loc.end));\n}\nfunction processFragments(ast) {\n var seenKeys = new Set();\n var definitions = [];\n ast.definitions.forEach(function (fragmentDefinition) {\n if (fragmentDefinition.kind === 'FragmentDefinition') {\n var fragmentName = fragmentDefinition.name.value;\n var sourceKey = cacheKeyFromLoc(fragmentDefinition.loc);\n var sourceKeySet = fragmentSourceMap.get(fragmentName);\n if (sourceKeySet && !sourceKeySet.has(sourceKey)) {\n if (printFragmentWarnings) {\n console.warn(\"Warning: fragment with name \" + fragmentName + \" already exists.\\n\"\n + \"graphql-tag enforces all fragment names across your application to be unique; read more about\\n\"\n + \"this in the docs: http://dev.apollodata.com/core/fragments.html#unique-names\");\n }\n }\n else if (!sourceKeySet) {\n fragmentSourceMap.set(fragmentName, sourceKeySet = new Set);\n }\n sourceKeySet.add(sourceKey);\n if (!seenKeys.has(sourceKey)) {\n seenKeys.add(sourceKey);\n definitions.push(fragmentDefinition);\n }\n }\n else {\n definitions.push(fragmentDefinition);\n }\n });\n return __assign(__assign({}, ast), { definitions: definitions });\n}\nfunction stripLoc(doc) {\n var workSet = new Set(doc.definitions);\n workSet.forEach(function (node) {\n if (node.loc)\n delete node.loc;\n Object.keys(node).forEach(function (key) {\n var value = node[key];\n if (value && typeof value === 'object') {\n workSet.add(value);\n }\n });\n });\n var loc = doc.loc;\n if (loc) {\n delete loc.startToken;\n delete loc.endToken;\n }\n return doc;\n}\nfunction parseDocument(source) {\n var cacheKey = normalize(source);\n if (!docCache.has(cacheKey)) {\n var parsed = parse(source, {\n experimentalFragmentVariables: experimentalFragmentVariables,\n allowLegacyFragmentVariables: experimentalFragmentVariables\n });\n if (!parsed || parsed.kind !== 'Document') {\n throw new Error('Not a valid GraphQL document.');\n }\n docCache.set(cacheKey, stripLoc(processFragments(parsed)));\n }\n return docCache.get(cacheKey);\n}\nexport function gql(literals) {\n var args = [];\n for (var _i = 1; _i < arguments.length; _i++) {\n args[_i - 1] = arguments[_i];\n }\n if (typeof literals === 'string') {\n literals = [literals];\n }\n var result = literals[0];\n args.forEach(function (arg, i) {\n if (arg && arg.kind === 'Document') {\n result += arg.loc.source.body;\n }\n else {\n result += arg;\n }\n result += literals[i + 1];\n });\n return parseDocument(result);\n}\nexport function resetCaches() {\n docCache.clear();\n fragmentSourceMap.clear();\n}\nexport function disableFragmentWarnings() {\n printFragmentWarnings = false;\n}\nexport function enableExperimentalFragmentVariables() {\n experimentalFragmentVariables = true;\n}\nexport function disableExperimentalFragmentVariables() {\n experimentalFragmentVariables = false;\n}\nvar extras = {\n gql: gql,\n resetCaches: resetCaches,\n disableFragmentWarnings: disableFragmentWarnings,\n enableExperimentalFragmentVariables: enableExperimentalFragmentVariables,\n disableExperimentalFragmentVariables: disableExperimentalFragmentVariables\n};\n(function (gql_1) {\n gql_1.gql = extras.gql, gql_1.resetCaches = extras.resetCaches, gql_1.disableFragmentWarnings = extras.disableFragmentWarnings, gql_1.enableExperimentalFragmentVariables = extras.enableExperimentalFragmentVariables, gql_1.disableExperimentalFragmentVariables = extras.disableExperimentalFragmentVariables;\n})(gql || (gql = {}));\ngql[\"default\"] = gql;\nexport default gql;\n//# sourceMappingURL=index.js.map","function _extends() {\n return _extends = Object.assign ? Object.assign.bind() : function (n) {\n for (var e = 1; e < arguments.length; e++) {\n var t = arguments[e];\n for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);\n }\n return n;\n }, _extends.apply(null, arguments);\n}\nexport { _extends as default };","function isAbsolute(pathname) {\n return pathname.charAt(0) === '/';\n}\n\n// About 1.5x faster than the two-arg version of Array#splice()\nfunction spliceOne(list, index) {\n for (var i = index, k = i + 1, n = list.length; k < n; i += 1, k += 1) {\n list[i] = list[k];\n }\n\n list.pop();\n}\n\n// This implementation is based heavily on node's url.parse\nfunction resolvePathname(to, from) {\n if (from === undefined) from = '';\n\n var toParts = (to && to.split('/')) || [];\n var fromParts = (from && from.split('/')) || [];\n\n var isToAbs = to && isAbsolute(to);\n var isFromAbs = from && isAbsolute(from);\n var mustEndAbs = isToAbs || isFromAbs;\n\n if (to && isAbsolute(to)) {\n // to is absolute\n fromParts = toParts;\n } else if (toParts.length) {\n // to is relative, drop the filename\n fromParts.pop();\n fromParts = fromParts.concat(toParts);\n }\n\n if (!fromParts.length) return '/';\n\n var hasTrailingSlash;\n if (fromParts.length) {\n var last = fromParts[fromParts.length - 1];\n hasTrailingSlash = last === '.' || last === '..' || last === '';\n } else {\n hasTrailingSlash = false;\n }\n\n var up = 0;\n for (var i = fromParts.length; i >= 0; i--) {\n var part = fromParts[i];\n\n if (part === '.') {\n spliceOne(fromParts, i);\n } else if (part === '..') {\n spliceOne(fromParts, i);\n up++;\n } else if (up) {\n spliceOne(fromParts, i);\n up--;\n }\n }\n\n if (!mustEndAbs) for (; up--; up) fromParts.unshift('..');\n\n if (\n mustEndAbs &&\n fromParts[0] !== '' &&\n (!fromParts[0] || !isAbsolute(fromParts[0]))\n )\n fromParts.unshift('');\n\n var result = fromParts.join('/');\n\n if (hasTrailingSlash && result.substr(-1) !== '/') result += '/';\n\n return result;\n}\n\nexport default resolvePathname;\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport resolvePathname from 'resolve-pathname';\nimport valueEqual from 'value-equal';\nimport warning from 'tiny-warning';\nimport invariant from 'tiny-invariant';\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === '/' ? path : '/' + path;\n}\nfunction stripLeadingSlash(path) {\n return path.charAt(0) === '/' ? path.substr(1) : path;\n}\nfunction hasBasename(path, prefix) {\n return path.toLowerCase().indexOf(prefix.toLowerCase()) === 0 && '/?#'.indexOf(path.charAt(prefix.length)) !== -1;\n}\nfunction stripBasename(path, prefix) {\n return hasBasename(path, prefix) ? path.substr(prefix.length) : path;\n}\nfunction stripTrailingSlash(path) {\n return path.charAt(path.length - 1) === '/' ? path.slice(0, -1) : path;\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}\nfunction createPath(location) {\n var pathname = location.pathname,\n search = location.search,\n hash = location.hash;\n var path = pathname || '/';\n if (search && search !== '?') path += search.charAt(0) === '?' ? search : \"?\" + search;\n if (hash && hash !== '#') path += hash.charAt(0) === '#' ? hash : \"#\" + hash;\n return path;\n}\n\nfunction createLocation(path, state, key, currentLocation) {\n var location;\n\n if (typeof path === 'string') {\n // Two-arg form: push(path, state)\n location = parsePath(path);\n location.state = state;\n } else {\n // One-arg form: push(location)\n location = _extends({}, path);\n if (location.pathname === undefined) location.pathname = '';\n\n if (location.search) {\n if (location.search.charAt(0) !== '?') location.search = '?' + location.search;\n } else {\n location.search = '';\n }\n\n if (location.hash) {\n if (location.hash.charAt(0) !== '#') location.hash = '#' + location.hash;\n } else {\n location.hash = '';\n }\n\n if (state !== undefined && location.state === undefined) location.state = state;\n }\n\n try {\n location.pathname = decodeURI(location.pathname);\n } catch (e) {\n if (e instanceof URIError) {\n throw new URIError('Pathname \"' + location.pathname + '\" could not be decoded. ' + 'This is likely caused by an invalid percent-encoding.');\n } else {\n throw e;\n }\n }\n\n if (key) location.key = key;\n\n if (currentLocation) {\n // Resolve incomplete/relative pathname relative to current location.\n if (!location.pathname) {\n location.pathname = currentLocation.pathname;\n } else if (location.pathname.charAt(0) !== '/') {\n location.pathname = resolvePathname(location.pathname, currentLocation.pathname);\n }\n } else {\n // When there is no prior location and pathname is empty, set it to /\n if (!location.pathname) {\n location.pathname = '/';\n }\n }\n\n return location;\n}\nfunction locationsAreEqual(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash && a.key === b.key && valueEqual(a.state, b.state);\n}\n\nfunction createTransitionManager() {\n var prompt = null;\n\n function setPrompt(nextPrompt) {\n process.env.NODE_ENV !== \"production\" ? warning(prompt == null, 'A history supports only one prompt at a time') : void 0;\n prompt = nextPrompt;\n return function () {\n if (prompt === nextPrompt) prompt = null;\n };\n }\n\n function confirmTransitionTo(location, action, getUserConfirmation, callback) {\n // TODO: If another transition starts while we're still confirming\n // the previous one, we may end up in a weird state. Figure out the\n // best way to handle this.\n if (prompt != null) {\n var result = typeof prompt === 'function' ? prompt(location, action) : prompt;\n\n if (typeof result === 'string') {\n if (typeof getUserConfirmation === 'function') {\n getUserConfirmation(result, callback);\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'A history needs a getUserConfirmation function in order to use a prompt message') : void 0;\n callback(true);\n }\n } else {\n // Return false from a transition hook to cancel the transition.\n callback(result !== false);\n }\n } else {\n callback(true);\n }\n }\n\n var listeners = [];\n\n function appendListener(fn) {\n var isActive = true;\n\n function listener() {\n if (isActive) fn.apply(void 0, arguments);\n }\n\n listeners.push(listener);\n return function () {\n isActive = false;\n listeners = listeners.filter(function (item) {\n return item !== listener;\n });\n };\n }\n\n function notifyListeners() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n listeners.forEach(function (listener) {\n return listener.apply(void 0, args);\n });\n }\n\n return {\n setPrompt: setPrompt,\n confirmTransitionTo: confirmTransitionTo,\n appendListener: appendListener,\n notifyListeners: notifyListeners\n };\n}\n\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nfunction getConfirmation(message, callback) {\n callback(window.confirm(message)); // eslint-disable-line no-alert\n}\n/**\n * Returns true if the HTML5 history API is supported. Taken from Modernizr.\n *\n * https://github.com/Modernizr/Modernizr/blob/master/LICENSE\n * https://github.com/Modernizr/Modernizr/blob/master/feature-detects/history.js\n * changed to avoid false negatives for Windows Phones: https://github.com/reactjs/react-router/issues/586\n */\n\nfunction supportsHistory() {\n var ua = window.navigator.userAgent;\n if ((ua.indexOf('Android 2.') !== -1 || ua.indexOf('Android 4.0') !== -1) && ua.indexOf('Mobile Safari') !== -1 && ua.indexOf('Chrome') === -1 && ua.indexOf('Windows Phone') === -1) return false;\n return window.history && 'pushState' in window.history;\n}\n/**\n * Returns true if browser fires popstate on hash change.\n * IE10 and IE11 do not.\n */\n\nfunction supportsPopStateOnHashChange() {\n return window.navigator.userAgent.indexOf('Trident') === -1;\n}\n/**\n * Returns false if using go(n) with hash history causes a full page reload.\n */\n\nfunction supportsGoWithoutReloadUsingHash() {\n return window.navigator.userAgent.indexOf('Firefox') === -1;\n}\n/**\n * Returns true if a given popstate event is an extraneous WebKit event.\n * Accounts for the fact that Chrome on iOS fires real popstate events\n * containing undefined state when pressing the back button.\n */\n\nfunction isExtraneousPopstateEvent(event) {\n return event.state === undefined && navigator.userAgent.indexOf('CriOS') === -1;\n}\n\nvar PopStateEvent = 'popstate';\nvar HashChangeEvent = 'hashchange';\n\nfunction getHistoryState() {\n try {\n return window.history.state || {};\n } catch (e) {\n // IE 11 sometimes throws when accessing window.history.state\n // See https://github.com/ReactTraining/history/pull/289\n return {};\n }\n}\n/**\n * Creates a history object that uses the HTML5 history API including\n * pushState, replaceState, and the popstate event.\n */\n\n\nfunction createBrowserHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Browser history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canUseHistory = supportsHistory();\n var needsHashChangeListener = !supportsPopStateOnHashChange();\n var _props = props,\n _props$forceRefresh = _props.forceRefresh,\n forceRefresh = _props$forceRefresh === void 0 ? false : _props$forceRefresh,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n\n function getDOMLocation(historyState) {\n var _ref = historyState || {},\n key = _ref.key,\n state = _ref.state;\n\n var _window$location = window.location,\n pathname = _window$location.pathname,\n search = _window$location.search,\n hash = _window$location.hash;\n var path = pathname + search + hash;\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path, state, key);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function handlePopState(event) {\n // Ignore extraneous popstate events in WebKit.\n if (isExtraneousPopstateEvent(event)) return;\n handlePop(getDOMLocation(event.state));\n }\n\n function handleHashChange() {\n handlePop(getDOMLocation(getHistoryState()));\n }\n\n var forceNextPop = false;\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of keys we've seen in sessionStorage.\n // Instead, we just default to 0 for keys we don't know.\n\n var toIndex = allKeys.indexOf(toLocation.key);\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allKeys.indexOf(fromLocation.key);\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n }\n\n var initialLocation = getDOMLocation(getHistoryState());\n var allKeys = [initialLocation.key]; // Public interface\n\n function createHref(location) {\n return basename + createPath(location);\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.pushState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.href = href;\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n var nextKeys = allKeys.slice(0, prevIndex + 1);\n nextKeys.push(location.key);\n allKeys = nextKeys;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot push state in browsers that do not support HTML5 history') : void 0;\n window.location.href = href;\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.replaceState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.replace(href);\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n if (prevIndex !== -1) allKeys[prevIndex] = location.key;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot replace state in browsers that do not support HTML5 history') : void 0;\n window.location.replace(href);\n }\n });\n }\n\n function go(n) {\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.addEventListener(HashChangeEvent, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.removeEventListener(HashChangeEvent, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nvar HashChangeEvent$1 = 'hashchange';\nvar HashPathCoders = {\n hashbang: {\n encodePath: function encodePath(path) {\n return path.charAt(0) === '!' ? path : '!/' + stripLeadingSlash(path);\n },\n decodePath: function decodePath(path) {\n return path.charAt(0) === '!' ? path.substr(1) : path;\n }\n },\n noslash: {\n encodePath: stripLeadingSlash,\n decodePath: addLeadingSlash\n },\n slash: {\n encodePath: addLeadingSlash,\n decodePath: addLeadingSlash\n }\n};\n\nfunction stripHash(url) {\n var hashIndex = url.indexOf('#');\n return hashIndex === -1 ? url : url.slice(0, hashIndex);\n}\n\nfunction getHashPath() {\n // We can't use window.location.hash here because it's not\n // consistent across browsers - Firefox will pre-decode it!\n var href = window.location.href;\n var hashIndex = href.indexOf('#');\n return hashIndex === -1 ? '' : href.substring(hashIndex + 1);\n}\n\nfunction pushHashPath(path) {\n window.location.hash = path;\n}\n\nfunction replaceHashPath(path) {\n window.location.replace(stripHash(window.location.href) + '#' + path);\n}\n\nfunction createHashHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Hash history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canGoWithoutReload = supportsGoWithoutReloadUsingHash();\n var _props = props,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$hashType = _props.hashType,\n hashType = _props$hashType === void 0 ? 'slash' : _props$hashType;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n var _HashPathCoders$hashT = HashPathCoders[hashType],\n encodePath = _HashPathCoders$hashT.encodePath,\n decodePath = _HashPathCoders$hashT.decodePath;\n\n function getDOMLocation() {\n var path = decodePath(getHashPath());\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n var forceNextPop = false;\n var ignorePath = null;\n\n function locationsAreEqual$$1(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash;\n }\n\n function handleHashChange() {\n var path = getHashPath();\n var encodedPath = encodePath(path);\n\n if (path !== encodedPath) {\n // Ensure we always have a properly-encoded hash.\n replaceHashPath(encodedPath);\n } else {\n var location = getDOMLocation();\n var prevLocation = history.location;\n if (!forceNextPop && locationsAreEqual$$1(prevLocation, location)) return; // A hashchange doesn't always == location change.\n\n if (ignorePath === createPath(location)) return; // Ignore this change; we already setState in push/replace.\n\n ignorePath = null;\n handlePop(location);\n }\n }\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of paths we've seen in sessionStorage.\n // Instead, we just default to 0 for paths we don't know.\n\n var toIndex = allPaths.lastIndexOf(createPath(toLocation));\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allPaths.lastIndexOf(createPath(fromLocation));\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n } // Ensure the hash is encoded properly before doing anything else.\n\n\n var path = getHashPath();\n var encodedPath = encodePath(path);\n if (path !== encodedPath) replaceHashPath(encodedPath);\n var initialLocation = getDOMLocation();\n var allPaths = [createPath(initialLocation)]; // Public interface\n\n function createHref(location) {\n var baseTag = document.querySelector('base');\n var href = '';\n\n if (baseTag && baseTag.getAttribute('href')) {\n href = stripHash(window.location.href);\n }\n\n return href + '#' + encodePath(basename + createPath(location));\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot push state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a PUSH, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n pushHashPath(encodedPath);\n var prevIndex = allPaths.lastIndexOf(createPath(history.location));\n var nextPaths = allPaths.slice(0, prevIndex + 1);\n nextPaths.push(path);\n allPaths = nextPaths;\n setState({\n action: action,\n location: location\n });\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'Hash history cannot PUSH the same path; a new entry will not be added to the history stack') : void 0;\n setState();\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot replace state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a REPLACE, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n replaceHashPath(encodedPath);\n }\n\n var prevIndex = allPaths.indexOf(createPath(history.location));\n if (prevIndex !== -1) allPaths[prevIndex] = path;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n process.env.NODE_ENV !== \"production\" ? warning(canGoWithoutReload, 'Hash history go(n) causes a full page reload in this browser') : void 0;\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(HashChangeEvent$1, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(HashChangeEvent$1, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nfunction clamp(n, lowerBound, upperBound) {\n return Math.min(Math.max(n, lowerBound), upperBound);\n}\n/**\n * Creates a history object that stores locations in memory.\n */\n\n\nfunction createMemoryHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n var _props = props,\n getUserConfirmation = _props.getUserConfirmation,\n _props$initialEntries = _props.initialEntries,\n initialEntries = _props$initialEntries === void 0 ? ['/'] : _props$initialEntries,\n _props$initialIndex = _props.initialIndex,\n initialIndex = _props$initialIndex === void 0 ? 0 : _props$initialIndex,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = history.entries.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var index = clamp(initialIndex, 0, initialEntries.length - 1);\n var entries = initialEntries.map(function (entry) {\n return typeof entry === 'string' ? createLocation(entry, undefined, createKey()) : createLocation(entry, undefined, entry.key || createKey());\n }); // Public interface\n\n var createHref = createPath;\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var prevIndex = history.index;\n var nextIndex = prevIndex + 1;\n var nextEntries = history.entries.slice(0);\n\n if (nextEntries.length > nextIndex) {\n nextEntries.splice(nextIndex, nextEntries.length - nextIndex, location);\n } else {\n nextEntries.push(location);\n }\n\n setState({\n action: action,\n location: location,\n index: nextIndex,\n entries: nextEntries\n });\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n history.entries[history.index] = location;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n var nextIndex = clamp(history.index + n, 0, history.entries.length - 1);\n var action = 'POP';\n var location = history.entries[nextIndex];\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location,\n index: nextIndex\n });\n } else {\n // Mimic the behavior of DOM histories by\n // causing a render after a cancelled POP.\n setState();\n }\n });\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n function canGo(n) {\n var nextIndex = history.index + n;\n return nextIndex >= 0 && nextIndex < history.entries.length;\n }\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n return transitionManager.setPrompt(prompt);\n }\n\n function listen(listener) {\n return transitionManager.appendListener(listener);\n }\n\n var history = {\n length: entries.length,\n action: 'POP',\n location: entries[index],\n index: index,\n entries: entries,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n canGo: canGo,\n block: block,\n listen: listen\n };\n return history;\n}\n\nexport { createBrowserHistory, createHashHistory, createMemoryHistory, createLocation, locationsAreEqual, parsePath, createPath };\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;\n\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\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\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\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","/**\n * @license\n * Lodash \n * Copyright OpenJS Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n;(function() {\n\n /** Used as a safe reference for `undefined` in pre-ES5 environments. */\n var undefined;\n\n /** Used as the semantic version number. */\n var VERSION = '4.17.21';\n\n /** Used as the size to enable large array optimizations. */\n var LARGE_ARRAY_SIZE = 200;\n\n /** Error message constants. */\n var CORE_ERROR_TEXT = 'Unsupported core-js use. Try https://npms.io/search?q=ponyfill.',\n FUNC_ERROR_TEXT = 'Expected a function',\n INVALID_TEMPL_VAR_ERROR_TEXT = 'Invalid `variable` option passed into `_.template`';\n\n /** Used to stand-in for `undefined` hash values. */\n var HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n /** Used as the maximum memoize cache size. */\n var MAX_MEMOIZE_SIZE = 500;\n\n /** Used as the internal argument placeholder. */\n var PLACEHOLDER = '__lodash_placeholder__';\n\n /** Used to compose bitmasks for cloning. */\n var CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n /** Used to compose bitmasks for value comparisons. */\n var COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n /** Used to compose bitmasks for function metadata. */\n var WRAP_BIND_FLAG = 1,\n WRAP_BIND_KEY_FLAG = 2,\n WRAP_CURRY_BOUND_FLAG = 4,\n WRAP_CURRY_FLAG = 8,\n WRAP_CURRY_RIGHT_FLAG = 16,\n WRAP_PARTIAL_FLAG = 32,\n WRAP_PARTIAL_RIGHT_FLAG = 64,\n WRAP_ARY_FLAG = 128,\n WRAP_REARG_FLAG = 256,\n WRAP_FLIP_FLAG = 512;\n\n /** Used as default options for `_.truncate`. */\n var DEFAULT_TRUNC_LENGTH = 30,\n DEFAULT_TRUNC_OMISSION = '...';\n\n /** Used to detect hot functions by number of calls within a span of milliseconds. */\n var HOT_COUNT = 800,\n HOT_SPAN = 16;\n\n /** Used to indicate the type of lazy iteratees. */\n var LAZY_FILTER_FLAG = 1,\n LAZY_MAP_FLAG = 2,\n LAZY_WHILE_FLAG = 3;\n\n /** Used as references for various `Number` constants. */\n var INFINITY = 1 / 0,\n MAX_SAFE_INTEGER = 9007199254740991,\n MAX_INTEGER = 1.7976931348623157e+308,\n NAN = 0 / 0;\n\n /** Used as references for the maximum length and index of an array. */\n var MAX_ARRAY_LENGTH = 4294967295,\n MAX_ARRAY_INDEX = MAX_ARRAY_LENGTH - 1,\n HALF_MAX_ARRAY_LENGTH = MAX_ARRAY_LENGTH >>> 1;\n\n /** Used to associate wrap methods with their bit flags. */\n var wrapFlags = [\n ['ary', WRAP_ARY_FLAG],\n ['bind', WRAP_BIND_FLAG],\n ['bindKey', WRAP_BIND_KEY_FLAG],\n ['curry', WRAP_CURRY_FLAG],\n ['curryRight', WRAP_CURRY_RIGHT_FLAG],\n ['flip', WRAP_FLIP_FLAG],\n ['partial', WRAP_PARTIAL_FLAG],\n ['partialRight', WRAP_PARTIAL_RIGHT_FLAG],\n ['rearg', WRAP_REARG_FLAG]\n ];\n\n /** `Object#toString` result references. */\n var argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n asyncTag = '[object AsyncFunction]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n domExcTag = '[object DOMException]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n nullTag = '[object Null]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n proxyTag = '[object Proxy]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n undefinedTag = '[object Undefined]',\n weakMapTag = '[object WeakMap]',\n weakSetTag = '[object WeakSet]';\n\n var arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n /** Used to match empty string literals in compiled template source. */\n var reEmptyStringLeading = /\\b__p \\+= '';/g,\n reEmptyStringMiddle = /\\b(__p \\+=) '' \\+/g,\n reEmptyStringTrailing = /(__e\\(.*?\\)|\\b__t\\)) \\+\\n'';/g;\n\n /** Used to match HTML entities and HTML characters. */\n var reEscapedHtml = /&(?:amp|lt|gt|quot|#39);/g,\n reUnescapedHtml = /[&<>\"']/g,\n reHasEscapedHtml = RegExp(reEscapedHtml.source),\n reHasUnescapedHtml = RegExp(reUnescapedHtml.source);\n\n /** Used to match template delimiters. */\n var reEscape = /<%-([\\s\\S]+?)%>/g,\n reEvaluate = /<%([\\s\\S]+?)%>/g,\n reInterpolate = /<%=([\\s\\S]+?)%>/g;\n\n /** Used to match property names within property paths. */\n var reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/,\n rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n /**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\n var reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g,\n reHasRegExpChar = RegExp(reRegExpChar.source);\n\n /** Used to match leading whitespace. */\n var reTrimStart = /^\\s+/;\n\n /** Used to match a single whitespace character. */\n var reWhitespace = /\\s/;\n\n /** Used to match wrap detail comments. */\n var reWrapComment = /\\{(?:\\n\\/\\* \\[wrapped with .+\\] \\*\\/)?\\n?/,\n reWrapDetails = /\\{\\n\\/\\* \\[wrapped with (.+)\\] \\*/,\n reSplitDetails = /,? & /;\n\n /** Used to match words composed of alphanumeric characters. */\n var reAsciiWord = /[^\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\x7f]+/g;\n\n /**\n * Used to validate the `validate` option in `_.template` variable.\n *\n * Forbids characters which could potentially change the meaning of the function argument definition:\n * - \"(),\" (modification of function parameters)\n * - \"=\" (default value)\n * - \"[]{}\" (destructuring of function parameters)\n * - \"/\" (beginning of a comment)\n * - whitespace\n */\n var reForbiddenIdentifierChars = /[()=,{}\\[\\]\\/\\s]/;\n\n /** Used to match backslashes in property paths. */\n var reEscapeChar = /\\\\(\\\\)?/g;\n\n /**\n * Used to match\n * [ES template delimiters](http://ecma-international.org/ecma-262/7.0/#sec-template-literal-lexical-components).\n */\n var reEsTemplate = /\\$\\{([^\\\\}]*(?:\\\\.[^\\\\}]*)*)\\}/g;\n\n /** Used to match `RegExp` flags from their coerced string values. */\n var reFlags = /\\w*$/;\n\n /** Used to detect bad signed hexadecimal string values. */\n var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n /** Used to detect binary string values. */\n var reIsBinary = /^0b[01]+$/i;\n\n /** Used to detect host constructors (Safari). */\n var reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n /** Used to detect octal string values. */\n var reIsOctal = /^0o[0-7]+$/i;\n\n /** Used to detect unsigned integer values. */\n var reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n /** Used to match Latin Unicode letters (excluding mathematical operators). */\n var reLatin = /[\\xc0-\\xd6\\xd8-\\xf6\\xf8-\\xff\\u0100-\\u017f]/g;\n\n /** Used to ensure capturing order of template delimiters. */\n var reNoMatch = /($^)/;\n\n /** Used to match unescaped characters in compiled string literals. */\n var reUnescapedString = /['\\n\\r\\u2028\\u2029\\\\]/g;\n\n /** Used to compose unicode character classes. */\n var rsAstralRange = '\\\\ud800-\\\\udfff',\n rsComboMarksRange = '\\\\u0300-\\\\u036f',\n reComboHalfMarksRange = '\\\\ufe20-\\\\ufe2f',\n rsComboSymbolsRange = '\\\\u20d0-\\\\u20ff',\n rsComboRange = rsComboMarksRange + reComboHalfMarksRange + rsComboSymbolsRange,\n rsDingbatRange = '\\\\u2700-\\\\u27bf',\n rsLowerRange = 'a-z\\\\xdf-\\\\xf6\\\\xf8-\\\\xff',\n rsMathOpRange = '\\\\xac\\\\xb1\\\\xd7\\\\xf7',\n rsNonCharRange = '\\\\x00-\\\\x2f\\\\x3a-\\\\x40\\\\x5b-\\\\x60\\\\x7b-\\\\xbf',\n rsPunctuationRange = '\\\\u2000-\\\\u206f',\n rsSpaceRange = ' \\\\t\\\\x0b\\\\f\\\\xa0\\\\ufeff\\\\n\\\\r\\\\u2028\\\\u2029\\\\u1680\\\\u180e\\\\u2000\\\\u2001\\\\u2002\\\\u2003\\\\u2004\\\\u2005\\\\u2006\\\\u2007\\\\u2008\\\\u2009\\\\u200a\\\\u202f\\\\u205f\\\\u3000',\n rsUpperRange = 'A-Z\\\\xc0-\\\\xd6\\\\xd8-\\\\xde',\n rsVarRange = '\\\\ufe0e\\\\ufe0f',\n rsBreakRange = rsMathOpRange + rsNonCharRange + rsPunctuationRange + rsSpaceRange;\n\n /** Used to compose unicode capture groups. */\n var rsApos = \"['\\u2019]\",\n rsAstral = '[' + rsAstralRange + ']',\n rsBreak = '[' + rsBreakRange + ']',\n rsCombo = '[' + rsComboRange + ']',\n rsDigits = '\\\\d+',\n rsDingbat = '[' + rsDingbatRange + ']',\n rsLower = '[' + rsLowerRange + ']',\n rsMisc = '[^' + rsAstralRange + rsBreakRange + rsDigits + rsDingbatRange + rsLowerRange + rsUpperRange + ']',\n rsFitz = '\\\\ud83c[\\\\udffb-\\\\udfff]',\n rsModifier = '(?:' + rsCombo + '|' + rsFitz + ')',\n rsNonAstral = '[^' + rsAstralRange + ']',\n rsRegional = '(?:\\\\ud83c[\\\\udde6-\\\\uddff]){2}',\n rsSurrPair = '[\\\\ud800-\\\\udbff][\\\\udc00-\\\\udfff]',\n rsUpper = '[' + rsUpperRange + ']',\n rsZWJ = '\\\\u200d';\n\n /** Used to compose unicode regexes. */\n var rsMiscLower = '(?:' + rsLower + '|' + rsMisc + ')',\n rsMiscUpper = '(?:' + rsUpper + '|' + rsMisc + ')',\n rsOptContrLower = '(?:' + rsApos + '(?:d|ll|m|re|s|t|ve))?',\n rsOptContrUpper = '(?:' + rsApos + '(?:D|LL|M|RE|S|T|VE))?',\n reOptMod = rsModifier + '?',\n rsOptVar = '[' + rsVarRange + ']?',\n rsOptJoin = '(?:' + rsZWJ + '(?:' + [rsNonAstral, rsRegional, rsSurrPair].join('|') + ')' + rsOptVar + reOptMod + ')*',\n rsOrdLower = '\\\\d*(?:1st|2nd|3rd|(?![123])\\\\dth)(?=\\\\b|[A-Z_])',\n rsOrdUpper = '\\\\d*(?:1ST|2ND|3RD|(?![123])\\\\dTH)(?=\\\\b|[a-z_])',\n rsSeq = rsOptVar + reOptMod + rsOptJoin,\n rsEmoji = '(?:' + [rsDingbat, rsRegional, rsSurrPair].join('|') + ')' + rsSeq,\n rsSymbol = '(?:' + [rsNonAstral + rsCombo + '?', rsCombo, rsRegional, rsSurrPair, rsAstral].join('|') + ')';\n\n /** Used to match apostrophes. */\n var reApos = RegExp(rsApos, 'g');\n\n /**\n * Used to match [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks) and\n * [combining diacritical marks for symbols](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks_for_Symbols).\n */\n var reComboMark = RegExp(rsCombo, 'g');\n\n /** Used to match [string symbols](https://mathiasbynens.be/notes/javascript-unicode). */\n var reUnicode = RegExp(rsFitz + '(?=' + rsFitz + ')|' + rsSymbol + rsSeq, 'g');\n\n /** Used to match complex or compound words. */\n var reUnicodeWord = RegExp([\n rsUpper + '?' + rsLower + '+' + rsOptContrLower + '(?=' + [rsBreak, rsUpper, '$'].join('|') + ')',\n rsMiscUpper + '+' + rsOptContrUpper + '(?=' + [rsBreak, rsUpper + rsMiscLower, '$'].join('|') + ')',\n rsUpper + '?' + rsMiscLower + '+' + rsOptContrLower,\n rsUpper + '+' + rsOptContrUpper,\n rsOrdUpper,\n rsOrdLower,\n rsDigits,\n rsEmoji\n ].join('|'), 'g');\n\n /** Used to detect strings with [zero-width joiners or code points from the astral planes](http://eev.ee/blog/2015/09/12/dark-corners-of-unicode/). */\n var reHasUnicode = RegExp('[' + rsZWJ + rsAstralRange + rsComboRange + rsVarRange + ']');\n\n /** Used to detect strings that need a more robust regexp to match words. */\n var reHasUnicodeWord = /[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;\n\n /** Used to assign default `context` object properties. */\n var contextProps = [\n 'Array', 'Buffer', 'DataView', 'Date', 'Error', 'Float32Array', 'Float64Array',\n 'Function', 'Int8Array', 'Int16Array', 'Int32Array', 'Map', 'Math', 'Object',\n 'Promise', 'RegExp', 'Set', 'String', 'Symbol', 'TypeError', 'Uint8Array',\n 'Uint8ClampedArray', 'Uint16Array', 'Uint32Array', 'WeakMap',\n '_', 'clearTimeout', 'isFinite', 'parseInt', 'setTimeout'\n ];\n\n /** Used to make template sourceURLs easier to identify. */\n var templateCounter = -1;\n\n /** Used to identify `toStringTag` values of typed arrays. */\n var typedArrayTags = {};\n typedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\n typedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\n typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\n typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\n typedArrayTags[uint32Tag] = true;\n typedArrayTags[argsTag] = typedArrayTags[arrayTag] =\n typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\n typedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\n typedArrayTags[errorTag] = typedArrayTags[funcTag] =\n typedArrayTags[mapTag] = typedArrayTags[numberTag] =\n typedArrayTags[objectTag] = typedArrayTags[regexpTag] =\n typedArrayTags[setTag] = typedArrayTags[stringTag] =\n typedArrayTags[weakMapTag] = false;\n\n /** Used to identify `toStringTag` values supported by `_.clone`. */\n var cloneableTags = {};\n cloneableTags[argsTag] = cloneableTags[arrayTag] =\n cloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\n cloneableTags[boolTag] = cloneableTags[dateTag] =\n cloneableTags[float32Tag] = cloneableTags[float64Tag] =\n cloneableTags[int8Tag] = cloneableTags[int16Tag] =\n cloneableTags[int32Tag] = cloneableTags[mapTag] =\n cloneableTags[numberTag] = cloneableTags[objectTag] =\n cloneableTags[regexpTag] = cloneableTags[setTag] =\n cloneableTags[stringTag] = cloneableTags[symbolTag] =\n cloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\n cloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\n cloneableTags[errorTag] = cloneableTags[funcTag] =\n cloneableTags[weakMapTag] = false;\n\n /** Used to map Latin Unicode letters to basic Latin letters. */\n var deburredLetters = {\n // Latin-1 Supplement block.\n '\\xc0': 'A', '\\xc1': 'A', '\\xc2': 'A', '\\xc3': 'A', '\\xc4': 'A', '\\xc5': 'A',\n '\\xe0': 'a', '\\xe1': 'a', '\\xe2': 'a', '\\xe3': 'a', '\\xe4': 'a', '\\xe5': 'a',\n '\\xc7': 'C', '\\xe7': 'c',\n '\\xd0': 'D', '\\xf0': 'd',\n '\\xc8': 'E', '\\xc9': 'E', '\\xca': 'E', '\\xcb': 'E',\n '\\xe8': 'e', '\\xe9': 'e', '\\xea': 'e', '\\xeb': 'e',\n '\\xcc': 'I', '\\xcd': 'I', '\\xce': 'I', '\\xcf': 'I',\n '\\xec': 'i', '\\xed': 'i', '\\xee': 'i', '\\xef': 'i',\n '\\xd1': 'N', '\\xf1': 'n',\n '\\xd2': 'O', '\\xd3': 'O', '\\xd4': 'O', '\\xd5': 'O', '\\xd6': 'O', '\\xd8': 'O',\n '\\xf2': 'o', '\\xf3': 'o', '\\xf4': 'o', '\\xf5': 'o', '\\xf6': 'o', '\\xf8': 'o',\n '\\xd9': 'U', '\\xda': 'U', '\\xdb': 'U', '\\xdc': 'U',\n '\\xf9': 'u', '\\xfa': 'u', '\\xfb': 'u', '\\xfc': 'u',\n '\\xdd': 'Y', '\\xfd': 'y', '\\xff': 'y',\n '\\xc6': 'Ae', '\\xe6': 'ae',\n '\\xde': 'Th', '\\xfe': 'th',\n '\\xdf': 'ss',\n // Latin Extended-A block.\n '\\u0100': 'A', '\\u0102': 'A', '\\u0104': 'A',\n '\\u0101': 'a', '\\u0103': 'a', '\\u0105': 'a',\n '\\u0106': 'C', '\\u0108': 'C', '\\u010a': 'C', '\\u010c': 'C',\n '\\u0107': 'c', '\\u0109': 'c', '\\u010b': 'c', '\\u010d': 'c',\n '\\u010e': 'D', '\\u0110': 'D', '\\u010f': 'd', '\\u0111': 'd',\n '\\u0112': 'E', '\\u0114': 'E', '\\u0116': 'E', '\\u0118': 'E', '\\u011a': 'E',\n '\\u0113': 'e', '\\u0115': 'e', '\\u0117': 'e', '\\u0119': 'e', '\\u011b': 'e',\n '\\u011c': 'G', '\\u011e': 'G', '\\u0120': 'G', '\\u0122': 'G',\n '\\u011d': 'g', '\\u011f': 'g', '\\u0121': 'g', '\\u0123': 'g',\n '\\u0124': 'H', '\\u0126': 'H', '\\u0125': 'h', '\\u0127': 'h',\n '\\u0128': 'I', '\\u012a': 'I', '\\u012c': 'I', '\\u012e': 'I', '\\u0130': 'I',\n '\\u0129': 'i', '\\u012b': 'i', '\\u012d': 'i', '\\u012f': 'i', '\\u0131': 'i',\n '\\u0134': 'J', '\\u0135': 'j',\n '\\u0136': 'K', '\\u0137': 'k', '\\u0138': 'k',\n '\\u0139': 'L', '\\u013b': 'L', '\\u013d': 'L', '\\u013f': 'L', '\\u0141': 'L',\n '\\u013a': 'l', '\\u013c': 'l', '\\u013e': 'l', '\\u0140': 'l', '\\u0142': 'l',\n '\\u0143': 'N', '\\u0145': 'N', '\\u0147': 'N', '\\u014a': 'N',\n '\\u0144': 'n', '\\u0146': 'n', '\\u0148': 'n', '\\u014b': 'n',\n '\\u014c': 'O', '\\u014e': 'O', '\\u0150': 'O',\n '\\u014d': 'o', '\\u014f': 'o', '\\u0151': 'o',\n '\\u0154': 'R', '\\u0156': 'R', '\\u0158': 'R',\n '\\u0155': 'r', '\\u0157': 'r', '\\u0159': 'r',\n '\\u015a': 'S', '\\u015c': 'S', '\\u015e': 'S', '\\u0160': 'S',\n '\\u015b': 's', '\\u015d': 's', '\\u015f': 's', '\\u0161': 's',\n '\\u0162': 'T', '\\u0164': 'T', '\\u0166': 'T',\n '\\u0163': 't', '\\u0165': 't', '\\u0167': 't',\n '\\u0168': 'U', '\\u016a': 'U', '\\u016c': 'U', '\\u016e': 'U', '\\u0170': 'U', '\\u0172': 'U',\n '\\u0169': 'u', '\\u016b': 'u', '\\u016d': 'u', '\\u016f': 'u', '\\u0171': 'u', '\\u0173': 'u',\n '\\u0174': 'W', '\\u0175': 'w',\n '\\u0176': 'Y', '\\u0177': 'y', '\\u0178': 'Y',\n '\\u0179': 'Z', '\\u017b': 'Z', '\\u017d': 'Z',\n '\\u017a': 'z', '\\u017c': 'z', '\\u017e': 'z',\n '\\u0132': 'IJ', '\\u0133': 'ij',\n '\\u0152': 'Oe', '\\u0153': 'oe',\n '\\u0149': \"'n\", '\\u017f': 's'\n };\n\n /** Used to map characters to HTML entities. */\n var htmlEscapes = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": '''\n };\n\n /** Used to map HTML entities to characters. */\n var htmlUnescapes = {\n '&': '&',\n '<': '<',\n '>': '>',\n '"': '\"',\n ''': \"'\"\n };\n\n /** Used to escape characters for inclusion in compiled string literals. */\n var stringEscapes = {\n '\\\\': '\\\\',\n \"'\": \"'\",\n '\\n': 'n',\n '\\r': 'r',\n '\\u2028': 'u2028',\n '\\u2029': 'u2029'\n };\n\n /** Built-in method references without a dependency on `root`. */\n var freeParseFloat = parseFloat,\n freeParseInt = parseInt;\n\n /** Detect free variable `global` from Node.js. */\n var freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n /** Detect free variable `self`. */\n var freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n /** Used as a reference to the global object. */\n var root = freeGlobal || freeSelf || Function('return this')();\n\n /** Detect free variable `exports`. */\n var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n /** Detect free variable `module`. */\n var freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n /** Detect the popular CommonJS extension `module.exports`. */\n var moduleExports = freeModule && freeModule.exports === freeExports;\n\n /** Detect free variable `process` from Node.js. */\n var freeProcess = moduleExports && freeGlobal.process;\n\n /** Used to access faster Node.js helpers. */\n var nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n }());\n\n /* Node.js helper references. */\n var nodeIsArrayBuffer = nodeUtil && nodeUtil.isArrayBuffer,\n nodeIsDate = nodeUtil && nodeUtil.isDate,\n nodeIsMap = nodeUtil && nodeUtil.isMap,\n nodeIsRegExp = nodeUtil && nodeUtil.isRegExp,\n nodeIsSet = nodeUtil && nodeUtil.isSet,\n nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n /*--------------------------------------------------------------------------*/\n\n /**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\n function apply(func, thisArg, args) {\n switch (args.length) {\n case 0: return func.call(thisArg);\n case 1: return func.call(thisArg, args[0]);\n case 2: return func.call(thisArg, args[0], args[1]);\n case 3: return func.call(thisArg, args[0], args[1], args[2]);\n }\n return func.apply(thisArg, args);\n }\n\n /**\n * A specialized version of `baseAggregator` for arrays.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\n function arrayAggregator(array, setter, iteratee, accumulator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n var value = array[index];\n setter(accumulator, value, iteratee(value), array);\n }\n return accumulator;\n }\n\n /**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\n function arrayEach(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n }\n\n /**\n * A specialized version of `_.forEachRight` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\n function arrayEachRight(array, iteratee) {\n var length = array == null ? 0 : array.length;\n\n while (length--) {\n if (iteratee(array[length], length, array) === false) {\n break;\n }\n }\n return array;\n }\n\n /**\n * A specialized version of `_.every` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`.\n */\n function arrayEvery(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (!predicate(array[index], index, array)) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\n function arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n }\n\n /**\n * A specialized version of `_.includes` for arrays without support for\n * specifying an index to search from.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\n function arrayIncludes(array, value) {\n var length = array == null ? 0 : array.length;\n return !!length && baseIndexOf(array, value, 0) > -1;\n }\n\n /**\n * This function is like `arrayIncludes` except that it accepts a comparator.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\n function arrayIncludesWith(array, value, comparator) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (comparator(value, array[index])) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\n function arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n }\n\n /**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\n function arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n }\n\n /**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\n function arrayReduce(array, iteratee, accumulator, initAccum) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n if (initAccum && length) {\n accumulator = array[++index];\n }\n while (++index < length) {\n accumulator = iteratee(accumulator, array[index], index, array);\n }\n return accumulator;\n }\n\n /**\n * A specialized version of `_.reduceRight` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the last element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\n function arrayReduceRight(array, iteratee, accumulator, initAccum) {\n var length = array == null ? 0 : array.length;\n if (initAccum && length) {\n accumulator = array[--length];\n }\n while (length--) {\n accumulator = iteratee(accumulator, array[length], length, array);\n }\n return accumulator;\n }\n\n /**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\n function arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Gets the size of an ASCII `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\n var asciiSize = baseProperty('length');\n\n /**\n * Converts an ASCII `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function asciiToArray(string) {\n return string.split('');\n }\n\n /**\n * Splits an ASCII `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\n function asciiWords(string) {\n return string.match(reAsciiWord) || [];\n }\n\n /**\n * The base implementation of methods like `_.findKey` and `_.findLastKey`,\n * without support for iteratee shorthands, which iterates over `collection`\n * using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the found element or its key, else `undefined`.\n */\n function baseFindKey(collection, predicate, eachFunc) {\n var result;\n eachFunc(collection, function(value, key, collection) {\n if (predicate(value, key, collection)) {\n result = key;\n return false;\n }\n });\n return result;\n }\n\n /**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function baseFindIndex(array, predicate, fromIndex, fromRight) {\n var length = array.length,\n index = fromIndex + (fromRight ? 1 : -1);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (predicate(array[index], index, array)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function baseIndexOf(array, value, fromIndex) {\n return value === value\n ? strictIndexOf(array, value, fromIndex)\n : baseFindIndex(array, baseIsNaN, fromIndex);\n }\n\n /**\n * This function is like `baseIndexOf` except that it accepts a comparator.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function baseIndexOfWith(array, value, fromIndex, comparator) {\n var index = fromIndex - 1,\n length = array.length;\n\n while (++index < length) {\n if (comparator(array[index], value)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * The base implementation of `_.isNaN` without support for number objects.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n */\n function baseIsNaN(value) {\n return value !== value;\n }\n\n /**\n * The base implementation of `_.mean` and `_.meanBy` without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {number} Returns the mean.\n */\n function baseMean(array, iteratee) {\n var length = array == null ? 0 : array.length;\n return length ? (baseSum(array, iteratee) / length) : NAN;\n }\n\n /**\n * The base implementation of `_.property` without support for deep paths.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\n function baseProperty(key) {\n return function(object) {\n return object == null ? undefined : object[key];\n };\n }\n\n /**\n * The base implementation of `_.propertyOf` without support for deep paths.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Function} Returns the new accessor function.\n */\n function basePropertyOf(object) {\n return function(key) {\n return object == null ? undefined : object[key];\n };\n }\n\n /**\n * The base implementation of `_.reduce` and `_.reduceRight`, without support\n * for iteratee shorthands, which iterates over `collection` using `eachFunc`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} accumulator The initial value.\n * @param {boolean} initAccum Specify using the first or last element of\n * `collection` as the initial value.\n * @param {Function} eachFunc The function to iterate over `collection`.\n * @returns {*} Returns the accumulated value.\n */\n function baseReduce(collection, iteratee, accumulator, initAccum, eachFunc) {\n eachFunc(collection, function(value, index, collection) {\n accumulator = initAccum\n ? (initAccum = false, value)\n : iteratee(accumulator, value, index, collection);\n });\n return accumulator;\n }\n\n /**\n * The base implementation of `_.sortBy` which uses `comparer` to define the\n * sort order of `array` and replaces criteria objects with their corresponding\n * values.\n *\n * @private\n * @param {Array} array The array to sort.\n * @param {Function} comparer The function to define sort order.\n * @returns {Array} Returns `array`.\n */\n function baseSortBy(array, comparer) {\n var length = array.length;\n\n array.sort(comparer);\n while (length--) {\n array[length] = array[length].value;\n }\n return array;\n }\n\n /**\n * The base implementation of `_.sum` and `_.sumBy` without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {number} Returns the sum.\n */\n function baseSum(array, iteratee) {\n var result,\n index = -1,\n length = array.length;\n\n while (++index < length) {\n var current = iteratee(array[index]);\n if (current !== undefined) {\n result = result === undefined ? current : (result + current);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\n function baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n }\n\n /**\n * The base implementation of `_.toPairs` and `_.toPairsIn` which creates an array\n * of key-value pairs for `object` corresponding to the property names of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the key-value pairs.\n */\n function baseToPairs(object, props) {\n return arrayMap(props, function(key) {\n return [key, object[key]];\n });\n }\n\n /**\n * The base implementation of `_.trim`.\n *\n * @private\n * @param {string} string The string to trim.\n * @returns {string} Returns the trimmed string.\n */\n function baseTrim(string) {\n return string\n ? string.slice(0, trimmedEndIndex(string) + 1).replace(reTrimStart, '')\n : string;\n }\n\n /**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\n function baseUnary(func) {\n return function(value) {\n return func(value);\n };\n }\n\n /**\n * The base implementation of `_.values` and `_.valuesIn` which creates an\n * array of `object` property values corresponding to the property names\n * of `props`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} props The property names to get values for.\n * @returns {Object} Returns the array of property values.\n */\n function baseValues(object, props) {\n return arrayMap(props, function(key) {\n return object[key];\n });\n }\n\n /**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function cacheHas(cache, key) {\n return cache.has(key);\n }\n\n /**\n * Used by `_.trim` and `_.trimStart` to get the index of the first string symbol\n * that is not found in the character symbols.\n *\n * @private\n * @param {Array} strSymbols The string symbols to inspect.\n * @param {Array} chrSymbols The character symbols to find.\n * @returns {number} Returns the index of the first unmatched string symbol.\n */\n function charsStartIndex(strSymbols, chrSymbols) {\n var index = -1,\n length = strSymbols.length;\n\n while (++index < length && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\n return index;\n }\n\n /**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last string symbol\n * that is not found in the character symbols.\n *\n * @private\n * @param {Array} strSymbols The string symbols to inspect.\n * @param {Array} chrSymbols The character symbols to find.\n * @returns {number} Returns the index of the last unmatched string symbol.\n */\n function charsEndIndex(strSymbols, chrSymbols) {\n var index = strSymbols.length;\n\n while (index-- && baseIndexOf(chrSymbols, strSymbols[index], 0) > -1) {}\n return index;\n }\n\n /**\n * Gets the number of `placeholder` occurrences in `array`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} placeholder The placeholder to search for.\n * @returns {number} Returns the placeholder count.\n */\n function countHolders(array, placeholder) {\n var length = array.length,\n result = 0;\n\n while (length--) {\n if (array[length] === placeholder) {\n ++result;\n }\n }\n return result;\n }\n\n /**\n * Used by `_.deburr` to convert Latin-1 Supplement and Latin Extended-A\n * letters to basic Latin letters.\n *\n * @private\n * @param {string} letter The matched letter to deburr.\n * @returns {string} Returns the deburred letter.\n */\n var deburrLetter = basePropertyOf(deburredLetters);\n\n /**\n * Used by `_.escape` to convert characters to HTML entities.\n *\n * @private\n * @param {string} chr The matched character to escape.\n * @returns {string} Returns the escaped character.\n */\n var escapeHtmlChar = basePropertyOf(htmlEscapes);\n\n /**\n * Used by `_.template` to escape characters for inclusion in compiled string literals.\n *\n * @private\n * @param {string} chr The matched character to escape.\n * @returns {string} Returns the escaped character.\n */\n function escapeStringChar(chr) {\n return '\\\\' + stringEscapes[chr];\n }\n\n /**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\n function getValue(object, key) {\n return object == null ? undefined : object[key];\n }\n\n /**\n * Checks if `string` contains Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a symbol is found, else `false`.\n */\n function hasUnicode(string) {\n return reHasUnicode.test(string);\n }\n\n /**\n * Checks if `string` contains a word composed of Unicode symbols.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {boolean} Returns `true` if a word is found, else `false`.\n */\n function hasUnicodeWord(string) {\n return reHasUnicodeWord.test(string);\n }\n\n /**\n * Converts `iterator` to an array.\n *\n * @private\n * @param {Object} iterator The iterator to convert.\n * @returns {Array} Returns the converted array.\n */\n function iteratorToArray(iterator) {\n var data,\n result = [];\n\n while (!(data = iterator.next()).done) {\n result.push(data.value);\n }\n return result;\n }\n\n /**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\n function mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n }\n\n /**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\n function overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n }\n\n /**\n * Replaces all `placeholder` elements in `array` with an internal placeholder\n * and returns an array of their indexes.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {*} placeholder The placeholder to replace.\n * @returns {Array} Returns the new array of placeholder indexes.\n */\n function replaceHolders(array, placeholder) {\n var index = -1,\n length = array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (value === placeholder || value === PLACEHOLDER) {\n array[index] = PLACEHOLDER;\n result[resIndex++] = index;\n }\n }\n return result;\n }\n\n /**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\n function setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n }\n\n /**\n * Converts `set` to its value-value pairs.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the value-value pairs.\n */\n function setToPairs(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = [value, value];\n });\n return result;\n }\n\n /**\n * A specialized version of `_.indexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function strictIndexOf(array, value, fromIndex) {\n var index = fromIndex - 1,\n length = array.length;\n\n while (++index < length) {\n if (array[index] === value) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * A specialized version of `_.lastIndexOf` which performs strict equality\n * comparisons of values, i.e. `===`.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function strictLastIndexOf(array, value, fromIndex) {\n var index = fromIndex + 1;\n while (index--) {\n if (array[index] === value) {\n return index;\n }\n }\n return index;\n }\n\n /**\n * Gets the number of symbols in `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the string size.\n */\n function stringSize(string) {\n return hasUnicode(string)\n ? unicodeSize(string)\n : asciiSize(string);\n }\n\n /**\n * Converts `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function stringToArray(string) {\n return hasUnicode(string)\n ? unicodeToArray(string)\n : asciiToArray(string);\n }\n\n /**\n * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace\n * character of `string`.\n *\n * @private\n * @param {string} string The string to inspect.\n * @returns {number} Returns the index of the last non-whitespace character.\n */\n function trimmedEndIndex(string) {\n var index = string.length;\n\n while (index-- && reWhitespace.test(string.charAt(index))) {}\n return index;\n }\n\n /**\n * Used by `_.unescape` to convert HTML entities to characters.\n *\n * @private\n * @param {string} chr The matched character to unescape.\n * @returns {string} Returns the unescaped character.\n */\n var unescapeHtmlChar = basePropertyOf(htmlUnescapes);\n\n /**\n * Gets the size of a Unicode `string`.\n *\n * @private\n * @param {string} string The string inspect.\n * @returns {number} Returns the string size.\n */\n function unicodeSize(string) {\n var result = reUnicode.lastIndex = 0;\n while (reUnicode.test(string)) {\n ++result;\n }\n return result;\n }\n\n /**\n * Converts a Unicode `string` to an array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the converted array.\n */\n function unicodeToArray(string) {\n return string.match(reUnicode) || [];\n }\n\n /**\n * Splits a Unicode `string` into an array of its words.\n *\n * @private\n * @param {string} The string to inspect.\n * @returns {Array} Returns the words of `string`.\n */\n function unicodeWords(string) {\n return string.match(reUnicodeWord) || [];\n }\n\n /*--------------------------------------------------------------------------*/\n\n /**\n * Create a new pristine `lodash` function using the `context` object.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Util\n * @param {Object} [context=root] The context object.\n * @returns {Function} Returns a new `lodash` function.\n * @example\n *\n * _.mixin({ 'foo': _.constant('foo') });\n *\n * var lodash = _.runInContext();\n * lodash.mixin({ 'bar': lodash.constant('bar') });\n *\n * _.isFunction(_.foo);\n * // => true\n * _.isFunction(_.bar);\n * // => false\n *\n * lodash.isFunction(lodash.foo);\n * // => false\n * lodash.isFunction(lodash.bar);\n * // => true\n *\n * // Create a suped-up `defer` in Node.js.\n * var defer = _.runInContext({ 'setTimeout': setImmediate }).defer;\n */\n var runInContext = (function runInContext(context) {\n context = context == null ? root : _.defaults(root.Object(), context, _.pick(root, contextProps));\n\n /** Built-in constructor references. */\n var Array = context.Array,\n Date = context.Date,\n Error = context.Error,\n Function = context.Function,\n Math = context.Math,\n Object = context.Object,\n RegExp = context.RegExp,\n String = context.String,\n TypeError = context.TypeError;\n\n /** Used for built-in method references. */\n var arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n /** Used to detect overreaching core-js shims. */\n var coreJsData = context['__core-js_shared__'];\n\n /** Used to resolve the decompiled source of functions. */\n var funcToString = funcProto.toString;\n\n /** Used to check objects for own properties. */\n var hasOwnProperty = objectProto.hasOwnProperty;\n\n /** Used to generate unique IDs. */\n var idCounter = 0;\n\n /** Used to detect methods masquerading as native. */\n var maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n }());\n\n /**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\n var nativeObjectToString = objectProto.toString;\n\n /** Used to infer the `Object` constructor. */\n var objectCtorString = funcToString.call(Object);\n\n /** Used to restore the original `_` reference in `_.noConflict`. */\n var oldDash = root._;\n\n /** Used to detect if a method is native. */\n var reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n );\n\n /** Built-in value references. */\n var Buffer = moduleExports ? context.Buffer : undefined,\n Symbol = context.Symbol,\n Uint8Array = context.Uint8Array,\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined,\n getPrototype = overArg(Object.getPrototypeOf, Object),\n objectCreate = Object.create,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice,\n spreadableSymbol = Symbol ? Symbol.isConcatSpreadable : undefined,\n symIterator = Symbol ? Symbol.iterator : undefined,\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n var defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n }());\n\n /** Mocked built-ins. */\n var ctxClearTimeout = context.clearTimeout !== root.clearTimeout && context.clearTimeout,\n ctxNow = Date && Date.now !== root.Date.now && Date.now,\n ctxSetTimeout = context.setTimeout !== root.setTimeout && context.setTimeout;\n\n /* Built-in method references for those with the same name as other `lodash` methods. */\n var nativeCeil = Math.ceil,\n nativeFloor = Math.floor,\n nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeIsFinite = context.isFinite,\n nativeJoin = arrayProto.join,\n nativeKeys = overArg(Object.keys, Object),\n nativeMax = Math.max,\n nativeMin = Math.min,\n nativeNow = Date.now,\n nativeParseInt = context.parseInt,\n nativeRandom = Math.random,\n nativeReverse = arrayProto.reverse;\n\n /* Built-in method references that are verified to be native. */\n var DataView = getNative(context, 'DataView'),\n Map = getNative(context, 'Map'),\n Promise = getNative(context, 'Promise'),\n Set = getNative(context, 'Set'),\n WeakMap = getNative(context, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n /** Used to store function metadata. */\n var metaMap = WeakMap && new WeakMap;\n\n /** Used to lookup unminified function names. */\n var realNames = {};\n\n /** Used to detect maps, sets, and weakmaps. */\n var dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n /** Used to convert symbols to primitives and strings. */\n var symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a `lodash` object which wraps `value` to enable implicit method\n * chain sequences. Methods that operate on and return arrays, collections,\n * and functions can be chained together. Methods that retrieve a single value\n * or may return a primitive value will automatically end the chain sequence\n * and return the unwrapped value. Otherwise, the value must be unwrapped\n * with `_#value`.\n *\n * Explicit chain sequences, which must be unwrapped with `_#value`, may be\n * enabled using `_.chain`.\n *\n * The execution of chained methods is lazy, that is, it's deferred until\n * `_#value` is implicitly or explicitly called.\n *\n * Lazy evaluation allows several methods to support shortcut fusion.\n * Shortcut fusion is an optimization to merge iteratee calls; this avoids\n * the creation of intermediate arrays and can greatly reduce the number of\n * iteratee executions. Sections of a chain sequence qualify for shortcut\n * fusion if the section is applied to an array and iteratees accept only\n * one argument. The heuristic for whether a section qualifies for shortcut\n * fusion is subject to change.\n *\n * Chaining is supported in custom builds as long as the `_#value` method is\n * directly or indirectly included in the build.\n *\n * In addition to lodash methods, wrappers have `Array` and `String` methods.\n *\n * The wrapper `Array` methods are:\n * `concat`, `join`, `pop`, `push`, `shift`, `sort`, `splice`, and `unshift`\n *\n * The wrapper `String` methods are:\n * `replace` and `split`\n *\n * The wrapper methods that support shortcut fusion are:\n * `at`, `compact`, `drop`, `dropRight`, `dropWhile`, `filter`, `find`,\n * `findLast`, `head`, `initial`, `last`, `map`, `reject`, `reverse`, `slice`,\n * `tail`, `take`, `takeRight`, `takeRightWhile`, `takeWhile`, and `toArray`\n *\n * The chainable wrapper methods are:\n * `after`, `ary`, `assign`, `assignIn`, `assignInWith`, `assignWith`, `at`,\n * `before`, `bind`, `bindAll`, `bindKey`, `castArray`, `chain`, `chunk`,\n * `commit`, `compact`, `concat`, `conforms`, `constant`, `countBy`, `create`,\n * `curry`, `debounce`, `defaults`, `defaultsDeep`, `defer`, `delay`,\n * `difference`, `differenceBy`, `differenceWith`, `drop`, `dropRight`,\n * `dropRightWhile`, `dropWhile`, `extend`, `extendWith`, `fill`, `filter`,\n * `flatMap`, `flatMapDeep`, `flatMapDepth`, `flatten`, `flattenDeep`,\n * `flattenDepth`, `flip`, `flow`, `flowRight`, `fromPairs`, `functions`,\n * `functionsIn`, `groupBy`, `initial`, `intersection`, `intersectionBy`,\n * `intersectionWith`, `invert`, `invertBy`, `invokeMap`, `iteratee`, `keyBy`,\n * `keys`, `keysIn`, `map`, `mapKeys`, `mapValues`, `matches`, `matchesProperty`,\n * `memoize`, `merge`, `mergeWith`, `method`, `methodOf`, `mixin`, `negate`,\n * `nthArg`, `omit`, `omitBy`, `once`, `orderBy`, `over`, `overArgs`,\n * `overEvery`, `overSome`, `partial`, `partialRight`, `partition`, `pick`,\n * `pickBy`, `plant`, `property`, `propertyOf`, `pull`, `pullAll`, `pullAllBy`,\n * `pullAllWith`, `pullAt`, `push`, `range`, `rangeRight`, `rearg`, `reject`,\n * `remove`, `rest`, `reverse`, `sampleSize`, `set`, `setWith`, `shuffle`,\n * `slice`, `sort`, `sortBy`, `splice`, `spread`, `tail`, `take`, `takeRight`,\n * `takeRightWhile`, `takeWhile`, `tap`, `throttle`, `thru`, `toArray`,\n * `toPairs`, `toPairsIn`, `toPath`, `toPlainObject`, `transform`, `unary`,\n * `union`, `unionBy`, `unionWith`, `uniq`, `uniqBy`, `uniqWith`, `unset`,\n * `unshift`, `unzip`, `unzipWith`, `update`, `updateWith`, `values`,\n * `valuesIn`, `without`, `wrap`, `xor`, `xorBy`, `xorWith`, `zip`,\n * `zipObject`, `zipObjectDeep`, and `zipWith`\n *\n * The wrapper methods that are **not** chainable by default are:\n * `add`, `attempt`, `camelCase`, `capitalize`, `ceil`, `clamp`, `clone`,\n * `cloneDeep`, `cloneDeepWith`, `cloneWith`, `conformsTo`, `deburr`,\n * `defaultTo`, `divide`, `each`, `eachRight`, `endsWith`, `eq`, `escape`,\n * `escapeRegExp`, `every`, `find`, `findIndex`, `findKey`, `findLast`,\n * `findLastIndex`, `findLastKey`, `first`, `floor`, `forEach`, `forEachRight`,\n * `forIn`, `forInRight`, `forOwn`, `forOwnRight`, `get`, `gt`, `gte`, `has`,\n * `hasIn`, `head`, `identity`, `includes`, `indexOf`, `inRange`, `invoke`,\n * `isArguments`, `isArray`, `isArrayBuffer`, `isArrayLike`, `isArrayLikeObject`,\n * `isBoolean`, `isBuffer`, `isDate`, `isElement`, `isEmpty`, `isEqual`,\n * `isEqualWith`, `isError`, `isFinite`, `isFunction`, `isInteger`, `isLength`,\n * `isMap`, `isMatch`, `isMatchWith`, `isNaN`, `isNative`, `isNil`, `isNull`,\n * `isNumber`, `isObject`, `isObjectLike`, `isPlainObject`, `isRegExp`,\n * `isSafeInteger`, `isSet`, `isString`, `isUndefined`, `isTypedArray`,\n * `isWeakMap`, `isWeakSet`, `join`, `kebabCase`, `last`, `lastIndexOf`,\n * `lowerCase`, `lowerFirst`, `lt`, `lte`, `max`, `maxBy`, `mean`, `meanBy`,\n * `min`, `minBy`, `multiply`, `noConflict`, `noop`, `now`, `nth`, `pad`,\n * `padEnd`, `padStart`, `parseInt`, `pop`, `random`, `reduce`, `reduceRight`,\n * `repeat`, `result`, `round`, `runInContext`, `sample`, `shift`, `size`,\n * `snakeCase`, `some`, `sortedIndex`, `sortedIndexBy`, `sortedLastIndex`,\n * `sortedLastIndexBy`, `startCase`, `startsWith`, `stubArray`, `stubFalse`,\n * `stubObject`, `stubString`, `stubTrue`, `subtract`, `sum`, `sumBy`,\n * `template`, `times`, `toFinite`, `toInteger`, `toJSON`, `toLength`,\n * `toLower`, `toNumber`, `toSafeInteger`, `toString`, `toUpper`, `trim`,\n * `trimEnd`, `trimStart`, `truncate`, `unescape`, `uniqueId`, `upperCase`,\n * `upperFirst`, `value`, and `words`\n *\n * @name _\n * @constructor\n * @category Seq\n * @param {*} value The value to wrap in a `lodash` instance.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var wrapped = _([1, 2, 3]);\n *\n * // Returns an unwrapped value.\n * wrapped.reduce(_.add);\n * // => 6\n *\n * // Returns a wrapped value.\n * var squares = wrapped.map(square);\n *\n * _.isArray(squares);\n * // => false\n *\n * _.isArray(squares.value());\n * // => true\n */\n function lodash(value) {\n if (isObjectLike(value) && !isArray(value) && !(value instanceof LazyWrapper)) {\n if (value instanceof LodashWrapper) {\n return value;\n }\n if (hasOwnProperty.call(value, '__wrapped__')) {\n return wrapperClone(value);\n }\n }\n return new LodashWrapper(value);\n }\n\n /**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\n var baseCreate = (function() {\n function object() {}\n return function(proto) {\n if (!isObject(proto)) {\n return {};\n }\n if (objectCreate) {\n return objectCreate(proto);\n }\n object.prototype = proto;\n var result = new object;\n object.prototype = undefined;\n return result;\n };\n }());\n\n /**\n * The function whose prototype chain sequence wrappers inherit from.\n *\n * @private\n */\n function baseLodash() {\n // No operation performed.\n }\n\n /**\n * The base constructor for creating `lodash` wrapper objects.\n *\n * @private\n * @param {*} value The value to wrap.\n * @param {boolean} [chainAll] Enable explicit method chain sequences.\n */\n function LodashWrapper(value, chainAll) {\n this.__wrapped__ = value;\n this.__actions__ = [];\n this.__chain__ = !!chainAll;\n this.__index__ = 0;\n this.__values__ = undefined;\n }\n\n /**\n * By default, the template delimiters used by lodash are like those in\n * embedded Ruby (ERB) as well as ES2015 template strings. Change the\n * following template settings to use alternative delimiters.\n *\n * @static\n * @memberOf _\n * @type {Object}\n */\n lodash.templateSettings = {\n\n /**\n * Used to detect `data` property values to be HTML-escaped.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'escape': reEscape,\n\n /**\n * Used to detect code to be evaluated.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'evaluate': reEvaluate,\n\n /**\n * Used to detect `data` property values to inject.\n *\n * @memberOf _.templateSettings\n * @type {RegExp}\n */\n 'interpolate': reInterpolate,\n\n /**\n * Used to reference the data object in the template text.\n *\n * @memberOf _.templateSettings\n * @type {string}\n */\n 'variable': '',\n\n /**\n * Used to import variables into the compiled template.\n *\n * @memberOf _.templateSettings\n * @type {Object}\n */\n 'imports': {\n\n /**\n * A reference to the `lodash` function.\n *\n * @memberOf _.templateSettings.imports\n * @type {Function}\n */\n '_': lodash\n }\n };\n\n // Ensure wrappers are instances of `baseLodash`.\n lodash.prototype = baseLodash.prototype;\n lodash.prototype.constructor = lodash;\n\n LodashWrapper.prototype = baseCreate(baseLodash.prototype);\n LodashWrapper.prototype.constructor = LodashWrapper;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a lazy wrapper object which wraps `value` to enable lazy evaluation.\n *\n * @private\n * @constructor\n * @param {*} value The value to wrap.\n */\n function LazyWrapper(value) {\n this.__wrapped__ = value;\n this.__actions__ = [];\n this.__dir__ = 1;\n this.__filtered__ = false;\n this.__iteratees__ = [];\n this.__takeCount__ = MAX_ARRAY_LENGTH;\n this.__views__ = [];\n }\n\n /**\n * Creates a clone of the lazy wrapper object.\n *\n * @private\n * @name clone\n * @memberOf LazyWrapper\n * @returns {Object} Returns the cloned `LazyWrapper` object.\n */\n function lazyClone() {\n var result = new LazyWrapper(this.__wrapped__);\n result.__actions__ = copyArray(this.__actions__);\n result.__dir__ = this.__dir__;\n result.__filtered__ = this.__filtered__;\n result.__iteratees__ = copyArray(this.__iteratees__);\n result.__takeCount__ = this.__takeCount__;\n result.__views__ = copyArray(this.__views__);\n return result;\n }\n\n /**\n * Reverses the direction of lazy iteration.\n *\n * @private\n * @name reverse\n * @memberOf LazyWrapper\n * @returns {Object} Returns the new reversed `LazyWrapper` object.\n */\n function lazyReverse() {\n if (this.__filtered__) {\n var result = new LazyWrapper(this);\n result.__dir__ = -1;\n result.__filtered__ = true;\n } else {\n result = this.clone();\n result.__dir__ *= -1;\n }\n return result;\n }\n\n /**\n * Extracts the unwrapped value from its lazy wrapper.\n *\n * @private\n * @name value\n * @memberOf LazyWrapper\n * @returns {*} Returns the unwrapped value.\n */\n function lazyValue() {\n var array = this.__wrapped__.value(),\n dir = this.__dir__,\n isArr = isArray(array),\n isRight = dir < 0,\n arrLength = isArr ? array.length : 0,\n view = getView(0, arrLength, this.__views__),\n start = view.start,\n end = view.end,\n length = end - start,\n index = isRight ? end : (start - 1),\n iteratees = this.__iteratees__,\n iterLength = iteratees.length,\n resIndex = 0,\n takeCount = nativeMin(length, this.__takeCount__);\n\n if (!isArr || (!isRight && arrLength == length && takeCount == length)) {\n return baseWrapperValue(array, this.__actions__);\n }\n var result = [];\n\n outer:\n while (length-- && resIndex < takeCount) {\n index += dir;\n\n var iterIndex = -1,\n value = array[index];\n\n while (++iterIndex < iterLength) {\n var data = iteratees[iterIndex],\n iteratee = data.iteratee,\n type = data.type,\n computed = iteratee(value);\n\n if (type == LAZY_MAP_FLAG) {\n value = computed;\n } else if (!computed) {\n if (type == LAZY_FILTER_FLAG) {\n continue outer;\n } else {\n break outer;\n }\n }\n }\n result[resIndex++] = value;\n }\n return result;\n }\n\n // Ensure `LazyWrapper` is an instance of `baseLodash`.\n LazyWrapper.prototype = baseCreate(baseLodash.prototype);\n LazyWrapper.prototype.constructor = LazyWrapper;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n }\n\n /**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\n function hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n }\n\n /**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n }\n\n /**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n }\n\n /**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n }\n\n /**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\n function hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n }\n\n // Add methods to `Hash`.\n Hash.prototype.clear = hashClear;\n Hash.prototype['delete'] = hashDelete;\n Hash.prototype.get = hashGet;\n Hash.prototype.has = hashHas;\n Hash.prototype.set = hashSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n }\n\n /**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\n function listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n }\n\n /**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n }\n\n /**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n }\n\n /**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n }\n\n /**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\n function listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n }\n\n // Add methods to `ListCache`.\n ListCache.prototype.clear = listCacheClear;\n ListCache.prototype['delete'] = listCacheDelete;\n ListCache.prototype.get = listCacheGet;\n ListCache.prototype.has = listCacheHas;\n ListCache.prototype.set = listCacheSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n }\n\n /**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\n function mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n }\n\n /**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n }\n\n /**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function mapCacheGet(key) {\n return getMapData(this, key).get(key);\n }\n\n /**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function mapCacheHas(key) {\n return getMapData(this, key).has(key);\n }\n\n /**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\n function mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n }\n\n // Add methods to `MapCache`.\n MapCache.prototype.clear = mapCacheClear;\n MapCache.prototype['delete'] = mapCacheDelete;\n MapCache.prototype.get = mapCacheGet;\n MapCache.prototype.has = mapCacheHas;\n MapCache.prototype.set = mapCacheSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\n function SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n }\n\n /**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\n function setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n }\n\n /**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\n function setCacheHas(value) {\n return this.__data__.has(value);\n }\n\n // Add methods to `SetCache`.\n SetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\n SetCache.prototype.has = setCacheHas;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\n function Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n }\n\n /**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\n function stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n }\n\n /**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\n function stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n }\n\n /**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\n function stackGet(key) {\n return this.__data__.get(key);\n }\n\n /**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\n function stackHas(key) {\n return this.__data__.has(key);\n }\n\n /**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\n function stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n }\n\n // Add methods to `Stack`.\n Stack.prototype.clear = stackClear;\n Stack.prototype['delete'] = stackDelete;\n Stack.prototype.get = stackGet;\n Stack.prototype.has = stackHas;\n Stack.prototype.set = stackSet;\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\n function arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n }\n\n /**\n * A specialized version of `_.sample` for arrays.\n *\n * @private\n * @param {Array} array The array to sample.\n * @returns {*} Returns the random element.\n */\n function arraySample(array) {\n var length = array.length;\n return length ? array[baseRandom(0, length - 1)] : undefined;\n }\n\n /**\n * A specialized version of `_.sampleSize` for arrays.\n *\n * @private\n * @param {Array} array The array to sample.\n * @param {number} n The number of elements to sample.\n * @returns {Array} Returns the random elements.\n */\n function arraySampleSize(array, n) {\n return shuffleSelf(copyArray(array), baseClamp(n, 0, array.length));\n }\n\n /**\n * A specialized version of `_.shuffle` for arrays.\n *\n * @private\n * @param {Array} array The array to shuffle.\n * @returns {Array} Returns the new shuffled array.\n */\n function arrayShuffle(array) {\n return shuffleSelf(copyArray(array));\n }\n\n /**\n * This function is like `assignValue` except that it doesn't assign\n * `undefined` values.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\n function assignMergeValue(object, key, value) {\n if ((value !== undefined && !eq(object[key], value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n }\n\n /**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\n function assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n }\n\n /**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\n function assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n }\n\n /**\n * Aggregates elements of `collection` on `accumulator` with keys transformed\n * by `iteratee` and values set by `setter`.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform keys.\n * @param {Object} accumulator The initial aggregated object.\n * @returns {Function} Returns `accumulator`.\n */\n function baseAggregator(collection, setter, iteratee, accumulator) {\n baseEach(collection, function(value, key, collection) {\n setter(accumulator, value, iteratee(value), collection);\n });\n return accumulator;\n }\n\n /**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\n function baseAssign(object, source) {\n return object && copyObject(source, keys(source), object);\n }\n\n /**\n * The base implementation of `_.assignIn` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\n function baseAssignIn(object, source) {\n return object && copyObject(source, keysIn(source), object);\n }\n\n /**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\n function baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n }\n\n /**\n * The base implementation of `_.at` without support for individual paths.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {string[]} paths The property paths to pick.\n * @returns {Array} Returns the picked elements.\n */\n function baseAt(object, paths) {\n var index = -1,\n length = paths.length,\n result = Array(length),\n skip = object == null;\n\n while (++index < length) {\n result[index] = skip ? undefined : get(object, paths[index]);\n }\n return result;\n }\n\n /**\n * The base implementation of `_.clamp` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n */\n function baseClamp(number, lower, upper) {\n if (number === number) {\n if (upper !== undefined) {\n number = number <= upper ? number : upper;\n }\n if (lower !== undefined) {\n number = number >= lower ? number : lower;\n }\n }\n return number;\n }\n\n /**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Deep clone\n * 2 - Flatten inherited properties\n * 4 - Clone symbols\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\n function baseClone(value, bitmask, customizer, key, object, stack) {\n var result,\n isDeep = bitmask & CLONE_DEEP_FLAG,\n isFlat = bitmask & CLONE_FLAT_FLAG,\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\n\n if (customizer) {\n result = object ? customizer(value, key, object, stack) : customizer(value);\n }\n if (result !== undefined) {\n return result;\n }\n if (!isObject(value)) {\n return value;\n }\n var isArr = isArray(value);\n if (isArr) {\n result = initCloneArray(value);\n if (!isDeep) {\n return copyArray(value, result);\n }\n } else {\n var tag = getTag(value),\n isFunc = tag == funcTag || tag == genTag;\n\n if (isBuffer(value)) {\n return cloneBuffer(value, isDeep);\n }\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\n if (!isDeep) {\n return isFlat\n ? copySymbolsIn(value, baseAssignIn(result, value))\n : copySymbols(value, baseAssign(result, value));\n }\n } else {\n if (!cloneableTags[tag]) {\n return object ? value : {};\n }\n result = initCloneByTag(value, tag, isDeep);\n }\n }\n // Check for circular references and return its corresponding clone.\n stack || (stack = new Stack);\n var stacked = stack.get(value);\n if (stacked) {\n return stacked;\n }\n stack.set(value, result);\n\n if (isSet(value)) {\n value.forEach(function(subValue) {\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\n });\n } else if (isMap(value)) {\n value.forEach(function(subValue, key) {\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n }\n\n var keysFunc = isFull\n ? (isFlat ? getAllKeysIn : getAllKeys)\n : (isFlat ? keysIn : keys);\n\n var props = isArr ? undefined : keysFunc(value);\n arrayEach(props || value, function(subValue, key) {\n if (props) {\n key = subValue;\n subValue = value[key];\n }\n // Recursively populate clone (susceptible to call stack limits).\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n return result;\n }\n\n /**\n * The base implementation of `_.conforms` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property predicates to conform to.\n * @returns {Function} Returns the new spec function.\n */\n function baseConforms(source) {\n var props = keys(source);\n return function(object) {\n return baseConformsTo(object, source, props);\n };\n }\n\n /**\n * The base implementation of `_.conformsTo` which accepts `props` to check.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property predicates to conform to.\n * @returns {boolean} Returns `true` if `object` conforms, else `false`.\n */\n function baseConformsTo(object, source, props) {\n var length = props.length;\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (length--) {\n var key = props[length],\n predicate = source[key],\n value = object[key];\n\n if ((value === undefined && !(key in object)) || !predicate(value)) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * The base implementation of `_.delay` and `_.defer` which accepts `args`\n * to provide to `func`.\n *\n * @private\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @param {Array} args The arguments to provide to `func`.\n * @returns {number|Object} Returns the timer id or timeout object.\n */\n function baseDelay(func, wait, args) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n return setTimeout(function() { func.apply(undefined, args); }, wait);\n }\n\n /**\n * The base implementation of methods like `_.difference` without support\n * for excluding multiple arrays or iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Array} values The values to exclude.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n */\n function baseDifference(array, values, iteratee, comparator) {\n var index = -1,\n includes = arrayIncludes,\n isCommon = true,\n length = array.length,\n result = [],\n valuesLength = values.length;\n\n if (!length) {\n return result;\n }\n if (iteratee) {\n values = arrayMap(values, baseUnary(iteratee));\n }\n if (comparator) {\n includes = arrayIncludesWith;\n isCommon = false;\n }\n else if (values.length >= LARGE_ARRAY_SIZE) {\n includes = cacheHas;\n isCommon = false;\n values = new SetCache(values);\n }\n outer:\n while (++index < length) {\n var value = array[index],\n computed = iteratee == null ? value : iteratee(value);\n\n value = (comparator || value !== 0) ? value : 0;\n if (isCommon && computed === computed) {\n var valuesIndex = valuesLength;\n while (valuesIndex--) {\n if (values[valuesIndex] === computed) {\n continue outer;\n }\n }\n result.push(value);\n }\n else if (!includes(values, computed, comparator)) {\n result.push(value);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.forEach` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\n var baseEach = createBaseEach(baseForOwn);\n\n /**\n * The base implementation of `_.forEachRight` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n */\n var baseEachRight = createBaseEach(baseForOwnRight, true);\n\n /**\n * The base implementation of `_.every` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`\n */\n function baseEvery(collection, predicate) {\n var result = true;\n baseEach(collection, function(value, index, collection) {\n result = !!predicate(value, index, collection);\n return result;\n });\n return result;\n }\n\n /**\n * The base implementation of methods like `_.max` and `_.min` which accepts a\n * `comparator` to determine the extremum value.\n *\n * @private\n * @param {Array} array The array to iterate over.\n * @param {Function} iteratee The iteratee invoked per iteration.\n * @param {Function} comparator The comparator used to compare values.\n * @returns {*} Returns the extremum value.\n */\n function baseExtremum(array, iteratee, comparator) {\n var index = -1,\n length = array.length;\n\n while (++index < length) {\n var value = array[index],\n current = iteratee(value);\n\n if (current != null && (computed === undefined\n ? (current === current && !isSymbol(current))\n : comparator(current, computed)\n )) {\n var computed = current,\n result = value;\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.fill` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n */\n function baseFill(array, value, start, end) {\n var length = array.length;\n\n start = toInteger(start);\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = (end === undefined || end > length) ? length : toInteger(end);\n if (end < 0) {\n end += length;\n }\n end = start > end ? 0 : toLength(end);\n while (start < end) {\n array[start++] = value;\n }\n return array;\n }\n\n /**\n * The base implementation of `_.filter` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\n function baseFilter(collection, predicate) {\n var result = [];\n baseEach(collection, function(value, index, collection) {\n if (predicate(value, index, collection)) {\n result.push(value);\n }\n });\n return result;\n }\n\n /**\n * The base implementation of `_.flatten` with support for restricting flattening.\n *\n * @private\n * @param {Array} array The array to flatten.\n * @param {number} depth The maximum recursion depth.\n * @param {boolean} [predicate=isFlattenable] The function invoked per iteration.\n * @param {boolean} [isStrict] Restrict to values that pass `predicate` checks.\n * @param {Array} [result=[]] The initial result value.\n * @returns {Array} Returns the new flattened array.\n */\n function baseFlatten(array, depth, predicate, isStrict, result) {\n var index = -1,\n length = array.length;\n\n predicate || (predicate = isFlattenable);\n result || (result = []);\n\n while (++index < length) {\n var value = array[index];\n if (depth > 0 && predicate(value)) {\n if (depth > 1) {\n // Recursively flatten arrays (susceptible to call stack limits).\n baseFlatten(value, depth - 1, predicate, isStrict, result);\n } else {\n arrayPush(result, value);\n }\n } else if (!isStrict) {\n result[result.length] = value;\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `baseForOwn` which iterates over `object`\n * properties returned by `keysFunc` and invokes `iteratee` for each property.\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\n var baseFor = createBaseFor();\n\n /**\n * This function is like `baseFor` except that it iterates over properties\n * in the opposite order.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @returns {Object} Returns `object`.\n */\n var baseForRight = createBaseFor(true);\n\n /**\n * The base implementation of `_.forOwn` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\n function baseForOwn(object, iteratee) {\n return object && baseFor(object, iteratee, keys);\n }\n\n /**\n * The base implementation of `_.forOwnRight` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Object} Returns `object`.\n */\n function baseForOwnRight(object, iteratee) {\n return object && baseForRight(object, iteratee, keys);\n }\n\n /**\n * The base implementation of `_.functions` which creates an array of\n * `object` function property names filtered from `props`.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Array} props The property names to filter.\n * @returns {Array} Returns the function names.\n */\n function baseFunctions(object, props) {\n return arrayFilter(props, function(key) {\n return isFunction(object[key]);\n });\n }\n\n /**\n * The base implementation of `_.get` without support for default values.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @returns {*} Returns the resolved value.\n */\n function baseGet(object, path) {\n path = castPath(path, object);\n\n var index = 0,\n length = path.length;\n\n while (object != null && index < length) {\n object = object[toKey(path[index++])];\n }\n return (index && index == length) ? object : undefined;\n }\n\n /**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\n function baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n }\n\n /**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\n function baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n }\n\n /**\n * The base implementation of `_.gt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n * else `false`.\n */\n function baseGt(value, other) {\n return value > other;\n }\n\n /**\n * The base implementation of `_.has` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\n function baseHas(object, key) {\n return object != null && hasOwnProperty.call(object, key);\n }\n\n /**\n * The base implementation of `_.hasIn` without support for deep paths.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {Array|string} key The key to check.\n * @returns {boolean} Returns `true` if `key` exists, else `false`.\n */\n function baseHasIn(object, key) {\n return object != null && key in Object(object);\n }\n\n /**\n * The base implementation of `_.inRange` which doesn't coerce arguments.\n *\n * @private\n * @param {number} number The number to check.\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @returns {boolean} Returns `true` if `number` is in the range, else `false`.\n */\n function baseInRange(number, start, end) {\n return number >= nativeMin(start, end) && number < nativeMax(start, end);\n }\n\n /**\n * The base implementation of methods like `_.intersection`, without support\n * for iteratee shorthands, that accepts an array of arrays to inspect.\n *\n * @private\n * @param {Array} arrays The arrays to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of shared values.\n */\n function baseIntersection(arrays, iteratee, comparator) {\n var includes = comparator ? arrayIncludesWith : arrayIncludes,\n length = arrays[0].length,\n othLength = arrays.length,\n othIndex = othLength,\n caches = Array(othLength),\n maxLength = Infinity,\n result = [];\n\n while (othIndex--) {\n var array = arrays[othIndex];\n if (othIndex && iteratee) {\n array = arrayMap(array, baseUnary(iteratee));\n }\n maxLength = nativeMin(array.length, maxLength);\n caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120))\n ? new SetCache(othIndex && array)\n : undefined;\n }\n array = arrays[0];\n\n var index = -1,\n seen = caches[0];\n\n outer:\n while (++index < length && result.length < maxLength) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n value = (comparator || value !== 0) ? value : 0;\n if (!(seen\n ? cacheHas(seen, computed)\n : includes(result, computed, comparator)\n )) {\n othIndex = othLength;\n while (--othIndex) {\n var cache = caches[othIndex];\n if (!(cache\n ? cacheHas(cache, computed)\n : includes(arrays[othIndex], computed, comparator))\n ) {\n continue outer;\n }\n }\n if (seen) {\n seen.push(computed);\n }\n result.push(value);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.invert` and `_.invertBy` which inverts\n * `object` with values transformed by `iteratee` and set by `setter`.\n *\n * @private\n * @param {Object} object The object to iterate over.\n * @param {Function} setter The function to set `accumulator` values.\n * @param {Function} iteratee The iteratee to transform values.\n * @param {Object} accumulator The initial inverted object.\n * @returns {Function} Returns `accumulator`.\n */\n function baseInverter(object, setter, iteratee, accumulator) {\n baseForOwn(object, function(value, key, object) {\n setter(accumulator, iteratee(value), key, object);\n });\n return accumulator;\n }\n\n /**\n * The base implementation of `_.invoke` without support for individual\n * method arguments.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the method to invoke.\n * @param {Array} args The arguments to invoke the method with.\n * @returns {*} Returns the result of the invoked method.\n */\n function baseInvoke(object, path, args) {\n path = castPath(path, object);\n object = parent(object, path);\n var func = object == null ? object : object[toKey(last(path))];\n return func == null ? undefined : apply(func, object, args);\n }\n\n /**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\n function baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n }\n\n /**\n * The base implementation of `_.isArrayBuffer` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.\n */\n function baseIsArrayBuffer(value) {\n return isObjectLike(value) && baseGetTag(value) == arrayBufferTag;\n }\n\n /**\n * The base implementation of `_.isDate` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\n */\n function baseIsDate(value) {\n return isObjectLike(value) && baseGetTag(value) == dateTag;\n }\n\n /**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\n function baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n }\n\n /**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\n function baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n }\n\n /**\n * The base implementation of `_.isMap` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n */\n function baseIsMap(value) {\n return isObjectLike(value) && getTag(value) == mapTag;\n }\n\n /**\n * The base implementation of `_.isMatch` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Array} matchData The property names, values, and compare flags to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n */\n function baseIsMatch(object, source, matchData, customizer) {\n var index = matchData.length,\n length = index,\n noCustomizer = !customizer;\n\n if (object == null) {\n return !length;\n }\n object = Object(object);\n while (index--) {\n var data = matchData[index];\n if ((noCustomizer && data[2])\n ? data[1] !== object[data[0]]\n : !(data[0] in object)\n ) {\n return false;\n }\n }\n while (++index < length) {\n data = matchData[index];\n var key = data[0],\n objValue = object[key],\n srcValue = data[1];\n\n if (noCustomizer && data[2]) {\n if (objValue === undefined && !(key in object)) {\n return false;\n }\n } else {\n var stack = new Stack;\n if (customizer) {\n var result = customizer(objValue, srcValue, key, object, source, stack);\n }\n if (!(result === undefined\n ? baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG, customizer, stack)\n : result\n )) {\n return false;\n }\n }\n }\n return true;\n }\n\n /**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\n function baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n }\n\n /**\n * The base implementation of `_.isRegExp` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n */\n function baseIsRegExp(value) {\n return isObjectLike(value) && baseGetTag(value) == regexpTag;\n }\n\n /**\n * The base implementation of `_.isSet` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n */\n function baseIsSet(value) {\n return isObjectLike(value) && getTag(value) == setTag;\n }\n\n /**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\n function baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n }\n\n /**\n * The base implementation of `_.iteratee`.\n *\n * @private\n * @param {*} [value=_.identity] The value to convert to an iteratee.\n * @returns {Function} Returns the iteratee.\n */\n function baseIteratee(value) {\n // Don't store the `typeof` result in a variable to avoid a JIT bug in Safari 9.\n // See https://bugs.webkit.org/show_bug.cgi?id=156034 for more details.\n if (typeof value == 'function') {\n return value;\n }\n if (value == null) {\n return identity;\n }\n if (typeof value == 'object') {\n return isArray(value)\n ? baseMatchesProperty(value[0], value[1])\n : baseMatches(value);\n }\n return property(value);\n }\n\n /**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\n function baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.keysIn` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\n function baseKeysIn(object) {\n if (!isObject(object)) {\n return nativeKeysIn(object);\n }\n var isProto = isPrototype(object),\n result = [];\n\n for (var key in object) {\n if (!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) {\n result.push(key);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.lt` which doesn't coerce arguments.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n * else `false`.\n */\n function baseLt(value, other) {\n return value < other;\n }\n\n /**\n * The base implementation of `_.map` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\n function baseMap(collection, iteratee) {\n var index = -1,\n result = isArrayLike(collection) ? Array(collection.length) : [];\n\n baseEach(collection, function(value, key, collection) {\n result[++index] = iteratee(value, key, collection);\n });\n return result;\n }\n\n /**\n * The base implementation of `_.matches` which doesn't clone `source`.\n *\n * @private\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n */\n function baseMatches(source) {\n var matchData = getMatchData(source);\n if (matchData.length == 1 && matchData[0][2]) {\n return matchesStrictComparable(matchData[0][0], matchData[0][1]);\n }\n return function(object) {\n return object === source || baseIsMatch(object, source, matchData);\n };\n }\n\n /**\n * The base implementation of `_.matchesProperty` which doesn't clone `srcValue`.\n *\n * @private\n * @param {string} path The path of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\n function baseMatchesProperty(path, srcValue) {\n if (isKey(path) && isStrictComparable(srcValue)) {\n return matchesStrictComparable(toKey(path), srcValue);\n }\n return function(object) {\n var objValue = get(object, path);\n return (objValue === undefined && objValue === srcValue)\n ? hasIn(object, path)\n : baseIsEqual(srcValue, objValue, COMPARE_PARTIAL_FLAG | COMPARE_UNORDERED_FLAG);\n };\n }\n\n /**\n * The base implementation of `_.merge` without support for multiple sources.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} [customizer] The function to customize merged values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\n function baseMerge(object, source, srcIndex, customizer, stack) {\n if (object === source) {\n return;\n }\n baseFor(source, function(srcValue, key) {\n stack || (stack = new Stack);\n if (isObject(srcValue)) {\n baseMergeDeep(object, source, key, srcIndex, baseMerge, customizer, stack);\n }\n else {\n var newValue = customizer\n ? customizer(safeGet(object, key), srcValue, (key + ''), object, source, stack)\n : undefined;\n\n if (newValue === undefined) {\n newValue = srcValue;\n }\n assignMergeValue(object, key, newValue);\n }\n }, keysIn);\n }\n\n /**\n * A specialized version of `baseMerge` for arrays and objects which performs\n * deep merges and tracks traversed objects enabling objects with circular\n * references to be merged.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @param {string} key The key of the value to merge.\n * @param {number} srcIndex The index of `source`.\n * @param {Function} mergeFunc The function to merge values.\n * @param {Function} [customizer] The function to customize assigned values.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n */\n function baseMergeDeep(object, source, key, srcIndex, mergeFunc, customizer, stack) {\n var objValue = safeGet(object, key),\n srcValue = safeGet(source, key),\n stacked = stack.get(srcValue);\n\n if (stacked) {\n assignMergeValue(object, key, stacked);\n return;\n }\n var newValue = customizer\n ? customizer(objValue, srcValue, (key + ''), object, source, stack)\n : undefined;\n\n var isCommon = newValue === undefined;\n\n if (isCommon) {\n var isArr = isArray(srcValue),\n isBuff = !isArr && isBuffer(srcValue),\n isTyped = !isArr && !isBuff && isTypedArray(srcValue);\n\n newValue = srcValue;\n if (isArr || isBuff || isTyped) {\n if (isArray(objValue)) {\n newValue = objValue;\n }\n else if (isArrayLikeObject(objValue)) {\n newValue = copyArray(objValue);\n }\n else if (isBuff) {\n isCommon = false;\n newValue = cloneBuffer(srcValue, true);\n }\n else if (isTyped) {\n isCommon = false;\n newValue = cloneTypedArray(srcValue, true);\n }\n else {\n newValue = [];\n }\n }\n else if (isPlainObject(srcValue) || isArguments(srcValue)) {\n newValue = objValue;\n if (isArguments(objValue)) {\n newValue = toPlainObject(objValue);\n }\n else if (!isObject(objValue) || isFunction(objValue)) {\n newValue = initCloneObject(srcValue);\n }\n }\n else {\n isCommon = false;\n }\n }\n if (isCommon) {\n // Recursively merge objects and arrays (susceptible to call stack limits).\n stack.set(srcValue, newValue);\n mergeFunc(newValue, srcValue, srcIndex, customizer, stack);\n stack['delete'](srcValue);\n }\n assignMergeValue(object, key, newValue);\n }\n\n /**\n * The base implementation of `_.nth` which doesn't coerce arguments.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {number} n The index of the element to return.\n * @returns {*} Returns the nth element of `array`.\n */\n function baseNth(array, n) {\n var length = array.length;\n if (!length) {\n return;\n }\n n += n < 0 ? length : 0;\n return isIndex(n, length) ? array[n] : undefined;\n }\n\n /**\n * The base implementation of `_.orderBy` without param guards.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function[]|Object[]|string[]} iteratees The iteratees to sort by.\n * @param {string[]} orders The sort orders of `iteratees`.\n * @returns {Array} Returns the new sorted array.\n */\n function baseOrderBy(collection, iteratees, orders) {\n if (iteratees.length) {\n iteratees = arrayMap(iteratees, function(iteratee) {\n if (isArray(iteratee)) {\n return function(value) {\n return baseGet(value, iteratee.length === 1 ? iteratee[0] : iteratee);\n }\n }\n return iteratee;\n });\n } else {\n iteratees = [identity];\n }\n\n var index = -1;\n iteratees = arrayMap(iteratees, baseUnary(getIteratee()));\n\n var result = baseMap(collection, function(value, key, collection) {\n var criteria = arrayMap(iteratees, function(iteratee) {\n return iteratee(value);\n });\n return { 'criteria': criteria, 'index': ++index, 'value': value };\n });\n\n return baseSortBy(result, function(object, other) {\n return compareMultiple(object, other, orders);\n });\n }\n\n /**\n * The base implementation of `_.pick` without support for individual\n * property identifiers.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @returns {Object} Returns the new object.\n */\n function basePick(object, paths) {\n return basePickBy(object, paths, function(value, path) {\n return hasIn(object, path);\n });\n }\n\n /**\n * The base implementation of `_.pickBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Object} object The source object.\n * @param {string[]} paths The property paths to pick.\n * @param {Function} predicate The function invoked per property.\n * @returns {Object} Returns the new object.\n */\n function basePickBy(object, paths, predicate) {\n var index = -1,\n length = paths.length,\n result = {};\n\n while (++index < length) {\n var path = paths[index],\n value = baseGet(object, path);\n\n if (predicate(value, path)) {\n baseSet(result, castPath(path, object), value);\n }\n }\n return result;\n }\n\n /**\n * A specialized version of `baseProperty` which supports deep paths.\n *\n * @private\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n */\n function basePropertyDeep(path) {\n return function(object) {\n return baseGet(object, path);\n };\n }\n\n /**\n * The base implementation of `_.pullAllBy` without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns `array`.\n */\n function basePullAll(array, values, iteratee, comparator) {\n var indexOf = comparator ? baseIndexOfWith : baseIndexOf,\n index = -1,\n length = values.length,\n seen = array;\n\n if (array === values) {\n values = copyArray(values);\n }\n if (iteratee) {\n seen = arrayMap(array, baseUnary(iteratee));\n }\n while (++index < length) {\n var fromIndex = 0,\n value = values[index],\n computed = iteratee ? iteratee(value) : value;\n\n while ((fromIndex = indexOf(seen, computed, fromIndex, comparator)) > -1) {\n if (seen !== array) {\n splice.call(seen, fromIndex, 1);\n }\n splice.call(array, fromIndex, 1);\n }\n }\n return array;\n }\n\n /**\n * The base implementation of `_.pullAt` without support for individual\n * indexes or capturing the removed elements.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {number[]} indexes The indexes of elements to remove.\n * @returns {Array} Returns `array`.\n */\n function basePullAt(array, indexes) {\n var length = array ? indexes.length : 0,\n lastIndex = length - 1;\n\n while (length--) {\n var index = indexes[length];\n if (length == lastIndex || index !== previous) {\n var previous = index;\n if (isIndex(index)) {\n splice.call(array, index, 1);\n } else {\n baseUnset(array, index);\n }\n }\n }\n return array;\n }\n\n /**\n * The base implementation of `_.random` without support for returning\n * floating-point numbers.\n *\n * @private\n * @param {number} lower The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the random number.\n */\n function baseRandom(lower, upper) {\n return lower + nativeFloor(nativeRandom() * (upper - lower + 1));\n }\n\n /**\n * The base implementation of `_.range` and `_.rangeRight` which doesn't\n * coerce arguments.\n *\n * @private\n * @param {number} start The start of the range.\n * @param {number} end The end of the range.\n * @param {number} step The value to increment or decrement by.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the range of numbers.\n */\n function baseRange(start, end, step, fromRight) {\n var index = -1,\n length = nativeMax(nativeCeil((end - start) / (step || 1)), 0),\n result = Array(length);\n\n while (length--) {\n result[fromRight ? length : ++index] = start;\n start += step;\n }\n return result;\n }\n\n /**\n * The base implementation of `_.repeat` which doesn't coerce arguments.\n *\n * @private\n * @param {string} string The string to repeat.\n * @param {number} n The number of times to repeat the string.\n * @returns {string} Returns the repeated string.\n */\n function baseRepeat(string, n) {\n var result = '';\n if (!string || n < 1 || n > MAX_SAFE_INTEGER) {\n return result;\n }\n // Leverage the exponentiation by squaring algorithm for a faster repeat.\n // See https://en.wikipedia.org/wiki/Exponentiation_by_squaring for more details.\n do {\n if (n % 2) {\n result += string;\n }\n n = nativeFloor(n / 2);\n if (n) {\n string += string;\n }\n } while (n);\n\n return result;\n }\n\n /**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\n function baseRest(func, start) {\n return setToString(overRest(func, start, identity), func + '');\n }\n\n /**\n * The base implementation of `_.sample`.\n *\n * @private\n * @param {Array|Object} collection The collection to sample.\n * @returns {*} Returns the random element.\n */\n function baseSample(collection) {\n return arraySample(values(collection));\n }\n\n /**\n * The base implementation of `_.sampleSize` without param guards.\n *\n * @private\n * @param {Array|Object} collection The collection to sample.\n * @param {number} n The number of elements to sample.\n * @returns {Array} Returns the random elements.\n */\n function baseSampleSize(collection, n) {\n var array = values(collection);\n return shuffleSelf(array, baseClamp(n, 0, array.length));\n }\n\n /**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\n function baseSet(object, path, value, customizer) {\n if (!isObject(object)) {\n return object;\n }\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n lastIndex = length - 1,\n nested = object;\n\n while (nested != null && ++index < length) {\n var key = toKey(path[index]),\n newValue = value;\n\n if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n return object;\n }\n\n if (index != lastIndex) {\n var objValue = nested[key];\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\n if (newValue === undefined) {\n newValue = isObject(objValue)\n ? objValue\n : (isIndex(path[index + 1]) ? [] : {});\n }\n }\n assignValue(nested, key, newValue);\n nested = nested[key];\n }\n return object;\n }\n\n /**\n * The base implementation of `setData` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\n var baseSetData = !metaMap ? identity : function(func, data) {\n metaMap.set(func, data);\n return func;\n };\n\n /**\n * The base implementation of `setToString` without support for hot loop shorting.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\n var baseSetToString = !defineProperty ? identity : function(func, string) {\n return defineProperty(func, 'toString', {\n 'configurable': true,\n 'enumerable': false,\n 'value': constant(string),\n 'writable': true\n });\n };\n\n /**\n * The base implementation of `_.shuffle`.\n *\n * @private\n * @param {Array|Object} collection The collection to shuffle.\n * @returns {Array} Returns the new shuffled array.\n */\n function baseShuffle(collection) {\n return shuffleSelf(values(collection));\n }\n\n /**\n * The base implementation of `_.slice` without an iteratee call guard.\n *\n * @private\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\n function baseSlice(array, start, end) {\n var index = -1,\n length = array.length;\n\n if (start < 0) {\n start = -start > length ? 0 : (length + start);\n }\n end = end > length ? length : end;\n if (end < 0) {\n end += length;\n }\n length = start > end ? 0 : ((end - start) >>> 0);\n start >>>= 0;\n\n var result = Array(length);\n while (++index < length) {\n result[index] = array[index + start];\n }\n return result;\n }\n\n /**\n * The base implementation of `_.some` without support for iteratee shorthands.\n *\n * @private\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\n function baseSome(collection, predicate) {\n var result;\n\n baseEach(collection, function(value, index, collection) {\n result = predicate(value, index, collection);\n return !result;\n });\n return !!result;\n }\n\n /**\n * The base implementation of `_.sortedIndex` and `_.sortedLastIndex` which\n * performs a binary search of `array` to determine the index at which `value`\n * should be inserted into `array` in order to maintain its sort order.\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n */\n function baseSortedIndex(array, value, retHighest) {\n var low = 0,\n high = array == null ? low : array.length;\n\n if (typeof value == 'number' && value === value && high <= HALF_MAX_ARRAY_LENGTH) {\n while (low < high) {\n var mid = (low + high) >>> 1,\n computed = array[mid];\n\n if (computed !== null && !isSymbol(computed) &&\n (retHighest ? (computed <= value) : (computed < value))) {\n low = mid + 1;\n } else {\n high = mid;\n }\n }\n return high;\n }\n return baseSortedIndexBy(array, value, identity, retHighest);\n }\n\n /**\n * The base implementation of `_.sortedIndexBy` and `_.sortedLastIndexBy`\n * which invokes `iteratee` for `value` and each element of `array` to compute\n * their sort ranking. The iteratee is invoked with one argument; (value).\n *\n * @private\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} iteratee The iteratee invoked per element.\n * @param {boolean} [retHighest] Specify returning the highest qualified index.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n */\n function baseSortedIndexBy(array, value, iteratee, retHighest) {\n var low = 0,\n high = array == null ? 0 : array.length;\n if (high === 0) {\n return 0;\n }\n\n value = iteratee(value);\n var valIsNaN = value !== value,\n valIsNull = value === null,\n valIsSymbol = isSymbol(value),\n valIsUndefined = value === undefined;\n\n while (low < high) {\n var mid = nativeFloor((low + high) / 2),\n computed = iteratee(array[mid]),\n othIsDefined = computed !== undefined,\n othIsNull = computed === null,\n othIsReflexive = computed === computed,\n othIsSymbol = isSymbol(computed);\n\n if (valIsNaN) {\n var setLow = retHighest || othIsReflexive;\n } else if (valIsUndefined) {\n setLow = othIsReflexive && (retHighest || othIsDefined);\n } else if (valIsNull) {\n setLow = othIsReflexive && othIsDefined && (retHighest || !othIsNull);\n } else if (valIsSymbol) {\n setLow = othIsReflexive && othIsDefined && !othIsNull && (retHighest || !othIsSymbol);\n } else if (othIsNull || othIsSymbol) {\n setLow = false;\n } else {\n setLow = retHighest ? (computed <= value) : (computed < value);\n }\n if (setLow) {\n low = mid + 1;\n } else {\n high = mid;\n }\n }\n return nativeMin(high, MAX_ARRAY_INDEX);\n }\n\n /**\n * The base implementation of `_.sortedUniq` and `_.sortedUniqBy` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\n function baseSortedUniq(array, iteratee) {\n var index = -1,\n length = array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n if (!index || !eq(computed, seen)) {\n var seen = computed;\n result[resIndex++] = value === 0 ? 0 : value;\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.toNumber` which doesn't ensure correct\n * conversions of binary, hexadecimal, or octal string values.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n */\n function baseToNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n return +value;\n }\n\n /**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\n function baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n }\n\n /**\n * The base implementation of `_.uniqBy` without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n */\n function baseUniq(array, iteratee, comparator) {\n var index = -1,\n includes = arrayIncludes,\n length = array.length,\n isCommon = true,\n result = [],\n seen = result;\n\n if (comparator) {\n isCommon = false;\n includes = arrayIncludesWith;\n }\n else if (length >= LARGE_ARRAY_SIZE) {\n var set = iteratee ? null : createSet(array);\n if (set) {\n return setToArray(set);\n }\n isCommon = false;\n includes = cacheHas;\n seen = new SetCache;\n }\n else {\n seen = iteratee ? [] : result;\n }\n outer:\n while (++index < length) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n value = (comparator || value !== 0) ? value : 0;\n if (isCommon && computed === computed) {\n var seenIndex = seen.length;\n while (seenIndex--) {\n if (seen[seenIndex] === computed) {\n continue outer;\n }\n }\n if (iteratee) {\n seen.push(computed);\n }\n result.push(value);\n }\n else if (!includes(seen, computed, comparator)) {\n if (seen !== result) {\n seen.push(computed);\n }\n result.push(value);\n }\n }\n return result;\n }\n\n /**\n * The base implementation of `_.unset`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The property path to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n */\n function baseUnset(object, path) {\n path = castPath(path, object);\n object = parent(object, path);\n return object == null || delete object[toKey(last(path))];\n }\n\n /**\n * The base implementation of `_.update`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to update.\n * @param {Function} updater The function to produce the updated value.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\n function baseUpdate(object, path, updater, customizer) {\n return baseSet(object, path, updater(baseGet(object, path)), customizer);\n }\n\n /**\n * The base implementation of methods like `_.dropWhile` and `_.takeWhile`\n * without support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to query.\n * @param {Function} predicate The function invoked per iteration.\n * @param {boolean} [isDrop] Specify dropping elements instead of taking them.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Array} Returns the slice of `array`.\n */\n function baseWhile(array, predicate, isDrop, fromRight) {\n var length = array.length,\n index = fromRight ? length : -1;\n\n while ((fromRight ? index-- : ++index < length) &&\n predicate(array[index], index, array)) {}\n\n return isDrop\n ? baseSlice(array, (fromRight ? 0 : index), (fromRight ? index + 1 : length))\n : baseSlice(array, (fromRight ? index + 1 : 0), (fromRight ? length : index));\n }\n\n /**\n * The base implementation of `wrapperValue` which returns the result of\n * performing a sequence of actions on the unwrapped `value`, where each\n * successive action is supplied the return value of the previous.\n *\n * @private\n * @param {*} value The unwrapped value.\n * @param {Array} actions Actions to perform to resolve the unwrapped value.\n * @returns {*} Returns the resolved value.\n */\n function baseWrapperValue(value, actions) {\n var result = value;\n if (result instanceof LazyWrapper) {\n result = result.value();\n }\n return arrayReduce(actions, function(result, action) {\n return action.func.apply(action.thisArg, arrayPush([result], action.args));\n }, result);\n }\n\n /**\n * The base implementation of methods like `_.xor`, without support for\n * iteratee shorthands, that accepts an array of arrays to inspect.\n *\n * @private\n * @param {Array} arrays The arrays to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of values.\n */\n function baseXor(arrays, iteratee, comparator) {\n var length = arrays.length;\n if (length < 2) {\n return length ? baseUniq(arrays[0]) : [];\n }\n var index = -1,\n result = Array(length);\n\n while (++index < length) {\n var array = arrays[index],\n othIndex = -1;\n\n while (++othIndex < length) {\n if (othIndex != index) {\n result[index] = baseDifference(result[index] || array, arrays[othIndex], iteratee, comparator);\n }\n }\n }\n return baseUniq(baseFlatten(result, 1), iteratee, comparator);\n }\n\n /**\n * This base implementation of `_.zipObject` which assigns values using `assignFunc`.\n *\n * @private\n * @param {Array} props The property identifiers.\n * @param {Array} values The property values.\n * @param {Function} assignFunc The function to assign values.\n * @returns {Object} Returns the new object.\n */\n function baseZipObject(props, values, assignFunc) {\n var index = -1,\n length = props.length,\n valsLength = values.length,\n result = {};\n\n while (++index < length) {\n var value = index < valsLength ? values[index] : undefined;\n assignFunc(result, props[index], value);\n }\n return result;\n }\n\n /**\n * Casts `value` to an empty array if it's not an array like object.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Array|Object} Returns the cast array-like object.\n */\n function castArrayLikeObject(value) {\n return isArrayLikeObject(value) ? value : [];\n }\n\n /**\n * Casts `value` to `identity` if it's not a function.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Function} Returns cast function.\n */\n function castFunction(value) {\n return typeof value == 'function' ? value : identity;\n }\n\n /**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\n function castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n }\n\n /**\n * A `baseRest` alias which can be replaced with `identity` by module\n * replacement plugins.\n *\n * @private\n * @type {Function}\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\n var castRest = baseRest;\n\n /**\n * Casts `array` to a slice if it's needed.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {number} start The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the cast slice.\n */\n function castSlice(array, start, end) {\n var length = array.length;\n end = end === undefined ? length : end;\n return (!start && end >= length) ? array : baseSlice(array, start, end);\n }\n\n /**\n * A simple wrapper around the global [`clearTimeout`](https://mdn.io/clearTimeout).\n *\n * @private\n * @param {number|Object} id The timer id or timeout object of the timer to clear.\n */\n var clearTimeout = ctxClearTimeout || function(id) {\n return root.clearTimeout(id);\n };\n\n /**\n * Creates a clone of `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\n function cloneBuffer(buffer, isDeep) {\n if (isDeep) {\n return buffer.slice();\n }\n var length = buffer.length,\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n buffer.copy(result);\n return result;\n }\n\n /**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\n function cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n }\n\n /**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\n function cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n }\n\n /**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\n function cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n }\n\n /**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\n function cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n }\n\n /**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\n function cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n }\n\n /**\n * Compares values to sort them in ascending order.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {number} Returns the sort order indicator for `value`.\n */\n function compareAscending(value, other) {\n if (value !== other) {\n var valIsDefined = value !== undefined,\n valIsNull = value === null,\n valIsReflexive = value === value,\n valIsSymbol = isSymbol(value);\n\n var othIsDefined = other !== undefined,\n othIsNull = other === null,\n othIsReflexive = other === other,\n othIsSymbol = isSymbol(other);\n\n if ((!othIsNull && !othIsSymbol && !valIsSymbol && value > other) ||\n (valIsSymbol && othIsDefined && othIsReflexive && !othIsNull && !othIsSymbol) ||\n (valIsNull && othIsDefined && othIsReflexive) ||\n (!valIsDefined && othIsReflexive) ||\n !valIsReflexive) {\n return 1;\n }\n if ((!valIsNull && !valIsSymbol && !othIsSymbol && value < other) ||\n (othIsSymbol && valIsDefined && valIsReflexive && !valIsNull && !valIsSymbol) ||\n (othIsNull && valIsDefined && valIsReflexive) ||\n (!othIsDefined && valIsReflexive) ||\n !othIsReflexive) {\n return -1;\n }\n }\n return 0;\n }\n\n /**\n * Used by `_.orderBy` to compare multiple properties of a value to another\n * and stable sort them.\n *\n * If `orders` is unspecified, all values are sorted in ascending order. Otherwise,\n * specify an order of \"desc\" for descending or \"asc\" for ascending sort order\n * of corresponding values.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {boolean[]|string[]} orders The order to sort by for each property.\n * @returns {number} Returns the sort order indicator for `object`.\n */\n function compareMultiple(object, other, orders) {\n var index = -1,\n objCriteria = object.criteria,\n othCriteria = other.criteria,\n length = objCriteria.length,\n ordersLength = orders.length;\n\n while (++index < length) {\n var result = compareAscending(objCriteria[index], othCriteria[index]);\n if (result) {\n if (index >= ordersLength) {\n return result;\n }\n var order = orders[index];\n return result * (order == 'desc' ? -1 : 1);\n }\n }\n // Fixes an `Array#sort` bug in the JS engine embedded in Adobe applications\n // that causes it, under certain circumstances, to provide the same value for\n // `object` and `other`. See https://github.com/jashkenas/underscore/pull/1247\n // for more details.\n //\n // This also ensures a stable sort in V8 and other engines.\n // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.\n return object.index - other.index;\n }\n\n /**\n * Creates an array that is the composition of partially applied arguments,\n * placeholders, and provided arguments into a single array of arguments.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to prepend to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\n function composeArgs(args, partials, holders, isCurried) {\n var argsIndex = -1,\n argsLength = args.length,\n holdersLength = holders.length,\n leftIndex = -1,\n leftLength = partials.length,\n rangeLength = nativeMax(argsLength - holdersLength, 0),\n result = Array(leftLength + rangeLength),\n isUncurried = !isCurried;\n\n while (++leftIndex < leftLength) {\n result[leftIndex] = partials[leftIndex];\n }\n while (++argsIndex < holdersLength) {\n if (isUncurried || argsIndex < argsLength) {\n result[holders[argsIndex]] = args[argsIndex];\n }\n }\n while (rangeLength--) {\n result[leftIndex++] = args[argsIndex++];\n }\n return result;\n }\n\n /**\n * This function is like `composeArgs` except that the arguments composition\n * is tailored for `_.partialRight`.\n *\n * @private\n * @param {Array} args The provided arguments.\n * @param {Array} partials The arguments to append to those provided.\n * @param {Array} holders The `partials` placeholder indexes.\n * @params {boolean} [isCurried] Specify composing for a curried function.\n * @returns {Array} Returns the new array of composed arguments.\n */\n function composeArgsRight(args, partials, holders, isCurried) {\n var argsIndex = -1,\n argsLength = args.length,\n holdersIndex = -1,\n holdersLength = holders.length,\n rightIndex = -1,\n rightLength = partials.length,\n rangeLength = nativeMax(argsLength - holdersLength, 0),\n result = Array(rangeLength + rightLength),\n isUncurried = !isCurried;\n\n while (++argsIndex < rangeLength) {\n result[argsIndex] = args[argsIndex];\n }\n var offset = argsIndex;\n while (++rightIndex < rightLength) {\n result[offset + rightIndex] = partials[rightIndex];\n }\n while (++holdersIndex < holdersLength) {\n if (isUncurried || argsIndex < argsLength) {\n result[offset + holders[holdersIndex]] = args[argsIndex++];\n }\n }\n return result;\n }\n\n /**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\n function copyArray(source, array) {\n var index = -1,\n length = source.length;\n\n array || (array = Array(length));\n while (++index < length) {\n array[index] = source[index];\n }\n return array;\n }\n\n /**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\n function copyObject(source, props, object, customizer) {\n var isNew = !object;\n object || (object = {});\n\n var index = -1,\n length = props.length;\n\n while (++index < length) {\n var key = props[index];\n\n var newValue = customizer\n ? customizer(object[key], source[key], key, object, source)\n : undefined;\n\n if (newValue === undefined) {\n newValue = source[key];\n }\n if (isNew) {\n baseAssignValue(object, key, newValue);\n } else {\n assignValue(object, key, newValue);\n }\n }\n return object;\n }\n\n /**\n * Copies own symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\n function copySymbols(source, object) {\n return copyObject(source, getSymbols(source), object);\n }\n\n /**\n * Copies own and inherited symbols of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\n function copySymbolsIn(source, object) {\n return copyObject(source, getSymbolsIn(source), object);\n }\n\n /**\n * Creates a function like `_.groupBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} [initializer] The accumulator object initializer.\n * @returns {Function} Returns the new aggregator function.\n */\n function createAggregator(setter, initializer) {\n return function(collection, iteratee) {\n var func = isArray(collection) ? arrayAggregator : baseAggregator,\n accumulator = initializer ? initializer() : {};\n\n return func(collection, setter, getIteratee(iteratee, 2), accumulator);\n };\n }\n\n /**\n * Creates a function like `_.assign`.\n *\n * @private\n * @param {Function} assigner The function to assign values.\n * @returns {Function} Returns the new assigner function.\n */\n function createAssigner(assigner) {\n return baseRest(function(object, sources) {\n var index = -1,\n length = sources.length,\n customizer = length > 1 ? sources[length - 1] : undefined,\n guard = length > 2 ? sources[2] : undefined;\n\n customizer = (assigner.length > 3 && typeof customizer == 'function')\n ? (length--, customizer)\n : undefined;\n\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n customizer = length < 3 ? undefined : customizer;\n length = 1;\n }\n object = Object(object);\n while (++index < length) {\n var source = sources[index];\n if (source) {\n assigner(object, source, index, customizer);\n }\n }\n return object;\n });\n }\n\n /**\n * Creates a `baseEach` or `baseEachRight` function.\n *\n * @private\n * @param {Function} eachFunc The function to iterate over a collection.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\n function createBaseEach(eachFunc, fromRight) {\n return function(collection, iteratee) {\n if (collection == null) {\n return collection;\n }\n if (!isArrayLike(collection)) {\n return eachFunc(collection, iteratee);\n }\n var length = collection.length,\n index = fromRight ? length : -1,\n iterable = Object(collection);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (iteratee(iterable[index], index, iterable) === false) {\n break;\n }\n }\n return collection;\n };\n }\n\n /**\n * Creates a base function for methods like `_.forIn` and `_.forOwn`.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new base function.\n */\n function createBaseFor(fromRight) {\n return function(object, iteratee, keysFunc) {\n var index = -1,\n iterable = Object(object),\n props = keysFunc(object),\n length = props.length;\n\n while (length--) {\n var key = props[fromRight ? length : ++index];\n if (iteratee(iterable[key], key, iterable) === false) {\n break;\n }\n }\n return object;\n };\n }\n\n /**\n * Creates a function that wraps `func` to invoke it with the optional `this`\n * binding of `thisArg`.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createBind(func, bitmask, thisArg) {\n var isBind = bitmask & WRAP_BIND_FLAG,\n Ctor = createCtor(func);\n\n function wrapper() {\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n return fn.apply(isBind ? thisArg : this, arguments);\n }\n return wrapper;\n }\n\n /**\n * Creates a function like `_.lowerFirst`.\n *\n * @private\n * @param {string} methodName The name of the `String` case method to use.\n * @returns {Function} Returns the new case function.\n */\n function createCaseFirst(methodName) {\n return function(string) {\n string = toString(string);\n\n var strSymbols = hasUnicode(string)\n ? stringToArray(string)\n : undefined;\n\n var chr = strSymbols\n ? strSymbols[0]\n : string.charAt(0);\n\n var trailing = strSymbols\n ? castSlice(strSymbols, 1).join('')\n : string.slice(1);\n\n return chr[methodName]() + trailing;\n };\n }\n\n /**\n * Creates a function like `_.camelCase`.\n *\n * @private\n * @param {Function} callback The function to combine each word.\n * @returns {Function} Returns the new compounder function.\n */\n function createCompounder(callback) {\n return function(string) {\n return arrayReduce(words(deburr(string).replace(reApos, '')), callback, '');\n };\n }\n\n /**\n * Creates a function that produces an instance of `Ctor` regardless of\n * whether it was invoked as part of a `new` expression or by `call` or `apply`.\n *\n * @private\n * @param {Function} Ctor The constructor to wrap.\n * @returns {Function} Returns the new wrapped function.\n */\n function createCtor(Ctor) {\n return function() {\n // Use a `switch` statement to work with class constructors. See\n // http://ecma-international.org/ecma-262/7.0/#sec-ecmascript-function-objects-call-thisargument-argumentslist\n // for more details.\n var args = arguments;\n switch (args.length) {\n case 0: return new Ctor;\n case 1: return new Ctor(args[0]);\n case 2: return new Ctor(args[0], args[1]);\n case 3: return new Ctor(args[0], args[1], args[2]);\n case 4: return new Ctor(args[0], args[1], args[2], args[3]);\n case 5: return new Ctor(args[0], args[1], args[2], args[3], args[4]);\n case 6: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5]);\n case 7: return new Ctor(args[0], args[1], args[2], args[3], args[4], args[5], args[6]);\n }\n var thisBinding = baseCreate(Ctor.prototype),\n result = Ctor.apply(thisBinding, args);\n\n // Mimic the constructor's `return` behavior.\n // See https://es5.github.io/#x13.2.2 for more details.\n return isObject(result) ? result : thisBinding;\n };\n }\n\n /**\n * Creates a function that wraps `func` to enable currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {number} arity The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createCurry(func, bitmask, arity) {\n var Ctor = createCtor(func);\n\n function wrapper() {\n var length = arguments.length,\n args = Array(length),\n index = length,\n placeholder = getHolder(wrapper);\n\n while (index--) {\n args[index] = arguments[index];\n }\n var holders = (length < 3 && args[0] !== placeholder && args[length - 1] !== placeholder)\n ? []\n : replaceHolders(args, placeholder);\n\n length -= holders.length;\n if (length < arity) {\n return createRecurry(\n func, bitmask, createHybrid, wrapper.placeholder, undefined,\n args, holders, undefined, undefined, arity - length);\n }\n var fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n return apply(fn, this, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a `_.find` or `_.findLast` function.\n *\n * @private\n * @param {Function} findIndexFunc The function to find the collection index.\n * @returns {Function} Returns the new find function.\n */\n function createFind(findIndexFunc) {\n return function(collection, predicate, fromIndex) {\n var iterable = Object(collection);\n if (!isArrayLike(collection)) {\n var iteratee = getIteratee(predicate, 3);\n collection = keys(collection);\n predicate = function(key) { return iteratee(iterable[key], key, iterable); };\n }\n var index = findIndexFunc(collection, predicate, fromIndex);\n return index > -1 ? iterable[iteratee ? collection[index] : index] : undefined;\n };\n }\n\n /**\n * Creates a `_.flow` or `_.flowRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new flow function.\n */\n function createFlow(fromRight) {\n return flatRest(function(funcs) {\n var length = funcs.length,\n index = length,\n prereq = LodashWrapper.prototype.thru;\n\n if (fromRight) {\n funcs.reverse();\n }\n while (index--) {\n var func = funcs[index];\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (prereq && !wrapper && getFuncName(func) == 'wrapper') {\n var wrapper = new LodashWrapper([], true);\n }\n }\n index = wrapper ? index : length;\n while (++index < length) {\n func = funcs[index];\n\n var funcName = getFuncName(func),\n data = funcName == 'wrapper' ? getData(func) : undefined;\n\n if (data && isLaziable(data[0]) &&\n data[1] == (WRAP_ARY_FLAG | WRAP_CURRY_FLAG | WRAP_PARTIAL_FLAG | WRAP_REARG_FLAG) &&\n !data[4].length && data[9] == 1\n ) {\n wrapper = wrapper[getFuncName(data[0])].apply(wrapper, data[3]);\n } else {\n wrapper = (func.length == 1 && isLaziable(func))\n ? wrapper[funcName]()\n : wrapper.thru(func);\n }\n }\n return function() {\n var args = arguments,\n value = args[0];\n\n if (wrapper && args.length == 1 && isArray(value)) {\n return wrapper.plant(value).value();\n }\n var index = 0,\n result = length ? funcs[index].apply(this, args) : value;\n\n while (++index < length) {\n result = funcs[index].call(this, result);\n }\n return result;\n };\n });\n }\n\n /**\n * Creates a function that wraps `func` to invoke it with optional `this`\n * binding of `thisArg`, partial application, and currying.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n * the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [partialsRight] The arguments to append to those provided\n * to the new function.\n * @param {Array} [holdersRight] The `partialsRight` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createHybrid(func, bitmask, thisArg, partials, holders, partialsRight, holdersRight, argPos, ary, arity) {\n var isAry = bitmask & WRAP_ARY_FLAG,\n isBind = bitmask & WRAP_BIND_FLAG,\n isBindKey = bitmask & WRAP_BIND_KEY_FLAG,\n isCurried = bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG),\n isFlip = bitmask & WRAP_FLIP_FLAG,\n Ctor = isBindKey ? undefined : createCtor(func);\n\n function wrapper() {\n var length = arguments.length,\n args = Array(length),\n index = length;\n\n while (index--) {\n args[index] = arguments[index];\n }\n if (isCurried) {\n var placeholder = getHolder(wrapper),\n holdersCount = countHolders(args, placeholder);\n }\n if (partials) {\n args = composeArgs(args, partials, holders, isCurried);\n }\n if (partialsRight) {\n args = composeArgsRight(args, partialsRight, holdersRight, isCurried);\n }\n length -= holdersCount;\n if (isCurried && length < arity) {\n var newHolders = replaceHolders(args, placeholder);\n return createRecurry(\n func, bitmask, createHybrid, wrapper.placeholder, thisArg,\n args, newHolders, argPos, ary, arity - length\n );\n }\n var thisBinding = isBind ? thisArg : this,\n fn = isBindKey ? thisBinding[func] : func;\n\n length = args.length;\n if (argPos) {\n args = reorder(args, argPos);\n } else if (isFlip && length > 1) {\n args.reverse();\n }\n if (isAry && ary < length) {\n args.length = ary;\n }\n if (this && this !== root && this instanceof wrapper) {\n fn = Ctor || createCtor(fn);\n }\n return fn.apply(thisBinding, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a function like `_.invertBy`.\n *\n * @private\n * @param {Function} setter The function to set accumulator values.\n * @param {Function} toIteratee The function to resolve iteratees.\n * @returns {Function} Returns the new inverter function.\n */\n function createInverter(setter, toIteratee) {\n return function(object, iteratee) {\n return baseInverter(object, setter, toIteratee(iteratee), {});\n };\n }\n\n /**\n * Creates a function that performs a mathematical operation on two values.\n *\n * @private\n * @param {Function} operator The function to perform the operation.\n * @param {number} [defaultValue] The value used for `undefined` arguments.\n * @returns {Function} Returns the new mathematical operation function.\n */\n function createMathOperation(operator, defaultValue) {\n return function(value, other) {\n var result;\n if (value === undefined && other === undefined) {\n return defaultValue;\n }\n if (value !== undefined) {\n result = value;\n }\n if (other !== undefined) {\n if (result === undefined) {\n return other;\n }\n if (typeof value == 'string' || typeof other == 'string') {\n value = baseToString(value);\n other = baseToString(other);\n } else {\n value = baseToNumber(value);\n other = baseToNumber(other);\n }\n result = operator(value, other);\n }\n return result;\n };\n }\n\n /**\n * Creates a function like `_.over`.\n *\n * @private\n * @param {Function} arrayFunc The function to iterate over iteratees.\n * @returns {Function} Returns the new over function.\n */\n function createOver(arrayFunc) {\n return flatRest(function(iteratees) {\n iteratees = arrayMap(iteratees, baseUnary(getIteratee()));\n return baseRest(function(args) {\n var thisArg = this;\n return arrayFunc(iteratees, function(iteratee) {\n return apply(iteratee, thisArg, args);\n });\n });\n });\n }\n\n /**\n * Creates the padding for `string` based on `length`. The `chars` string\n * is truncated if the number of characters exceeds `length`.\n *\n * @private\n * @param {number} length The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padding for `string`.\n */\n function createPadding(length, chars) {\n chars = chars === undefined ? ' ' : baseToString(chars);\n\n var charsLength = chars.length;\n if (charsLength < 2) {\n return charsLength ? baseRepeat(chars, length) : chars;\n }\n var result = baseRepeat(chars, nativeCeil(length / stringSize(chars)));\n return hasUnicode(chars)\n ? castSlice(stringToArray(result), 0, length).join('')\n : result.slice(0, length);\n }\n\n /**\n * Creates a function that wraps `func` to invoke it with the `this` binding\n * of `thisArg` and `partials` prepended to the arguments it receives.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} partials The arguments to prepend to those provided to\n * the new function.\n * @returns {Function} Returns the new wrapped function.\n */\n function createPartial(func, bitmask, thisArg, partials) {\n var isBind = bitmask & WRAP_BIND_FLAG,\n Ctor = createCtor(func);\n\n function wrapper() {\n var argsIndex = -1,\n argsLength = arguments.length,\n leftIndex = -1,\n leftLength = partials.length,\n args = Array(leftLength + argsLength),\n fn = (this && this !== root && this instanceof wrapper) ? Ctor : func;\n\n while (++leftIndex < leftLength) {\n args[leftIndex] = partials[leftIndex];\n }\n while (argsLength--) {\n args[leftIndex++] = arguments[++argsIndex];\n }\n return apply(fn, isBind ? thisArg : this, args);\n }\n return wrapper;\n }\n\n /**\n * Creates a `_.range` or `_.rangeRight` function.\n *\n * @private\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {Function} Returns the new range function.\n */\n function createRange(fromRight) {\n return function(start, end, step) {\n if (step && typeof step != 'number' && isIterateeCall(start, end, step)) {\n end = step = undefined;\n }\n // Ensure the sign of `-0` is preserved.\n start = toFinite(start);\n if (end === undefined) {\n end = start;\n start = 0;\n } else {\n end = toFinite(end);\n }\n step = step === undefined ? (start < end ? 1 : -1) : toFinite(step);\n return baseRange(start, end, step, fromRight);\n };\n }\n\n /**\n * Creates a function that performs a relational operation on two values.\n *\n * @private\n * @param {Function} operator The function to perform the operation.\n * @returns {Function} Returns the new relational operation function.\n */\n function createRelationalOperation(operator) {\n return function(value, other) {\n if (!(typeof value == 'string' && typeof other == 'string')) {\n value = toNumber(value);\n other = toNumber(other);\n }\n return operator(value, other);\n };\n }\n\n /**\n * Creates a function that wraps `func` to continue currying.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @param {Function} wrapFunc The function to create the `func` wrapper.\n * @param {*} placeholder The placeholder value.\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to prepend to those provided to\n * the new function.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createRecurry(func, bitmask, wrapFunc, placeholder, thisArg, partials, holders, argPos, ary, arity) {\n var isCurry = bitmask & WRAP_CURRY_FLAG,\n newHolders = isCurry ? holders : undefined,\n newHoldersRight = isCurry ? undefined : holders,\n newPartials = isCurry ? partials : undefined,\n newPartialsRight = isCurry ? undefined : partials;\n\n bitmask |= (isCurry ? WRAP_PARTIAL_FLAG : WRAP_PARTIAL_RIGHT_FLAG);\n bitmask &= ~(isCurry ? WRAP_PARTIAL_RIGHT_FLAG : WRAP_PARTIAL_FLAG);\n\n if (!(bitmask & WRAP_CURRY_BOUND_FLAG)) {\n bitmask &= ~(WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG);\n }\n var newData = [\n func, bitmask, thisArg, newPartials, newHolders, newPartialsRight,\n newHoldersRight, argPos, ary, arity\n ];\n\n var result = wrapFunc.apply(undefined, newData);\n if (isLaziable(func)) {\n setData(result, newData);\n }\n result.placeholder = placeholder;\n return setWrapToString(result, func, bitmask);\n }\n\n /**\n * Creates a function like `_.round`.\n *\n * @private\n * @param {string} methodName The name of the `Math` method to use when rounding.\n * @returns {Function} Returns the new round function.\n */\n function createRound(methodName) {\n var func = Math[methodName];\n return function(number, precision) {\n number = toNumber(number);\n precision = precision == null ? 0 : nativeMin(toInteger(precision), 292);\n if (precision && nativeIsFinite(number)) {\n // Shift with exponential notation to avoid floating-point issues.\n // See [MDN](https://mdn.io/round#Examples) for more details.\n var pair = (toString(number) + 'e').split('e'),\n value = func(pair[0] + 'e' + (+pair[1] + precision));\n\n pair = (toString(value) + 'e').split('e');\n return +(pair[0] + 'e' + (+pair[1] - precision));\n }\n return func(number);\n };\n }\n\n /**\n * Creates a set object of `values`.\n *\n * @private\n * @param {Array} values The values to add to the set.\n * @returns {Object} Returns the new set.\n */\n var createSet = !(Set && (1 / setToArray(new Set([,-0]))[1]) == INFINITY) ? noop : function(values) {\n return new Set(values);\n };\n\n /**\n * Creates a `_.toPairs` or `_.toPairsIn` function.\n *\n * @private\n * @param {Function} keysFunc The function to get the keys of a given object.\n * @returns {Function} Returns the new pairs function.\n */\n function createToPairs(keysFunc) {\n return function(object) {\n var tag = getTag(object);\n if (tag == mapTag) {\n return mapToArray(object);\n }\n if (tag == setTag) {\n return setToPairs(object);\n }\n return baseToPairs(object, keysFunc(object));\n };\n }\n\n /**\n * Creates a function that either curries or invokes `func` with optional\n * `this` binding and partially applied arguments.\n *\n * @private\n * @param {Function|string} func The function or method name to wrap.\n * @param {number} bitmask The bitmask flags.\n * 1 - `_.bind`\n * 2 - `_.bindKey`\n * 4 - `_.curry` or `_.curryRight` of a bound function\n * 8 - `_.curry`\n * 16 - `_.curryRight`\n * 32 - `_.partial`\n * 64 - `_.partialRight`\n * 128 - `_.rearg`\n * 256 - `_.ary`\n * 512 - `_.flip`\n * @param {*} [thisArg] The `this` binding of `func`.\n * @param {Array} [partials] The arguments to be partially applied.\n * @param {Array} [holders] The `partials` placeholder indexes.\n * @param {Array} [argPos] The argument positions of the new function.\n * @param {number} [ary] The arity cap of `func`.\n * @param {number} [arity] The arity of `func`.\n * @returns {Function} Returns the new wrapped function.\n */\n function createWrap(func, bitmask, thisArg, partials, holders, argPos, ary, arity) {\n var isBindKey = bitmask & WRAP_BIND_KEY_FLAG;\n if (!isBindKey && typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var length = partials ? partials.length : 0;\n if (!length) {\n bitmask &= ~(WRAP_PARTIAL_FLAG | WRAP_PARTIAL_RIGHT_FLAG);\n partials = holders = undefined;\n }\n ary = ary === undefined ? ary : nativeMax(toInteger(ary), 0);\n arity = arity === undefined ? arity : toInteger(arity);\n length -= holders ? holders.length : 0;\n\n if (bitmask & WRAP_PARTIAL_RIGHT_FLAG) {\n var partialsRight = partials,\n holdersRight = holders;\n\n partials = holders = undefined;\n }\n var data = isBindKey ? undefined : getData(func);\n\n var newData = [\n func, bitmask, thisArg, partials, holders, partialsRight, holdersRight,\n argPos, ary, arity\n ];\n\n if (data) {\n mergeData(newData, data);\n }\n func = newData[0];\n bitmask = newData[1];\n thisArg = newData[2];\n partials = newData[3];\n holders = newData[4];\n arity = newData[9] = newData[9] === undefined\n ? (isBindKey ? 0 : func.length)\n : nativeMax(newData[9] - length, 0);\n\n if (!arity && bitmask & (WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG)) {\n bitmask &= ~(WRAP_CURRY_FLAG | WRAP_CURRY_RIGHT_FLAG);\n }\n if (!bitmask || bitmask == WRAP_BIND_FLAG) {\n var result = createBind(func, bitmask, thisArg);\n } else if (bitmask == WRAP_CURRY_FLAG || bitmask == WRAP_CURRY_RIGHT_FLAG) {\n result = createCurry(func, bitmask, arity);\n } else if ((bitmask == WRAP_PARTIAL_FLAG || bitmask == (WRAP_BIND_FLAG | WRAP_PARTIAL_FLAG)) && !holders.length) {\n result = createPartial(func, bitmask, thisArg, partials);\n } else {\n result = createHybrid.apply(undefined, newData);\n }\n var setter = data ? baseSetData : setData;\n return setWrapToString(setter(result, newData), func, bitmask);\n }\n\n /**\n * Used by `_.defaults` to customize its `_.assignIn` use to assign properties\n * of source objects to the destination object for all destination properties\n * that resolve to `undefined`.\n *\n * @private\n * @param {*} objValue The destination value.\n * @param {*} srcValue The source value.\n * @param {string} key The key of the property to assign.\n * @param {Object} object The parent object of `objValue`.\n * @returns {*} Returns the value to assign.\n */\n function customDefaultsAssignIn(objValue, srcValue, key, object) {\n if (objValue === undefined ||\n (eq(objValue, objectProto[key]) && !hasOwnProperty.call(object, key))) {\n return srcValue;\n }\n return objValue;\n }\n\n /**\n * Used by `_.defaultsDeep` to customize its `_.merge` use to merge source\n * objects into destination objects that are passed thru.\n *\n * @private\n * @param {*} objValue The destination value.\n * @param {*} srcValue The source value.\n * @param {string} key The key of the property to merge.\n * @param {Object} object The parent object of `objValue`.\n * @param {Object} source The parent object of `srcValue`.\n * @param {Object} [stack] Tracks traversed source values and their merged\n * counterparts.\n * @returns {*} Returns the value to assign.\n */\n function customDefaultsMerge(objValue, srcValue, key, object, source, stack) {\n if (isObject(objValue) && isObject(srcValue)) {\n // Recursively merge objects and arrays (susceptible to call stack limits).\n stack.set(srcValue, objValue);\n baseMerge(objValue, srcValue, undefined, customDefaultsMerge, stack);\n stack['delete'](srcValue);\n }\n return objValue;\n }\n\n /**\n * Used by `_.omit` to customize its `_.cloneDeep` use to only clone plain\n * objects.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {string} key The key of the property to inspect.\n * @returns {*} Returns the uncloned value or `undefined` to defer cloning to `_.cloneDeep`.\n */\n function customOmitClone(value) {\n return isPlainObject(value) ? undefined : value;\n }\n\n /**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\n function equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Check that cyclic values are equal.\n var arrStacked = stack.get(array);\n var othStacked = stack.get(other);\n if (arrStacked && othStacked) {\n return arrStacked == other && othStacked == array;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n }\n\n /**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\n function equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n }\n\n /**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\n function equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Check that cyclic values are equal.\n var objStacked = stack.get(object);\n var othStacked = stack.get(other);\n if (objStacked && othStacked) {\n return objStacked == other && othStacked == object;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n }\n\n /**\n * A specialized version of `baseRest` which flattens the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @returns {Function} Returns the new function.\n */\n function flatRest(func) {\n return setToString(overRest(func, undefined, flatten), func + '');\n }\n\n /**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\n function getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n }\n\n /**\n * Creates an array of own and inherited enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\n function getAllKeysIn(object) {\n return baseGetAllKeys(object, keysIn, getSymbolsIn);\n }\n\n /**\n * Gets metadata for `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {*} Returns the metadata for `func`.\n */\n var getData = !metaMap ? noop : function(func) {\n return metaMap.get(func);\n };\n\n /**\n * Gets the name of `func`.\n *\n * @private\n * @param {Function} func The function to query.\n * @returns {string} Returns the function name.\n */\n function getFuncName(func) {\n var result = (func.name + ''),\n array = realNames[result],\n length = hasOwnProperty.call(realNames, result) ? array.length : 0;\n\n while (length--) {\n var data = array[length],\n otherFunc = data.func;\n if (otherFunc == null || otherFunc == func) {\n return data.name;\n }\n }\n return result;\n }\n\n /**\n * Gets the argument placeholder value for `func`.\n *\n * @private\n * @param {Function} func The function to inspect.\n * @returns {*} Returns the placeholder value.\n */\n function getHolder(func) {\n var object = hasOwnProperty.call(lodash, 'placeholder') ? lodash : func;\n return object.placeholder;\n }\n\n /**\n * Gets the appropriate \"iteratee\" function. If `_.iteratee` is customized,\n * this function returns the custom method, otherwise it returns `baseIteratee`.\n * If arguments are provided, the chosen function is invoked with them and\n * its result is returned.\n *\n * @private\n * @param {*} [value] The value to convert to an iteratee.\n * @param {number} [arity] The arity of the created iteratee.\n * @returns {Function} Returns the chosen function or its result.\n */\n function getIteratee() {\n var result = lodash.iteratee || iteratee;\n result = result === iteratee ? baseIteratee : result;\n return arguments.length ? result(arguments[0], arguments[1]) : result;\n }\n\n /**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\n function getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n }\n\n /**\n * Gets the property names, values, and compare flags of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the match data of `object`.\n */\n function getMatchData(object) {\n var result = keys(object),\n length = result.length;\n\n while (length--) {\n var key = result[length],\n value = object[key];\n\n result[length] = [key, value, isStrictComparable(value)];\n }\n return result;\n }\n\n /**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\n function getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n }\n\n /**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\n function getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n }\n\n /**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\n var getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n };\n\n /**\n * Creates an array of the own and inherited enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\n var getSymbolsIn = !nativeGetSymbols ? stubArray : function(object) {\n var result = [];\n while (object) {\n arrayPush(result, getSymbols(object));\n object = getPrototype(object);\n }\n return result;\n };\n\n /**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\n var getTag = baseGetTag;\n\n // Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\n if ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n }\n\n /**\n * Gets the view, applying any `transforms` to the `start` and `end` positions.\n *\n * @private\n * @param {number} start The start of the view.\n * @param {number} end The end of the view.\n * @param {Array} transforms The transformations to apply to the view.\n * @returns {Object} Returns an object containing the `start` and `end`\n * positions of the view.\n */\n function getView(start, end, transforms) {\n var index = -1,\n length = transforms.length;\n\n while (++index < length) {\n var data = transforms[index],\n size = data.size;\n\n switch (data.type) {\n case 'drop': start += size; break;\n case 'dropRight': end -= size; break;\n case 'take': end = nativeMin(end, start + size); break;\n case 'takeRight': start = nativeMax(start, end - size); break;\n }\n }\n return { 'start': start, 'end': end };\n }\n\n /**\n * Extracts wrapper details from the `source` body comment.\n *\n * @private\n * @param {string} source The source to inspect.\n * @returns {Array} Returns the wrapper details.\n */\n function getWrapDetails(source) {\n var match = source.match(reWrapDetails);\n return match ? match[1].split(reSplitDetails) : [];\n }\n\n /**\n * Checks if `path` exists on `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @param {Function} hasFunc The function to check properties.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n */\n function hasPath(object, path, hasFunc) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n result = false;\n\n while (++index < length) {\n var key = toKey(path[index]);\n if (!(result = object != null && hasFunc(object, key))) {\n break;\n }\n object = object[key];\n }\n if (result || ++index != length) {\n return result;\n }\n length = object == null ? 0 : object.length;\n return !!length && isLength(length) && isIndex(key, length) &&\n (isArray(object) || isArguments(object));\n }\n\n /**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\n function initCloneArray(array) {\n var length = array.length,\n result = new array.constructor(length);\n\n // Add properties assigned by `RegExp#exec`.\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n result.index = array.index;\n result.input = array.input;\n }\n return result;\n }\n\n /**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\n function initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n }\n\n /**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\n function initCloneByTag(object, tag, isDeep) {\n var Ctor = object.constructor;\n switch (tag) {\n case arrayBufferTag:\n return cloneArrayBuffer(object);\n\n case boolTag:\n case dateTag:\n return new Ctor(+object);\n\n case dataViewTag:\n return cloneDataView(object, isDeep);\n\n case float32Tag: case float64Tag:\n case int8Tag: case int16Tag: case int32Tag:\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n return cloneTypedArray(object, isDeep);\n\n case mapTag:\n return new Ctor;\n\n case numberTag:\n case stringTag:\n return new Ctor(object);\n\n case regexpTag:\n return cloneRegExp(object);\n\n case setTag:\n return new Ctor;\n\n case symbolTag:\n return cloneSymbol(object);\n }\n }\n\n /**\n * Inserts wrapper `details` in a comment at the top of the `source` body.\n *\n * @private\n * @param {string} source The source to modify.\n * @returns {Array} details The details to insert.\n * @returns {string} Returns the modified source.\n */\n function insertWrapDetails(source, details) {\n var length = details.length;\n if (!length) {\n return source;\n }\n var lastIndex = length - 1;\n details[lastIndex] = (length > 1 ? '& ' : '') + details[lastIndex];\n details = details.join(length > 2 ? ', ' : ' ');\n return source.replace(reWrapComment, '{\\n/* [wrapped with ' + details + '] */\\n');\n }\n\n /**\n * Checks if `value` is a flattenable `arguments` object or array.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is flattenable, else `false`.\n */\n function isFlattenable(value) {\n return isArray(value) || isArguments(value) ||\n !!(spreadableSymbol && value && value[spreadableSymbol]);\n }\n\n /**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\n function isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n }\n\n /**\n * Checks if the given arguments are from an iteratee call.\n *\n * @private\n * @param {*} value The potential iteratee value argument.\n * @param {*} index The potential iteratee index or key argument.\n * @param {*} object The potential iteratee object argument.\n * @returns {boolean} Returns `true` if the arguments are from an iteratee call,\n * else `false`.\n */\n function isIterateeCall(value, index, object) {\n if (!isObject(object)) {\n return false;\n }\n var type = typeof index;\n if (type == 'number'\n ? (isArrayLike(object) && isIndex(index, object.length))\n : (type == 'string' && index in object)\n ) {\n return eq(object[index], value);\n }\n return false;\n }\n\n /**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\n function isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n }\n\n /**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\n function isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n }\n\n /**\n * Checks if `func` has a lazy counterpart.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` has a lazy counterpart,\n * else `false`.\n */\n function isLaziable(func) {\n var funcName = getFuncName(func),\n other = lodash[funcName];\n\n if (typeof other != 'function' || !(funcName in LazyWrapper.prototype)) {\n return false;\n }\n if (func === other) {\n return true;\n }\n var data = getData(other);\n return !!data && func === data[0];\n }\n\n /**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\n function isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n }\n\n /**\n * Checks if `func` is capable of being masked.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `func` is maskable, else `false`.\n */\n var isMaskable = coreJsData ? isFunction : stubFalse;\n\n /**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\n function isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n }\n\n /**\n * Checks if `value` is suitable for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` if suitable for strict\n * equality comparisons, else `false`.\n */\n function isStrictComparable(value) {\n return value === value && !isObject(value);\n }\n\n /**\n * A specialized version of `matchesProperty` for source values suitable\n * for strict equality comparisons, i.e. `===`.\n *\n * @private\n * @param {string} key The key of the property to get.\n * @param {*} srcValue The value to match.\n * @returns {Function} Returns the new spec function.\n */\n function matchesStrictComparable(key, srcValue) {\n return function(object) {\n if (object == null) {\n return false;\n }\n return object[key] === srcValue &&\n (srcValue !== undefined || (key in Object(object)));\n };\n }\n\n /**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\n function memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n }\n\n /**\n * Merges the function metadata of `source` into `data`.\n *\n * Merging metadata reduces the number of wrappers used to invoke a function.\n * This is possible because methods like `_.bind`, `_.curry`, and `_.partial`\n * may be applied regardless of execution order. Methods like `_.ary` and\n * `_.rearg` modify function arguments, making the order in which they are\n * executed important, preventing the merging of metadata. However, we make\n * an exception for a safe combined case where curried functions have `_.ary`\n * and or `_.rearg` applied.\n *\n * @private\n * @param {Array} data The destination metadata.\n * @param {Array} source The source metadata.\n * @returns {Array} Returns `data`.\n */\n function mergeData(data, source) {\n var bitmask = data[1],\n srcBitmask = source[1],\n newBitmask = bitmask | srcBitmask,\n isCommon = newBitmask < (WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG | WRAP_ARY_FLAG);\n\n var isCombo =\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_CURRY_FLAG)) ||\n ((srcBitmask == WRAP_ARY_FLAG) && (bitmask == WRAP_REARG_FLAG) && (data[7].length <= source[8])) ||\n ((srcBitmask == (WRAP_ARY_FLAG | WRAP_REARG_FLAG)) && (source[7].length <= source[8]) && (bitmask == WRAP_CURRY_FLAG));\n\n // Exit early if metadata can't be merged.\n if (!(isCommon || isCombo)) {\n return data;\n }\n // Use source `thisArg` if available.\n if (srcBitmask & WRAP_BIND_FLAG) {\n data[2] = source[2];\n // Set when currying a bound function.\n newBitmask |= bitmask & WRAP_BIND_FLAG ? 0 : WRAP_CURRY_BOUND_FLAG;\n }\n // Compose partial arguments.\n var value = source[3];\n if (value) {\n var partials = data[3];\n data[3] = partials ? composeArgs(partials, value, source[4]) : value;\n data[4] = partials ? replaceHolders(data[3], PLACEHOLDER) : source[4];\n }\n // Compose partial right arguments.\n value = source[5];\n if (value) {\n partials = data[5];\n data[5] = partials ? composeArgsRight(partials, value, source[6]) : value;\n data[6] = partials ? replaceHolders(data[5], PLACEHOLDER) : source[6];\n }\n // Use source `argPos` if available.\n value = source[7];\n if (value) {\n data[7] = value;\n }\n // Use source `ary` if it's smaller.\n if (srcBitmask & WRAP_ARY_FLAG) {\n data[8] = data[8] == null ? source[8] : nativeMin(data[8], source[8]);\n }\n // Use source `arity` if one is not provided.\n if (data[9] == null) {\n data[9] = source[9];\n }\n // Use source `func` and merge bitmasks.\n data[0] = source[0];\n data[1] = newBitmask;\n\n return data;\n }\n\n /**\n * This function is like\n * [`Object.keys`](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * except that it includes inherited enumerable properties.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\n function nativeKeysIn(object) {\n var result = [];\n if (object != null) {\n for (var key in Object(object)) {\n result.push(key);\n }\n }\n return result;\n }\n\n /**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\n function objectToString(value) {\n return nativeObjectToString.call(value);\n }\n\n /**\n * A specialized version of `baseRest` which transforms the rest array.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @param {Function} transform The rest array transform.\n * @returns {Function} Returns the new function.\n */\n function overRest(func, start, transform) {\n start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n return function() {\n var args = arguments,\n index = -1,\n length = nativeMax(args.length - start, 0),\n array = Array(length);\n\n while (++index < length) {\n array[index] = args[start + index];\n }\n index = -1;\n var otherArgs = Array(start + 1);\n while (++index < start) {\n otherArgs[index] = args[index];\n }\n otherArgs[start] = transform(array);\n return apply(func, this, otherArgs);\n };\n }\n\n /**\n * Gets the parent value at `path` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Array} path The path to get the parent value of.\n * @returns {*} Returns the parent value.\n */\n function parent(object, path) {\n return path.length < 2 ? object : baseGet(object, baseSlice(path, 0, -1));\n }\n\n /**\n * Reorder `array` according to the specified indexes where the element at\n * the first index is assigned as the first element, the element at\n * the second index is assigned as the second element, and so on.\n *\n * @private\n * @param {Array} array The array to reorder.\n * @param {Array} indexes The arranged array indexes.\n * @returns {Array} Returns `array`.\n */\n function reorder(array, indexes) {\n var arrLength = array.length,\n length = nativeMin(indexes.length, arrLength),\n oldArray = copyArray(array);\n\n while (length--) {\n var index = indexes[length];\n array[length] = isIndex(index, arrLength) ? oldArray[index] : undefined;\n }\n return array;\n }\n\n /**\n * Gets the value at `key`, unless `key` is \"__proto__\" or \"constructor\".\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\n function safeGet(object, key) {\n if (key === 'constructor' && typeof object[key] === 'function') {\n return;\n }\n\n if (key == '__proto__') {\n return;\n }\n\n return object[key];\n }\n\n /**\n * Sets metadata for `func`.\n *\n * **Note:** If this function becomes hot, i.e. is invoked a lot in a short\n * period of time, it will trip its breaker and transition to an identity\n * function to avoid garbage collection pauses in V8. See\n * [V8 issue 2070](https://bugs.chromium.org/p/v8/issues/detail?id=2070)\n * for more details.\n *\n * @private\n * @param {Function} func The function to associate metadata with.\n * @param {*} data The metadata.\n * @returns {Function} Returns `func`.\n */\n var setData = shortOut(baseSetData);\n\n /**\n * A simple wrapper around the global [`setTimeout`](https://mdn.io/setTimeout).\n *\n * @private\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @returns {number|Object} Returns the timer id or timeout object.\n */\n var setTimeout = ctxSetTimeout || function(func, wait) {\n return root.setTimeout(func, wait);\n };\n\n /**\n * Sets the `toString` method of `func` to return `string`.\n *\n * @private\n * @param {Function} func The function to modify.\n * @param {Function} string The `toString` result.\n * @returns {Function} Returns `func`.\n */\n var setToString = shortOut(baseSetToString);\n\n /**\n * Sets the `toString` method of `wrapper` to mimic the source of `reference`\n * with wrapper details in a comment at the top of the source body.\n *\n * @private\n * @param {Function} wrapper The function to modify.\n * @param {Function} reference The reference function.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Function} Returns `wrapper`.\n */\n function setWrapToString(wrapper, reference, bitmask) {\n var source = (reference + '');\n return setToString(wrapper, insertWrapDetails(source, updateWrapDetails(getWrapDetails(source), bitmask)));\n }\n\n /**\n * Creates a function that'll short out and invoke `identity` instead\n * of `func` when it's called `HOT_COUNT` or more times in `HOT_SPAN`\n * milliseconds.\n *\n * @private\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new shortable function.\n */\n function shortOut(func) {\n var count = 0,\n lastCalled = 0;\n\n return function() {\n var stamp = nativeNow(),\n remaining = HOT_SPAN - (stamp - lastCalled);\n\n lastCalled = stamp;\n if (remaining > 0) {\n if (++count >= HOT_COUNT) {\n return arguments[0];\n }\n } else {\n count = 0;\n }\n return func.apply(undefined, arguments);\n };\n }\n\n /**\n * A specialized version of `_.shuffle` which mutates and sets the size of `array`.\n *\n * @private\n * @param {Array} array The array to shuffle.\n * @param {number} [size=array.length] The size of `array`.\n * @returns {Array} Returns `array`.\n */\n function shuffleSelf(array, size) {\n var index = -1,\n length = array.length,\n lastIndex = length - 1;\n\n size = size === undefined ? length : size;\n while (++index < size) {\n var rand = baseRandom(index, lastIndex),\n value = array[rand];\n\n array[rand] = array[index];\n array[index] = value;\n }\n array.length = size;\n return array;\n }\n\n /**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\n var stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n });\n\n /**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\n function toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n }\n\n /**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\n function toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n }\n\n /**\n * Updates wrapper `details` based on `bitmask` flags.\n *\n * @private\n * @returns {Array} details The details to modify.\n * @param {number} bitmask The bitmask flags. See `createWrap` for more details.\n * @returns {Array} Returns `details`.\n */\n function updateWrapDetails(details, bitmask) {\n arrayEach(wrapFlags, function(pair) {\n var value = '_.' + pair[0];\n if ((bitmask & pair[1]) && !arrayIncludes(details, value)) {\n details.push(value);\n }\n });\n return details.sort();\n }\n\n /**\n * Creates a clone of `wrapper`.\n *\n * @private\n * @param {Object} wrapper The wrapper to clone.\n * @returns {Object} Returns the cloned wrapper.\n */\n function wrapperClone(wrapper) {\n if (wrapper instanceof LazyWrapper) {\n return wrapper.clone();\n }\n var result = new LodashWrapper(wrapper.__wrapped__, wrapper.__chain__);\n result.__actions__ = copyArray(wrapper.__actions__);\n result.__index__ = wrapper.__index__;\n result.__values__ = wrapper.__values__;\n return result;\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an array of elements split into groups the length of `size`.\n * If `array` can't be split evenly, the final chunk will be the remaining\n * elements.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to process.\n * @param {number} [size=1] The length of each chunk\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the new array of chunks.\n * @example\n *\n * _.chunk(['a', 'b', 'c', 'd'], 2);\n * // => [['a', 'b'], ['c', 'd']]\n *\n * _.chunk(['a', 'b', 'c', 'd'], 3);\n * // => [['a', 'b', 'c'], ['d']]\n */\n function chunk(array, size, guard) {\n if ((guard ? isIterateeCall(array, size, guard) : size === undefined)) {\n size = 1;\n } else {\n size = nativeMax(toInteger(size), 0);\n }\n var length = array == null ? 0 : array.length;\n if (!length || size < 1) {\n return [];\n }\n var index = 0,\n resIndex = 0,\n result = Array(nativeCeil(length / size));\n\n while (index < length) {\n result[resIndex++] = baseSlice(array, index, (index += size));\n }\n return result;\n }\n\n /**\n * Creates an array with all falsey values removed. The values `false`, `null`,\n * `0`, `\"\"`, `undefined`, and `NaN` are falsey.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to compact.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.compact([0, 1, false, 2, '', 3]);\n * // => [1, 2, 3]\n */\n function compact(array) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (value) {\n result[resIndex++] = value;\n }\n }\n return result;\n }\n\n /**\n * Creates a new array concatenating `array` with any additional arrays\n * and/or values.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to concatenate.\n * @param {...*} [values] The values to concatenate.\n * @returns {Array} Returns the new concatenated array.\n * @example\n *\n * var array = [1];\n * var other = _.concat(array, 2, [3], [[4]]);\n *\n * console.log(other);\n * // => [1, 2, 3, [4]]\n *\n * console.log(array);\n * // => [1]\n */\n function concat() {\n var length = arguments.length;\n if (!length) {\n return [];\n }\n var args = Array(length - 1),\n array = arguments[0],\n index = length;\n\n while (index--) {\n args[index - 1] = arguments[index];\n }\n return arrayPush(isArray(array) ? copyArray(array) : [array], baseFlatten(args, 1));\n }\n\n /**\n * Creates an array of `array` values not included in the other given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order and references of result values are\n * determined by the first array.\n *\n * **Note:** Unlike `_.pullAll`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.without, _.xor\n * @example\n *\n * _.difference([2, 1], [2, 3]);\n * // => [1]\n */\n var difference = baseRest(function(array, values) {\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true))\n : [];\n });\n\n /**\n * This method is like `_.difference` except that it accepts `iteratee` which\n * is invoked for each element of `array` and `values` to generate the criterion\n * by which they're compared. The order and references of result values are\n * determined by the first array. The iteratee is invoked with one argument:\n * (value).\n *\n * **Note:** Unlike `_.pullAllBy`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.differenceBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.differenceBy([{ 'x': 2 }, { 'x': 1 }], [{ 'x': 1 }], 'x');\n * // => [{ 'x': 2 }]\n */\n var differenceBy = baseRest(function(array, values) {\n var iteratee = last(values);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), getIteratee(iteratee, 2))\n : [];\n });\n\n /**\n * This method is like `_.difference` except that it accepts `comparator`\n * which is invoked to compare elements of `array` to `values`. The order and\n * references of result values are determined by the first array. The comparator\n * is invoked with two arguments: (arrVal, othVal).\n *\n * **Note:** Unlike `_.pullAllWith`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...Array} [values] The values to exclude.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n *\n * _.differenceWith(objects, [{ 'x': 1, 'y': 2 }], _.isEqual);\n * // => [{ 'x': 2, 'y': 1 }]\n */\n var differenceWith = baseRest(function(array, values) {\n var comparator = last(values);\n if (isArrayLikeObject(comparator)) {\n comparator = undefined;\n }\n return isArrayLikeObject(array)\n ? baseDifference(array, baseFlatten(values, 1, isArrayLikeObject, true), undefined, comparator)\n : [];\n });\n\n /**\n * Creates a slice of `array` with `n` elements dropped from the beginning.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to drop.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.drop([1, 2, 3]);\n * // => [2, 3]\n *\n * _.drop([1, 2, 3], 2);\n * // => [3]\n *\n * _.drop([1, 2, 3], 5);\n * // => []\n *\n * _.drop([1, 2, 3], 0);\n * // => [1, 2, 3]\n */\n function drop(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n return baseSlice(array, n < 0 ? 0 : n, length);\n }\n\n /**\n * Creates a slice of `array` with `n` elements dropped from the end.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to drop.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.dropRight([1, 2, 3]);\n * // => [1, 2]\n *\n * _.dropRight([1, 2, 3], 2);\n * // => [1]\n *\n * _.dropRight([1, 2, 3], 5);\n * // => []\n *\n * _.dropRight([1, 2, 3], 0);\n * // => [1, 2, 3]\n */\n function dropRight(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n n = length - n;\n return baseSlice(array, 0, n < 0 ? 0 : n);\n }\n\n /**\n * Creates a slice of `array` excluding elements dropped from the end.\n * Elements are dropped until `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.dropRightWhile(users, function(o) { return !o.active; });\n * // => objects for ['barney']\n *\n * // The `_.matches` iteratee shorthand.\n * _.dropRightWhile(users, { 'user': 'pebbles', 'active': false });\n * // => objects for ['barney', 'fred']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.dropRightWhile(users, ['active', false]);\n * // => objects for ['barney']\n *\n * // The `_.property` iteratee shorthand.\n * _.dropRightWhile(users, 'active');\n * // => objects for ['barney', 'fred', 'pebbles']\n */\n function dropRightWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), true, true)\n : [];\n }\n\n /**\n * Creates a slice of `array` excluding elements dropped from the beginning.\n * Elements are dropped until `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.dropWhile(users, function(o) { return !o.active; });\n * // => objects for ['pebbles']\n *\n * // The `_.matches` iteratee shorthand.\n * _.dropWhile(users, { 'user': 'barney', 'active': false });\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.dropWhile(users, ['active', false]);\n * // => objects for ['pebbles']\n *\n * // The `_.property` iteratee shorthand.\n * _.dropWhile(users, 'active');\n * // => objects for ['barney', 'fred', 'pebbles']\n */\n function dropWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), true)\n : [];\n }\n\n /**\n * Fills elements of `array` with `value` from `start` up to, but not\n * including, `end`.\n *\n * **Note:** This method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Array\n * @param {Array} array The array to fill.\n * @param {*} value The value to fill `array` with.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.fill(array, 'a');\n * console.log(array);\n * // => ['a', 'a', 'a']\n *\n * _.fill(Array(3), 2);\n * // => [2, 2, 2]\n *\n * _.fill([4, 6, 8, 10], '*', 1, 3);\n * // => [4, '*', '*', 10]\n */\n function fill(array, value, start, end) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n if (start && typeof start != 'number' && isIterateeCall(array, value, start)) {\n start = 0;\n end = length;\n }\n return baseFill(array, value, start, end);\n }\n\n /**\n * This method is like `_.find` except that it returns the index of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.findIndex(users, function(o) { return o.user == 'barney'; });\n * // => 0\n *\n * // The `_.matches` iteratee shorthand.\n * _.findIndex(users, { 'user': 'fred', 'active': false });\n * // => 1\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findIndex(users, ['active', false]);\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.findIndex(users, 'active');\n * // => 2\n */\n function findIndex(array, predicate, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\n if (index < 0) {\n index = nativeMax(length + index, 0);\n }\n return baseFindIndex(array, getIteratee(predicate, 3), index);\n }\n\n /**\n * This method is like `_.findIndex` except that it iterates over elements\n * of `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=array.length-1] The index to search from.\n * @returns {number} Returns the index of the found element, else `-1`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.findLastIndex(users, function(o) { return o.user == 'pebbles'; });\n * // => 2\n *\n * // The `_.matches` iteratee shorthand.\n * _.findLastIndex(users, { 'user': 'barney', 'active': true });\n * // => 0\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findLastIndex(users, ['active', false]);\n * // => 2\n *\n * // The `_.property` iteratee shorthand.\n * _.findLastIndex(users, 'active');\n * // => 0\n */\n function findLastIndex(array, predicate, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = length - 1;\n if (fromIndex !== undefined) {\n index = toInteger(fromIndex);\n index = fromIndex < 0\n ? nativeMax(length + index, 0)\n : nativeMin(index, length - 1);\n }\n return baseFindIndex(array, getIteratee(predicate, 3), index, true);\n }\n\n /**\n * Flattens `array` a single level deep.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flatten([1, [2, [3, [4]], 5]]);\n * // => [1, 2, [3, [4]], 5]\n */\n function flatten(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, 1) : [];\n }\n\n /**\n * Recursively flattens `array`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * _.flattenDeep([1, [2, [3, [4]], 5]]);\n * // => [1, 2, 3, 4, 5]\n */\n function flattenDeep(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseFlatten(array, INFINITY) : [];\n }\n\n /**\n * Recursively flatten `array` up to `depth` times.\n *\n * @static\n * @memberOf _\n * @since 4.4.0\n * @category Array\n * @param {Array} array The array to flatten.\n * @param {number} [depth=1] The maximum recursion depth.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * var array = [1, [2, [3, [4]], 5]];\n *\n * _.flattenDepth(array, 1);\n * // => [1, 2, [3, [4]], 5]\n *\n * _.flattenDepth(array, 2);\n * // => [1, 2, 3, [4], 5]\n */\n function flattenDepth(array, depth) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n depth = depth === undefined ? 1 : toInteger(depth);\n return baseFlatten(array, depth);\n }\n\n /**\n * The inverse of `_.toPairs`; this method returns an object composed\n * from key-value `pairs`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} pairs The key-value pairs.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.fromPairs([['a', 1], ['b', 2]]);\n * // => { 'a': 1, 'b': 2 }\n */\n function fromPairs(pairs) {\n var index = -1,\n length = pairs == null ? 0 : pairs.length,\n result = {};\n\n while (++index < length) {\n var pair = pairs[index];\n result[pair[0]] = pair[1];\n }\n return result;\n }\n\n /**\n * Gets the first element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @alias first\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the first element of `array`.\n * @example\n *\n * _.head([1, 2, 3]);\n * // => 1\n *\n * _.head([]);\n * // => undefined\n */\n function head(array) {\n return (array && array.length) ? array[0] : undefined;\n }\n\n /**\n * Gets the index at which the first occurrence of `value` is found in `array`\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. If `fromIndex` is negative, it's used as the\n * offset from the end of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.indexOf([1, 2, 1, 2], 2);\n * // => 1\n *\n * // Search from the `fromIndex`.\n * _.indexOf([1, 2, 1, 2], 2, 2);\n * // => 3\n */\n function indexOf(array, value, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = fromIndex == null ? 0 : toInteger(fromIndex);\n if (index < 0) {\n index = nativeMax(length + index, 0);\n }\n return baseIndexOf(array, value, index);\n }\n\n /**\n * Gets all but the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.initial([1, 2, 3]);\n * // => [1, 2]\n */\n function initial(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseSlice(array, 0, -1) : [];\n }\n\n /**\n * Creates an array of unique values that are included in all given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order and references of result values are\n * determined by the first array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * _.intersection([2, 1], [2, 3]);\n * // => [2]\n */\n var intersection = baseRest(function(arrays) {\n var mapped = arrayMap(arrays, castArrayLikeObject);\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped)\n : [];\n });\n\n /**\n * This method is like `_.intersection` except that it accepts `iteratee`\n * which is invoked for each element of each `arrays` to generate the criterion\n * by which they're compared. The order and references of result values are\n * determined by the first array. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * _.intersectionBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [2.1]\n *\n * // The `_.property` iteratee shorthand.\n * _.intersectionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }]\n */\n var intersectionBy = baseRest(function(arrays) {\n var iteratee = last(arrays),\n mapped = arrayMap(arrays, castArrayLikeObject);\n\n if (iteratee === last(mapped)) {\n iteratee = undefined;\n } else {\n mapped.pop();\n }\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped, getIteratee(iteratee, 2))\n : [];\n });\n\n /**\n * This method is like `_.intersection` except that it accepts `comparator`\n * which is invoked to compare elements of `arrays`. The order and references\n * of result values are determined by the first array. The comparator is\n * invoked with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.intersectionWith(objects, others, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }]\n */\n var intersectionWith = baseRest(function(arrays) {\n var comparator = last(arrays),\n mapped = arrayMap(arrays, castArrayLikeObject);\n\n comparator = typeof comparator == 'function' ? comparator : undefined;\n if (comparator) {\n mapped.pop();\n }\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped, undefined, comparator)\n : [];\n });\n\n /**\n * Converts all elements in `array` into a string separated by `separator`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to convert.\n * @param {string} [separator=','] The element separator.\n * @returns {string} Returns the joined string.\n * @example\n *\n * _.join(['a', 'b', 'c'], '~');\n * // => 'a~b~c'\n */\n function join(array, separator) {\n return array == null ? '' : nativeJoin.call(array, separator);\n }\n\n /**\n * Gets the last element of `array`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {*} Returns the last element of `array`.\n * @example\n *\n * _.last([1, 2, 3]);\n * // => 3\n */\n function last(array) {\n var length = array == null ? 0 : array.length;\n return length ? array[length - 1] : undefined;\n }\n\n /**\n * This method is like `_.indexOf` except that it iterates over elements of\n * `array` from right to left.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=array.length-1] The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.lastIndexOf([1, 2, 1, 2], 2);\n * // => 3\n *\n * // Search from the `fromIndex`.\n * _.lastIndexOf([1, 2, 1, 2], 2, 2);\n * // => 1\n */\n function lastIndexOf(array, value, fromIndex) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return -1;\n }\n var index = length;\n if (fromIndex !== undefined) {\n index = toInteger(fromIndex);\n index = index < 0 ? nativeMax(length + index, 0) : nativeMin(index, length - 1);\n }\n return value === value\n ? strictLastIndexOf(array, value, index)\n : baseFindIndex(array, baseIsNaN, index, true);\n }\n\n /**\n * Gets the element at index `n` of `array`. If `n` is negative, the nth\n * element from the end is returned.\n *\n * @static\n * @memberOf _\n * @since 4.11.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=0] The index of the element to return.\n * @returns {*} Returns the nth element of `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'd'];\n *\n * _.nth(array, 1);\n * // => 'b'\n *\n * _.nth(array, -2);\n * // => 'c';\n */\n function nth(array, n) {\n return (array && array.length) ? baseNth(array, toInteger(n)) : undefined;\n }\n\n /**\n * Removes all given values from `array` using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * **Note:** Unlike `_.without`, this method mutates `array`. Use `_.remove`\n * to remove elements from an array by predicate.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {...*} [values] The values to remove.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'a', 'b', 'c'];\n *\n * _.pull(array, 'a', 'c');\n * console.log(array);\n * // => ['b', 'b']\n */\n var pull = baseRest(pullAll);\n\n /**\n * This method is like `_.pull` except that it accepts an array of values to remove.\n *\n * **Note:** Unlike `_.difference`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = ['a', 'b', 'c', 'a', 'b', 'c'];\n *\n * _.pullAll(array, ['a', 'c']);\n * console.log(array);\n * // => ['b', 'b']\n */\n function pullAll(array, values) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values)\n : array;\n }\n\n /**\n * This method is like `_.pullAll` except that it accepts `iteratee` which is\n * invoked for each element of `array` and `values` to generate the criterion\n * by which they're compared. The iteratee is invoked with one argument: (value).\n *\n * **Note:** Unlike `_.differenceBy`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [{ 'x': 1 }, { 'x': 2 }, { 'x': 3 }, { 'x': 1 }];\n *\n * _.pullAllBy(array, [{ 'x': 1 }, { 'x': 3 }], 'x');\n * console.log(array);\n * // => [{ 'x': 2 }]\n */\n function pullAllBy(array, values, iteratee) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values, getIteratee(iteratee, 2))\n : array;\n }\n\n /**\n * This method is like `_.pullAll` except that it accepts `comparator` which\n * is invoked to compare elements of `array` to `values`. The comparator is\n * invoked with two arguments: (arrVal, othVal).\n *\n * **Note:** Unlike `_.differenceWith`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Array} values The values to remove.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [{ 'x': 1, 'y': 2 }, { 'x': 3, 'y': 4 }, { 'x': 5, 'y': 6 }];\n *\n * _.pullAllWith(array, [{ 'x': 3, 'y': 4 }], _.isEqual);\n * console.log(array);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 5, 'y': 6 }]\n */\n function pullAllWith(array, values, comparator) {\n return (array && array.length && values && values.length)\n ? basePullAll(array, values, undefined, comparator)\n : array;\n }\n\n /**\n * Removes elements from `array` corresponding to `indexes` and returns an\n * array of removed elements.\n *\n * **Note:** Unlike `_.at`, this method mutates `array`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {...(number|number[])} [indexes] The indexes of elements to remove.\n * @returns {Array} Returns the new array of removed elements.\n * @example\n *\n * var array = ['a', 'b', 'c', 'd'];\n * var pulled = _.pullAt(array, [1, 3]);\n *\n * console.log(array);\n * // => ['a', 'c']\n *\n * console.log(pulled);\n * // => ['b', 'd']\n */\n var pullAt = flatRest(function(array, indexes) {\n var length = array == null ? 0 : array.length,\n result = baseAt(array, indexes);\n\n basePullAt(array, arrayMap(indexes, function(index) {\n return isIndex(index, length) ? +index : index;\n }).sort(compareAscending));\n\n return result;\n });\n\n /**\n * Removes all elements from `array` that `predicate` returns truthy for\n * and returns an array of the removed elements. The predicate is invoked\n * with three arguments: (value, index, array).\n *\n * **Note:** Unlike `_.filter`, this method mutates `array`. Use `_.pull`\n * to pull elements from an array by value.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new array of removed elements.\n * @example\n *\n * var array = [1, 2, 3, 4];\n * var evens = _.remove(array, function(n) {\n * return n % 2 == 0;\n * });\n *\n * console.log(array);\n * // => [1, 3]\n *\n * console.log(evens);\n * // => [2, 4]\n */\n function remove(array, predicate) {\n var result = [];\n if (!(array && array.length)) {\n return result;\n }\n var index = -1,\n indexes = [],\n length = array.length;\n\n predicate = getIteratee(predicate, 3);\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result.push(value);\n indexes.push(index);\n }\n }\n basePullAt(array, indexes);\n return result;\n }\n\n /**\n * Reverses `array` so that the first element becomes the last, the second\n * element becomes the second to last, and so on.\n *\n * **Note:** This method mutates `array` and is based on\n * [`Array#reverse`](https://mdn.io/Array/reverse).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to modify.\n * @returns {Array} Returns `array`.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _.reverse(array);\n * // => [3, 2, 1]\n *\n * console.log(array);\n * // => [3, 2, 1]\n */\n function reverse(array) {\n return array == null ? array : nativeReverse.call(array);\n }\n\n /**\n * Creates a slice of `array` from `start` up to, but not including, `end`.\n *\n * **Note:** This method is used instead of\n * [`Array#slice`](https://mdn.io/Array/slice) to ensure dense arrays are\n * returned.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to slice.\n * @param {number} [start=0] The start position.\n * @param {number} [end=array.length] The end position.\n * @returns {Array} Returns the slice of `array`.\n */\n function slice(array, start, end) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n if (end && typeof end != 'number' && isIterateeCall(array, start, end)) {\n start = 0;\n end = length;\n }\n else {\n start = start == null ? 0 : toInteger(start);\n end = end === undefined ? length : toInteger(end);\n }\n return baseSlice(array, start, end);\n }\n\n /**\n * Uses a binary search to determine the lowest index at which `value`\n * should be inserted into `array` in order to maintain its sort order.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * _.sortedIndex([30, 50], 40);\n * // => 1\n */\n function sortedIndex(array, value) {\n return baseSortedIndex(array, value);\n }\n\n /**\n * This method is like `_.sortedIndex` except that it accepts `iteratee`\n * which is invoked for `value` and each element of `array` to compute their\n * sort ranking. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * var objects = [{ 'x': 4 }, { 'x': 5 }];\n *\n * _.sortedIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });\n * // => 0\n *\n * // The `_.property` iteratee shorthand.\n * _.sortedIndexBy(objects, { 'x': 4 }, 'x');\n * // => 0\n */\n function sortedIndexBy(array, value, iteratee) {\n return baseSortedIndexBy(array, value, getIteratee(iteratee, 2));\n }\n\n /**\n * This method is like `_.indexOf` except that it performs a binary\n * search on a sorted `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.sortedIndexOf([4, 5, 5, 5, 6], 5);\n * // => 1\n */\n function sortedIndexOf(array, value) {\n var length = array == null ? 0 : array.length;\n if (length) {\n var index = baseSortedIndex(array, value);\n if (index < length && eq(array[index], value)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * This method is like `_.sortedIndex` except that it returns the highest\n * index at which `value` should be inserted into `array` in order to\n * maintain its sort order.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * _.sortedLastIndex([4, 5, 5, 5, 6], 5);\n * // => 4\n */\n function sortedLastIndex(array, value) {\n return baseSortedIndex(array, value, true);\n }\n\n /**\n * This method is like `_.sortedLastIndex` except that it accepts `iteratee`\n * which is invoked for `value` and each element of `array` to compute their\n * sort ranking. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The sorted array to inspect.\n * @param {*} value The value to evaluate.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the index at which `value` should be inserted\n * into `array`.\n * @example\n *\n * var objects = [{ 'x': 4 }, { 'x': 5 }];\n *\n * _.sortedLastIndexBy(objects, { 'x': 4 }, function(o) { return o.x; });\n * // => 1\n *\n * // The `_.property` iteratee shorthand.\n * _.sortedLastIndexBy(objects, { 'x': 4 }, 'x');\n * // => 1\n */\n function sortedLastIndexBy(array, value, iteratee) {\n return baseSortedIndexBy(array, value, getIteratee(iteratee, 2), true);\n }\n\n /**\n * This method is like `_.lastIndexOf` except that it performs a binary\n * search on a sorted `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n * @example\n *\n * _.sortedLastIndexOf([4, 5, 5, 5, 6], 5);\n * // => 3\n */\n function sortedLastIndexOf(array, value) {\n var length = array == null ? 0 : array.length;\n if (length) {\n var index = baseSortedIndex(array, value, true) - 1;\n if (eq(array[index], value)) {\n return index;\n }\n }\n return -1;\n }\n\n /**\n * This method is like `_.uniq` except that it's designed and optimized\n * for sorted arrays.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.sortedUniq([1, 1, 2]);\n * // => [1, 2]\n */\n function sortedUniq(array) {\n return (array && array.length)\n ? baseSortedUniq(array)\n : [];\n }\n\n /**\n * This method is like `_.uniqBy` except that it's designed and optimized\n * for sorted arrays.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.sortedUniqBy([1.1, 1.2, 2.3, 2.4], Math.floor);\n * // => [1.1, 2.3]\n */\n function sortedUniqBy(array, iteratee) {\n return (array && array.length)\n ? baseSortedUniq(array, getIteratee(iteratee, 2))\n : [];\n }\n\n /**\n * Gets all but the first element of `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.tail([1, 2, 3]);\n * // => [2, 3]\n */\n function tail(array) {\n var length = array == null ? 0 : array.length;\n return length ? baseSlice(array, 1, length) : [];\n }\n\n /**\n * Creates a slice of `array` with `n` elements taken from the beginning.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to take.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.take([1, 2, 3]);\n * // => [1]\n *\n * _.take([1, 2, 3], 2);\n * // => [1, 2]\n *\n * _.take([1, 2, 3], 5);\n * // => [1, 2, 3]\n *\n * _.take([1, 2, 3], 0);\n * // => []\n */\n function take(array, n, guard) {\n if (!(array && array.length)) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n return baseSlice(array, 0, n < 0 ? 0 : n);\n }\n\n /**\n * Creates a slice of `array` with `n` elements taken from the end.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {number} [n=1] The number of elements to take.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * _.takeRight([1, 2, 3]);\n * // => [3]\n *\n * _.takeRight([1, 2, 3], 2);\n * // => [2, 3]\n *\n * _.takeRight([1, 2, 3], 5);\n * // => [1, 2, 3]\n *\n * _.takeRight([1, 2, 3], 0);\n * // => []\n */\n function takeRight(array, n, guard) {\n var length = array == null ? 0 : array.length;\n if (!length) {\n return [];\n }\n n = (guard || n === undefined) ? 1 : toInteger(n);\n n = length - n;\n return baseSlice(array, n < 0 ? 0 : n, length);\n }\n\n /**\n * Creates a slice of `array` with elements taken from the end. Elements are\n * taken until `predicate` returns falsey. The predicate is invoked with\n * three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': false }\n * ];\n *\n * _.takeRightWhile(users, function(o) { return !o.active; });\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.matches` iteratee shorthand.\n * _.takeRightWhile(users, { 'user': 'pebbles', 'active': false });\n * // => objects for ['pebbles']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.takeRightWhile(users, ['active', false]);\n * // => objects for ['fred', 'pebbles']\n *\n * // The `_.property` iteratee shorthand.\n * _.takeRightWhile(users, 'active');\n * // => []\n */\n function takeRightWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3), false, true)\n : [];\n }\n\n /**\n * Creates a slice of `array` with elements taken from the beginning. Elements\n * are taken until `predicate` returns falsey. The predicate is invoked with\n * three arguments: (value, index, array).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Array\n * @param {Array} array The array to query.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the slice of `array`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'active': false },\n * { 'user': 'fred', 'active': false },\n * { 'user': 'pebbles', 'active': true }\n * ];\n *\n * _.takeWhile(users, function(o) { return !o.active; });\n * // => objects for ['barney', 'fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.takeWhile(users, { 'user': 'barney', 'active': false });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.takeWhile(users, ['active', false]);\n * // => objects for ['barney', 'fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.takeWhile(users, 'active');\n * // => []\n */\n function takeWhile(array, predicate) {\n return (array && array.length)\n ? baseWhile(array, getIteratee(predicate, 3))\n : [];\n }\n\n /**\n * Creates an array of unique values, in order, from all given arrays using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.union([2], [1, 2]);\n * // => [2, 1]\n */\n var union = baseRest(function(arrays) {\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true));\n });\n\n /**\n * This method is like `_.union` except that it accepts `iteratee` which is\n * invoked for each element of each `arrays` to generate the criterion by\n * which uniqueness is computed. Result values are chosen from the first\n * array in which the value occurs. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * _.unionBy([2.1], [1.2, 2.3], Math.floor);\n * // => [2.1, 1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.unionBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }, { 'x': 2 }]\n */\n var unionBy = baseRest(function(arrays) {\n var iteratee = last(arrays);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), getIteratee(iteratee, 2));\n });\n\n /**\n * This method is like `_.union` except that it accepts `comparator` which\n * is invoked to compare elements of `arrays`. Result values are chosen from\n * the first array in which the value occurs. The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of combined values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.unionWith(objects, others, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]\n */\n var unionWith = baseRest(function(arrays) {\n var comparator = last(arrays);\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return baseUniq(baseFlatten(arrays, 1, isArrayLikeObject, true), undefined, comparator);\n });\n\n /**\n * Creates a duplicate-free version of an array, using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons, in which only the first occurrence of each element\n * is kept. The order of result values is determined by the order they occur\n * in the array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.uniq([2, 1, 2]);\n * // => [2, 1]\n */\n function uniq(array) {\n return (array && array.length) ? baseUniq(array) : [];\n }\n\n /**\n * This method is like `_.uniq` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the criterion by which\n * uniqueness is computed. The order of result values is determined by the\n * order they occur in the array. The iteratee is invoked with one argument:\n * (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * _.uniqBy([2.1, 1.2, 2.3], Math.floor);\n * // => [2.1, 1.2]\n *\n * // The `_.property` iteratee shorthand.\n * _.uniqBy([{ 'x': 1 }, { 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 1 }, { 'x': 2 }]\n */\n function uniqBy(array, iteratee) {\n return (array && array.length) ? baseUniq(array, getIteratee(iteratee, 2)) : [];\n }\n\n /**\n * This method is like `_.uniq` except that it accepts `comparator` which\n * is invoked to compare elements of `array`. The order of result values is\n * determined by the order they occur in the array.The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new duplicate free array.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.uniqWith(objects, _.isEqual);\n * // => [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }]\n */\n function uniqWith(array, comparator) {\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return (array && array.length) ? baseUniq(array, undefined, comparator) : [];\n }\n\n /**\n * This method is like `_.zip` except that it accepts an array of grouped\n * elements and creates an array regrouping the elements to their pre-zip\n * configuration.\n *\n * @static\n * @memberOf _\n * @since 1.2.0\n * @category Array\n * @param {Array} array The array of grouped elements to process.\n * @returns {Array} Returns the new array of regrouped elements.\n * @example\n *\n * var zipped = _.zip(['a', 'b'], [1, 2], [true, false]);\n * // => [['a', 1, true], ['b', 2, false]]\n *\n * _.unzip(zipped);\n * // => [['a', 'b'], [1, 2], [true, false]]\n */\n function unzip(array) {\n if (!(array && array.length)) {\n return [];\n }\n var length = 0;\n array = arrayFilter(array, function(group) {\n if (isArrayLikeObject(group)) {\n length = nativeMax(group.length, length);\n return true;\n }\n });\n return baseTimes(length, function(index) {\n return arrayMap(array, baseProperty(index));\n });\n }\n\n /**\n * This method is like `_.unzip` except that it accepts `iteratee` to specify\n * how regrouped values should be combined. The iteratee is invoked with the\n * elements of each group: (...group).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Array\n * @param {Array} array The array of grouped elements to process.\n * @param {Function} [iteratee=_.identity] The function to combine\n * regrouped values.\n * @returns {Array} Returns the new array of regrouped elements.\n * @example\n *\n * var zipped = _.zip([1, 2], [10, 20], [100, 200]);\n * // => [[1, 10, 100], [2, 20, 200]]\n *\n * _.unzipWith(zipped, _.add);\n * // => [3, 30, 300]\n */\n function unzipWith(array, iteratee) {\n if (!(array && array.length)) {\n return [];\n }\n var result = unzip(array);\n if (iteratee == null) {\n return result;\n }\n return arrayMap(result, function(group) {\n return apply(iteratee, undefined, group);\n });\n }\n\n /**\n * Creates an array excluding all given values using\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * **Note:** Unlike `_.pull`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {Array} array The array to inspect.\n * @param {...*} [values] The values to exclude.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.difference, _.xor\n * @example\n *\n * _.without([2, 1, 2, 3], 1, 2);\n * // => [3]\n */\n var without = baseRest(function(array, values) {\n return isArrayLikeObject(array)\n ? baseDifference(array, values)\n : [];\n });\n\n /**\n * Creates an array of unique values that is the\n * [symmetric difference](https://en.wikipedia.org/wiki/Symmetric_difference)\n * of the given arrays. The order of result values is determined by the order\n * they occur in the arrays.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of filtered values.\n * @see _.difference, _.without\n * @example\n *\n * _.xor([2, 1], [2, 3]);\n * // => [1, 3]\n */\n var xor = baseRest(function(arrays) {\n return baseXor(arrayFilter(arrays, isArrayLikeObject));\n });\n\n /**\n * This method is like `_.xor` except that it accepts `iteratee` which is\n * invoked for each element of each `arrays` to generate the criterion by\n * which by which they're compared. The order of result values is determined\n * by the order they occur in the arrays. The iteratee is invoked with one\n * argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * _.xorBy([2.1, 1.2], [2.3, 3.4], Math.floor);\n * // => [1.2, 3.4]\n *\n * // The `_.property` iteratee shorthand.\n * _.xorBy([{ 'x': 1 }], [{ 'x': 2 }, { 'x': 1 }], 'x');\n * // => [{ 'x': 2 }]\n */\n var xorBy = baseRest(function(arrays) {\n var iteratee = last(arrays);\n if (isArrayLikeObject(iteratee)) {\n iteratee = undefined;\n }\n return baseXor(arrayFilter(arrays, isArrayLikeObject), getIteratee(iteratee, 2));\n });\n\n /**\n * This method is like `_.xor` except that it accepts `comparator` which is\n * invoked to compare elements of `arrays`. The order of result values is\n * determined by the order they occur in the arrays. The comparator is invoked\n * with two arguments: (arrVal, othVal).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of filtered values.\n * @example\n *\n * var objects = [{ 'x': 1, 'y': 2 }, { 'x': 2, 'y': 1 }];\n * var others = [{ 'x': 1, 'y': 1 }, { 'x': 1, 'y': 2 }];\n *\n * _.xorWith(objects, others, _.isEqual);\n * // => [{ 'x': 2, 'y': 1 }, { 'x': 1, 'y': 1 }]\n */\n var xorWith = baseRest(function(arrays) {\n var comparator = last(arrays);\n comparator = typeof comparator == 'function' ? comparator : undefined;\n return baseXor(arrayFilter(arrays, isArrayLikeObject), undefined, comparator);\n });\n\n /**\n * Creates an array of grouped elements, the first of which contains the\n * first elements of the given arrays, the second of which contains the\n * second elements of the given arrays, and so on.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to process.\n * @returns {Array} Returns the new array of grouped elements.\n * @example\n *\n * _.zip(['a', 'b'], [1, 2], [true, false]);\n * // => [['a', 1, true], ['b', 2, false]]\n */\n var zip = baseRest(unzip);\n\n /**\n * This method is like `_.fromPairs` except that it accepts two arrays,\n * one of property identifiers and one of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 0.4.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObject(['a', 'b'], [1, 2]);\n * // => { 'a': 1, 'b': 2 }\n */\n function zipObject(props, values) {\n return baseZipObject(props || [], values || [], assignValue);\n }\n\n /**\n * This method is like `_.zipObject` except that it supports property paths.\n *\n * @static\n * @memberOf _\n * @since 4.1.0\n * @category Array\n * @param {Array} [props=[]] The property identifiers.\n * @param {Array} [values=[]] The property values.\n * @returns {Object} Returns the new object.\n * @example\n *\n * _.zipObjectDeep(['a.b[0].c', 'a.b[1].d'], [1, 2]);\n * // => { 'a': { 'b': [{ 'c': 1 }, { 'd': 2 }] } }\n */\n function zipObjectDeep(props, values) {\n return baseZipObject(props || [], values || [], baseSet);\n }\n\n /**\n * This method is like `_.zip` except that it accepts `iteratee` to specify\n * how grouped values should be combined. The iteratee is invoked with the\n * elements of each group: (...group).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Array\n * @param {...Array} [arrays] The arrays to process.\n * @param {Function} [iteratee=_.identity] The function to combine\n * grouped values.\n * @returns {Array} Returns the new array of grouped elements.\n * @example\n *\n * _.zipWith([1, 2], [10, 20], [100, 200], function(a, b, c) {\n * return a + b + c;\n * });\n * // => [111, 222]\n */\n var zipWith = baseRest(function(arrays) {\n var length = arrays.length,\n iteratee = length > 1 ? arrays[length - 1] : undefined;\n\n iteratee = typeof iteratee == 'function' ? (arrays.pop(), iteratee) : undefined;\n return unzipWith(arrays, iteratee);\n });\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates a `lodash` wrapper instance that wraps `value` with explicit method\n * chain sequences enabled. The result of such sequences must be unwrapped\n * with `_#value`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Seq\n * @param {*} value The value to wrap.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 40 },\n * { 'user': 'pebbles', 'age': 1 }\n * ];\n *\n * var youngest = _\n * .chain(users)\n * .sortBy('age')\n * .map(function(o) {\n * return o.user + ' is ' + o.age;\n * })\n * .head()\n * .value();\n * // => 'pebbles is 1'\n */\n function chain(value) {\n var result = lodash(value);\n result.__chain__ = true;\n return result;\n }\n\n /**\n * This method invokes `interceptor` and returns `value`. The interceptor\n * is invoked with one argument; (value). The purpose of this method is to\n * \"tap into\" a method chain sequence in order to modify intermediate results.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @param {*} value The value to provide to `interceptor`.\n * @param {Function} interceptor The function to invoke.\n * @returns {*} Returns `value`.\n * @example\n *\n * _([1, 2, 3])\n * .tap(function(array) {\n * // Mutate input array.\n * array.pop();\n * })\n * .reverse()\n * .value();\n * // => [2, 1]\n */\n function tap(value, interceptor) {\n interceptor(value);\n return value;\n }\n\n /**\n * This method is like `_.tap` except that it returns the result of `interceptor`.\n * The purpose of this method is to \"pass thru\" values replacing intermediate\n * results in a method chain sequence.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Seq\n * @param {*} value The value to provide to `interceptor`.\n * @param {Function} interceptor The function to invoke.\n * @returns {*} Returns the result of `interceptor`.\n * @example\n *\n * _(' abc ')\n * .chain()\n * .trim()\n * .thru(function(value) {\n * return [value];\n * })\n * .value();\n * // => ['abc']\n */\n function thru(value, interceptor) {\n return interceptor(value);\n }\n\n /**\n * This method is the wrapper version of `_.at`.\n *\n * @name at\n * @memberOf _\n * @since 1.0.0\n * @category Seq\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\n *\n * _(object).at(['a[0].b.c', 'a[1]']).value();\n * // => [3, 4]\n */\n var wrapperAt = flatRest(function(paths) {\n var length = paths.length,\n start = length ? paths[0] : 0,\n value = this.__wrapped__,\n interceptor = function(object) { return baseAt(object, paths); };\n\n if (length > 1 || this.__actions__.length ||\n !(value instanceof LazyWrapper) || !isIndex(start)) {\n return this.thru(interceptor);\n }\n value = value.slice(start, +start + (length ? 1 : 0));\n value.__actions__.push({\n 'func': thru,\n 'args': [interceptor],\n 'thisArg': undefined\n });\n return new LodashWrapper(value, this.__chain__).thru(function(array) {\n if (length && !array.length) {\n array.push(undefined);\n }\n return array;\n });\n });\n\n /**\n * Creates a `lodash` wrapper instance with explicit method chain sequences enabled.\n *\n * @name chain\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 40 }\n * ];\n *\n * // A sequence without explicit chaining.\n * _(users).head();\n * // => { 'user': 'barney', 'age': 36 }\n *\n * // A sequence with explicit chaining.\n * _(users)\n * .chain()\n * .head()\n * .pick('user')\n * .value();\n * // => { 'user': 'barney' }\n */\n function wrapperChain() {\n return chain(this);\n }\n\n /**\n * Executes the chain sequence and returns the wrapped result.\n *\n * @name commit\n * @memberOf _\n * @since 3.2.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var array = [1, 2];\n * var wrapped = _(array).push(3);\n *\n * console.log(array);\n * // => [1, 2]\n *\n * wrapped = wrapped.commit();\n * console.log(array);\n * // => [1, 2, 3]\n *\n * wrapped.last();\n * // => 3\n *\n * console.log(array);\n * // => [1, 2, 3]\n */\n function wrapperCommit() {\n return new LodashWrapper(this.value(), this.__chain__);\n }\n\n /**\n * Gets the next value on a wrapped object following the\n * [iterator protocol](https://mdn.io/iteration_protocols#iterator).\n *\n * @name next\n * @memberOf _\n * @since 4.0.0\n * @category Seq\n * @returns {Object} Returns the next iterator value.\n * @example\n *\n * var wrapped = _([1, 2]);\n *\n * wrapped.next();\n * // => { 'done': false, 'value': 1 }\n *\n * wrapped.next();\n * // => { 'done': false, 'value': 2 }\n *\n * wrapped.next();\n * // => { 'done': true, 'value': undefined }\n */\n function wrapperNext() {\n if (this.__values__ === undefined) {\n this.__values__ = toArray(this.value());\n }\n var done = this.__index__ >= this.__values__.length,\n value = done ? undefined : this.__values__[this.__index__++];\n\n return { 'done': done, 'value': value };\n }\n\n /**\n * Enables the wrapper to be iterable.\n *\n * @name Symbol.iterator\n * @memberOf _\n * @since 4.0.0\n * @category Seq\n * @returns {Object} Returns the wrapper object.\n * @example\n *\n * var wrapped = _([1, 2]);\n *\n * wrapped[Symbol.iterator]() === wrapped;\n * // => true\n *\n * Array.from(wrapped);\n * // => [1, 2]\n */\n function wrapperToIterator() {\n return this;\n }\n\n /**\n * Creates a clone of the chain sequence planting `value` as the wrapped value.\n *\n * @name plant\n * @memberOf _\n * @since 3.2.0\n * @category Seq\n * @param {*} value The value to plant.\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var wrapped = _([1, 2]).map(square);\n * var other = wrapped.plant([3, 4]);\n *\n * other.value();\n * // => [9, 16]\n *\n * wrapped.value();\n * // => [1, 4]\n */\n function wrapperPlant(value) {\n var result,\n parent = this;\n\n while (parent instanceof baseLodash) {\n var clone = wrapperClone(parent);\n clone.__index__ = 0;\n clone.__values__ = undefined;\n if (result) {\n previous.__wrapped__ = clone;\n } else {\n result = clone;\n }\n var previous = clone;\n parent = parent.__wrapped__;\n }\n previous.__wrapped__ = value;\n return result;\n }\n\n /**\n * This method is the wrapper version of `_.reverse`.\n *\n * **Note:** This method mutates the wrapped array.\n *\n * @name reverse\n * @memberOf _\n * @since 0.1.0\n * @category Seq\n * @returns {Object} Returns the new `lodash` wrapper instance.\n * @example\n *\n * var array = [1, 2, 3];\n *\n * _(array).reverse().value()\n * // => [3, 2, 1]\n *\n * console.log(array);\n * // => [3, 2, 1]\n */\n function wrapperReverse() {\n var value = this.__wrapped__;\n if (value instanceof LazyWrapper) {\n var wrapped = value;\n if (this.__actions__.length) {\n wrapped = new LazyWrapper(this);\n }\n wrapped = wrapped.reverse();\n wrapped.__actions__.push({\n 'func': thru,\n 'args': [reverse],\n 'thisArg': undefined\n });\n return new LodashWrapper(wrapped, this.__chain__);\n }\n return this.thru(reverse);\n }\n\n /**\n * Executes the chain sequence to resolve the unwrapped value.\n *\n * @name value\n * @memberOf _\n * @since 0.1.0\n * @alias toJSON, valueOf\n * @category Seq\n * @returns {*} Returns the resolved unwrapped value.\n * @example\n *\n * _([1, 2, 3]).value();\n * // => [1, 2, 3]\n */\n function wrapperValue() {\n return baseWrapperValue(this.__wrapped__, this.__actions__);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The corresponding value of\n * each key is the number of times the key was returned by `iteratee`. The\n * iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.countBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': 1, '6': 2 }\n *\n * // The `_.property` iteratee shorthand.\n * _.countBy(['one', 'two', 'three'], 'length');\n * // => { '3': 2, '5': 1 }\n */\n var countBy = createAggregator(function(result, value, key) {\n if (hasOwnProperty.call(result, key)) {\n ++result[key];\n } else {\n baseAssignValue(result, key, 1);\n }\n });\n\n /**\n * Checks if `predicate` returns truthy for **all** elements of `collection`.\n * Iteration is stopped once `predicate` returns falsey. The predicate is\n * invoked with three arguments: (value, index|key, collection).\n *\n * **Note:** This method returns `true` for\n * [empty collections](https://en.wikipedia.org/wiki/Empty_set) because\n * [everything is true](https://en.wikipedia.org/wiki/Vacuous_truth) of\n * elements of empty collections.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {boolean} Returns `true` if all elements pass the predicate check,\n * else `false`.\n * @example\n *\n * _.every([true, 1, null, 'yes'], Boolean);\n * // => false\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.every(users, { 'user': 'barney', 'active': false });\n * // => false\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.every(users, ['active', false]);\n * // => true\n *\n * // The `_.property` iteratee shorthand.\n * _.every(users, 'active');\n * // => false\n */\n function every(collection, predicate, guard) {\n var func = isArray(collection) ? arrayEvery : baseEvery;\n if (guard && isIterateeCall(collection, predicate, guard)) {\n predicate = undefined;\n }\n return func(collection, getIteratee(predicate, 3));\n }\n\n /**\n * Iterates over elements of `collection`, returning an array of all elements\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * **Note:** Unlike `_.remove`, this method returns a new array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.reject\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false }\n * ];\n *\n * _.filter(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.filter(users, { 'age': 36, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.filter(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.filter(users, 'active');\n * // => objects for ['barney']\n *\n * // Combining several predicates using `_.overEvery` or `_.overSome`.\n * _.filter(users, _.overSome([{ 'age': 36 }, ['age', 40]]));\n * // => objects for ['fred', 'barney']\n */\n function filter(collection, predicate) {\n var func = isArray(collection) ? arrayFilter : baseFilter;\n return func(collection, getIteratee(predicate, 3));\n }\n\n /**\n * Iterates over elements of `collection`, returning the first element\n * `predicate` returns truthy for. The predicate is invoked with three\n * arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=0] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false },\n * { 'user': 'pebbles', 'age': 1, 'active': true }\n * ];\n *\n * _.find(users, function(o) { return o.age < 40; });\n * // => object for 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.find(users, { 'age': 1, 'active': true });\n * // => object for 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.find(users, ['active', false]);\n * // => object for 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.find(users, 'active');\n * // => object for 'barney'\n */\n var find = createFind(findIndex);\n\n /**\n * This method is like `_.find` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param {number} [fromIndex=collection.length-1] The index to search from.\n * @returns {*} Returns the matched element, else `undefined`.\n * @example\n *\n * _.findLast([1, 2, 3, 4], function(n) {\n * return n % 2 == 1;\n * });\n * // => 3\n */\n var findLast = createFind(findLastIndex);\n\n /**\n * Creates a flattened array of values by running each element in `collection`\n * thru `iteratee` and flattening the mapped results. The iteratee is invoked\n * with three arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [n, n];\n * }\n *\n * _.flatMap([1, 2], duplicate);\n * // => [1, 1, 2, 2]\n */\n function flatMap(collection, iteratee) {\n return baseFlatten(map(collection, iteratee), 1);\n }\n\n /**\n * This method is like `_.flatMap` except that it recursively flattens the\n * mapped results.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [[[n, n]]];\n * }\n *\n * _.flatMapDeep([1, 2], duplicate);\n * // => [1, 1, 2, 2]\n */\n function flatMapDeep(collection, iteratee) {\n return baseFlatten(map(collection, iteratee), INFINITY);\n }\n\n /**\n * This method is like `_.flatMap` except that it recursively flattens the\n * mapped results up to `depth` times.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {number} [depth=1] The maximum recursion depth.\n * @returns {Array} Returns the new flattened array.\n * @example\n *\n * function duplicate(n) {\n * return [[[n, n]]];\n * }\n *\n * _.flatMapDepth([1, 2], duplicate, 2);\n * // => [[1, 1], [2, 2]]\n */\n function flatMapDepth(collection, iteratee, depth) {\n depth = depth === undefined ? 1 : toInteger(depth);\n return baseFlatten(map(collection, iteratee), depth);\n }\n\n /**\n * Iterates over elements of `collection` and invokes `iteratee` for each element.\n * The iteratee is invoked with three arguments: (value, index|key, collection).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * **Note:** As with other \"Collections\" methods, objects with a \"length\"\n * property are iterated like arrays. To avoid this behavior use `_.forIn`\n * or `_.forOwn` for object iteration.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @alias each\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n * @see _.forEachRight\n * @example\n *\n * _.forEach([1, 2], function(value) {\n * console.log(value);\n * });\n * // => Logs `1` then `2`.\n *\n * _.forEach({ 'a': 1, 'b': 2 }, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\n function forEach(collection, iteratee) {\n var func = isArray(collection) ? arrayEach : baseEach;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.forEach` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @alias eachRight\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array|Object} Returns `collection`.\n * @see _.forEach\n * @example\n *\n * _.forEachRight([1, 2], function(value) {\n * console.log(value);\n * });\n * // => Logs `2` then `1`.\n */\n function forEachRight(collection, iteratee) {\n var func = isArray(collection) ? arrayEachRight : baseEachRight;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The order of grouped values\n * is determined by the order they occur in `collection`. The corresponding\n * value of each key is an array of elements responsible for generating the\n * key. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * _.groupBy([6.1, 4.2, 6.3], Math.floor);\n * // => { '4': [4.2], '6': [6.1, 6.3] }\n *\n * // The `_.property` iteratee shorthand.\n * _.groupBy(['one', 'two', 'three'], 'length');\n * // => { '3': ['one', 'two'], '5': ['three'] }\n */\n var groupBy = createAggregator(function(result, value, key) {\n if (hasOwnProperty.call(result, key)) {\n result[key].push(value);\n } else {\n baseAssignValue(result, key, [value]);\n }\n });\n\n /**\n * Checks if `value` is in `collection`. If `collection` is a string, it's\n * checked for a substring of `value`, otherwise\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * is used for equality comparisons. If `fromIndex` is negative, it's used as\n * the offset from the end of `collection`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @param {*} value The value to search for.\n * @param {number} [fromIndex=0] The index to search from.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.\n * @returns {boolean} Returns `true` if `value` is found, else `false`.\n * @example\n *\n * _.includes([1, 2, 3], 1);\n * // => true\n *\n * _.includes([1, 2, 3], 1, 2);\n * // => false\n *\n * _.includes({ 'a': 1, 'b': 2 }, 1);\n * // => true\n *\n * _.includes('abcd', 'bc');\n * // => true\n */\n function includes(collection, value, fromIndex, guard) {\n collection = isArrayLike(collection) ? collection : values(collection);\n fromIndex = (fromIndex && !guard) ? toInteger(fromIndex) : 0;\n\n var length = collection.length;\n if (fromIndex < 0) {\n fromIndex = nativeMax(length + fromIndex, 0);\n }\n return isString(collection)\n ? (fromIndex <= length && collection.indexOf(value, fromIndex) > -1)\n : (!!length && baseIndexOf(collection, value, fromIndex) > -1);\n }\n\n /**\n * Invokes the method at `path` of each element in `collection`, returning\n * an array of the results of each invoked method. Any additional arguments\n * are provided to each invoked method. If `path` is a function, it's invoked\n * for, and `this` bound to, each element in `collection`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Array|Function|string} path The path of the method to invoke or\n * the function invoked per iteration.\n * @param {...*} [args] The arguments to invoke each method with.\n * @returns {Array} Returns the array of results.\n * @example\n *\n * _.invokeMap([[5, 1, 7], [3, 2, 1]], 'sort');\n * // => [[1, 5, 7], [1, 2, 3]]\n *\n * _.invokeMap([123, 456], String.prototype.split, '');\n * // => [['1', '2', '3'], ['4', '5', '6']]\n */\n var invokeMap = baseRest(function(collection, path, args) {\n var index = -1,\n isFunc = typeof path == 'function',\n result = isArrayLike(collection) ? Array(collection.length) : [];\n\n baseEach(collection, function(value) {\n result[++index] = isFunc ? apply(path, value, args) : baseInvoke(value, path, args);\n });\n return result;\n });\n\n /**\n * Creates an object composed of keys generated from the results of running\n * each element of `collection` thru `iteratee`. The corresponding value of\n * each key is the last element responsible for generating the key. The\n * iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee to transform keys.\n * @returns {Object} Returns the composed aggregate object.\n * @example\n *\n * var array = [\n * { 'dir': 'left', 'code': 97 },\n * { 'dir': 'right', 'code': 100 }\n * ];\n *\n * _.keyBy(array, function(o) {\n * return String.fromCharCode(o.code);\n * });\n * // => { 'a': { 'dir': 'left', 'code': 97 }, 'd': { 'dir': 'right', 'code': 100 } }\n *\n * _.keyBy(array, 'dir');\n * // => { 'left': { 'dir': 'left', 'code': 97 }, 'right': { 'dir': 'right', 'code': 100 } }\n */\n var keyBy = createAggregator(function(result, value, key) {\n baseAssignValue(result, key, value);\n });\n\n /**\n * Creates an array of values by running each element in `collection` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.every`, `_.filter`, `_.map`, `_.mapValues`, `_.reject`, and `_.some`.\n *\n * The guarded methods are:\n * `ary`, `chunk`, `curry`, `curryRight`, `drop`, `dropRight`, `every`,\n * `fill`, `invert`, `parseInt`, `random`, `range`, `rangeRight`, `repeat`,\n * `sampleSize`, `slice`, `some`, `sortBy`, `split`, `take`, `takeRight`,\n * `template`, `trim`, `trimEnd`, `trimStart`, and `words`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * _.map([4, 8], square);\n * // => [16, 64]\n *\n * _.map({ 'a': 4, 'b': 8 }, square);\n * // => [16, 64] (iteration order is not guaranteed)\n *\n * var users = [\n * { 'user': 'barney' },\n * { 'user': 'fred' }\n * ];\n *\n * // The `_.property` iteratee shorthand.\n * _.map(users, 'user');\n * // => ['barney', 'fred']\n */\n function map(collection, iteratee) {\n var func = isArray(collection) ? arrayMap : baseMap;\n return func(collection, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.sortBy` except that it allows specifying the sort\n * orders of the iteratees to sort by. If `orders` is unspecified, all values\n * are sorted in ascending order. Otherwise, specify an order of \"desc\" for\n * descending or \"asc\" for ascending sort order of corresponding values.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Array[]|Function[]|Object[]|string[]} [iteratees=[_.identity]]\n * The iteratees to sort by.\n * @param {string[]} [orders] The sort orders of `iteratees`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.reduce`.\n * @returns {Array} Returns the new sorted array.\n * @example\n *\n * var users = [\n * { 'user': 'fred', 'age': 48 },\n * { 'user': 'barney', 'age': 34 },\n * { 'user': 'fred', 'age': 40 },\n * { 'user': 'barney', 'age': 36 }\n * ];\n *\n * // Sort by `user` in ascending order and by `age` in descending order.\n * _.orderBy(users, ['user', 'age'], ['asc', 'desc']);\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 40]]\n */\n function orderBy(collection, iteratees, orders, guard) {\n if (collection == null) {\n return [];\n }\n if (!isArray(iteratees)) {\n iteratees = iteratees == null ? [] : [iteratees];\n }\n orders = guard ? undefined : orders;\n if (!isArray(orders)) {\n orders = orders == null ? [] : [orders];\n }\n return baseOrderBy(collection, iteratees, orders);\n }\n\n /**\n * Creates an array of elements split into two groups, the first of which\n * contains elements `predicate` returns truthy for, the second of which\n * contains elements `predicate` returns falsey for. The predicate is\n * invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the array of grouped elements.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': true },\n * { 'user': 'pebbles', 'age': 1, 'active': false }\n * ];\n *\n * _.partition(users, function(o) { return o.active; });\n * // => objects for [['fred'], ['barney', 'pebbles']]\n *\n * // The `_.matches` iteratee shorthand.\n * _.partition(users, { 'age': 1, 'active': false });\n * // => objects for [['pebbles'], ['barney', 'fred']]\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.partition(users, ['active', false]);\n * // => objects for [['barney', 'pebbles'], ['fred']]\n *\n * // The `_.property` iteratee shorthand.\n * _.partition(users, 'active');\n * // => objects for [['fred'], ['barney', 'pebbles']]\n */\n var partition = createAggregator(function(result, value, key) {\n result[key ? 0 : 1].push(value);\n }, function() { return [[], []]; });\n\n /**\n * Reduces `collection` to a value which is the accumulated result of running\n * each element in `collection` thru `iteratee`, where each successive\n * invocation is supplied the return value of the previous. If `accumulator`\n * is not given, the first element of `collection` is used as the initial\n * value. The iteratee is invoked with four arguments:\n * (accumulator, value, index|key, collection).\n *\n * Many lodash methods are guarded to work as iteratees for methods like\n * `_.reduce`, `_.reduceRight`, and `_.transform`.\n *\n * The guarded methods are:\n * `assign`, `defaults`, `defaultsDeep`, `includes`, `merge`, `orderBy`,\n * and `sortBy`\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduceRight\n * @example\n *\n * _.reduce([1, 2], function(sum, n) {\n * return sum + n;\n * }, 0);\n * // => 3\n *\n * _.reduce({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * return result;\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] } (iteration order is not guaranteed)\n */\n function reduce(collection, iteratee, accumulator) {\n var func = isArray(collection) ? arrayReduce : baseReduce,\n initAccum = arguments.length < 3;\n\n return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEach);\n }\n\n /**\n * This method is like `_.reduce` except that it iterates over elements of\n * `collection` from right to left.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @returns {*} Returns the accumulated value.\n * @see _.reduce\n * @example\n *\n * var array = [[0, 1], [2, 3], [4, 5]];\n *\n * _.reduceRight(array, function(flattened, other) {\n * return flattened.concat(other);\n * }, []);\n * // => [4, 5, 2, 3, 0, 1]\n */\n function reduceRight(collection, iteratee, accumulator) {\n var func = isArray(collection) ? arrayReduceRight : baseReduce,\n initAccum = arguments.length < 3;\n\n return func(collection, getIteratee(iteratee, 4), accumulator, initAccum, baseEachRight);\n }\n\n /**\n * The opposite of `_.filter`; this method returns the elements of `collection`\n * that `predicate` does **not** return truthy for.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n * @see _.filter\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': false },\n * { 'user': 'fred', 'age': 40, 'active': true }\n * ];\n *\n * _.reject(users, function(o) { return !o.active; });\n * // => objects for ['fred']\n *\n * // The `_.matches` iteratee shorthand.\n * _.reject(users, { 'age': 40, 'active': true });\n * // => objects for ['barney']\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.reject(users, ['active', false]);\n * // => objects for ['fred']\n *\n * // The `_.property` iteratee shorthand.\n * _.reject(users, 'active');\n * // => objects for ['barney']\n */\n function reject(collection, predicate) {\n var func = isArray(collection) ? arrayFilter : baseFilter;\n return func(collection, negate(getIteratee(predicate, 3)));\n }\n\n /**\n * Gets a random element from `collection`.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to sample.\n * @returns {*} Returns the random element.\n * @example\n *\n * _.sample([1, 2, 3, 4]);\n * // => 2\n */\n function sample(collection) {\n var func = isArray(collection) ? arraySample : baseSample;\n return func(collection);\n }\n\n /**\n * Gets `n` random elements at unique keys from `collection` up to the\n * size of `collection`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Collection\n * @param {Array|Object} collection The collection to sample.\n * @param {number} [n=1] The number of elements to sample.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the random elements.\n * @example\n *\n * _.sampleSize([1, 2, 3], 2);\n * // => [3, 1]\n *\n * _.sampleSize([1, 2, 3], 4);\n * // => [2, 3, 1]\n */\n function sampleSize(collection, n, guard) {\n if ((guard ? isIterateeCall(collection, n, guard) : n === undefined)) {\n n = 1;\n } else {\n n = toInteger(n);\n }\n var func = isArray(collection) ? arraySampleSize : baseSampleSize;\n return func(collection, n);\n }\n\n /**\n * Creates an array of shuffled values, using a version of the\n * [Fisher-Yates shuffle](https://en.wikipedia.org/wiki/Fisher-Yates_shuffle).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to shuffle.\n * @returns {Array} Returns the new shuffled array.\n * @example\n *\n * _.shuffle([1, 2, 3, 4]);\n * // => [4, 1, 3, 2]\n */\n function shuffle(collection) {\n var func = isArray(collection) ? arrayShuffle : baseShuffle;\n return func(collection);\n }\n\n /**\n * Gets the size of `collection` by returning its length for array-like\n * values or the number of own enumerable string keyed properties for objects.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object|string} collection The collection to inspect.\n * @returns {number} Returns the collection size.\n * @example\n *\n * _.size([1, 2, 3]);\n * // => 3\n *\n * _.size({ 'a': 1, 'b': 2 });\n * // => 2\n *\n * _.size('pebbles');\n * // => 7\n */\n function size(collection) {\n if (collection == null) {\n return 0;\n }\n if (isArrayLike(collection)) {\n return isString(collection) ? stringSize(collection) : collection.length;\n }\n var tag = getTag(collection);\n if (tag == mapTag || tag == setTag) {\n return collection.size;\n }\n return baseKeys(collection).length;\n }\n\n /**\n * Checks if `predicate` returns truthy for **any** element of `collection`.\n * Iteration is stopped once `predicate` returns truthy. The predicate is\n * invoked with three arguments: (value, index|key, collection).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n * @example\n *\n * _.some([null, 0, 'yes', false], Boolean);\n * // => true\n *\n * var users = [\n * { 'user': 'barney', 'active': true },\n * { 'user': 'fred', 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.some(users, { 'user': 'barney', 'active': false });\n * // => false\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.some(users, ['active', false]);\n * // => true\n *\n * // The `_.property` iteratee shorthand.\n * _.some(users, 'active');\n * // => true\n */\n function some(collection, predicate, guard) {\n var func = isArray(collection) ? arraySome : baseSome;\n if (guard && isIterateeCall(collection, predicate, guard)) {\n predicate = undefined;\n }\n return func(collection, getIteratee(predicate, 3));\n }\n\n /**\n * Creates an array of elements, sorted in ascending order by the results of\n * running each element in a collection thru each iteratee. This method\n * performs a stable sort, that is, it preserves the original sort order of\n * equal elements. The iteratees are invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Collection\n * @param {Array|Object} collection The collection to iterate over.\n * @param {...(Function|Function[])} [iteratees=[_.identity]]\n * The iteratees to sort by.\n * @returns {Array} Returns the new sorted array.\n * @example\n *\n * var users = [\n * { 'user': 'fred', 'age': 48 },\n * { 'user': 'barney', 'age': 36 },\n * { 'user': 'fred', 'age': 30 },\n * { 'user': 'barney', 'age': 34 }\n * ];\n *\n * _.sortBy(users, [function(o) { return o.user; }]);\n * // => objects for [['barney', 36], ['barney', 34], ['fred', 48], ['fred', 30]]\n *\n * _.sortBy(users, ['user', 'age']);\n * // => objects for [['barney', 34], ['barney', 36], ['fred', 30], ['fred', 48]]\n */\n var sortBy = baseRest(function(collection, iteratees) {\n if (collection == null) {\n return [];\n }\n var length = iteratees.length;\n if (length > 1 && isIterateeCall(collection, iteratees[0], iteratees[1])) {\n iteratees = [];\n } else if (length > 2 && isIterateeCall(iteratees[0], iteratees[1], iteratees[2])) {\n iteratees = [iteratees[0]];\n }\n return baseOrderBy(collection, baseFlatten(iteratees, 1), []);\n });\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\n var now = ctxNow || function() {\n return root.Date.now();\n };\n\n /*------------------------------------------------------------------------*/\n\n /**\n * The opposite of `_.before`; this method creates a function that invokes\n * `func` once it's called `n` or more times.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {number} n The number of calls before `func` is invoked.\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * var saves = ['profile', 'settings'];\n *\n * var done = _.after(saves.length, function() {\n * console.log('done saving!');\n * });\n *\n * _.forEach(saves, function(type) {\n * asyncSave({ 'type': type, 'complete': done });\n * });\n * // => Logs 'done saving!' after the two async saves have completed.\n */\n function after(n, func) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n n = toInteger(n);\n return function() {\n if (--n < 1) {\n return func.apply(this, arguments);\n }\n };\n }\n\n /**\n * Creates a function that invokes `func`, with up to `n` arguments,\n * ignoring any additional arguments.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to cap arguments for.\n * @param {number} [n=func.length] The arity cap.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new capped function.\n * @example\n *\n * _.map(['6', '8', '10'], _.ary(parseInt, 1));\n * // => [6, 8, 10]\n */\n function ary(func, n, guard) {\n n = guard ? undefined : n;\n n = (func && n == null) ? func.length : n;\n return createWrap(func, WRAP_ARY_FLAG, undefined, undefined, undefined, undefined, n);\n }\n\n /**\n * Creates a function that invokes `func`, with the `this` binding and arguments\n * of the created function, while it's called less than `n` times. Subsequent\n * calls to the created function return the result of the last `func` invocation.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {number} n The number of calls at which `func` is no longer invoked.\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * jQuery(element).on('click', _.before(5, addContactToList));\n * // => Allows adding up to 4 contacts to the list.\n */\n function before(n, func) {\n var result;\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n n = toInteger(n);\n return function() {\n if (--n > 0) {\n result = func.apply(this, arguments);\n }\n if (n <= 1) {\n func = undefined;\n }\n return result;\n };\n }\n\n /**\n * Creates a function that invokes `func` with the `this` binding of `thisArg`\n * and `partials` prepended to the arguments it receives.\n *\n * The `_.bind.placeholder` value, which defaults to `_` in monolithic builds,\n * may be used as a placeholder for partially applied arguments.\n *\n * **Note:** Unlike native `Function#bind`, this method doesn't set the \"length\"\n * property of bound functions.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to bind.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new bound function.\n * @example\n *\n * function greet(greeting, punctuation) {\n * return greeting + ' ' + this.user + punctuation;\n * }\n *\n * var object = { 'user': 'fred' };\n *\n * var bound = _.bind(greet, object, 'hi');\n * bound('!');\n * // => 'hi fred!'\n *\n * // Bound with placeholders.\n * var bound = _.bind(greet, object, _, '!');\n * bound('hi');\n * // => 'hi fred!'\n */\n var bind = baseRest(function(func, thisArg, partials) {\n var bitmask = WRAP_BIND_FLAG;\n if (partials.length) {\n var holders = replaceHolders(partials, getHolder(bind));\n bitmask |= WRAP_PARTIAL_FLAG;\n }\n return createWrap(func, bitmask, thisArg, partials, holders);\n });\n\n /**\n * Creates a function that invokes the method at `object[key]` with `partials`\n * prepended to the arguments it receives.\n *\n * This method differs from `_.bind` by allowing bound functions to reference\n * methods that may be redefined or don't yet exist. See\n * [Peter Michaux's article](http://peter.michaux.ca/articles/lazy-function-definition-pattern)\n * for more details.\n *\n * The `_.bindKey.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * @static\n * @memberOf _\n * @since 0.10.0\n * @category Function\n * @param {Object} object The object to invoke the method on.\n * @param {string} key The key of the method.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new bound function.\n * @example\n *\n * var object = {\n * 'user': 'fred',\n * 'greet': function(greeting, punctuation) {\n * return greeting + ' ' + this.user + punctuation;\n * }\n * };\n *\n * var bound = _.bindKey(object, 'greet', 'hi');\n * bound('!');\n * // => 'hi fred!'\n *\n * object.greet = function(greeting, punctuation) {\n * return greeting + 'ya ' + this.user + punctuation;\n * };\n *\n * bound('!');\n * // => 'hiya fred!'\n *\n * // Bound with placeholders.\n * var bound = _.bindKey(object, 'greet', _, '!');\n * bound('hi');\n * // => 'hiya fred!'\n */\n var bindKey = baseRest(function(object, key, partials) {\n var bitmask = WRAP_BIND_FLAG | WRAP_BIND_KEY_FLAG;\n if (partials.length) {\n var holders = replaceHolders(partials, getHolder(bindKey));\n bitmask |= WRAP_PARTIAL_FLAG;\n }\n return createWrap(key, bitmask, object, partials, holders);\n });\n\n /**\n * Creates a function that accepts arguments of `func` and either invokes\n * `func` returning its result, if at least `arity` number of arguments have\n * been provided, or returns a function that accepts the remaining `func`\n * arguments, and so on. The arity of `func` may be specified if `func.length`\n * is not sufficient.\n *\n * The `_.curry.placeholder` value, which defaults to `_` in monolithic builds,\n * may be used as a placeholder for provided arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of curried functions.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Function\n * @param {Function} func The function to curry.\n * @param {number} [arity=func.length] The arity of `func`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new curried function.\n * @example\n *\n * var abc = function(a, b, c) {\n * return [a, b, c];\n * };\n *\n * var curried = _.curry(abc);\n *\n * curried(1)(2)(3);\n * // => [1, 2, 3]\n *\n * curried(1, 2)(3);\n * // => [1, 2, 3]\n *\n * curried(1, 2, 3);\n * // => [1, 2, 3]\n *\n * // Curried with placeholders.\n * curried(1)(_, 3)(2);\n * // => [1, 2, 3]\n */\n function curry(func, arity, guard) {\n arity = guard ? undefined : arity;\n var result = createWrap(func, WRAP_CURRY_FLAG, undefined, undefined, undefined, undefined, undefined, arity);\n result.placeholder = curry.placeholder;\n return result;\n }\n\n /**\n * This method is like `_.curry` except that arguments are applied to `func`\n * in the manner of `_.partialRight` instead of `_.partial`.\n *\n * The `_.curryRight.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for provided arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of curried functions.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to curry.\n * @param {number} [arity=func.length] The arity of `func`.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the new curried function.\n * @example\n *\n * var abc = function(a, b, c) {\n * return [a, b, c];\n * };\n *\n * var curried = _.curryRight(abc);\n *\n * curried(3)(2)(1);\n * // => [1, 2, 3]\n *\n * curried(2, 3)(1);\n * // => [1, 2, 3]\n *\n * curried(1, 2, 3);\n * // => [1, 2, 3]\n *\n * // Curried with placeholders.\n * curried(3)(1, _)(2);\n * // => [1, 2, 3]\n */\n function curryRight(func, arity, guard) {\n arity = guard ? undefined : arity;\n var result = createWrap(func, WRAP_CURRY_RIGHT_FLAG, undefined, undefined, undefined, undefined, undefined, arity);\n result.placeholder = curryRight.placeholder;\n return result;\n }\n\n /**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\n function debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n timeWaiting = wait - timeSinceLastCall;\n\n return maxing\n ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)\n : timeWaiting;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n clearTimeout(timerId);\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n }\n\n /**\n * Defers invoking the `func` until the current call stack has cleared. Any\n * additional arguments are provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to defer.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {number} Returns the timer id.\n * @example\n *\n * _.defer(function(text) {\n * console.log(text);\n * }, 'deferred');\n * // => Logs 'deferred' after one millisecond.\n */\n var defer = baseRest(function(func, args) {\n return baseDelay(func, 1, args);\n });\n\n /**\n * Invokes `func` after `wait` milliseconds. Any additional arguments are\n * provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to delay.\n * @param {number} wait The number of milliseconds to delay invocation.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {number} Returns the timer id.\n * @example\n *\n * _.delay(function(text) {\n * console.log(text);\n * }, 1000, 'later');\n * // => Logs 'later' after one second.\n */\n var delay = baseRest(function(func, wait, args) {\n return baseDelay(func, toNumber(wait) || 0, args);\n });\n\n /**\n * Creates a function that invokes `func` with arguments reversed.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to flip arguments for.\n * @returns {Function} Returns the new flipped function.\n * @example\n *\n * var flipped = _.flip(function() {\n * return _.toArray(arguments);\n * });\n *\n * flipped('a', 'b', 'c', 'd');\n * // => ['d', 'c', 'b', 'a']\n */\n function flip(func) {\n return createWrap(func, WRAP_FLIP_FLAG);\n }\n\n /**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\n function memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n }\n\n // Expose `MapCache`.\n memoize.Cache = MapCache;\n\n /**\n * Creates a function that negates the result of the predicate `func`. The\n * `func` predicate is invoked with the `this` binding and arguments of the\n * created function.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} predicate The predicate to negate.\n * @returns {Function} Returns the new negated function.\n * @example\n *\n * function isEven(n) {\n * return n % 2 == 0;\n * }\n *\n * _.filter([1, 2, 3, 4, 5, 6], _.negate(isEven));\n * // => [1, 3, 5]\n */\n function negate(predicate) {\n if (typeof predicate != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n return function() {\n var args = arguments;\n switch (args.length) {\n case 0: return !predicate.call(this);\n case 1: return !predicate.call(this, args[0]);\n case 2: return !predicate.call(this, args[0], args[1]);\n case 3: return !predicate.call(this, args[0], args[1], args[2]);\n }\n return !predicate.apply(this, args);\n };\n }\n\n /**\n * Creates a function that is restricted to invoking `func` once. Repeat calls\n * to the function return the value of the first invocation. The `func` is\n * invoked with the `this` binding and arguments of the created function.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to restrict.\n * @returns {Function} Returns the new restricted function.\n * @example\n *\n * var initialize = _.once(createApplication);\n * initialize();\n * initialize();\n * // => `createApplication` is invoked once\n */\n function once(func) {\n return before(2, func);\n }\n\n /**\n * Creates a function that invokes `func` with its arguments transformed.\n *\n * @static\n * @since 4.0.0\n * @memberOf _\n * @category Function\n * @param {Function} func The function to wrap.\n * @param {...(Function|Function[])} [transforms=[_.identity]]\n * The argument transforms.\n * @returns {Function} Returns the new function.\n * @example\n *\n * function doubled(n) {\n * return n * 2;\n * }\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var func = _.overArgs(function(x, y) {\n * return [x, y];\n * }, [square, doubled]);\n *\n * func(9, 3);\n * // => [81, 6]\n *\n * func(10, 5);\n * // => [100, 10]\n */\n var overArgs = castRest(function(func, transforms) {\n transforms = (transforms.length == 1 && isArray(transforms[0]))\n ? arrayMap(transforms[0], baseUnary(getIteratee()))\n : arrayMap(baseFlatten(transforms, 1), baseUnary(getIteratee()));\n\n var funcsLength = transforms.length;\n return baseRest(function(args) {\n var index = -1,\n length = nativeMin(args.length, funcsLength);\n\n while (++index < length) {\n args[index] = transforms[index].call(this, args[index]);\n }\n return apply(func, this, args);\n });\n });\n\n /**\n * Creates a function that invokes `func` with `partials` prepended to the\n * arguments it receives. This method is like `_.bind` except it does **not**\n * alter the `this` binding.\n *\n * The `_.partial.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of partially\n * applied functions.\n *\n * @static\n * @memberOf _\n * @since 0.2.0\n * @category Function\n * @param {Function} func The function to partially apply arguments to.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new partially applied function.\n * @example\n *\n * function greet(greeting, name) {\n * return greeting + ' ' + name;\n * }\n *\n * var sayHelloTo = _.partial(greet, 'hello');\n * sayHelloTo('fred');\n * // => 'hello fred'\n *\n * // Partially applied with placeholders.\n * var greetFred = _.partial(greet, _, 'fred');\n * greetFred('hi');\n * // => 'hi fred'\n */\n var partial = baseRest(function(func, partials) {\n var holders = replaceHolders(partials, getHolder(partial));\n return createWrap(func, WRAP_PARTIAL_FLAG, undefined, partials, holders);\n });\n\n /**\n * This method is like `_.partial` except that partially applied arguments\n * are appended to the arguments it receives.\n *\n * The `_.partialRight.placeholder` value, which defaults to `_` in monolithic\n * builds, may be used as a placeholder for partially applied arguments.\n *\n * **Note:** This method doesn't set the \"length\" property of partially\n * applied functions.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Function\n * @param {Function} func The function to partially apply arguments to.\n * @param {...*} [partials] The arguments to be partially applied.\n * @returns {Function} Returns the new partially applied function.\n * @example\n *\n * function greet(greeting, name) {\n * return greeting + ' ' + name;\n * }\n *\n * var greetFred = _.partialRight(greet, 'fred');\n * greetFred('hi');\n * // => 'hi fred'\n *\n * // Partially applied with placeholders.\n * var sayHelloTo = _.partialRight(greet, 'hello', _);\n * sayHelloTo('fred');\n * // => 'hello fred'\n */\n var partialRight = baseRest(function(func, partials) {\n var holders = replaceHolders(partials, getHolder(partialRight));\n return createWrap(func, WRAP_PARTIAL_RIGHT_FLAG, undefined, partials, holders);\n });\n\n /**\n * Creates a function that invokes `func` with arguments arranged according\n * to the specified `indexes` where the argument value at the first index is\n * provided as the first argument, the argument value at the second index is\n * provided as the second argument, and so on.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Function\n * @param {Function} func The function to rearrange arguments for.\n * @param {...(number|number[])} indexes The arranged argument indexes.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var rearged = _.rearg(function(a, b, c) {\n * return [a, b, c];\n * }, [2, 0, 1]);\n *\n * rearged('b', 'c', 'a')\n * // => ['a', 'b', 'c']\n */\n var rearg = flatRest(function(func, indexes) {\n return createWrap(func, WRAP_REARG_FLAG, undefined, undefined, undefined, indexes);\n });\n\n /**\n * Creates a function that invokes `func` with the `this` binding of the\n * created function and arguments from `start` and beyond provided as\n * an array.\n *\n * **Note:** This method is based on the\n * [rest parameter](https://mdn.io/rest_parameters).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var say = _.rest(function(what, names) {\n * return what + ' ' + _.initial(names).join(', ') +\n * (_.size(names) > 1 ? ', & ' : '') + _.last(names);\n * });\n *\n * say('hello', 'fred', 'barney', 'pebbles');\n * // => 'hello fred, barney, & pebbles'\n */\n function rest(func, start) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n start = start === undefined ? start : toInteger(start);\n return baseRest(func, start);\n }\n\n /**\n * Creates a function that invokes `func` with the `this` binding of the\n * create function and an array of arguments much like\n * [`Function#apply`](http://www.ecma-international.org/ecma-262/7.0/#sec-function.prototype.apply).\n *\n * **Note:** This method is based on the\n * [spread operator](https://mdn.io/spread_operator).\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Function\n * @param {Function} func The function to spread arguments over.\n * @param {number} [start=0] The start position of the spread.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var say = _.spread(function(who, what) {\n * return who + ' says ' + what;\n * });\n *\n * say(['fred', 'hello']);\n * // => 'fred says hello'\n *\n * var numbers = Promise.all([\n * Promise.resolve(40),\n * Promise.resolve(36)\n * ]);\n *\n * numbers.then(_.spread(function(x, y) {\n * return x + y;\n * }));\n * // => a Promise of 76\n */\n function spread(func, start) {\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n start = start == null ? 0 : nativeMax(toInteger(start), 0);\n return baseRest(function(args) {\n var array = args[start],\n otherArgs = castSlice(args, 0, start);\n\n if (array) {\n arrayPush(otherArgs, array);\n }\n return apply(func, this, otherArgs);\n });\n }\n\n /**\n * Creates a throttled function that only invokes `func` at most once per\n * every `wait` milliseconds. The throttled function comes with a `cancel`\n * method to cancel delayed `func` invocations and a `flush` method to\n * immediately invoke them. Provide `options` to indicate whether `func`\n * should be invoked on the leading and/or trailing edge of the `wait`\n * timeout. The `func` is invoked with the last arguments provided to the\n * throttled function. Subsequent calls to the throttled function return the\n * result of the last `func` invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the throttled function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.throttle` and `_.debounce`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to throttle.\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=true]\n * Specify invoking on the leading edge of the timeout.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new throttled function.\n * @example\n *\n * // Avoid excessively updating the position while scrolling.\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\n *\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\n * jQuery(element).on('click', throttled);\n *\n * // Cancel the trailing throttled invocation.\n * jQuery(window).on('popstate', throttled.cancel);\n */\n function throttle(func, wait, options) {\n var leading = true,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (isObject(options)) {\n leading = 'leading' in options ? !!options.leading : leading;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n return debounce(func, wait, {\n 'leading': leading,\n 'maxWait': wait,\n 'trailing': trailing\n });\n }\n\n /**\n * Creates a function that accepts up to one argument, ignoring any\n * additional arguments.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Function\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n * @example\n *\n * _.map(['6', '8', '10'], _.unary(parseInt));\n * // => [6, 8, 10]\n */\n function unary(func) {\n return ary(func, 1);\n }\n\n /**\n * Creates a function that provides `value` to `wrapper` as its first\n * argument. Any additional arguments provided to the function are appended\n * to those provided to the `wrapper`. The wrapper is invoked with the `this`\n * binding of the created function.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {*} value The value to wrap.\n * @param {Function} [wrapper=identity] The wrapper function.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var p = _.wrap(_.escape, function(func, text) {\n * return '

' + func(text) + '

';\n * });\n *\n * p('fred, barney, & pebbles');\n * // => '

fred, barney, & pebbles

'\n */\n function wrap(value, wrapper) {\n return partial(castFunction(wrapper), value);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Casts `value` as an array if it's not one.\n *\n * @static\n * @memberOf _\n * @since 4.4.0\n * @category Lang\n * @param {*} value The value to inspect.\n * @returns {Array} Returns the cast array.\n * @example\n *\n * _.castArray(1);\n * // => [1]\n *\n * _.castArray({ 'a': 1 });\n * // => [{ 'a': 1 }]\n *\n * _.castArray('abc');\n * // => ['abc']\n *\n * _.castArray(null);\n * // => [null]\n *\n * _.castArray(undefined);\n * // => [undefined]\n *\n * _.castArray();\n * // => []\n *\n * var array = [1, 2, 3];\n * console.log(_.castArray(array) === array);\n * // => true\n */\n function castArray() {\n if (!arguments.length) {\n return [];\n }\n var value = arguments[0];\n return isArray(value) ? value : [value];\n }\n\n /**\n * Creates a shallow clone of `value`.\n *\n * **Note:** This method is loosely based on the\n * [structured clone algorithm](https://mdn.io/Structured_clone_algorithm)\n * and supports cloning arrays, array buffers, booleans, date objects, maps,\n * numbers, `Object` objects, regexes, sets, strings, symbols, and typed\n * arrays. The own enumerable properties of `arguments` objects are cloned\n * as plain objects. An empty object is returned for uncloneable values such\n * as error objects, functions, DOM nodes, and WeakMaps.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to clone.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeep\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var shallow = _.clone(objects);\n * console.log(shallow[0] === objects[0]);\n * // => true\n */\n function clone(value) {\n return baseClone(value, CLONE_SYMBOLS_FLAG);\n }\n\n /**\n * This method is like `_.clone` except that it accepts `customizer` which\n * is invoked to produce the cloned value. If `customizer` returns `undefined`,\n * cloning is handled by the method instead. The `customizer` is invoked with\n * up to four arguments; (value [, index|key, object, stack]).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to clone.\n * @param {Function} [customizer] The function to customize cloning.\n * @returns {*} Returns the cloned value.\n * @see _.cloneDeepWith\n * @example\n *\n * function customizer(value) {\n * if (_.isElement(value)) {\n * return value.cloneNode(false);\n * }\n * }\n *\n * var el = _.cloneWith(document.body, customizer);\n *\n * console.log(el === document.body);\n * // => false\n * console.log(el.nodeName);\n * // => 'BODY'\n * console.log(el.childNodes.length);\n * // => 0\n */\n function cloneWith(value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseClone(value, CLONE_SYMBOLS_FLAG, customizer);\n }\n\n /**\n * This method is like `_.clone` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @returns {*} Returns the deep cloned value.\n * @see _.clone\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var deep = _.cloneDeep(objects);\n * console.log(deep[0] === objects[0]);\n * // => false\n */\n function cloneDeep(value) {\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n }\n\n /**\n * This method is like `_.cloneWith` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @param {Function} [customizer] The function to customize cloning.\n * @returns {*} Returns the deep cloned value.\n * @see _.cloneWith\n * @example\n *\n * function customizer(value) {\n * if (_.isElement(value)) {\n * return value.cloneNode(true);\n * }\n * }\n *\n * var el = _.cloneDeepWith(document.body, customizer);\n *\n * console.log(el === document.body);\n * // => false\n * console.log(el.nodeName);\n * // => 'BODY'\n * console.log(el.childNodes.length);\n * // => 20\n */\n function cloneDeepWith(value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG, customizer);\n }\n\n /**\n * Checks if `object` conforms to `source` by invoking the predicate\n * properties of `source` with the corresponding property values of `object`.\n *\n * **Note:** This method is equivalent to `_.conforms` when `source` is\n * partially applied.\n *\n * @static\n * @memberOf _\n * @since 4.14.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property predicates to conform to.\n * @returns {boolean} Returns `true` if `object` conforms, else `false`.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n *\n * _.conformsTo(object, { 'b': function(n) { return n > 1; } });\n * // => true\n *\n * _.conformsTo(object, { 'b': function(n) { return n > 2; } });\n * // => false\n */\n function conformsTo(object, source) {\n return source == null || baseConformsTo(object, source, keys(source));\n }\n\n /**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\n function eq(value, other) {\n return value === other || (value !== value && other !== other);\n }\n\n /**\n * Checks if `value` is greater than `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than `other`,\n * else `false`.\n * @see _.lt\n * @example\n *\n * _.gt(3, 1);\n * // => true\n *\n * _.gt(3, 3);\n * // => false\n *\n * _.gt(1, 3);\n * // => false\n */\n var gt = createRelationalOperation(baseGt);\n\n /**\n * Checks if `value` is greater than or equal to `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is greater than or equal to\n * `other`, else `false`.\n * @see _.lte\n * @example\n *\n * _.gte(3, 1);\n * // => true\n *\n * _.gte(3, 3);\n * // => true\n *\n * _.gte(1, 3);\n * // => false\n */\n var gte = createRelationalOperation(function(value, other) {\n return value >= other;\n });\n\n /**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\n var isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n };\n\n /**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\n var isArray = Array.isArray;\n\n /**\n * Checks if `value` is classified as an `ArrayBuffer` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array buffer, else `false`.\n * @example\n *\n * _.isArrayBuffer(new ArrayBuffer(2));\n * // => true\n *\n * _.isArrayBuffer(new Array(2));\n * // => false\n */\n var isArrayBuffer = nodeIsArrayBuffer ? baseUnary(nodeIsArrayBuffer) : baseIsArrayBuffer;\n\n /**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\n function isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n }\n\n /**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n * else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\n function isArrayLikeObject(value) {\n return isObjectLike(value) && isArrayLike(value);\n }\n\n /**\n * Checks if `value` is classified as a boolean primitive or object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a boolean, else `false`.\n * @example\n *\n * _.isBoolean(false);\n * // => true\n *\n * _.isBoolean(null);\n * // => false\n */\n function isBoolean(value) {\n return value === true || value === false ||\n (isObjectLike(value) && baseGetTag(value) == boolTag);\n }\n\n /**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\n var isBuffer = nativeIsBuffer || stubFalse;\n\n /**\n * Checks if `value` is classified as a `Date` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a date object, else `false`.\n * @example\n *\n * _.isDate(new Date);\n * // => true\n *\n * _.isDate('Mon April 23 2012');\n * // => false\n */\n var isDate = nodeIsDate ? baseUnary(nodeIsDate) : baseIsDate;\n\n /**\n * Checks if `value` is likely a DOM element.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a DOM element, else `false`.\n * @example\n *\n * _.isElement(document.body);\n * // => true\n *\n * _.isElement('');\n * // => false\n */\n function isElement(value) {\n return isObjectLike(value) && value.nodeType === 1 && !isPlainObject(value);\n }\n\n /**\n * Checks if `value` is an empty object, collection, map, or set.\n *\n * Objects are considered empty if they have no own enumerable string keyed\n * properties.\n *\n * Array-like values such as `arguments` objects, arrays, buffers, strings, or\n * jQuery-like collections are considered empty if they have a `length` of `0`.\n * Similarly, maps and sets are considered empty if they have a `size` of `0`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is empty, else `false`.\n * @example\n *\n * _.isEmpty(null);\n * // => true\n *\n * _.isEmpty(true);\n * // => true\n *\n * _.isEmpty(1);\n * // => true\n *\n * _.isEmpty([1, 2, 3]);\n * // => false\n *\n * _.isEmpty({ 'a': 1 });\n * // => false\n */\n function isEmpty(value) {\n if (value == null) {\n return true;\n }\n if (isArrayLike(value) &&\n (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' ||\n isBuffer(value) || isTypedArray(value) || isArguments(value))) {\n return !value.length;\n }\n var tag = getTag(value);\n if (tag == mapTag || tag == setTag) {\n return !value.size;\n }\n if (isPrototype(value)) {\n return !baseKeys(value).length;\n }\n for (var key in value) {\n if (hasOwnProperty.call(value, key)) {\n return false;\n }\n }\n return true;\n }\n\n /**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\n function isEqual(value, other) {\n return baseIsEqual(value, other);\n }\n\n /**\n * This method is like `_.isEqual` except that it accepts `customizer` which\n * is invoked to compare values. If `customizer` returns `undefined`, comparisons\n * are handled by the method instead. The `customizer` is invoked with up to\n * six arguments: (objValue, othValue [, index|key, object, other, stack]).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * function isGreeting(value) {\n * return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, othValue) {\n * if (isGreeting(objValue) && isGreeting(othValue)) {\n * return true;\n * }\n * }\n *\n * var array = ['hello', 'goodbye'];\n * var other = ['hi', 'goodbye'];\n *\n * _.isEqualWith(array, other, customizer);\n * // => true\n */\n function isEqualWith(value, other, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n var result = customizer ? customizer(value, other) : undefined;\n return result === undefined ? baseIsEqual(value, other, undefined, customizer) : !!result;\n }\n\n /**\n * Checks if `value` is an `Error`, `EvalError`, `RangeError`, `ReferenceError`,\n * `SyntaxError`, `TypeError`, or `URIError` object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an error object, else `false`.\n * @example\n *\n * _.isError(new Error);\n * // => true\n *\n * _.isError(Error);\n * // => false\n */\n function isError(value) {\n if (!isObjectLike(value)) {\n return false;\n }\n var tag = baseGetTag(value);\n return tag == errorTag || tag == domExcTag ||\n (typeof value.message == 'string' && typeof value.name == 'string' && !isPlainObject(value));\n }\n\n /**\n * Checks if `value` is a finite primitive number.\n *\n * **Note:** This method is based on\n * [`Number.isFinite`](https://mdn.io/Number/isFinite).\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a finite number, else `false`.\n * @example\n *\n * _.isFinite(3);\n * // => true\n *\n * _.isFinite(Number.MIN_VALUE);\n * // => true\n *\n * _.isFinite(Infinity);\n * // => false\n *\n * _.isFinite('3');\n * // => false\n */\n function isFinite(value) {\n return typeof value == 'number' && nativeIsFinite(value);\n }\n\n /**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\n function isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n }\n\n /**\n * Checks if `value` is an integer.\n *\n * **Note:** This method is based on\n * [`Number.isInteger`](https://mdn.io/Number/isInteger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an integer, else `false`.\n * @example\n *\n * _.isInteger(3);\n * // => true\n *\n * _.isInteger(Number.MIN_VALUE);\n * // => false\n *\n * _.isInteger(Infinity);\n * // => false\n *\n * _.isInteger('3');\n * // => false\n */\n function isInteger(value) {\n return typeof value == 'number' && value == toInteger(value);\n }\n\n /**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\n function isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n }\n\n /**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\n function isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n }\n\n /**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\n function isObjectLike(value) {\n return value != null && typeof value == 'object';\n }\n\n /**\n * Checks if `value` is classified as a `Map` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n * @example\n *\n * _.isMap(new Map);\n * // => true\n *\n * _.isMap(new WeakMap);\n * // => false\n */\n var isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\n /**\n * Performs a partial deep comparison between `object` and `source` to\n * determine if `object` contains equivalent property values.\n *\n * **Note:** This method is equivalent to `_.matches` when `source` is\n * partially applied.\n *\n * Partial comparisons will match empty array and empty object `source`\n * values against any array or object value, respectively. See `_.isEqual`\n * for a list of supported value comparisons.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n *\n * _.isMatch(object, { 'b': 2 });\n * // => true\n *\n * _.isMatch(object, { 'b': 1 });\n * // => false\n */\n function isMatch(object, source) {\n return object === source || baseIsMatch(object, source, getMatchData(source));\n }\n\n /**\n * This method is like `_.isMatch` except that it accepts `customizer` which\n * is invoked to compare values. If `customizer` returns `undefined`, comparisons\n * are handled by the method instead. The `customizer` is invoked with five\n * arguments: (objValue, srcValue, index|key, object, source).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {Object} object The object to inspect.\n * @param {Object} source The object of property values to match.\n * @param {Function} [customizer] The function to customize comparisons.\n * @returns {boolean} Returns `true` if `object` is a match, else `false`.\n * @example\n *\n * function isGreeting(value) {\n * return /^h(?:i|ello)$/.test(value);\n * }\n *\n * function customizer(objValue, srcValue) {\n * if (isGreeting(objValue) && isGreeting(srcValue)) {\n * return true;\n * }\n * }\n *\n * var object = { 'greeting': 'hello' };\n * var source = { 'greeting': 'hi' };\n *\n * _.isMatchWith(object, source, customizer);\n * // => true\n */\n function isMatchWith(object, source, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return baseIsMatch(object, source, getMatchData(source), customizer);\n }\n\n /**\n * Checks if `value` is `NaN`.\n *\n * **Note:** This method is based on\n * [`Number.isNaN`](https://mdn.io/Number/isNaN) and is not the same as\n * global [`isNaN`](https://mdn.io/isNaN) which returns `true` for\n * `undefined` and other non-number values.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n * @example\n *\n * _.isNaN(NaN);\n * // => true\n *\n * _.isNaN(new Number(NaN));\n * // => true\n *\n * isNaN(undefined);\n * // => true\n *\n * _.isNaN(undefined);\n * // => false\n */\n function isNaN(value) {\n // An `NaN` primitive is the only value that is not equal to itself.\n // Perform the `toStringTag` check first to avoid errors with some\n // ActiveX objects in IE.\n return isNumber(value) && value != +value;\n }\n\n /**\n * Checks if `value` is a pristine native function.\n *\n * **Note:** This method can't reliably detect native functions in the presence\n * of the core-js package because core-js circumvents this kind of detection.\n * Despite multiple requests, the core-js maintainer has made it clear: any\n * attempt to fix the detection will be obstructed. As a result, we're left\n * with little choice but to throw an error. Unfortunately, this also affects\n * packages, like [babel-polyfill](https://www.npmjs.com/package/babel-polyfill),\n * which rely on core-js.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n * @example\n *\n * _.isNative(Array.prototype.push);\n * // => true\n *\n * _.isNative(_);\n * // => false\n */\n function isNative(value) {\n if (isMaskable(value)) {\n throw new Error(CORE_ERROR_TEXT);\n }\n return baseIsNative(value);\n }\n\n /**\n * Checks if `value` is `null`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `null`, else `false`.\n * @example\n *\n * _.isNull(null);\n * // => true\n *\n * _.isNull(void 0);\n * // => false\n */\n function isNull(value) {\n return value === null;\n }\n\n /**\n * Checks if `value` is `null` or `undefined`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is nullish, else `false`.\n * @example\n *\n * _.isNil(null);\n * // => true\n *\n * _.isNil(void 0);\n * // => true\n *\n * _.isNil(NaN);\n * // => false\n */\n function isNil(value) {\n return value == null;\n }\n\n /**\n * Checks if `value` is classified as a `Number` primitive or object.\n *\n * **Note:** To exclude `Infinity`, `-Infinity`, and `NaN`, which are\n * classified as numbers, use the `_.isFinite` method.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a number, else `false`.\n * @example\n *\n * _.isNumber(3);\n * // => true\n *\n * _.isNumber(Number.MIN_VALUE);\n * // => true\n *\n * _.isNumber(Infinity);\n * // => true\n *\n * _.isNumber('3');\n * // => false\n */\n function isNumber(value) {\n return typeof value == 'number' ||\n (isObjectLike(value) && baseGetTag(value) == numberTag);\n }\n\n /**\n * Checks if `value` is a plain object, that is, an object created by the\n * `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @static\n * @memberOf _\n * @since 0.8.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a plain object, else `false`.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * _.isPlainObject(new Foo);\n * // => false\n *\n * _.isPlainObject([1, 2, 3]);\n * // => false\n *\n * _.isPlainObject({ 'x': 0, 'y': 0 });\n * // => true\n *\n * _.isPlainObject(Object.create(null));\n * // => true\n */\n function isPlainObject(value) {\n if (!isObjectLike(value) || baseGetTag(value) != objectTag) {\n return false;\n }\n var proto = getPrototype(value);\n if (proto === null) {\n return true;\n }\n var Ctor = hasOwnProperty.call(proto, 'constructor') && proto.constructor;\n return typeof Ctor == 'function' && Ctor instanceof Ctor &&\n funcToString.call(Ctor) == objectCtorString;\n }\n\n /**\n * Checks if `value` is classified as a `RegExp` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a regexp, else `false`.\n * @example\n *\n * _.isRegExp(/abc/);\n * // => true\n *\n * _.isRegExp('/abc/');\n * // => false\n */\n var isRegExp = nodeIsRegExp ? baseUnary(nodeIsRegExp) : baseIsRegExp;\n\n /**\n * Checks if `value` is a safe integer. An integer is safe if it's an IEEE-754\n * double precision number which isn't the result of a rounded unsafe integer.\n *\n * **Note:** This method is based on\n * [`Number.isSafeInteger`](https://mdn.io/Number/isSafeInteger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a safe integer, else `false`.\n * @example\n *\n * _.isSafeInteger(3);\n * // => true\n *\n * _.isSafeInteger(Number.MIN_VALUE);\n * // => false\n *\n * _.isSafeInteger(Infinity);\n * // => false\n *\n * _.isSafeInteger('3');\n * // => false\n */\n function isSafeInteger(value) {\n return isInteger(value) && value >= -MAX_SAFE_INTEGER && value <= MAX_SAFE_INTEGER;\n }\n\n /**\n * Checks if `value` is classified as a `Set` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n * @example\n *\n * _.isSet(new Set);\n * // => true\n *\n * _.isSet(new WeakSet);\n * // => false\n */\n var isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\n /**\n * Checks if `value` is classified as a `String` primitive or object.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a string, else `false`.\n * @example\n *\n * _.isString('abc');\n * // => true\n *\n * _.isString(1);\n * // => false\n */\n function isString(value) {\n return typeof value == 'string' ||\n (!isArray(value) && isObjectLike(value) && baseGetTag(value) == stringTag);\n }\n\n /**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\n function isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n }\n\n /**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\n var isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n /**\n * Checks if `value` is `undefined`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `undefined`, else `false`.\n * @example\n *\n * _.isUndefined(void 0);\n * // => true\n *\n * _.isUndefined(null);\n * // => false\n */\n function isUndefined(value) {\n return value === undefined;\n }\n\n /**\n * Checks if `value` is classified as a `WeakMap` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a weak map, else `false`.\n * @example\n *\n * _.isWeakMap(new WeakMap);\n * // => true\n *\n * _.isWeakMap(new Map);\n * // => false\n */\n function isWeakMap(value) {\n return isObjectLike(value) && getTag(value) == weakMapTag;\n }\n\n /**\n * Checks if `value` is classified as a `WeakSet` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a weak set, else `false`.\n * @example\n *\n * _.isWeakSet(new WeakSet);\n * // => true\n *\n * _.isWeakSet(new Set);\n * // => false\n */\n function isWeakSet(value) {\n return isObjectLike(value) && baseGetTag(value) == weakSetTag;\n }\n\n /**\n * Checks if `value` is less than `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than `other`,\n * else `false`.\n * @see _.gt\n * @example\n *\n * _.lt(1, 3);\n * // => true\n *\n * _.lt(3, 3);\n * // => false\n *\n * _.lt(3, 1);\n * // => false\n */\n var lt = createRelationalOperation(baseLt);\n\n /**\n * Checks if `value` is less than or equal to `other`.\n *\n * @static\n * @memberOf _\n * @since 3.9.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if `value` is less than or equal to\n * `other`, else `false`.\n * @see _.gte\n * @example\n *\n * _.lte(1, 3);\n * // => true\n *\n * _.lte(3, 3);\n * // => true\n *\n * _.lte(3, 1);\n * // => false\n */\n var lte = createRelationalOperation(function(value, other) {\n return value <= other;\n });\n\n /**\n * Converts `value` to an array.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Array} Returns the converted array.\n * @example\n *\n * _.toArray({ 'a': 1, 'b': 2 });\n * // => [1, 2]\n *\n * _.toArray('abc');\n * // => ['a', 'b', 'c']\n *\n * _.toArray(1);\n * // => []\n *\n * _.toArray(null);\n * // => []\n */\n function toArray(value) {\n if (!value) {\n return [];\n }\n if (isArrayLike(value)) {\n return isString(value) ? stringToArray(value) : copyArray(value);\n }\n if (symIterator && value[symIterator]) {\n return iteratorToArray(value[symIterator]());\n }\n var tag = getTag(value),\n func = tag == mapTag ? mapToArray : (tag == setTag ? setToArray : values);\n\n return func(value);\n }\n\n /**\n * Converts `value` to a finite number.\n *\n * @static\n * @memberOf _\n * @since 4.12.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted number.\n * @example\n *\n * _.toFinite(3.2);\n * // => 3.2\n *\n * _.toFinite(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toFinite(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toFinite('3.2');\n * // => 3.2\n */\n function toFinite(value) {\n if (!value) {\n return value === 0 ? value : 0;\n }\n value = toNumber(value);\n if (value === INFINITY || value === -INFINITY) {\n var sign = (value < 0 ? -1 : 1);\n return sign * MAX_INTEGER;\n }\n return value === value ? value : 0;\n }\n\n /**\n * Converts `value` to an integer.\n *\n * **Note:** This method is loosely based on\n * [`ToInteger`](http://www.ecma-international.org/ecma-262/7.0/#sec-tointeger).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toInteger(3.2);\n * // => 3\n *\n * _.toInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toInteger(Infinity);\n * // => 1.7976931348623157e+308\n *\n * _.toInteger('3.2');\n * // => 3\n */\n function toInteger(value) {\n var result = toFinite(value),\n remainder = result % 1;\n\n return result === result ? (remainder ? result - remainder : result) : 0;\n }\n\n /**\n * Converts `value` to an integer suitable for use as the length of an\n * array-like object.\n *\n * **Note:** This method is based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toLength(3.2);\n * // => 3\n *\n * _.toLength(Number.MIN_VALUE);\n * // => 0\n *\n * _.toLength(Infinity);\n * // => 4294967295\n *\n * _.toLength('3.2');\n * // => 3\n */\n function toLength(value) {\n return value ? baseClamp(toInteger(value), 0, MAX_ARRAY_LENGTH) : 0;\n }\n\n /**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\n function toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = baseTrim(value);\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n }\n\n /**\n * Converts `value` to a plain object flattening inherited enumerable string\n * keyed properties of `value` to own properties of the plain object.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {Object} Returns the converted plain object.\n * @example\n *\n * function Foo() {\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.assign({ 'a': 1 }, new Foo);\n * // => { 'a': 1, 'b': 2 }\n *\n * _.assign({ 'a': 1 }, _.toPlainObject(new Foo));\n * // => { 'a': 1, 'b': 2, 'c': 3 }\n */\n function toPlainObject(value) {\n return copyObject(value, keysIn(value));\n }\n\n /**\n * Converts `value` to a safe integer. A safe integer can be compared and\n * represented correctly.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.toSafeInteger(3.2);\n * // => 3\n *\n * _.toSafeInteger(Number.MIN_VALUE);\n * // => 0\n *\n * _.toSafeInteger(Infinity);\n * // => 9007199254740991\n *\n * _.toSafeInteger('3.2');\n * // => 3\n */\n function toSafeInteger(value) {\n return value\n ? baseClamp(toInteger(value), -MAX_SAFE_INTEGER, MAX_SAFE_INTEGER)\n : (value === 0 ? value : 0);\n }\n\n /**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\n function toString(value) {\n return value == null ? '' : baseToString(value);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Assigns own enumerable string keyed properties of source objects to the\n * destination object. Source objects are applied from left to right.\n * Subsequent sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object` and is loosely based on\n * [`Object.assign`](https://mdn.io/Object/assign).\n *\n * @static\n * @memberOf _\n * @since 0.10.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assignIn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * function Bar() {\n * this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assign({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'c': 3 }\n */\n var assign = createAssigner(function(object, source) {\n if (isPrototype(source) || isArrayLike(source)) {\n copyObject(source, keys(source), object);\n return;\n }\n for (var key in source) {\n if (hasOwnProperty.call(source, key)) {\n assignValue(object, key, source[key]);\n }\n }\n });\n\n /**\n * This method is like `_.assign` except that it iterates over own and\n * inherited source properties.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias extend\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.assign\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * }\n *\n * function Bar() {\n * this.c = 3;\n * }\n *\n * Foo.prototype.b = 2;\n * Bar.prototype.d = 4;\n *\n * _.assignIn({ 'a': 0 }, new Foo, new Bar);\n * // => { 'a': 1, 'b': 2, 'c': 3, 'd': 4 }\n */\n var assignIn = createAssigner(function(object, source) {\n copyObject(source, keysIn(source), object);\n });\n\n /**\n * This method is like `_.assignIn` except that it accepts `customizer`\n * which is invoked to produce the assigned values. If `customizer` returns\n * `undefined`, assignment is handled by the method instead. The `customizer`\n * is invoked with five arguments: (objValue, srcValue, key, object, source).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias extendWith\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @see _.assignWith\n * @example\n *\n * function customizer(objValue, srcValue) {\n * return _.isUndefined(objValue) ? srcValue : objValue;\n * }\n *\n * var defaults = _.partialRight(_.assignInWith, customizer);\n *\n * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\n var assignInWith = createAssigner(function(object, source, srcIndex, customizer) {\n copyObject(source, keysIn(source), object, customizer);\n });\n\n /**\n * This method is like `_.assign` except that it accepts `customizer`\n * which is invoked to produce the assigned values. If `customizer` returns\n * `undefined`, assignment is handled by the method instead. The `customizer`\n * is invoked with five arguments: (objValue, srcValue, key, object, source).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @see _.assignInWith\n * @example\n *\n * function customizer(objValue, srcValue) {\n * return _.isUndefined(objValue) ? srcValue : objValue;\n * }\n *\n * var defaults = _.partialRight(_.assignWith, customizer);\n *\n * defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\n var assignWith = createAssigner(function(object, source, srcIndex, customizer) {\n copyObject(source, keys(source), object, customizer);\n });\n\n /**\n * Creates an array of values corresponding to `paths` of `object`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Array} Returns the picked values.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }, 4] };\n *\n * _.at(object, ['a[0].b.c', 'a[1]']);\n * // => [3, 4]\n */\n var at = flatRest(baseAt);\n\n /**\n * Creates an object that inherits from the `prototype` object. If a\n * `properties` object is given, its own enumerable string keyed properties\n * are assigned to the created object.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Object\n * @param {Object} prototype The object to inherit from.\n * @param {Object} [properties] The properties to assign to the object.\n * @returns {Object} Returns the new object.\n * @example\n *\n * function Shape() {\n * this.x = 0;\n * this.y = 0;\n * }\n *\n * function Circle() {\n * Shape.call(this);\n * }\n *\n * Circle.prototype = _.create(Shape.prototype, {\n * 'constructor': Circle\n * });\n *\n * var circle = new Circle;\n * circle instanceof Circle;\n * // => true\n *\n * circle instanceof Shape;\n * // => true\n */\n function create(prototype, properties) {\n var result = baseCreate(prototype);\n return properties == null ? result : baseAssign(result, properties);\n }\n\n /**\n * Assigns own and inherited enumerable string keyed properties of source\n * objects to the destination object for all destination properties that\n * resolve to `undefined`. Source objects are applied from left to right.\n * Once a property is set, additional values of the same property are ignored.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.defaultsDeep\n * @example\n *\n * _.defaults({ 'a': 1 }, { 'b': 2 }, { 'a': 3 });\n * // => { 'a': 1, 'b': 2 }\n */\n var defaults = baseRest(function(object, sources) {\n object = Object(object);\n\n var index = -1;\n var length = sources.length;\n var guard = length > 2 ? sources[2] : undefined;\n\n if (guard && isIterateeCall(sources[0], sources[1], guard)) {\n length = 1;\n }\n\n while (++index < length) {\n var source = sources[index];\n var props = keysIn(source);\n var propsIndex = -1;\n var propsLength = props.length;\n\n while (++propsIndex < propsLength) {\n var key = props[propsIndex];\n var value = object[key];\n\n if (value === undefined ||\n (eq(value, objectProto[key]) && !hasOwnProperty.call(object, key))) {\n object[key] = source[key];\n }\n }\n }\n\n return object;\n });\n\n /**\n * This method is like `_.defaults` except that it recursively assigns\n * default properties.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.10.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @see _.defaults\n * @example\n *\n * _.defaultsDeep({ 'a': { 'b': 2 } }, { 'a': { 'b': 1, 'c': 3 } });\n * // => { 'a': { 'b': 2, 'c': 3 } }\n */\n var defaultsDeep = baseRest(function(args) {\n args.push(undefined, customDefaultsMerge);\n return apply(mergeWith, undefined, args);\n });\n\n /**\n * This method is like `_.find` except that it returns the key of the first\n * element `predicate` returns truthy for instead of the element itself.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {string|undefined} Returns the key of the matched element,\n * else `undefined`.\n * @example\n *\n * var users = {\n * 'barney': { 'age': 36, 'active': true },\n * 'fred': { 'age': 40, 'active': false },\n * 'pebbles': { 'age': 1, 'active': true }\n * };\n *\n * _.findKey(users, function(o) { return o.age < 40; });\n * // => 'barney' (iteration order is not guaranteed)\n *\n * // The `_.matches` iteratee shorthand.\n * _.findKey(users, { 'age': 1, 'active': true });\n * // => 'pebbles'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findKey(users, ['active', false]);\n * // => 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.findKey(users, 'active');\n * // => 'barney'\n */\n function findKey(object, predicate) {\n return baseFindKey(object, getIteratee(predicate, 3), baseForOwn);\n }\n\n /**\n * This method is like `_.findKey` except that it iterates over elements of\n * a collection in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @param {Function} [predicate=_.identity] The function invoked per iteration.\n * @returns {string|undefined} Returns the key of the matched element,\n * else `undefined`.\n * @example\n *\n * var users = {\n * 'barney': { 'age': 36, 'active': true },\n * 'fred': { 'age': 40, 'active': false },\n * 'pebbles': { 'age': 1, 'active': true }\n * };\n *\n * _.findLastKey(users, function(o) { return o.age < 40; });\n * // => returns 'pebbles' assuming `_.findKey` returns 'barney'\n *\n * // The `_.matches` iteratee shorthand.\n * _.findLastKey(users, { 'age': 36, 'active': true });\n * // => 'barney'\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.findLastKey(users, ['active', false]);\n * // => 'fred'\n *\n * // The `_.property` iteratee shorthand.\n * _.findLastKey(users, 'active');\n * // => 'pebbles'\n */\n function findLastKey(object, predicate) {\n return baseFindKey(object, getIteratee(predicate, 3), baseForOwnRight);\n }\n\n /**\n * Iterates over own and inherited enumerable string keyed properties of an\n * object and invokes `iteratee` for each property. The iteratee is invoked\n * with three arguments: (value, key, object). Iteratee functions may exit\n * iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forInRight\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forIn(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a', 'b', then 'c' (iteration order is not guaranteed).\n */\n function forIn(object, iteratee) {\n return object == null\n ? object\n : baseFor(object, getIteratee(iteratee, 3), keysIn);\n }\n\n /**\n * This method is like `_.forIn` except that it iterates over properties of\n * `object` in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forIn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forInRight(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'c', 'b', then 'a' assuming `_.forIn` logs 'a', 'b', then 'c'.\n */\n function forInRight(object, iteratee) {\n return object == null\n ? object\n : baseForRight(object, getIteratee(iteratee, 3), keysIn);\n }\n\n /**\n * Iterates over own enumerable string keyed properties of an object and\n * invokes `iteratee` for each property. The iteratee is invoked with three\n * arguments: (value, key, object). Iteratee functions may exit iteration\n * early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 0.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forOwnRight\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forOwn(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'a' then 'b' (iteration order is not guaranteed).\n */\n function forOwn(object, iteratee) {\n return object && baseForOwn(object, getIteratee(iteratee, 3));\n }\n\n /**\n * This method is like `_.forOwn` except that it iterates over properties of\n * `object` in the opposite order.\n *\n * @static\n * @memberOf _\n * @since 2.0.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns `object`.\n * @see _.forOwn\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.forOwnRight(new Foo, function(value, key) {\n * console.log(key);\n * });\n * // => Logs 'b' then 'a' assuming `_.forOwn` logs 'a' then 'b'.\n */\n function forOwnRight(object, iteratee) {\n return object && baseForOwnRight(object, getIteratee(iteratee, 3));\n }\n\n /**\n * Creates an array of function property names from own enumerable properties\n * of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to inspect.\n * @returns {Array} Returns the function names.\n * @see _.functionsIn\n * @example\n *\n * function Foo() {\n * this.a = _.constant('a');\n * this.b = _.constant('b');\n * }\n *\n * Foo.prototype.c = _.constant('c');\n *\n * _.functions(new Foo);\n * // => ['a', 'b']\n */\n function functions(object) {\n return object == null ? [] : baseFunctions(object, keys(object));\n }\n\n /**\n * Creates an array of function property names from own and inherited\n * enumerable properties of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to inspect.\n * @returns {Array} Returns the function names.\n * @see _.functions\n * @example\n *\n * function Foo() {\n * this.a = _.constant('a');\n * this.b = _.constant('b');\n * }\n *\n * Foo.prototype.c = _.constant('c');\n *\n * _.functionsIn(new Foo);\n * // => ['a', 'b', 'c']\n */\n function functionsIn(object) {\n return object == null ? [] : baseFunctions(object, keysIn(object));\n }\n\n /**\n * Gets the value at `path` of `object`. If the resolved value is\n * `undefined`, the `defaultValue` is returned in its place.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to get.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.get(object, 'a[0].b.c');\n * // => 3\n *\n * _.get(object, ['a', '0', 'b', 'c']);\n * // => 3\n *\n * _.get(object, 'a.b.c', 'default');\n * // => 'default'\n */\n function get(object, path, defaultValue) {\n var result = object == null ? undefined : baseGet(object, path);\n return result === undefined ? defaultValue : result;\n }\n\n /**\n * Checks if `path` is a direct property of `object`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = { 'a': { 'b': 2 } };\n * var other = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.has(object, 'a');\n * // => true\n *\n * _.has(object, 'a.b');\n * // => true\n *\n * _.has(object, ['a', 'b']);\n * // => true\n *\n * _.has(other, 'a');\n * // => false\n */\n function has(object, path) {\n return object != null && hasPath(object, path, baseHas);\n }\n\n /**\n * Checks if `path` is a direct or inherited property of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path to check.\n * @returns {boolean} Returns `true` if `path` exists, else `false`.\n * @example\n *\n * var object = _.create({ 'a': _.create({ 'b': 2 }) });\n *\n * _.hasIn(object, 'a');\n * // => true\n *\n * _.hasIn(object, 'a.b');\n * // => true\n *\n * _.hasIn(object, ['a', 'b']);\n * // => true\n *\n * _.hasIn(object, 'b');\n * // => false\n */\n function hasIn(object, path) {\n return object != null && hasPath(object, path, baseHasIn);\n }\n\n /**\n * Creates an object composed of the inverted keys and values of `object`.\n * If `object` contains duplicate values, subsequent values overwrite\n * property assignments of previous values.\n *\n * @static\n * @memberOf _\n * @since 0.7.0\n * @category Object\n * @param {Object} object The object to invert.\n * @returns {Object} Returns the new inverted object.\n * @example\n *\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\n *\n * _.invert(object);\n * // => { '1': 'c', '2': 'b' }\n */\n var invert = createInverter(function(result, value, key) {\n if (value != null &&\n typeof value.toString != 'function') {\n value = nativeObjectToString.call(value);\n }\n\n result[value] = key;\n }, constant(identity));\n\n /**\n * This method is like `_.invert` except that the inverted object is generated\n * from the results of running each element of `object` thru `iteratee`. The\n * corresponding inverted value of each inverted key is an array of keys\n * responsible for generating the inverted value. The iteratee is invoked\n * with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.1.0\n * @category Object\n * @param {Object} object The object to invert.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {Object} Returns the new inverted object.\n * @example\n *\n * var object = { 'a': 1, 'b': 2, 'c': 1 };\n *\n * _.invertBy(object);\n * // => { '1': ['a', 'c'], '2': ['b'] }\n *\n * _.invertBy(object, function(value) {\n * return 'group' + value;\n * });\n * // => { 'group1': ['a', 'c'], 'group2': ['b'] }\n */\n var invertBy = createInverter(function(result, value, key) {\n if (value != null &&\n typeof value.toString != 'function') {\n value = nativeObjectToString.call(value);\n }\n\n if (hasOwnProperty.call(result, value)) {\n result[value].push(key);\n } else {\n result[value] = [key];\n }\n }, getIteratee);\n\n /**\n * Invokes the method at `path` of `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the method to invoke.\n * @param {...*} [args] The arguments to invoke the method with.\n * @returns {*} Returns the result of the invoked method.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': [1, 2, 3, 4] } }] };\n *\n * _.invoke(object, 'a[0].b.c.slice', 1, 3);\n * // => [2, 3]\n */\n var invoke = baseRest(baseInvoke);\n\n /**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\n function keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n }\n\n /**\n * Creates an array of the own and inherited enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keysIn(new Foo);\n * // => ['a', 'b', 'c'] (iteration order is not guaranteed)\n */\n function keysIn(object) {\n return isArrayLike(object) ? arrayLikeKeys(object, true) : baseKeysIn(object);\n }\n\n /**\n * The opposite of `_.mapValues`; this method creates an object with the\n * same values as `object` and keys generated by running each own enumerable\n * string keyed property of `object` thru `iteratee`. The iteratee is invoked\n * with three arguments: (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 3.8.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapValues\n * @example\n *\n * _.mapKeys({ 'a': 1, 'b': 2 }, function(value, key) {\n * return key + value;\n * });\n * // => { 'a1': 1, 'b2': 2 }\n */\n function mapKeys(object, iteratee) {\n var result = {};\n iteratee = getIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, iteratee(value, key, object), value);\n });\n return result;\n }\n\n /**\n * Creates an object with the same keys as `object` and values generated\n * by running each own enumerable string keyed property of `object` thru\n * `iteratee`. The iteratee is invoked with three arguments:\n * (value, key, object).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Object} Returns the new mapped object.\n * @see _.mapKeys\n * @example\n *\n * var users = {\n * 'fred': { 'user': 'fred', 'age': 40 },\n * 'pebbles': { 'user': 'pebbles', 'age': 1 }\n * };\n *\n * _.mapValues(users, function(o) { return o.age; });\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n *\n * // The `_.property` iteratee shorthand.\n * _.mapValues(users, 'age');\n * // => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)\n */\n function mapValues(object, iteratee) {\n var result = {};\n iteratee = getIteratee(iteratee, 3);\n\n baseForOwn(object, function(value, key, object) {\n baseAssignValue(result, key, iteratee(value, key, object));\n });\n return result;\n }\n\n /**\n * This method is like `_.assign` except that it recursively merges own and\n * inherited enumerable string keyed properties of source objects into the\n * destination object. Source properties that resolve to `undefined` are\n * skipped if a destination value exists. Array and plain object properties\n * are merged recursively. Other objects and value types are overridden by\n * assignment. Source objects are applied from left to right. Subsequent\n * sources overwrite property assignments of previous sources.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 0.5.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {\n * 'a': [{ 'b': 2 }, { 'd': 4 }]\n * };\n *\n * var other = {\n * 'a': [{ 'c': 3 }, { 'e': 5 }]\n * };\n *\n * _.merge(object, other);\n * // => { 'a': [{ 'b': 2, 'c': 3 }, { 'd': 4, 'e': 5 }] }\n */\n var merge = createAssigner(function(object, source, srcIndex) {\n baseMerge(object, source, srcIndex);\n });\n\n /**\n * This method is like `_.merge` except that it accepts `customizer` which\n * is invoked to produce the merged values of the destination and source\n * properties. If `customizer` returns `undefined`, merging is handled by the\n * method instead. The `customizer` is invoked with six arguments:\n * (objValue, srcValue, key, object, source, stack).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The destination object.\n * @param {...Object} sources The source objects.\n * @param {Function} customizer The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * function customizer(objValue, srcValue) {\n * if (_.isArray(objValue)) {\n * return objValue.concat(srcValue);\n * }\n * }\n *\n * var object = { 'a': [1], 'b': [2] };\n * var other = { 'a': [3], 'b': [4] };\n *\n * _.mergeWith(object, other, customizer);\n * // => { 'a': [1, 3], 'b': [2, 4] }\n */\n var mergeWith = createAssigner(function(object, source, srcIndex, customizer) {\n baseMerge(object, source, srcIndex, customizer);\n });\n\n /**\n * The opposite of `_.pick`; this method creates an object composed of the\n * own and inherited enumerable property paths of `object` that are not omitted.\n *\n * **Note:** This method is considerably slower than `_.pick`.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to omit.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.omit(object, ['a', 'c']);\n * // => { 'b': '2' }\n */\n var omit = flatRest(function(object, paths) {\n var result = {};\n if (object == null) {\n return result;\n }\n var isDeep = false;\n paths = arrayMap(paths, function(path) {\n path = castPath(path, object);\n isDeep || (isDeep = path.length > 1);\n return path;\n });\n copyObject(object, getAllKeysIn(object), result);\n if (isDeep) {\n result = baseClone(result, CLONE_DEEP_FLAG | CLONE_FLAT_FLAG | CLONE_SYMBOLS_FLAG, customOmitClone);\n }\n var length = paths.length;\n while (length--) {\n baseUnset(result, paths[length]);\n }\n return result;\n });\n\n /**\n * The opposite of `_.pickBy`; this method creates an object composed of\n * the own and inherited enumerable string keyed properties of `object` that\n * `predicate` doesn't return truthy for. The predicate is invoked with two\n * arguments: (value, key).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The source object.\n * @param {Function} [predicate=_.identity] The function invoked per property.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.omitBy(object, _.isNumber);\n * // => { 'b': '2' }\n */\n function omitBy(object, predicate) {\n return pickBy(object, negate(getIteratee(predicate)));\n }\n\n /**\n * Creates an object composed of the picked `object` properties.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The source object.\n * @param {...(string|string[])} [paths] The property paths to pick.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pick(object, ['a', 'c']);\n * // => { 'a': 1, 'c': 3 }\n */\n var pick = flatRest(function(object, paths) {\n return object == null ? {} : basePick(object, paths);\n });\n\n /**\n * Creates an object composed of the `object` properties `predicate` returns\n * truthy for. The predicate is invoked with two arguments: (value, key).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The source object.\n * @param {Function} [predicate=_.identity] The function invoked per property.\n * @returns {Object} Returns the new object.\n * @example\n *\n * var object = { 'a': 1, 'b': '2', 'c': 3 };\n *\n * _.pickBy(object, _.isNumber);\n * // => { 'a': 1, 'c': 3 }\n */\n function pickBy(object, predicate) {\n if (object == null) {\n return {};\n }\n var props = arrayMap(getAllKeysIn(object), function(prop) {\n return [prop];\n });\n predicate = getIteratee(predicate);\n return basePickBy(object, props, function(value, path) {\n return predicate(value, path[0]);\n });\n }\n\n /**\n * This method is like `_.get` except that if the resolved value is a\n * function it's invoked with the `this` binding of its parent object and\n * its result is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @param {Array|string} path The path of the property to resolve.\n * @param {*} [defaultValue] The value returned for `undefined` resolved values.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c1': 3, 'c2': _.constant(4) } }] };\n *\n * _.result(object, 'a[0].b.c1');\n * // => 3\n *\n * _.result(object, 'a[0].b.c2');\n * // => 4\n *\n * _.result(object, 'a[0].b.c3', 'default');\n * // => 'default'\n *\n * _.result(object, 'a[0].b.c3', _.constant('default'));\n * // => 'default'\n */\n function result(object, path, defaultValue) {\n path = castPath(path, object);\n\n var index = -1,\n length = path.length;\n\n // Ensure the loop is entered when path is empty.\n if (!length) {\n length = 1;\n object = undefined;\n }\n while (++index < length) {\n var value = object == null ? undefined : object[toKey(path[index])];\n if (value === undefined) {\n index = length;\n value = defaultValue;\n }\n object = isFunction(value) ? value.call(object) : value;\n }\n return object;\n }\n\n /**\n * Sets the value at `path` of `object`. If a portion of `path` doesn't exist,\n * it's created. Arrays are created for missing index properties while objects\n * are created for all other missing properties. Use `_.setWith` to customize\n * `path` creation.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.set(object, 'a[0].b.c', 4);\n * console.log(object.a[0].b.c);\n * // => 4\n *\n * _.set(object, ['x', '0', 'y', 'z'], 5);\n * console.log(object.x[0].y.z);\n * // => 5\n */\n function set(object, path, value) {\n return object == null ? object : baseSet(object, path, value);\n }\n\n /**\n * This method is like `_.set` except that it accepts `customizer` which is\n * invoked to produce the objects of `path`. If `customizer` returns `undefined`\n * path creation is handled by the method instead. The `customizer` is invoked\n * with three arguments: (nsValue, key, nsObject).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {};\n *\n * _.setWith(object, '[0][1]', 'a', Object);\n * // => { '0': { '1': 'a' } }\n */\n function setWith(object, path, value, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return object == null ? object : baseSet(object, path, value, customizer);\n }\n\n /**\n * Creates an array of own enumerable string keyed-value pairs for `object`\n * which can be consumed by `_.fromPairs`. If `object` is a map or set, its\n * entries are returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias entries\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the key-value pairs.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.toPairs(new Foo);\n * // => [['a', 1], ['b', 2]] (iteration order is not guaranteed)\n */\n var toPairs = createToPairs(keys);\n\n /**\n * Creates an array of own and inherited enumerable string keyed-value pairs\n * for `object` which can be consumed by `_.fromPairs`. If `object` is a map\n * or set, its entries are returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @alias entriesIn\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the key-value pairs.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.toPairsIn(new Foo);\n * // => [['a', 1], ['b', 2], ['c', 3]] (iteration order is not guaranteed)\n */\n var toPairsIn = createToPairs(keysIn);\n\n /**\n * An alternative to `_.reduce`; this method transforms `object` to a new\n * `accumulator` object which is the result of running each of its own\n * enumerable string keyed properties thru `iteratee`, with each invocation\n * potentially mutating the `accumulator` object. If `accumulator` is not\n * provided, a new object with the same `[[Prototype]]` will be used. The\n * iteratee is invoked with four arguments: (accumulator, value, key, object).\n * Iteratee functions may exit iteration early by explicitly returning `false`.\n *\n * @static\n * @memberOf _\n * @since 1.3.0\n * @category Object\n * @param {Object} object The object to iterate over.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @param {*} [accumulator] The custom accumulator value.\n * @returns {*} Returns the accumulated value.\n * @example\n *\n * _.transform([2, 3, 4], function(result, n) {\n * result.push(n *= n);\n * return n % 2 == 0;\n * }, []);\n * // => [4, 9]\n *\n * _.transform({ 'a': 1, 'b': 2, 'c': 1 }, function(result, value, key) {\n * (result[value] || (result[value] = [])).push(key);\n * }, {});\n * // => { '1': ['a', 'c'], '2': ['b'] }\n */\n function transform(object, iteratee, accumulator) {\n var isArr = isArray(object),\n isArrLike = isArr || isBuffer(object) || isTypedArray(object);\n\n iteratee = getIteratee(iteratee, 4);\n if (accumulator == null) {\n var Ctor = object && object.constructor;\n if (isArrLike) {\n accumulator = isArr ? new Ctor : [];\n }\n else if (isObject(object)) {\n accumulator = isFunction(Ctor) ? baseCreate(getPrototype(object)) : {};\n }\n else {\n accumulator = {};\n }\n }\n (isArrLike ? arrayEach : baseForOwn)(object, function(value, index, object) {\n return iteratee(accumulator, value, index, object);\n });\n return accumulator;\n }\n\n /**\n * Removes the property at `path` of `object`.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to unset.\n * @returns {boolean} Returns `true` if the property is deleted, else `false`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 7 } }] };\n * _.unset(object, 'a[0].b.c');\n * // => true\n *\n * console.log(object);\n * // => { 'a': [{ 'b': {} }] };\n *\n * _.unset(object, ['a', '0', 'b', 'c']);\n * // => true\n *\n * console.log(object);\n * // => { 'a': [{ 'b': {} }] };\n */\n function unset(object, path) {\n return object == null ? true : baseUnset(object, path);\n }\n\n /**\n * This method is like `_.set` except that accepts `updater` to produce the\n * value to set. Use `_.updateWith` to customize `path` creation. The `updater`\n * is invoked with one argument: (value).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {Function} updater The function to produce the updated value.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.update(object, 'a[0].b.c', function(n) { return n * n; });\n * console.log(object.a[0].b.c);\n * // => 9\n *\n * _.update(object, 'x[0].y.z', function(n) { return n ? n + 1 : 0; });\n * console.log(object.x[0].y.z);\n * // => 0\n */\n function update(object, path, updater) {\n return object == null ? object : baseUpdate(object, path, castFunction(updater));\n }\n\n /**\n * This method is like `_.update` except that it accepts `customizer` which is\n * invoked to produce the objects of `path`. If `customizer` returns `undefined`\n * path creation is handled by the method instead. The `customizer` is invoked\n * with three arguments: (nsValue, key, nsObject).\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 4.6.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {Function} updater The function to produce the updated value.\n * @param {Function} [customizer] The function to customize assigned values.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = {};\n *\n * _.updateWith(object, '[0][1]', _.constant('a'), Object);\n * // => { '0': { '1': 'a' } }\n */\n function updateWith(object, path, updater, customizer) {\n customizer = typeof customizer == 'function' ? customizer : undefined;\n return object == null ? object : baseUpdate(object, path, castFunction(updater), customizer);\n }\n\n /**\n * Creates an array of the own enumerable string keyed property values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.values(new Foo);\n * // => [1, 2] (iteration order is not guaranteed)\n *\n * _.values('hi');\n * // => ['h', 'i']\n */\n function values(object) {\n return object == null ? [] : baseValues(object, keys(object));\n }\n\n /**\n * Creates an array of the own and inherited enumerable string keyed property\n * values of `object`.\n *\n * **Note:** Non-object values are coerced to objects.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property values.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.valuesIn(new Foo);\n * // => [1, 2, 3] (iteration order is not guaranteed)\n */\n function valuesIn(object) {\n return object == null ? [] : baseValues(object, keysIn(object));\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Clamps `number` within the inclusive `lower` and `upper` bounds.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Number\n * @param {number} number The number to clamp.\n * @param {number} [lower] The lower bound.\n * @param {number} upper The upper bound.\n * @returns {number} Returns the clamped number.\n * @example\n *\n * _.clamp(-10, -5, 5);\n * // => -5\n *\n * _.clamp(10, -5, 5);\n * // => 5\n */\n function clamp(number, lower, upper) {\n if (upper === undefined) {\n upper = lower;\n lower = undefined;\n }\n if (upper !== undefined) {\n upper = toNumber(upper);\n upper = upper === upper ? upper : 0;\n }\n if (lower !== undefined) {\n lower = toNumber(lower);\n lower = lower === lower ? lower : 0;\n }\n return baseClamp(toNumber(number), lower, upper);\n }\n\n /**\n * Checks if `n` is between `start` and up to, but not including, `end`. If\n * `end` is not specified, it's set to `start` with `start` then set to `0`.\n * If `start` is greater than `end` the params are swapped to support\n * negative ranges.\n *\n * @static\n * @memberOf _\n * @since 3.3.0\n * @category Number\n * @param {number} number The number to check.\n * @param {number} [start=0] The start of the range.\n * @param {number} end The end of the range.\n * @returns {boolean} Returns `true` if `number` is in the range, else `false`.\n * @see _.range, _.rangeRight\n * @example\n *\n * _.inRange(3, 2, 4);\n * // => true\n *\n * _.inRange(4, 8);\n * // => true\n *\n * _.inRange(4, 2);\n * // => false\n *\n * _.inRange(2, 2);\n * // => false\n *\n * _.inRange(1.2, 2);\n * // => true\n *\n * _.inRange(5.2, 4);\n * // => false\n *\n * _.inRange(-3, -2, -6);\n * // => true\n */\n function inRange(number, start, end) {\n start = toFinite(start);\n if (end === undefined) {\n end = start;\n start = 0;\n } else {\n end = toFinite(end);\n }\n number = toNumber(number);\n return baseInRange(number, start, end);\n }\n\n /**\n * Produces a random number between the inclusive `lower` and `upper` bounds.\n * If only one argument is provided a number between `0` and the given number\n * is returned. If `floating` is `true`, or either `lower` or `upper` are\n * floats, a floating-point number is returned instead of an integer.\n *\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\n * floating-point values which can produce unexpected results.\n *\n * @static\n * @memberOf _\n * @since 0.7.0\n * @category Number\n * @param {number} [lower=0] The lower bound.\n * @param {number} [upper=1] The upper bound.\n * @param {boolean} [floating] Specify returning a floating-point number.\n * @returns {number} Returns the random number.\n * @example\n *\n * _.random(0, 5);\n * // => an integer between 0 and 5\n *\n * _.random(5);\n * // => also an integer between 0 and 5\n *\n * _.random(5, true);\n * // => a floating-point number between 0 and 5\n *\n * _.random(1.2, 5.2);\n * // => a floating-point number between 1.2 and 5.2\n */\n function random(lower, upper, floating) {\n if (floating && typeof floating != 'boolean' && isIterateeCall(lower, upper, floating)) {\n upper = floating = undefined;\n }\n if (floating === undefined) {\n if (typeof upper == 'boolean') {\n floating = upper;\n upper = undefined;\n }\n else if (typeof lower == 'boolean') {\n floating = lower;\n lower = undefined;\n }\n }\n if (lower === undefined && upper === undefined) {\n lower = 0;\n upper = 1;\n }\n else {\n lower = toFinite(lower);\n if (upper === undefined) {\n upper = lower;\n lower = 0;\n } else {\n upper = toFinite(upper);\n }\n }\n if (lower > upper) {\n var temp = lower;\n lower = upper;\n upper = temp;\n }\n if (floating || lower % 1 || upper % 1) {\n var rand = nativeRandom();\n return nativeMin(lower + (rand * (upper - lower + freeParseFloat('1e-' + ((rand + '').length - 1)))), upper);\n }\n return baseRandom(lower, upper);\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Converts `string` to [camel case](https://en.wikipedia.org/wiki/CamelCase).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the camel cased string.\n * @example\n *\n * _.camelCase('Foo Bar');\n * // => 'fooBar'\n *\n * _.camelCase('--foo-bar--');\n * // => 'fooBar'\n *\n * _.camelCase('__FOO_BAR__');\n * // => 'fooBar'\n */\n var camelCase = createCompounder(function(result, word, index) {\n word = word.toLowerCase();\n return result + (index ? capitalize(word) : word);\n });\n\n /**\n * Converts the first character of `string` to upper case and the remaining\n * to lower case.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to capitalize.\n * @returns {string} Returns the capitalized string.\n * @example\n *\n * _.capitalize('FRED');\n * // => 'Fred'\n */\n function capitalize(string) {\n return upperFirst(toString(string).toLowerCase());\n }\n\n /**\n * Deburrs `string` by converting\n * [Latin-1 Supplement](https://en.wikipedia.org/wiki/Latin-1_Supplement_(Unicode_block)#Character_table)\n * and [Latin Extended-A](https://en.wikipedia.org/wiki/Latin_Extended-A)\n * letters to basic Latin letters and removing\n * [combining diacritical marks](https://en.wikipedia.org/wiki/Combining_Diacritical_Marks).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to deburr.\n * @returns {string} Returns the deburred string.\n * @example\n *\n * _.deburr('déjà vu');\n * // => 'deja vu'\n */\n function deburr(string) {\n string = toString(string);\n return string && string.replace(reLatin, deburrLetter).replace(reComboMark, '');\n }\n\n /**\n * Checks if `string` ends with the given target string.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {string} [target] The string to search for.\n * @param {number} [position=string.length] The position to search up to.\n * @returns {boolean} Returns `true` if `string` ends with `target`,\n * else `false`.\n * @example\n *\n * _.endsWith('abc', 'c');\n * // => true\n *\n * _.endsWith('abc', 'b');\n * // => false\n *\n * _.endsWith('abc', 'b', 2);\n * // => true\n */\n function endsWith(string, target, position) {\n string = toString(string);\n target = baseToString(target);\n\n var length = string.length;\n position = position === undefined\n ? length\n : baseClamp(toInteger(position), 0, length);\n\n var end = position;\n position -= target.length;\n return position >= 0 && string.slice(position, end) == target;\n }\n\n /**\n * Converts the characters \"&\", \"<\", \">\", '\"', and \"'\" in `string` to their\n * corresponding HTML entities.\n *\n * **Note:** No other characters are escaped. To escape additional\n * characters use a third-party library like [_he_](https://mths.be/he).\n *\n * Though the \">\" character is escaped for symmetry, characters like\n * \">\" and \"/\" don't need escaping in HTML and have no special meaning\n * unless they're part of a tag or unquoted attribute value. See\n * [Mathias Bynens's article](https://mathiasbynens.be/notes/ambiguous-ampersands)\n * (under \"semi-related fun fact\") for more details.\n *\n * When working with HTML you should always\n * [quote attribute values](http://wonko.com/post/html-escaping) to reduce\n * XSS vectors.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category String\n * @param {string} [string=''] The string to escape.\n * @returns {string} Returns the escaped string.\n * @example\n *\n * _.escape('fred, barney, & pebbles');\n * // => 'fred, barney, & pebbles'\n */\n function escape(string) {\n string = toString(string);\n return (string && reHasUnescapedHtml.test(string))\n ? string.replace(reUnescapedHtml, escapeHtmlChar)\n : string;\n }\n\n /**\n * Escapes the `RegExp` special characters \"^\", \"$\", \"\\\", \".\", \"*\", \"+\",\n * \"?\", \"(\", \")\", \"[\", \"]\", \"{\", \"}\", and \"|\" in `string`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to escape.\n * @returns {string} Returns the escaped string.\n * @example\n *\n * _.escapeRegExp('[lodash](https://lodash.com/)');\n * // => '\\[lodash\\]\\(https://lodash\\.com/\\)'\n */\n function escapeRegExp(string) {\n string = toString(string);\n return (string && reHasRegExpChar.test(string))\n ? string.replace(reRegExpChar, '\\\\$&')\n : string;\n }\n\n /**\n * Converts `string` to\n * [kebab case](https://en.wikipedia.org/wiki/Letter_case#Special_case_styles).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the kebab cased string.\n * @example\n *\n * _.kebabCase('Foo Bar');\n * // => 'foo-bar'\n *\n * _.kebabCase('fooBar');\n * // => 'foo-bar'\n *\n * _.kebabCase('__FOO_BAR__');\n * // => 'foo-bar'\n */\n var kebabCase = createCompounder(function(result, word, index) {\n return result + (index ? '-' : '') + word.toLowerCase();\n });\n\n /**\n * Converts `string`, as space separated words, to lower case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the lower cased string.\n * @example\n *\n * _.lowerCase('--Foo-Bar--');\n * // => 'foo bar'\n *\n * _.lowerCase('fooBar');\n * // => 'foo bar'\n *\n * _.lowerCase('__FOO_BAR__');\n * // => 'foo bar'\n */\n var lowerCase = createCompounder(function(result, word, index) {\n return result + (index ? ' ' : '') + word.toLowerCase();\n });\n\n /**\n * Converts the first character of `string` to lower case.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.lowerFirst('Fred');\n * // => 'fred'\n *\n * _.lowerFirst('FRED');\n * // => 'fRED'\n */\n var lowerFirst = createCaseFirst('toLowerCase');\n\n /**\n * Pads `string` on the left and right sides if it's shorter than `length`.\n * Padding characters are truncated if they can't be evenly divided by `length`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.pad('abc', 8);\n * // => ' abc '\n *\n * _.pad('abc', 8, '_-');\n * // => '_-abc_-_'\n *\n * _.pad('abc', 3);\n * // => 'abc'\n */\n function pad(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n if (!length || strLength >= length) {\n return string;\n }\n var mid = (length - strLength) / 2;\n return (\n createPadding(nativeFloor(mid), chars) +\n string +\n createPadding(nativeCeil(mid), chars)\n );\n }\n\n /**\n * Pads `string` on the right side if it's shorter than `length`. Padding\n * characters are truncated if they exceed `length`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.padEnd('abc', 6);\n * // => 'abc '\n *\n * _.padEnd('abc', 6, '_-');\n * // => 'abc_-_'\n *\n * _.padEnd('abc', 3);\n * // => 'abc'\n */\n function padEnd(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n return (length && strLength < length)\n ? (string + createPadding(length - strLength, chars))\n : string;\n }\n\n /**\n * Pads `string` on the left side if it's shorter than `length`. Padding\n * characters are truncated if they exceed `length`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to pad.\n * @param {number} [length=0] The padding length.\n * @param {string} [chars=' '] The string used as padding.\n * @returns {string} Returns the padded string.\n * @example\n *\n * _.padStart('abc', 6);\n * // => ' abc'\n *\n * _.padStart('abc', 6, '_-');\n * // => '_-_abc'\n *\n * _.padStart('abc', 3);\n * // => 'abc'\n */\n function padStart(string, length, chars) {\n string = toString(string);\n length = toInteger(length);\n\n var strLength = length ? stringSize(string) : 0;\n return (length && strLength < length)\n ? (createPadding(length - strLength, chars) + string)\n : string;\n }\n\n /**\n * Converts `string` to an integer of the specified radix. If `radix` is\n * `undefined` or `0`, a `radix` of `10` is used unless `value` is a\n * hexadecimal, in which case a `radix` of `16` is used.\n *\n * **Note:** This method aligns with the\n * [ES5 implementation](https://es5.github.io/#x15.1.2.2) of `parseInt`.\n *\n * @static\n * @memberOf _\n * @since 1.1.0\n * @category String\n * @param {string} string The string to convert.\n * @param {number} [radix=10] The radix to interpret `value` by.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {number} Returns the converted integer.\n * @example\n *\n * _.parseInt('08');\n * // => 8\n *\n * _.map(['6', '08', '10'], _.parseInt);\n * // => [6, 8, 10]\n */\n function parseInt(string, radix, guard) {\n if (guard || radix == null) {\n radix = 0;\n } else if (radix) {\n radix = +radix;\n }\n return nativeParseInt(toString(string).replace(reTrimStart, ''), radix || 0);\n }\n\n /**\n * Repeats the given string `n` times.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to repeat.\n * @param {number} [n=1] The number of times to repeat the string.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {string} Returns the repeated string.\n * @example\n *\n * _.repeat('*', 3);\n * // => '***'\n *\n * _.repeat('abc', 2);\n * // => 'abcabc'\n *\n * _.repeat('abc', 0);\n * // => ''\n */\n function repeat(string, n, guard) {\n if ((guard ? isIterateeCall(string, n, guard) : n === undefined)) {\n n = 1;\n } else {\n n = toInteger(n);\n }\n return baseRepeat(toString(string), n);\n }\n\n /**\n * Replaces matches for `pattern` in `string` with `replacement`.\n *\n * **Note:** This method is based on\n * [`String#replace`](https://mdn.io/String/replace).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to modify.\n * @param {RegExp|string} pattern The pattern to replace.\n * @param {Function|string} replacement The match replacement.\n * @returns {string} Returns the modified string.\n * @example\n *\n * _.replace('Hi Fred', 'Fred', 'Barney');\n * // => 'Hi Barney'\n */\n function replace() {\n var args = arguments,\n string = toString(args[0]);\n\n return args.length < 3 ? string : string.replace(args[1], args[2]);\n }\n\n /**\n * Converts `string` to\n * [snake case](https://en.wikipedia.org/wiki/Snake_case).\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the snake cased string.\n * @example\n *\n * _.snakeCase('Foo Bar');\n * // => 'foo_bar'\n *\n * _.snakeCase('fooBar');\n * // => 'foo_bar'\n *\n * _.snakeCase('--FOO-BAR--');\n * // => 'foo_bar'\n */\n var snakeCase = createCompounder(function(result, word, index) {\n return result + (index ? '_' : '') + word.toLowerCase();\n });\n\n /**\n * Splits `string` by `separator`.\n *\n * **Note:** This method is based on\n * [`String#split`](https://mdn.io/String/split).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to split.\n * @param {RegExp|string} separator The separator pattern to split by.\n * @param {number} [limit] The length to truncate results to.\n * @returns {Array} Returns the string segments.\n * @example\n *\n * _.split('a-b-c', '-', 2);\n * // => ['a', 'b']\n */\n function split(string, separator, limit) {\n if (limit && typeof limit != 'number' && isIterateeCall(string, separator, limit)) {\n separator = limit = undefined;\n }\n limit = limit === undefined ? MAX_ARRAY_LENGTH : limit >>> 0;\n if (!limit) {\n return [];\n }\n string = toString(string);\n if (string && (\n typeof separator == 'string' ||\n (separator != null && !isRegExp(separator))\n )) {\n separator = baseToString(separator);\n if (!separator && hasUnicode(string)) {\n return castSlice(stringToArray(string), 0, limit);\n }\n }\n return string.split(separator, limit);\n }\n\n /**\n * Converts `string` to\n * [start case](https://en.wikipedia.org/wiki/Letter_case#Stylistic_or_specialised_usage).\n *\n * @static\n * @memberOf _\n * @since 3.1.0\n * @category String\n * @param {string} [string=''] The string to convert.\n * @returns {string} Returns the start cased string.\n * @example\n *\n * _.startCase('--foo-bar--');\n * // => 'Foo Bar'\n *\n * _.startCase('fooBar');\n * // => 'Foo Bar'\n *\n * _.startCase('__FOO_BAR__');\n * // => 'FOO BAR'\n */\n var startCase = createCompounder(function(result, word, index) {\n return result + (index ? ' ' : '') + upperFirst(word);\n });\n\n /**\n * Checks if `string` starts with the given target string.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {string} [target] The string to search for.\n * @param {number} [position=0] The position to search from.\n * @returns {boolean} Returns `true` if `string` starts with `target`,\n * else `false`.\n * @example\n *\n * _.startsWith('abc', 'a');\n * // => true\n *\n * _.startsWith('abc', 'b');\n * // => false\n *\n * _.startsWith('abc', 'b', 1);\n * // => true\n */\n function startsWith(string, target, position) {\n string = toString(string);\n position = position == null\n ? 0\n : baseClamp(toInteger(position), 0, string.length);\n\n target = baseToString(target);\n return string.slice(position, position + target.length) == target;\n }\n\n /**\n * Creates a compiled template function that can interpolate data properties\n * in \"interpolate\" delimiters, HTML-escape interpolated data properties in\n * \"escape\" delimiters, and execute JavaScript in \"evaluate\" delimiters. Data\n * properties may be accessed as free variables in the template. If a setting\n * object is given, it takes precedence over `_.templateSettings` values.\n *\n * **Note:** In the development build `_.template` utilizes\n * [sourceURLs](http://www.html5rocks.com/en/tutorials/developertools/sourcemaps/#toc-sourceurl)\n * for easier debugging.\n *\n * For more information on precompiling templates see\n * [lodash's custom builds documentation](https://lodash.com/custom-builds).\n *\n * For more information on Chrome extension sandboxes see\n * [Chrome's extensions documentation](https://developer.chrome.com/extensions/sandboxingEval).\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category String\n * @param {string} [string=''] The template string.\n * @param {Object} [options={}] The options object.\n * @param {RegExp} [options.escape=_.templateSettings.escape]\n * The HTML \"escape\" delimiter.\n * @param {RegExp} [options.evaluate=_.templateSettings.evaluate]\n * The \"evaluate\" delimiter.\n * @param {Object} [options.imports=_.templateSettings.imports]\n * An object to import into the template as free variables.\n * @param {RegExp} [options.interpolate=_.templateSettings.interpolate]\n * The \"interpolate\" delimiter.\n * @param {string} [options.sourceURL='lodash.templateSources[n]']\n * The sourceURL of the compiled template.\n * @param {string} [options.variable='obj']\n * The data object variable name.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Function} Returns the compiled template function.\n * @example\n *\n * // Use the \"interpolate\" delimiter to create a compiled template.\n * var compiled = _.template('hello <%= user %>!');\n * compiled({ 'user': 'fred' });\n * // => 'hello fred!'\n *\n * // Use the HTML \"escape\" delimiter to escape data property values.\n * var compiled = _.template('<%- value %>');\n * compiled({ 'value': '