{"version":3,"file":"static/js/main.a08abbd1.js","mappings":"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","sources":["assets/icons/LeftArrow.tsx","assets/icons/Close.tsx","assets/icons/Eye.tsx","assets/icons/Github.tsx","assets/icons/Linkedin.tsx","assets/icons/Logo.tsx","assets/icons/Message.tsx","assets/icons/RightArrow.tsx","components/BaseContainer.tsx","components/Button.tsx","hooks/useClickOutside.ts","components/LanguageSelector.tsx","../node_modules/hamburger-react/dist-esm/Burger.js","../node_modules/hamburger-react/dist-esm/Turn.js","components/ThemeToggle.tsx","components/Header.tsx","components/Loading.tsx","hooks/useDarkMode.tsx","../node_modules/react-hook-form/src/utils/isCheckBoxInput.ts","../node_modules/react-hook-form/src/utils/isDateObject.ts","../node_modules/react-hook-form/src/utils/isNullOrUndefined.ts","../node_modules/react-hook-form/src/utils/isObject.ts","../node_modules/react-hook-form/src/logic/getEventValue.ts","../node_modules/react-hook-form/src/logic/isNameInFieldArray.ts","../node_modules/react-hook-form/src/logic/getNodeParentName.ts","../node_modules/react-hook-form/src/utils/compact.ts","../node_modules/react-hook-form/src/utils/isUndefined.ts","../node_modules/react-hook-form/src/utils/get.ts","../node_modules/react-hook-form/src/constants.ts","../node_modules/react-hook-form/src/useFormContext.tsx","../node_modules/react-hook-form/src/logic/getProxyFormState.ts","../node_modules/react-hook-form/src/utils/isEmptyObject.ts","../node_modules/react-hook-form/src/logic/shouldRenderFormState.ts","../node_modules/react-hook-form/src/utils/convertToArrayPayload.ts","../node_modules/react-hook-form/src/useSubscribe.ts","../node_modules/react-hook-form/src/utils/isString.ts","../node_modules/react-hook-form/src/logic/generateWatchOutput.ts","../node_modules/react-hook-form/src/utils/isWeb.ts","../node_modules/react-hook-form/src/utils/cloneObject.ts","../node_modules/react-hook-form/src/utils/isPlainObject.ts","../node_modules/react-hook-form/src/logic/appendErrors.ts","../node_modules/react-hook-form/src/utils/isKey.ts","../node_modules/react-hook-form/src/utils/stringToPath.ts","../node_modules/react-hook-form/src/utils/set.ts","../node_modules/react-hook-form/src/logic/focusFieldBy.ts","../node_modules/react-hook-form/src/logic/generateId.ts","../node_modules/react-hook-form/src/logic/getValidationModes.ts","../node_modules/react-hook-form/src/logic/isWatched.ts","../node_modules/react-hook-form/src/logic/updateFieldArrayRootError.ts","../node_modules/react-hook-form/src/utils/isBoolean.ts","../node_modules/react-hook-form/src/utils/isFileInput.ts","../node_modules/react-hook-form/src/utils/isFunction.ts","../node_modules/react-hook-form/src/utils/isHTMLElement.ts","../node_modules/react-hook-form/src/utils/isMessage.ts","../node_modules/react-hook-form/src/utils/isRadioInput.ts","../node_modules/react-hook-form/src/utils/isRegex.ts","../node_modules/react-hook-form/src/logic/getCheckboxValue.ts","../node_modules/react-hook-form/src/logic/getRadioValue.ts","../node_modules/react-hook-form/src/logic/getValidateError.ts","../node_modules/react-hook-form/src/logic/getValueAndMessage.ts","../node_modules/react-hook-form/src/logic/validateField.ts","../node_modules/react-hook-form/src/utils/unset.ts","../node_modules/react-hook-form/src/utils/createSubject.ts","../node_modules/react-hook-form/src/utils/isPrimitive.ts","../node_modules/react-hook-form/src/utils/deepEqual.ts","../node_modules/react-hook-form/src/utils/isMultipleSelect.ts","../node_modules/react-hook-form/src/utils/isRadioOrCheckbox.ts","../node_modules/react-hook-form/src/utils/live.ts","../node_modules/react-hook-form/src/utils/objectHasFunction.ts","../node_modules/react-hook-form/src/logic/getDirtyFields.ts","../node_modules/react-hook-form/src/logic/getFieldValueAs.ts","../node_modules/react-hook-form/src/logic/getFieldValue.ts","../node_modules/react-hook-form/src/logic/getResolverOptions.ts","../node_modules/react-hook-form/src/logic/getRuleValue.ts","../node_modules/react-hook-form/src/logic/hasValidation.ts","../node_modules/react-hook-form/src/logic/schemaErrorLookup.ts","../node_modules/react-hook-form/src/logic/skipValidation.ts","../node_modules/react-hook-form/src/logic/unsetEmptyArray.ts","../node_modules/react-hook-form/src/logic/createFormControl.ts","components/Modal.tsx","hooks/useFormAlarmClock.ts","../node_modules/react-hook-form/src/useForm.ts","hooks/useGlobalModal.tsx","config.ts","libs/index.ts","theme/common.ts","theme/index.ts","../node_modules/@wry/equality/src/equality.ts","../node_modules/resolve-pathname/esm/resolve-pathname.js","../node_modules/value-equal/esm/value-equal.js","../node_modules/history/esm/history.js","../node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../node_modules/isarray/index.js","../node_modules/lodash/lodash.js","../node_modules/object-assign/index.js","../node_modules/path-to-regexp/index.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/index.js","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/react-dom/cjs/react-dom.production.min.js","../node_modules/react-dom/index.js","../node_modules/react-global-modal/dist/react-global-modal.es.js","../node_modules/react-i18next/dist/es/unescape.js","../node_modules/react-i18next/dist/es/context.js","../node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../node_modules/react-i18next/dist/es/utils.js","../node_modules/react-i18next/dist/es/useTranslation.js","../node_modules/react-is/cjs/react-is.production.min.js","../node_modules/react-is/index.js","../node_modules/react-router-dom/modules/BrowserRouter.js","../node_modules/react-router-dom/modules/HashRouter.js","../node_modules/react-router-dom/modules/utils/locationUtils.js","../node_modules/react-router-dom/modules/Link.js","../node_modules/react-router-dom/modules/NavLink.js","../node_modules/mini-create-react-context/dist/esm/index.js","../node_modules/react-router/modules/createNamedContext.js","../node_modules/react-router/modules/HistoryContext.js","../node_modules/react-router/modules/RouterContext.js","../node_modules/react-router/modules/Router.js","../node_modules/react-router/modules/MemoryRouter.js","../node_modules/react-router/modules/Lifecycle.js","../node_modules/react-router/modules/generatePath.js","../node_modules/react-router/modules/Redirect.js","../node_modules/react-router/modules/matchPath.js","../node_modules/react-router/modules/Route.js","../node_modules/react-router/modules/StaticRouter.js","../node_modules/react-router/modules/Switch.js","../node_modules/react-router/modules/hooks.js","../node_modules/react/cjs/react-jsx-runtime.production.min.js","../node_modules/react/cjs/react.production.min.js","../node_modules/react/index.js","../node_modules/react/jsx-runtime.js","../node_modules/scheduler/cjs/scheduler.production.min.js","../node_modules/scheduler/index.js","../node_modules/@emotion/unitless/dist/unitless.browser.esm.js","../node_modules/memoize-one/dist/memoize-one.esm.js","../node_modules/@emotion/is-prop-valid/dist/is-prop-valid.browser.esm.js","../node_modules/@emotion/memoize/dist/memoize.browser.esm.js","../node_modules/is-what/dist/index.esm.js","../node_modules/merge-anything/dist/index.esm.js","../node_modules/styled-components/src/models/StyleTags.js","../node_modules/styled-components/src/models/ThemeProvider.js","../node_modules/styled-components/src/models/GlobalStyle.js","../node_modules/stylis-rule-sheet/index.js","../node_modules/stylis/stylis.js","../node_modules/tiny-invariant/dist/tiny-invariant.esm.js","../node_modules/tslib/tslib.es6.js","../node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../node_modules/@babel/runtime/helpers/esm/classCallCheck.js","../node_modules/@babel/runtime/helpers/esm/createClass.js","../node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/@babel/runtime/helpers/esm/extends.js","../node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","../node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","../node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","../node_modules/@apollo/src/core/networkStatus.ts","../node_modules/@apollo/src/errors/index.ts","../node_modules/@apollo/src/react/context/ApolloContext.ts","../node_modules/@apollo/src/utilities/common/arrays.ts","../node_modules/@apollo/src/utilities/common/canUse.ts","../node_modules/@apollo/src/utilities/common/compact.ts","../node_modules/@apollo/src/utilities/common/maybeDeepFreeze.ts","../node_modules/@apollo/src/utilities/common/mergeOptions.ts","../node_modules/@apollo/src/utilities/common/objects.ts","../node_modules/ts-invariant/src/invariant.ts","../node_modules/@apollo/src/utilities/globals/maybe.ts","../node_modules/@apollo/src/utilities/globals/global.ts","../node_modules/@apollo/src/utilities/globals/DEV.ts","../node_modules/ts-invariant/process/index.js","../node_modules/graphql/polyfills/symbols.mjs","../node_modules/@apollo/src/utilities/globals/fix-graphql.ts","../node_modules/@apollo/src/utilities/globals/index.ts","../node_modules/graphql/jsutils/inspect.mjs","../node_modules/graphql/jsutils/nodejsCustomInspectSymbol.mjs","../webpack/bootstrap","../webpack/runtime/compat get default export","../webpack/runtime/create fake namespace object","../webpack/runtime/define property getters","../webpack/runtime/ensure chunk","../webpack/runtime/get javascript chunk filename","../webpack/runtime/get mini-css chunk filename","../webpack/runtime/global","../webpack/runtime/hasOwnProperty shorthand","../webpack/runtime/load script","../webpack/runtime/make namespace object","../webpack/runtime/node module decorator","../webpack/runtime/publicPath","../webpack/runtime/jsonp chunk loading","../webpack/runtime/nonce","../node_modules/@apollo/src/react/context/ApolloProvider.tsx","../node_modules/graphql/jsutils/defineInspect.mjs","../node_modules/graphql/jsutils/invariant.mjs","../node_modules/graphql/language/ast.mjs","../node_modules/graphql/language/visitor.mjs","../node_modules/zen-observable-ts/module.js","../node_modules/@apollo/src/utilities/graphql/fragments.ts","../node_modules/@apollo/src/utilities/graphql/storeUtils.ts","../node_modules/@apollo/src/utilities/graphql/getFromAST.ts","../node_modules/@apollo/src/link/core/ApolloLink.ts","../node_modules/@apollo/src/link/utils/createOperation.ts","../node_modules/@apollo/src/link/utils/transformOperation.ts","../node_modules/@apollo/src/link/utils/validateOperation.ts","../node_modules/@apollo/src/link/http/serializeFetchParameter.ts","../node_modules/@apollo/src/link/utils/throwServerError.ts","../node_modules/@apollo/src/link/http/parseAndCheckHttpResponse.ts","../node_modules/graphql/language/printer.mjs","../node_modules/graphql/language/blockString.mjs","../node_modules/@apollo/src/link/http/selectHttpOptionsAndBody.ts","../node_modules/@apollo/src/link/utils/fromError.ts","../node_modules/@apollo/src/link/http/createHttpLink.ts","../node_modules/@apollo/src/link/http/checkFetcher.ts","../node_modules/@apollo/src/link/http/selectURI.ts","../node_modules/@apollo/src/link/http/createSignalIfSupported.ts","../node_modules/@apollo/src/link/http/rewriteURIForGET.ts","../node_modules/@apollo/src/link/core/execute.ts","../node_modules/@apollo/src/link/http/HttpLink.ts","../node_modules/@wry/trie/src/trie.ts","../node_modules/@apollo/src/utilities/graphql/directives.ts","../node_modules/@apollo/src/utilities/common/mergeDeep.ts","../node_modules/@apollo/src/cache/inmemory/helpers.ts","../node_modules/@apollo/src/cache/inmemory/object-canon.ts","../node_modules/@apollo/src/utilities/observables/asyncMap.ts","../node_modules/@apollo/src/utilities/common/errorHandling.ts","../node_modules/@apollo/src/utilities/common/filterInPlace.ts","../node_modules/@apollo/src/utilities/graphql/transform.ts","../node_modules/@apollo/src/utilities/common/makeUniqueId.ts","../node_modules/@apollo/src/utilities/observables/iteration.ts","../node_modules/@apollo/src/utilities/observables/subclassing.ts","../node_modules/@apollo/src/utilities/observables/Concast.ts","../node_modules/@apollo/src/utilities/common/cloneDeep.ts","../node_modules/@apollo/src/core/ObservableQuery.ts","../node_modules/@wry/context/src/slot.ts","../node_modules/@wry/context/src/context.ts","../node_modules/optimism/src/cache.ts","../node_modules/optimism/src/context.ts","../node_modules/optimism/src/helpers.ts","../node_modules/optimism/src/entry.ts","../node_modules/optimism/src/dep.ts","../node_modules/optimism/src/index.ts","../node_modules/@apollo/src/cache/inmemory/reactiveVars.ts","../node_modules/@apollo/src/core/LocalState.ts","../node_modules/@apollo/src/core/QueryInfo.ts","../node_modules/@apollo/src/core/QueryManager.ts","../node_modules/@apollo/src/core/ApolloClient.ts","../node_modules/@apollo/src/version.ts","../node_modules/@apollo/src/cache/core/cache.ts","../node_modules/@apollo/src/cache/core/types/common.ts","../node_modules/@apollo/src/cache/inmemory/entityStore.ts","../node_modules/@apollo/src/cache/inmemory/readFromStore.ts","../node_modules/@apollo/src/cache/inmemory/key-extractor.ts","../node_modules/@apollo/src/cache/inmemory/policies.ts","../node_modules/@apollo/src/utilities/common/stringifyForDisplay.ts","../node_modules/@apollo/src/cache/inmemory/writeToStore.ts","../node_modules/@apollo/src/cache/inmemory/inMemoryCache.ts","libs/apolloClient.ts","../node_modules/@apollo/src/link/context/index.ts","providers/NavigationProvider.tsx","routes.tsx","App.tsx","../node_modules/@babel/runtime/helpers/esm/typeof.js","../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/@babel/runtime/helpers/esm/inherits.js","../node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js","../node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js","../node_modules/@babel/runtime/helpers/esm/toArray.js","../node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../node_modules/i18next/dist/esm/i18next.js","../node_modules/i18next-browser-languagedetector/dist/esm/i18nextBrowserLanguageDetector.js","i18n.ts","index.tsx"],"sourcesContent":["import { IconProps } from '@customTypes/Components'\nimport { useContext } from 'react'\nimport { ThemeContext } from 'styled-components'\n\nexport const LeftArrow: React.FC<IconProps> = ({ size }) => {\n const theme = useContext(ThemeContext)\n return <svg width={size} height={size} viewBox=\"0 0 42 42\" fill={theme.colors.icons} xmlns=\"http://www.w3.org/2000/svg\" >\n <path fillRule=\"evenodd\" clipRule=\"evenodd\" d=\"M2.5 20C2.5 24.6413 4.34374 29.0925 7.62563 32.3744C10.9075 35.6563 15.3587 37.5 20 37.5C24.6413 37.5 29.0925 35.6563 32.3744 32.3744C35.6563 29.0925 37.5 24.6413 37.5 20C37.5 15.3587 35.6563 10.9075 32.3744 7.62563C29.0925 4.34374 24.6413 2.5 20 2.5C15.3587 2.5 10.9075 4.34374 7.62563 7.62563C4.34374 10.9075 2.5 15.3587 2.5 20ZM40 20C40 25.3043 37.8929 30.3914 34.1421 34.1421C30.3914 37.8929 25.3043 40 20 40C14.6957 40 9.60859 37.8929 5.85786 34.1421C2.10714 30.3914 0 25.3043 0 20C0 14.6957 2.10714 9.60859 5.85786 5.85786C9.60859 2.10714 14.6957 0 20 0C25.3043 0 30.3914 2.10714 34.1421 5.85786C37.8929 9.60859 40 14.6957 40 20ZM28.75 18.75C29.0815 18.75 29.3995 18.8817 29.6339 19.1161C29.8683 19.3505 30 19.6685 30 20C30 20.3315 29.8683 20.6495 29.6339 20.8839C29.3995 21.1183 29.0815 21.25 28.75 21.25H14.2675L19.635 26.615C19.7512 26.7312 19.8434 26.8692 19.9063 27.021C19.9692 27.1729 20.0016 27.3356 20.0016 27.5C20.0016 27.6644 19.9692 27.8271 19.9063 27.979C19.8434 28.1308 19.7512 28.2688 19.635 28.385C19.5188 28.5012 19.3808 28.5934 19.229 28.6563C19.0771 28.7192 18.9144 28.7516 18.75 28.7516C18.5856 28.7516 18.4229 28.7192 18.271 28.6563C18.1192 28.5934 17.9812 28.5012 17.865 28.385L10.365 20.885C10.2486 20.7689 10.1562 20.6309 10.0932 20.4791C10.0302 20.3272 9.99777 20.1644 9.99777 20C9.99777 19.8356 10.0302 19.6728 10.0932 19.5209C10.1562 19.3691 10.2486 19.2311 10.365 19.115L17.865 11.615C18.0997 11.3803 18.4181 11.2484 18.75 11.2484C19.0819 11.2484 19.4003 11.3803 19.635 11.615C19.8697 11.8497 20.0016 12.1681 20.0016 12.5C20.0016 12.8319 19.8697 13.1503 19.635 13.385L14.2675 18.75H28.75Z\" fill={theme.colors.icons} />\n </svg>\n}\n","import { IconProps } from '@customTypes/Components'\nimport { useContext } from 'react'\nimport { ThemeContext } from 'styled-components'\n\nexport const Close: React.FC<IconProps> = ({ size }) => {\n const theme = useContext(ThemeContext)\n return (<svg width={size} height={size} viewBox=\"0 0 46 46\" fill={theme.colors.icons} xmlns=\"http://www.w3.org/2000/svg\" >\n <path d=\"M32.128 16.6312C32.128 16.425 31.9593 16.2562 31.753 16.2562L28.6593 16.2703L23.9999 21.825L19.3453 16.275L16.2468 16.2609C16.0406 16.2609 15.8718 16.425 15.8718 16.6359C15.8718 16.725 15.9046 16.8094 15.9609 16.8797L22.0593 24.1453L15.9609 31.4063C15.9042 31.475 15.8728 31.561 15.8718 31.65C15.8718 31.8563 16.0406 32.025 16.2468 32.025L19.3453 32.0109L23.9999 26.4563L28.6546 32.0063L31.7483 32.0203C31.9546 32.0203 32.1233 31.8563 32.1233 31.6453C32.1233 31.5563 32.0905 31.4719 32.0343 31.4016L25.9452 24.1406L32.0437 16.875C32.0999 16.8094 32.128 16.7203 32.128 16.6312Z\" fill={theme.colors.icons} />\n <path d=\"M24 3.04688C12.4031 3.04688 3 12.45 3 24.0469C3 35.6437 12.4031 45.0469 24 45.0469C35.5969 45.0469 45 35.6437 45 24.0469C45 12.45 35.5969 3.04688 24 3.04688ZM24 41.4844C14.3719 41.4844 6.5625 33.675 6.5625 24.0469C6.5625 14.4188 14.3719 6.60938 24 6.60938C33.6281 6.60938 41.4375 14.4188 41.4375 24.0469C41.4375 33.675 33.6281 41.4844 24 41.4844Z\" fill={theme.colors.icons} />\n </svg>\n\n )\n}\n\n\n\n\n","import { IconProps } from '@customTypes/Components'\n\nexport const Eye: React.FC<IconProps> = ({ size, fill = 'none' }) => (\n <svg width={size} height={size} viewBox=\"0 0 42 42\" fill={fill} xmlns=\"http://www.w3.org/2000/svg\" >\n <path d=\"M36.821 19.0584C37.6368 20.1256 37.6368 21.5662 36.821 22.6316C34.2513 25.9862 28.0861 32.8932 20.8881 32.8932C13.6902 32.8932 7.52494 25.9862 4.95523 22.6316C4.5583 22.1206 4.34283 21.492 4.34283 20.845C4.34283 20.198 4.5583 19.5694 4.95523 19.0584C7.52494 15.7039 13.6902 8.79681 20.8881 8.79681C28.0861 8.79681 34.2513 15.7039 36.821 19.0584V19.0584Z\" stroke=\"#23708E\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\" />\n <path d=\"M20.8881 26.0086C23.7399 26.0086 26.0516 23.6968 26.0516 20.8451C26.0516 17.9934 23.7399 15.6816 20.8881 15.6816C18.0364 15.6816 15.7246 17.9934 15.7246 20.8451C15.7246 23.6968 18.0364 26.0086 20.8881 26.0086Z\" stroke=\"#23708E\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\" />\n </svg>\n\n)\n\n\n","import { IconProps } from '@customTypes/Components'\n\nexport const Github: React.FC<IconProps> = ({ size, fill }) => (\n <svg\n width={size}\n fill={fill}\n viewBox=\"0 0 24 24\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <g data-name=\"Layer 2\">\n <rect width={size} height={size} transform=\"rotate(180 12 12)\" opacity=\"0\" />\n <path\n d=\"M12 1A10.89 10.89 0 0 0 1 11.77 10.79 10.79 0 0 0 8.52 22c.55.1.75-.23.75-.52v-1.83c-3.06.65-3.71-1.44-3.71-1.44a2.86 2.86 0 0 0-1.22-1.58c-1-.66.08-.65.08-.65a2.31 2.31 0 0 1 1.68 1.11 2.37 2.37 0 0 0 3.2.89 2.33 2.33 0 0 1 .7-1.44c-2.44-.27-5-1.19-5-5.32a4.15 4.15 0 0 1 1.11-2.91 3.78 3.78 0 0 1 .11-2.84s.93-.29 3 1.1a10.68 10.68 0 0 1 5.5 0c2.1-1.39 3-1.1 3-1.1a3.78 3.78 0 0 1 .11 2.84A4.15 4.15 0 0 1 19 11.2c0 4.14-2.58 5.05-5 5.32a2.5 2.5 0 0 1 .75 2v2.95c0 .35.2.63.75.52A10.8 10.8 0 0 0 23 11.77 10.89 10.89 0 0 0 12 1\"\n data-name=\"github\"\n />\n </g>\n </svg>\n)\n","import { IconProps } from '@customTypes/Components'\n\nexport const Linkedin: React.FC<IconProps> = ({ size, fill }) => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 291.319 291.319\"\n width={size}\n height={size}\n fill={fill}\n >\n <defs />\n <path d=\"M145.659 0c80.45 0 145.66 65.219 145.66 145.66s-65.21 145.659-145.66 145.659S0 226.1 0 145.66 65.21 0 145.659 0z\" />\n <path\n fill=\"#fff\"\n d=\"M82.079 200.136h27.275v-90.91H82.079v90.91zm106.259-94.059c-13.237 0-25.081 4.834-33.483 15.504v-12.654H127.48v91.21h27.375v-49.324c0-10.424 9.55-20.593 21.512-20.593s14.912 10.169 14.912 20.338v49.57h27.275v-51.6c-.001-35.842-16.97-42.451-30.216-42.451zm-92.749-5.936c7.538 0 13.656-6.118 13.656-13.656S103.127 72.83 95.589 72.83s-13.656 6.118-13.656 13.656 6.118 13.655 13.656 13.655z\"\n />\n </svg>\n)\n","import { IconProps } from '@customTypes/Components'\n\nexport const Logo: React.FC<IconProps> = ({ size }) => (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 800 800\" width={size} height={size}>\n <defs />\n <defs>\n <clipPath id=\"a\" clipPathUnits=\"userSpaceOnUse\">\n <path d=\"M0 600h600V0H0z\" />\n </clipPath>\n </defs>\n <g transform=\"matrix(1.33333 0 0 -1.33333 0 800)\">\n <path\n fill=\"#2c738b\"\n d=\"M510.5 300c0-116.256-94.244-210.5-210.5-210.5S89.5 183.744 89.5 300 183.744 510.5 300 510.5 510.5 416.256 510.5 300\"\n />\n <path\n fill=\"#fff\"\n d=\"M162.125 410.397h12.886l69.304-110.575h.349v110.575h11.318V284.673h-14.278l-67.912 108.659h-.349v-108.66h-11.318z\"\n />\n <path\n fill=\"none\"\n stroke=\"#fff\"\n strokeMiterlimit=\"10\"\n strokeWidth=\"4.837\"\n d=\"M221.43 140.154l163.14 317.691\"\n />\n <path\n fill=\"#fff\"\n d=\"M343.94 305.764h17.239V195.538h58.509V180.04H343.94z\"\n />\n </g>\n </svg>\n)\n","import { IconProps } from '@customTypes/Components'\n\nexport const Message: React.FC<IconProps> = ({ size, fill }) => (\n <svg\n width={size}\n height={size}\n fill={fill}\n viewBox=\"0 0 1024 1024\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M924.3 338.4a447.57 447.57 0 0 0-96.1-143.3 443.09 443.09 0 0 0-143-96.3A443.91 443.91 0 0 0 512 64h-2c-60.5.3-119 12.3-174.1 35.9a444.08 444.08 0 0 0-141.7 96.5 445 445 0 0 0-95 142.8A449.89 449.89 0 0 0 65 514.1c.3 69.4 16.9 138.3 47.9 199.9v152c0 25.4 20.6 46 45.9 46h151.8a447.72 447.72 0 0 0 199.5 48h2.1c59.8 0 117.7-11.6 172.3-34.3A443.2 443.2 0 0 0 827 830.5c41.2-40.9 73.6-88.7 96.3-142 23.5-55.2 35.5-113.9 35.8-174.5.2-60.9-11.6-120-34.8-175.6zM312.4 560c-26.4 0-47.9-21.5-47.9-48s21.5-48 47.9-48 47.9 21.5 47.9 48-21.4 48-47.9 48zm199.6 0c-26.4 0-47.9-21.5-47.9-48s21.5-48 47.9-48 47.9 21.5 47.9 48-21.5 48-47.9 48zm199.6 0c-26.4 0-47.9-21.5-47.9-48s21.5-48 47.9-48 47.9 21.5 47.9 48-21.5 48-47.9 48z\" />\n </svg>\n)\n\n","import { IconProps } from '@customTypes/Components'\nimport { useContext } from 'react'\nimport { ThemeContext } from 'styled-components'\n\nexport const RightArrow: React.FC<IconProps> = ({ size }) => {\n const theme = useContext(ThemeContext)\n return (\n <svg width={size} height={size} viewBox=\"0 0 42 42\" fill={theme.colors.icons} xmlns=\"http://www.w3.org/2000/svg\" >\n <g clipPath=\"url(#clip0_19_275)\">\n <path fillRule=\"evenodd\" clipRule=\"evenodd\" d=\"M37.5 20C37.5 15.3587 35.6563 10.9075 32.3744 7.62563C29.0925 4.34375 24.6413 2.5 20 2.5C15.3587 2.5 10.9075 4.34374 7.62564 7.62563C4.34375 10.9075 2.5 15.3587 2.5 20C2.5 24.6413 4.34375 29.0925 7.62563 32.3744C10.9075 35.6563 15.3587 37.5 20 37.5C24.6413 37.5 29.0925 35.6563 32.3744 32.3744C35.6563 29.0925 37.5 24.6413 37.5 20ZM1.74846e-06 20C2.21217e-06 14.6957 2.10714 9.60859 5.85787 5.85786C9.60859 2.10713 14.6957 -2.21217e-06 20 -1.74846e-06C25.3043 -1.28474e-06 30.3914 2.10713 34.1421 5.85786C37.8929 9.60859 40 14.6957 40 20C40 25.3043 37.8929 30.3914 34.1421 34.1421C30.3914 37.8929 25.3043 40 20 40C14.6957 40 9.60859 37.8929 5.85786 34.1421C2.10714 30.3914 1.28474e-06 25.3043 1.74846e-06 20ZM11.25 21.25C10.9185 21.25 10.6005 21.1183 10.3661 20.8839C10.1317 20.6495 10 20.3315 10 20C10 19.6685 10.1317 19.3505 10.3661 19.1161C10.6005 18.8817 10.9185 18.75 11.25 18.75L25.7325 18.75L20.365 13.385C20.2488 13.2688 20.1566 13.1308 20.0937 12.979C20.0308 12.8271 19.9984 12.6644 19.9984 12.5C19.9984 12.3356 20.0308 12.1729 20.0937 12.021C20.1566 11.8692 20.2488 11.7312 20.365 11.615C20.4812 11.4988 20.6192 11.4066 20.771 11.3437C20.9229 11.2808 21.0856 11.2484 21.25 11.2484C21.4144 11.2484 21.5771 11.2808 21.729 11.3437C21.8808 11.4066 22.0188 11.4988 22.135 11.615L29.635 19.115C29.7514 19.2311 29.8438 19.3691 29.9068 19.5209C29.9698 19.6728 30.0022 19.8356 30.0022 20C30.0022 20.1644 29.9698 20.3272 29.9068 20.4791C29.8438 20.6309 29.7514 20.7689 29.635 20.885L22.135 28.385C21.9003 28.6197 21.5819 28.7516 21.25 28.7516C20.9181 28.7516 20.5997 28.6197 20.365 28.385C20.1303 28.1503 19.9984 27.8319 19.9984 27.5C19.9984 27.1681 20.1303 26.8497 20.365 26.615L25.7325 21.25L11.25 21.25Z\" fill={theme.colors.icons} />\n </g>\n <defs>\n <clipPath id=\"clip0_19_275\">\n <rect width=\"40\" height=\"40\" fill={theme.colors.icons} transform=\"translate(40 40) rotate(-180)\" />\n </clipPath>\n </defs>\n </svg>\n )\n}\n\n\n\n","import { PAGE_PADDING_REM } from '@theme/index'\nimport styled from 'styled-components'\nimport { clampValues, phone, pxToRem } from '../libs'\n\nconst BaseContainerStyled = styled.div`\n height: 100%;\n width: 100%;\n max-width:${pxToRem(2100)};\n max-height:${pxToRem(1800)};\n margin: 0 auto;\n border: 3px solid ${({ theme }) => theme.colors.pageBorder};\n padding: ${clampValues(15, parseInt(PAGE_PADDING_REM) / 2)} ${clampValues(20, parseInt(PAGE_PADDING_REM))};\n`\n\nexport const BaseContainer: React.FC = ({ children }) => {\n return <BaseContainerStyled>{children}</BaseContainerStyled>\n}\n\ninterface FlexContainerProps {\n align?: 'center' | 'flex-start' | 'flex-end';\n}\n\nconst FlexContainerStyled = styled.div<FlexContainerProps>`\n display: flex;\n flex-direction: column;\n height: calc(100% - ${pxToRem(115)}); //115px height of the header\n justify-content: ${(props) => props.align};\n ${phone(`\n overflow: auto;\n padding-right: ${pxToRem(8)};\n justify-content: flex-start;\n `)}\n`\n\nexport const FlexContainer: React.FC<FlexContainerProps> = ({\n children,\n align = 'center',\n}) => <FlexContainerStyled align={align}>{children}</FlexContainerStyled>\n","import { Link, LinkProps } from 'react-router-dom'\nimport styled from 'styled-components'\nimport { clampValues, phone, pxToRem } from '../libs'\n\nconst StyledButton = styled.button`\n background: ${({ theme }) => theme.colors.primary};\n color: ${({ theme }) => theme.colors.buttonText};\n border: none;\n padding: ${pxToRem(24)} ${pxToRem(24)};\n font-size: ${clampValues(18, 24)};\n border-radius: ${pxToRem(16)};\n cursor: pointer;\n width: fit-content;\n ${phone(`\n width: 100%;\n `)}\n`\n\nexport const CustomButton: React.FC = ({ children }) => {\n return <StyledButton>{children}</StyledButton>\n}\n\nconst StyledLink = styled(Link)`\n color: ${({ theme }) => theme.colors.primary};\n padding: ${pxToRem(24)} ${pxToRem(24)};\n font-size: ${clampValues(18, 24)};\n border-radius: ${pxToRem(16)};\n border: 1px solid ${({ theme }) => theme.colors.primary};\n cursor: pointer;\n width: fit-content;\n text-decoration: underline;\n ${phone(`\n width: 100%;\n justify-content: center;\n `)}\n`\n\nexport const CustomLink: React.FC<LinkProps> = ({ children, ...props }) => {\n return <StyledLink {...props}>{children}</StyledLink>\n}\n","import { useEffect } from 'react'\n\nexport const useClickOutside = (\n ref: React.RefObject<HTMLElement>,\n cb: () => void,\n addListener = true\n) => {\n useEffect(() => {\n const handleAwayClick = (event: MouseEvent | TouchEvent) => {\n if (ref.current && !ref.current.contains(event.target as Element | null)) {\n cb()\n }\n }\n addListener && document.addEventListener('mousedown', handleAwayClick)\n addListener && document.addEventListener('touchstart', handleAwayClick)\n return () => {\n document.removeEventListener('mousedown', handleAwayClick)\n document.removeEventListener('touchstart', handleAwayClick)\n }\n }, [addListener, cb, ref])\n}\n","import { useRef } from 'react'\nimport styled from 'styled-components'\nimport { useClickOutside } from '../hooks/useClickOutside'\nimport { pxToRem } from '../libs'\n\ninterface LanguageSelectorProps {\n isVisible: boolean;\n setLanguageDropdownState: (state: boolean) => void;\n}\n\nconst LanguageSelectorDropdown = styled.div`\n position: absolute;\n min-height: ${pxToRem(50)};\n background: ${({ theme }) => theme.colors.projectCardBackground};\n -webkit-box-shadow: 0 4px 6px 0 rgba(0, 0, 0, 0.35);\n box-shadow: 0 4px 6px 0 rgba(0, 0, 0, 0.35);\n padding: ${pxToRem(16)};\n border-radius: ${pxToRem(8)};\n top: 100%;\n right: ${pxToRem(-26)};\n transform: translateX(-50%);\n min-width: ${pxToRem(150)};\n z-index: 2;\n\n &:after {\n content: \"\";\n position: absolute;\n display: block;\n width: 0;\n z-index: 1;\n border-style: solid;\n border-color: ${({ theme }) => theme.colors.projectCardBackground}\n transparent;\n border-width: 0 ${pxToRem(20)} ${pxToRem(20)};\n top: ${pxToRem(-12)};\n left: 50%;\n margin-left: ${pxToRem(-20)};\n }\n\n ul {\n list-style: none;\n margin: 0;\n padding-left: 0;\n text-align: left;\n width: 100%;\n li {\n line-height: ${pxToRem(40)};\n width: 100%;\n cursor: pointer;\n margin-bottom: ${pxToRem(8)};\n &:hover {\n color: ${({ theme }) => theme.colors.primary};\n }\n &.active {\n color: ${({ theme }) => theme.colors.primary};\n text-decoration: underline;\n }\n }\n }\n`\n\nexport const LanguageSelector: React.FC<LanguageSelectorProps> = ({\n isVisible = false,\n setLanguageDropdownState,\n}) => {\n const innerRef = useRef<HTMLDivElement | null>(null)\n // const { t } = useTranslation()\n // const { setLang } = useLanguage()\n useClickOutside(innerRef, () => setLanguageDropdownState(false))\n return isVisible ? (\n <LanguageSelectorDropdown ref={innerRef}>\n <ul>\n {/* <li\n onClick={() => setLang('en')}\n className={i18next.language === 'en' ? 'active' : ''}\n >\n {t('language.english')}\n </li>\n <li\n onClick={() => setLang('it')}\n className={i18next.language === 'it' ? 'active' : ''}\n > */}\n {/* {t('language.italian')}\n </li> */}\n </ul>\n </LanguageSelectorDropdown>\n ) : null\n}\n","import { useState } from 'react';\nconst area = 48;\nexport const Burger = ({\n color = 'currentColor',\n direction = 'left',\n distance = 'md',\n duration = 0.4,\n easing = 'cubic-bezier(0, 0, 0, 1)',\n hideOutline = true,\n label,\n lines = 3,\n onToggle,\n render,\n rounded = false,\n size = 32,\n toggle,\n toggled\n}) => {\n const [toggledInternal, toggleInternal] = useState(false);\n const width = Math.max(12, Math.min(area, size));\n const room = Math.round((area - width) / 2);\n const barHeightRaw = width / 12;\n const barHeight = Math.round(barHeightRaw);\n const space = distance === 'lg' ? 0.25 : distance === 'sm' ? 0.75 : 0.5;\n const marginRaw = width / (lines * (space + (lines === 3 ? 1 : 1.25)));\n const margin = Math.round(marginRaw);\n const height = barHeight * lines + margin * (lines - 1);\n const topOffset = Math.round((area - height) / 2);\n const translate = lines === 3 ? distance === 'lg' ? 4.0425 : distance === 'sm' ? 5.1625 : 4.6325 : distance === 'lg' ? 6.7875 : distance === 'sm' ? 8.4875 : 7.6675;\n const deviation = (barHeightRaw - barHeight + (marginRaw - margin)) / (lines === 3 ? 1 : 2);\n const move = parseFloat((width / translate - deviation / (4 / 3)).toFixed(2));\n const time = Math.max(0, duration);\n const burgerStyles = {\n cursor: 'pointer',\n height: `${area}px`,\n position: 'relative',\n transition: `${time}s ${easing}`,\n userSelect: 'none',\n width: `${area}px`\n };\n const barStyles = {\n background: color,\n height: `${barHeight}px`,\n left: `${room}px`,\n position: 'absolute'\n };\n\n if (hideOutline) {\n burgerStyles['outline'] = 'none';\n }\n\n if (rounded) {\n barStyles['borderRadius'] = '9em';\n }\n\n const toggleFunction = toggle || toggleInternal;\n const isToggled = toggled !== undefined ? toggled : toggledInternal;\n\n const handler = () => {\n toggleFunction(!isToggled);\n if (typeof onToggle === 'function') onToggle(!isToggled);\n };\n\n return render({\n barHeight,\n barStyles,\n burgerStyles,\n easing,\n handler,\n isLeft: direction === 'left',\n isToggled,\n label,\n margin,\n move,\n time,\n topOffset,\n width\n });\n};","function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nimport { Burger } from './Burger';\nimport React from 'react';\nexport const Turn = props => /*#__PURE__*/React.createElement(Burger, _extends({}, props, {\n render: o => /*#__PURE__*/React.createElement(\"div\", {\n className: \"hamburger-react\",\n \"aria-label\": o.label,\n \"aria-expanded\": o.isToggled,\n onClick: o.handler,\n onKeyUp: e => e.key === 'Enter' && o.handler(),\n role: \"button\",\n style: o.burgerStyles,\n tabIndex: 0\n }, /*#__PURE__*/React.createElement(\"div\", {\n style: { ...o.barStyles,\n width: `${o.width}px`,\n top: `${o.topOffset}px`,\n transition: `${o.time}s ${o.easing}`,\n transform: `${o.isToggled ? `rotate(${45 * (o.isLeft ? -1 : 1)}deg) translate(${o.move * (o.isLeft ? -1 : 1)}px, ${o.move}px)` : 'none'}`\n }\n }), /*#__PURE__*/React.createElement(\"div\", {\n style: { ...o.barStyles,\n width: `${o.width}px`,\n top: `${o.topOffset + o.barHeight + o.margin}px`,\n transition: `${o.time / 2}s ${o.easing}`,\n transform: `${o.isToggled ? 'scaleX(0)' : 'none'}`\n }\n }), /*#__PURE__*/React.createElement(\"div\", {\n style: { ...o.barStyles,\n width: `${o.width}px`,\n top: `${o.topOffset + o.barHeight * 2 + o.margin * 2}px`,\n transition: `${o.time}s ${o.easing}`,\n transform: `${o.isToggled ? `rotate(${45 * (o.isLeft ? 1 : -1)}deg) translate(${o.move * (o.isLeft ? -1 : 1)}px, ${o.move * -1}px)` : 'none'}`\n }\n }))\n}));","import { useDarkMode } from '@hooks/useDarkMode'\nimport React, { useEffect, useState } from 'react'\nimport styled from 'styled-components'\n\nconst ThemeSwtich = styled('div')`\n display: inline-block;\n position: relative;\n`\n\nconst ThemeSwitchLabel = styled('label')`\n cursor: pointer;\n display: inline-block;\n position: relative;\n width: 90px;\n height: 50px;\n background-color: #83d8ff;\n border-radius: 84px;\n transition: background-color 200ms cubic-bezier(0.445, 0.05, 0.55, 0.95);\n margin: 0;\n padding: 0;\n`\n\nconst ThemeSwitchHandle = styled('span')`\n display: inline-block;\n position: relative;\n z-index: 1;\n top: 3px;\n left: 3px;\n width: 44px;\n height: 44px;\n background-color: #ffcf96;\n border-radius: 50px;\n box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);\n transition: all 400ms cubic-bezier(0.68, -0.55, 0.265, 1.55);\n transform: rotate(-45deg);\n`\n\nconst Crater = styled('span')`\n position: absolute;\n background-color: #e8cda5;\n opacity: 0;\n transition: opacity 200ms ease-in-out;\n border-radius: 100%;\n &.crater-0 {\n top: 18px;\n left: 10px;\n width: 4px;\n height: 4px;\n }\n &.crater-1 {\n top: 28px;\n left: 22px;\n width: 6px;\n height: 6px;\n }\n &.crater-2 {\n top: 18px;\n left: 25px;\n width: 8px;\n height: 8px;\n }\n`\n\nconst StarCloud = styled('span')`\n position: absolute;\n background-color: #ffffff;\n transition: all 300ms cubic-bezier(0.445, 0.05, 0.55, 0.95);\n border-radius: 50%;\n &.star-0 {\n top: 10px;\n left: 35px;\n z-index: 0;\n width: 30px;\n height: 3px;\n }\n &.star-1 {\n top: 18px;\n left: 28px;\n z-index: 1;\n width: 30px;\n height: 3px;\n }\n &.star-2 {\n top: 27px;\n left: 40px;\n z-index: 0;\n width: 30px;\n height: 3px;\n }\n &.star-3,\n &.star-4,\n &.star-5 {\n opacity: 0;\n transition: all 300ms 0 cubic-bezier(0.445, 0.05, 0.55, 0.95);\n }\n &.star-3 {\n top: 16px;\n left: 11px;\n z-index: 0;\n width: 2px;\n height: 2px;\n transform: translate3d(3px, 0, 0);\n }\n &.star-4 {\n top: 32px;\n left: 17px;\n z-index: 0;\n width: 3px;\n height: 3px;\n transform: translate3d(3px, 0, 0);\n }\n &.star-5 {\n top: 36px;\n left: 28px;\n z-index: 0;\n width: 2px;\n height: 2px;\n transform: translate3d(3px, 0, 0);\n }\n`\n\nconst ThemeSwitchInput = styled('input')`\n position: absolute;\n cursor: pointer;\n width: 100%;\n height: 100%;\n z-index: 9;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n &:focus {\n border: none;\n outline: none;\n }\n &:checked {\n + ${ThemeSwitchLabel} {\n background-color: #749dd6;\n &:before {\n color: #749ed7;\n }\n &:after {\n color: #ffffff;\n }\n ${ThemeSwitchHandle} {\n background-color: #ffe5b5;\n transform: translate3d(40px, 0, 0) rotate(0);\n ${Crater} {\n opacity: 1;\n }\n }\n ${StarCloud} {\n &.star-0 {\n width: 2px;\n height: 2px;\n }\n &.star-1 {\n width: 4px;\n height: 4px;\n transform: translate3d(-5px, 0, 0);\n }\n &.star-2 {\n width: 2px;\n height: 2px;\n transform: translate3d(-7px, 0, 0);\n }\n &.star-3,\n &.star-4,\n &.star-5 {\n opacity: 1;\n transform: translate3d(0, 0, 0);\n }\n &.star-3 {\n transition: all 300ms 200ms cubic-bezier(0.445, 0.05, 0.55, 0.95);\n }\n &.star-4 {\n transition: all 300ms 300ms cubic-bezier(0.445, 0.05, 0.55, 0.95);\n }\n &.star-5 {\n transition: all 300ms 400ms cubic-bezier(0.445, 0.05, 0.55, 0.95);\n }\n }\n }\n }\n`\n\ninterface ReactLightsOffProps {\n lightsOff?: boolean;\n onChange: (e: React.ChangeEvent<HTMLInputElement>) => void;\n}\n\nexport const ThemeToggle: React.FC<ReactLightsOffProps> = ({\n onChange,\n}) => {\n const { theme } = useDarkMode()\n const [darkMode, setDarkMode] = useState<boolean>(theme === 'dark')\n\n useEffect(() => setDarkMode(theme === 'dark'), [theme])\n\n const handleChange = (evt: React.ChangeEvent<HTMLInputElement>) => {\n setDarkMode(evt.target.checked)\n onChange && onChange(evt)\n }\n\n return (\n <ThemeSwtich>\n <ThemeSwitchInput\n type=\"checkbox\"\n checked={darkMode}\n name=\"react-theme-switcher\"\n onChange={(evt) => handleChange(evt)}\n />\n <ThemeSwitchLabel htmlFor=\"react-theme-switcher\">\n <ThemeSwitchHandle>\n {Array.from({ length: 3 }, (_, index) => (\n <Crater key={index} className={`crater-${index}`}></Crater>\n ))}\n </ThemeSwitchHandle>\n {Array.from({ length: 6 }, (_, index) => (\n <StarCloud key={index} className={`star-${index}`}></StarCloud>\n ))}\n </ThemeSwitchLabel>\n </ThemeSwtich>\n )\n}\n","import { useContext, useRef, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\n// import { ReactLightsOff } from 'react-lights-off'\nimport { GithubIcon, LinkedinIcon, LogoIcon, MessageIcon } from '@assets/icons'\nimport { LanguageSelector } from '@components/LanguageSelector'\nimport { useClickOutside } from '@hooks/useClickOutside'\nimport { useGlobalModal } from '@hooks/useGlobalModal'\nimport { phone, pxToRem, tablet } from '@libs/index'\nimport { Turn as HamburgerIcon } from 'hamburger-react'\nimport { Link, NavLink } from 'react-router-dom'\nimport styled, { ThemeContext } from 'styled-components'\nimport { ThemeToggle } from './ThemeToggle'\n\ninterface HeaderProps {\n toggleTheme: (isDark: boolean) => void\n}\n\nconst HeaderContainer = styled.div`\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n height: ${pxToRem(115)};\n position: relative;\n z-index: 1;\n`\n\nconst Navigation = styled.div`\n display: flex;\n flex-direction: row;\n height: 100%;\n align-items: center;\n ${tablet(` \n width: 100%;\n justify-content: flex-end;\n `)}\n`\nconst MenuContainer = styled.div`\n border-right: 3px solid ${({ theme }) => theme.colors.primary};\n padding-right: ${pxToRem(17)};\n text-transform: uppercase;\n height: 100%;\n max-height: 70px;\n align-items: center;\n display: flex;\n ${tablet(` \n display: none;\n `)}\n`\nconst SocialContainer = styled.div`\n border-right: 3px solid ${({ theme }) => theme.colors.primary};\n padding: 0 ${pxToRem(19)};\n height: 100%;\n max-height: 70px;\n align-items: center;\n display: flex;\n ${tablet(` \n display: none;\n `)}\n\n svg {\n fill: ${({ theme }) => theme.colors.primary};\n margin: 0 ${pxToRem(10)};\n cursor: pointer;\n ${tablet('margin: unset')}\n }\n\n a {\n height: inherit;\n display: flex;\n align-items: center;\n ${tablet(\n `\n &:first-of-type{\n margin: 0 ${pxToRem(10)} 0 0;\n }\n &:last-of-type{\n margin: 0 0 0 ${pxToRem(10)};\n }\n `\n)}\n &:last-child {\n margin-right: 0%;\n }\n }\n`\n\nconst SocialContainerMobile = styled.div`\n ${({ theme }) =>\n tablet(`\n display: flex;\n border-right: 0;\n border-top: 2px solid ${theme.colors.primary};\n margin: ${pxToRem(20)} 0 0;\n justify-content: space-around;\n align-items: flex-start;\n max-height: unset;\n height: 80px;\n padding: unset;\n `)}\n svg {\n fill: ${({ theme }) => theme.colors.primary};\n margin: 0 ${pxToRem(10)};\n cursor: pointer;\n ${tablet('margin: unset')}\n }\n\n a {\n height: inherit;\n display: flex;\n align-items: center;\n ${tablet(\n `\n &:first-of-type{\n margin: 0 ${pxToRem(10)} 0 0;\n }\n &:last-of-type{\n margin: 0 0 0 ${pxToRem(10)};\n }\n `\n )}\n &:last-child {\n margin-right: 0%;\n }\n }\n`\n\nconst UtilsContainer = styled.div`\n padding-left: ${pxToRem(27)};\n height: 100%;\n max-height: 70px;\n align-items: center;\n display: flex;\n position: relative;\n\n /* > div {\n height: initial;\n display: flex;\n } */\n\n svg {\n fill: ${({ theme }) => theme.colors.primary};\n /* padding: 0 ${pxToRem(16)} 0 ${pxToRem(8)}; */\n margin-right: ${pxToRem(16)};\n margin-left: ${pxToRem(-8)};\n cursor: pointer;\n }\n`\n\nexport const HamburgerWrapper = styled.span`\n display: none;\n ${tablet(` \n display: flex;\n margin-left: ${pxToRem(16)};\n `)}\n`\n\nexport const StyledNavLink = styled(NavLink)`\n color: ${({ theme }) => theme.colors.text};\n text-decoration: none;\n padding: ${pxToRem(18)};\n height: 100%;\n display: flex;\n align-items: center;\n ${phone(`\n font-size: ${pxToRem(18)}; \n `)}\n\n &.active {\n color: ${({ theme }) => theme.colors.primary};\n text-decoration: underline;\n }\n\n &:hover {\n color: ${({ theme }) => theme.colors.primary};\n }\n`\n\nconst MobileNavigation = styled.div`\n display: none;\n position: relative;\n isolation: isolate;\n ${tablet(`\n display: flex;\n gap: ${pxToRem(16)}\n `)}\n`\n\nconst MobileMenuDropdown = styled.div`\n position: absolute;\n background: ${({ theme }) => theme.colors.projectCardBackground};\n -webkit-box-shadow: 0 4px 6px 0 rgba(0, 0, 0, 0.35);\n box-shadow: 0 4px 6px 0 rgba(0, 0, 0, 0.35);\n padding: ${pxToRem(16)};\n border-radius: ${pxToRem(8)};\n top: ${pxToRem(50)};\n right: 0;\n min-width: ${pxToRem(250)};\n z-index: 2;\n text-transform: uppercase;\n\n &:after {\n content: '';\n position: absolute;\n display: block;\n width: 0;\n z-index: 9;\n border-style: solid;\n border-color: ${({ theme }) => theme.colors.projectCardBackground} transparent;\n border-width: 0 ${pxToRem(20)} ${pxToRem(20)};\n top: ${pxToRem(-12)};\n right: ${pxToRem(2)};\n margin-left: ${pxToRem(-20)};\n }\n`\n\nconst ThemeToggleWrapper = styled.div`\n ${phone(`\n display: none;\n `)}\n`\n\nconst LogoLink = styled(Link)`\n margin-left: ${pxToRem(-16)};\n`\n\nexport const Header: React.FC<HeaderProps> = ({ toggleTheme }) => {\n const { t } = useTranslation()\n const { open } = useGlobalModal()\n const mobileMenuref = useRef(null)\n const theme = useContext(ThemeContext)\n const [mobileMenu, setMobileMenu] = useState(false)\n const [showLanguageList, setShowLanguageList] = useState<boolean>(false)\n const handleThemeSwitcher = (isDark: boolean) => {\n toggleTheme && toggleTheme(isDark)\n }\n\n useClickOutside(mobileMenuref, () => setMobileMenu(false))\n\n return (\n <HeaderContainer>\n <LogoLink to=\"/home\">\n <LogoIcon size={114} />\n </LogoLink>\n <Navigation>\n <MenuContainer>\n <StyledNavLink to=\"/home\">{t('navigation.home')}</StyledNavLink>\n <StyledNavLink to=\"/projects/all\">{t('navigation.projects')}</StyledNavLink>\n <StyledNavLink to=\"/about\">{t('navigation.about')}</StyledNavLink>\n </MenuContainer>\n <SocialContainer>\n <a onClick={() => open()}>\n <MessageIcon size={40} />\n </a>\n <a href=\"https://github.com/nickimola\" target=\"_blank\" rel=\"noreferrer\">\n <GithubIcon size={40} />\n </a>\n <a href=\"https://www.linkedin.com/in/nicholaslazzerini/\" target=\"_blank\" rel=\"noreferrer\">\n <LinkedinIcon size={40} />\n </a>\n {/* <a\n href=\"https://www.linkedin.com/in/nicholaslazzerini/\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n <CoffeeIcon size={40} />\n </a> */}\n </SocialContainer>\n <UtilsContainer>\n {/* <div onClick={() => setShowLanguageList(!showLanguageList)}>\n <LanguageSelectorIcon size={40} />\n </div> */}\n <ThemeToggleWrapper>\n <ThemeToggle\n onChange={(evt: React.ChangeEvent<HTMLInputElement>) => {\n handleThemeSwitcher(evt.currentTarget.checked)\n }}\n />\n </ThemeToggleWrapper>\n\n <LanguageSelector\n isVisible={showLanguageList}\n setLanguageDropdownState={setShowLanguageList}\n />\n <HamburgerWrapper>\n <HamburgerIcon\n size={40}\n direction=\"left\"\n color={theme.colors.text}\n toggled={mobileMenu}\n rounded\n hideOutline\n onToggle={toggled => setMobileMenu(toggled)}\n />\n </HamburgerWrapper>\n </UtilsContainer>\n </Navigation>\n <MobileNavigation>\n {mobileMenu && (\n <MobileMenuDropdown ref={mobileMenuref}>\n <StyledNavLink to=\"/home\" onClick={() => setMobileMenu(false)}>\n {t('navigation.home')}\n </StyledNavLink>\n <StyledNavLink onClick={() => setMobileMenu(false)} to=\"/projects/all\">\n {t('navigation.projects')}\n </StyledNavLink>\n <StyledNavLink onClick={() => setMobileMenu(false)} to=\"/about\">\n {t('navigation.about')}\n </StyledNavLink>\n <SocialContainerMobile>\n <a onClick={() => {\n setMobileMenu(false)\n open()\n }}>\n <MessageIcon size={40} />\n </a>\n <a href=\"https://github.com/nickimola\" target=\"_blank\" rel=\"noreferrer\">\n <GithubIcon size={40} />\n </a>\n <a\n href=\"https://www.linkedin.com/in/nicholaslazzerini/\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n <LinkedinIcon size={40} />\n </a>\n {/* <a\n href=\"https://www.linkedin.com/in/nicholaslazzerini/\"\n target=\"_blank\"\n rel=\"noreferrer\"\n >\n <CoffeeIcon size={40} />\n </a> */}\n </SocialContainerMobile>\n </MobileMenuDropdown>\n )}\n </MobileNavigation>\n </HeaderContainer>\n )\n}\n","\nimport styled, { keyframes } from 'styled-components'\n\nconst Animation = keyframes`\n\t0% {\n top: 36px;\n left: 36px;\n width: 0;\n height: 0;\n opacity: 0;\n }\n 4.9% {\n top: 36px;\n left: 36px;\n width: 0;\n height: 0;\n opacity: 0;\n }\n 5% {\n top: 36px;\n left: 36px;\n width: 0;\n height: 0;\n opacity: 1;\n }\n 100% {\n top: 0px;\n left: 0px;\n width: 72px;\n height: 72px;\n opacity: 0;\n }\n`\n\nconst LoaderContainer = styled.div`\n\tposition: fixed;\n\tbackground: ${({ theme }) => theme.colors.body};\n\tpointer-events: none;\n\toverflow: hidden;\n\ttop: 0;\n\tleft:0;\n\theight: 100%;\n\twidth: 100%;\n\tz-index: 1000;\n\tdisplay: flex;\n\talign-items: center;\n\tjustify-content: center;\n`\n\nconst LoaderSpinner = styled.div`\n display: inline-block;\n position: relative;\n width: 80px;\n height: 80px;\n`\n\nconst First = styled.div`\n\tposition: absolute;\n\tborder: ${({ theme }) => `4px solid ${theme.colors.primary}`};\n\topacity: 1;\n\tborder-radius: 50%;\n\tanimation: ${Animation} 1s cubic-bezier(0, 0.2, 0.8, 1) infinite;\n`\n\nconst Second = styled.div`\n\tposition: absolute;\n\tborder: ${({ theme }) => `4px solid ${theme.colors.primary}`};\n\topacity: 1;\n\tborder-radius: 50%;\n\tanimation: ${Animation} 1s cubic-bezier(0, 0.2, 0.8, 1) infinite;\n \tanimation-delay: -0.5s;\n`\n\nexport const Loading = () => (\n <LoaderContainer>\n <LoaderSpinner>\n <First></First>\n <Second></Second>\n </LoaderSpinner>\n </LoaderContainer>\n)","import { useEffect, useState } from 'react'\nexport const useDarkMode = () => {\n const [theme, setTheme] = useState<string>('light')\n\n const setMode = (mode: string) => {\n window.localStorage.setItem('nicholaslazzerini.com/theme', mode)\n setTheme(mode)\n }\n\n useEffect(() => {\n const userTheme =\n window.matchMedia &&\n window.matchMedia('(prefers-color-scheme: dark)').matches\n ? 'dark'\n : 'light'\n const localTheme = window.localStorage.getItem(\n 'nicholaslazzerini.com/theme'\n )\n setTheme(localTheme || userTheme || 'light')\n }, [])\n\n return { theme, setMode }\n}\n","import { FieldElement } from '../types';\n\nexport default (element: FieldElement): element is HTMLInputElement =>\n element.type === 'checkbox';\n","export default (value: unknown): value is Date => value instanceof Date;\n","export default (value: unknown): value is null | undefined => value == null;\n","import isDateObject from './isDateObject';\nimport isNullOrUndefined from './isNullOrUndefined';\n\nexport const isObjectType = (value: unknown) => typeof value === 'object';\n\nexport default <T extends object>(value: unknown): value is T =>\n !isNullOrUndefined(value) &&\n !Array.isArray(value) &&\n isObjectType(value) &&\n !isDateObject(value);\n","import isCheckBoxInput from '../utils/isCheckBoxInput';\nimport isObject from '../utils/isObject';\n\ntype Event = { target: any };\n\nexport default (event: unknown) =>\n isObject(event) && (event as Event).target\n ? isCheckBoxInput((event as Event).target)\n ? (event as Event).target.checked\n : (event as Event).target.value\n : event;\n","import { InternalFieldName } from '../types';\n\nimport getNodeParentName from './getNodeParentName';\n\nexport default (names: Set<InternalFieldName>, name: InternalFieldName) =>\n names.has(getNodeParentName(name));\n","export default (name: string) =>\n name.substring(0, name.search(/\\.\\d+(\\.|$)/)) || name;\n","export default <TValue>(value: TValue[]) =>\n Array.isArray(value) ? value.filter(Boolean) : [];\n","export default (val: unknown): val is undefined => val === undefined;\n","import compact from './compact';\nimport isNullOrUndefined from './isNullOrUndefined';\nimport isObject from './isObject';\nimport isUndefined from './isUndefined';\n\nexport default <T>(obj: T, path: string, defaultValue?: unknown): any => {\n if (!path || !isObject(obj)) {\n return defaultValue;\n }\n\n const result = compact(path.split(/[,[\\].]+?/)).reduce(\n (result, key) =>\n isNullOrUndefined(result) ? result : result[key as keyof {}],\n obj,\n );\n\n return isUndefined(result) || result === obj\n ? isUndefined(obj[path as keyof T])\n ? defaultValue\n : obj[path as keyof T]\n : result;\n};\n","import { ValidationMode } from './types';\n\nexport const EVENTS = {\n BLUR: 'blur',\n FOCUS_OUT: 'focusout',\n CHANGE: 'change',\n};\n\nexport const VALIDATION_MODE: ValidationMode = {\n onBlur: 'onBlur',\n onChange: 'onChange',\n onSubmit: 'onSubmit',\n onTouched: 'onTouched',\n all: 'all',\n};\n\nexport const INPUT_VALIDATION_RULES = {\n max: 'max',\n min: 'min',\n maxLength: 'maxLength',\n minLength: 'minLength',\n pattern: 'pattern',\n required: 'required',\n validate: 'validate',\n};\n","import React from 'react';\n\nimport { FieldValues, FormProviderProps, UseFormReturn } from './types';\n\nconst HookFormContext = React.createContext<UseFormReturn | null>(null);\n\n/**\n * This custom hook allows you to access the form context. useFormContext is intended to be used in deeply nested structures, where it would become inconvenient to pass the context as a prop. To be used with {@link FormProvider}.\n *\n * @remarks\n * [API](https://react-hook-form.com/api/useformcontext) • [Demo](https://codesandbox.io/s/react-hook-form-v7-form-context-ytudi)\n *\n * @returns return all useForm methods\n *\n * @example\n * ```tsx\n * function App() {\n * const methods = useForm();\n * const onSubmit = data => console.log(data);\n *\n * return (\n * <FormProvider {...methods} >\n * <form onSubmit={methods.handleSubmit(onSubmit)}>\n * <NestedInput />\n * <input type=\"submit\" />\n * </form>\n * </FormProvider>\n * );\n * }\n *\n * function NestedInput() {\n * const { register } = useFormContext(); // retrieve all hook methods\n * return <input {...register(\"test\")} />;\n * }\n * ```\n */\nexport const useFormContext = <\n TFieldValues extends FieldValues,\n>(): UseFormReturn<TFieldValues> =>\n React.useContext(HookFormContext) as unknown as UseFormReturn<TFieldValues>;\n\n/**\n * A provider component that propagates the `useForm` methods to all children components via [React Context](https://reactjs.org/docs/context.html) API. To be used with {@link useFormContext}.\n *\n * @remarks\n * [API](https://react-hook-form.com/api/useformcontext) • [Demo](https://codesandbox.io/s/react-hook-form-v7-form-context-ytudi)\n *\n * @param props - all useFrom methods\n *\n * @example\n * ```tsx\n * function App() {\n * const methods = useForm();\n * const onSubmit = data => console.log(data);\n *\n * return (\n * <FormProvider {...methods} >\n * <form onSubmit={methods.handleSubmit(onSubmit)}>\n * <NestedInput />\n * <input type=\"submit\" />\n * </form>\n * </FormProvider>\n * );\n * }\n *\n * function NestedInput() {\n * const { register } = useFormContext(); // retrieve all hook methods\n * return <input {...register(\"test\")} />;\n * }\n * ```\n */\nexport const FormProvider = <TFieldValues extends FieldValues, TContext = any>(\n props: FormProviderProps<TFieldValues, TContext>,\n) => {\n const { children, ...data } = props;\n return (\n <HookFormContext.Provider value={data as unknown as UseFormReturn}>\n {children}\n </HookFormContext.Provider>\n );\n};\n","import { VALIDATION_MODE } from '../constants';\nimport { Control, FieldValues, FormState, ReadFormState } from '../types';\n\nexport default <TFieldValues extends FieldValues, TContext = any>(\n formState: FormState<TFieldValues>,\n control: Control<TFieldValues, TContext>,\n localProxyFormState?: ReadFormState,\n isRoot = true,\n) => {\n const result = {\n defaultValues: control._defaultValues,\n } as typeof formState;\n\n for (const key in formState) {\n Object.defineProperty(result, key, {\n get: () => {\n const _key = key as keyof FormState<TFieldValues> & keyof ReadFormState;\n\n if (control._proxyFormState[_key] !== VALIDATION_MODE.all) {\n control._proxyFormState[_key] = !isRoot || VALIDATION_MODE.all;\n }\n\n localProxyFormState && (localProxyFormState[_key] = true);\n return formState[_key];\n },\n });\n }\n\n return result;\n};\n","import { EmptyObject } from '../types';\n\nimport isObject from './isObject';\n\nexport default (value: unknown): value is EmptyObject =>\n isObject(value) && !Object.keys(value).length;\n","import { VALIDATION_MODE } from '../constants';\nimport { ReadFormState } from '../types';\nimport isEmptyObject from '../utils/isEmptyObject';\n\nexport default <T extends Record<string, any>, K extends ReadFormState>(\n formStateData: T,\n _proxyFormState: K,\n isRoot?: boolean,\n) => {\n const { name, ...formState } = formStateData;\n\n return (\n isEmptyObject(formState) ||\n Object.keys(formState).length >= Object.keys(_proxyFormState).length ||\n Object.keys(formState).find(\n (key) =>\n _proxyFormState[key as keyof ReadFormState] ===\n (!isRoot || VALIDATION_MODE.all),\n )\n );\n};\n","export default <T>(value: T) => (Array.isArray(value) ? value : [value]);\n","import React from 'react';\n\nimport { Subject } from './utils/createSubject';\n\ntype Props<T> = {\n disabled?: boolean;\n subject: Subject<T>;\n next: (value: T) => void;\n};\n\nexport function useSubscribe<T>(props: Props<T>) {\n const _props = React.useRef(props);\n _props.current = props;\n\n React.useEffect(() => {\n const subscription =\n !props.disabled &&\n _props.current.subject.subscribe({\n next: _props.current.next,\n });\n\n return () => {\n subscription && subscription.unsubscribe();\n };\n }, [props.disabled]);\n}\n","export default (value: unknown): value is string => typeof value === 'string';\n","import { DeepPartial, FieldValues, Names } from '../types';\nimport get from '../utils/get';\nimport isString from '../utils/isString';\n\nexport default <T>(\n names: string | string[] | undefined,\n _names: Names,\n formValues?: FieldValues,\n isGlobal?: boolean,\n defaultValue?: DeepPartial<T> | unknown,\n) => {\n if (isString(names)) {\n isGlobal && _names.watch.add(names);\n return get(formValues, names, defaultValue);\n }\n\n if (Array.isArray(names)) {\n return names.map(\n (fieldName) => (\n isGlobal && _names.watch.add(fieldName), get(formValues, fieldName)\n ),\n );\n }\n\n isGlobal && (_names.watchAll = true);\n\n return formValues;\n};\n","export default typeof window !== 'undefined' &&\n typeof window.HTMLElement !== 'undefined' &&\n typeof document !== 'undefined';\n","import isObject from './isObject';\nimport isPlainObject from './isPlainObject';\nimport isWeb from './isWeb';\n\nexport default function cloneObject<T>(data: T): T {\n let copy: any;\n const isArray = Array.isArray(data);\n\n if (data instanceof Date) {\n copy = new Date(data);\n } else if (data instanceof Set) {\n copy = new Set(data);\n } else if (\n !(isWeb && (data instanceof Blob || data instanceof FileList)) &&\n (isArray || isObject(data))\n ) {\n copy = isArray ? [] : {};\n\n if (!Array.isArray(data) && !isPlainObject(data)) {\n copy = data;\n } else {\n for (const key in data) {\n copy[key] = cloneObject(data[key]);\n }\n }\n } else {\n return data;\n }\n\n return copy;\n}\n","import isObject from './isObject';\n\nexport default (tempObject: object) => {\n const prototypeCopy =\n tempObject.constructor && tempObject.constructor.prototype;\n\n return (\n isObject(prototypeCopy) && prototypeCopy.hasOwnProperty('isPrototypeOf')\n );\n};\n","import {\n InternalFieldErrors,\n InternalFieldName,\n ValidateResult,\n} from '../types';\n\nexport default (\n name: InternalFieldName,\n validateAllFieldCriteria: boolean,\n errors: InternalFieldErrors,\n type: string,\n message: ValidateResult,\n) =>\n validateAllFieldCriteria\n ? {\n ...errors[name],\n types: {\n ...(errors[name] && errors[name]!.types ? errors[name]!.types : {}),\n [type]: message || true,\n },\n }\n : {};\n","export default (value: string) => /^\\w*$/.test(value);\n","import compact from './compact';\n\nexport default (input: string): string[] =>\n compact(input.replace(/[\"|']|\\]/g, '').split(/\\.|\\[/));\n","import { FieldValues } from '../types';\n\nimport isKey from './isKey';\nimport isObject from './isObject';\nimport stringToPath from './stringToPath';\n\nexport default function set(\n object: FieldValues,\n path: string,\n value?: unknown,\n) {\n let index = -1;\n const tempPath = isKey(path) ? [path] : stringToPath(path);\n const length = tempPath.length;\n const lastIndex = length - 1;\n\n while (++index < length) {\n const key = tempPath[index];\n let newValue = value;\n\n if (index !== lastIndex) {\n const objValue = object[key];\n newValue =\n isObject(objValue) || Array.isArray(objValue)\n ? objValue\n : !isNaN(+tempPath[index + 1])\n ? []\n : {};\n }\n object[key] = newValue;\n object = object[key];\n }\n return object;\n}\n","import { FieldRefs, InternalFieldName } from '../types';\nimport { get } from '../utils';\nimport isObject from '../utils/isObject';\n\nconst focusFieldBy = (\n fields: FieldRefs,\n callback: (name?: string) => boolean,\n fieldsNames?: Set<InternalFieldName> | InternalFieldName[],\n) => {\n for (const key of fieldsNames || Object.keys(fields)) {\n const field = get(fields, key);\n\n if (field) {\n const { _f, ...currentField } = field;\n\n if (_f && callback(_f.name)) {\n if (_f.ref.focus) {\n _f.ref.focus();\n break;\n } else if (_f.refs && _f.refs[0].focus) {\n _f.refs[0].focus();\n break;\n }\n } else if (isObject(currentField)) {\n focusFieldBy(currentField, callback);\n }\n }\n }\n};\n\nexport default focusFieldBy;\n","export default () => {\n const d =\n typeof performance === 'undefined' ? Date.now() : performance.now() * 1000;\n\n return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {\n const r = (Math.random() * 16 + d) % 16 | 0;\n\n return (c == 'x' ? r : (r & 0x3) | 0x8).toString(16);\n });\n};\n","import { VALIDATION_MODE } from '../constants';\nimport { Mode } from '../types';\n\nexport default (\n mode?: Mode,\n): {\n isOnSubmit: boolean;\n isOnBlur: boolean;\n isOnChange: boolean;\n isOnAll: boolean;\n isOnTouch: boolean;\n} => ({\n isOnSubmit: !mode || mode === VALIDATION_MODE.onSubmit,\n isOnBlur: mode === VALIDATION_MODE.onBlur,\n isOnChange: mode === VALIDATION_MODE.onChange,\n isOnAll: mode === VALIDATION_MODE.all,\n isOnTouch: mode === VALIDATION_MODE.onTouched,\n});\n","import { InternalFieldName, Names } from '../types';\n\nexport default (\n name: InternalFieldName,\n _names: Names,\n isBlurEvent?: boolean,\n) =>\n !isBlurEvent &&\n (_names.watchAll ||\n _names.watch.has(name) ||\n [..._names.watch].some(\n (watchName) =>\n name.startsWith(watchName) &&\n /^\\.\\w+/.test(name.slice(watchName.length)),\n ));\n","import {\n FieldError,\n FieldErrors,\n FieldValues,\n InternalFieldName,\n} from '../types';\nimport compact from '../utils/compact';\nimport get from '../utils/get';\nimport set from '../utils/set';\n\nexport default <T extends FieldValues = FieldValues>(\n errors: FieldErrors<T>,\n error: Partial<Record<string, FieldError>>,\n name: InternalFieldName,\n): FieldErrors<T> => {\n const fieldArrayErrors = compact(get(errors, name));\n set(fieldArrayErrors, 'root', error[name]);\n set(errors, name, fieldArrayErrors);\n return errors;\n};\n","export default (value: unknown): value is boolean => typeof value === 'boolean';\n","import { FieldElement } from '../types';\n\nexport default (element: FieldElement): element is HTMLInputElement =>\n element.type === 'file';\n","export default (value: unknown): value is Function =>\n typeof value === 'function';\n","import isWeb from './isWeb';\n\nexport default (value: unknown): value is HTMLElement => {\n if (!isWeb) {\n return false;\n }\n\n const owner = value ? ((value as HTMLElement).ownerDocument as Document) : 0;\n return (\n value instanceof\n (owner && owner.defaultView ? owner.defaultView.HTMLElement : HTMLElement)\n );\n};\n","import React from 'react';\n\nimport { Message } from '../types';\nimport isString from '../utils/isString';\n\nexport default (value: unknown): value is Message =>\n isString(value) || React.isValidElement(value as JSX.Element);\n","import { FieldElement } from '../types';\n\nexport default (element: FieldElement): element is HTMLInputElement =>\n element.type === 'radio';\n","export default (value: unknown): value is RegExp => value instanceof RegExp;\n","import isUndefined from '../utils/isUndefined';\n\ntype CheckboxFieldResult = {\n isValid: boolean;\n value: string | string[] | boolean | undefined;\n};\n\nconst defaultResult: CheckboxFieldResult = {\n value: false,\n isValid: false,\n};\n\nconst validResult = { value: true, isValid: true };\n\nexport default (options?: HTMLInputElement[]): CheckboxFieldResult => {\n if (Array.isArray(options)) {\n if (options.length > 1) {\n const values = options\n .filter((option) => option && option.checked && !option.disabled)\n .map((option) => option.value);\n return { value: values, isValid: !!values.length };\n }\n\n return options[0].checked && !options[0].disabled\n ? // @ts-expect-error expected to work in the browser\n options[0].attributes && !isUndefined(options[0].attributes.value)\n ? isUndefined(options[0].value) || options[0].value === ''\n ? validResult\n : { value: options[0].value, isValid: true }\n : validResult\n : defaultResult;\n }\n\n return defaultResult;\n};\n","type RadioFieldResult = {\n isValid: boolean;\n value: number | string | null;\n};\n\nconst defaultReturn: RadioFieldResult = {\n isValid: false,\n value: null,\n};\n\nexport default (options?: HTMLInputElement[]): RadioFieldResult =>\n Array.isArray(options)\n ? options.reduce(\n (previous, option): RadioFieldResult =>\n option && option.checked && !option.disabled\n ? {\n isValid: true,\n value: option.value,\n }\n : previous,\n defaultReturn,\n )\n : defaultReturn;\n","import { FieldError, Ref, ValidateResult } from '../types';\nimport isBoolean from '../utils/isBoolean';\nimport isMessage from '../utils/isMessage';\n\nexport default function getValidateError(\n result: ValidateResult,\n ref: Ref,\n type = 'validate',\n): FieldError | void {\n if (\n isMessage(result) ||\n (Array.isArray(result) && result.every(isMessage)) ||\n (isBoolean(result) && !result)\n ) {\n return {\n type,\n message: isMessage(result) ? result : '',\n ref,\n };\n }\n}\n","import { ValidationRule } from '../types';\nimport isObject from '../utils/isObject';\nimport isRegex from '../utils/isRegex';\n\nexport default (validationData?: ValidationRule) =>\n isObject(validationData) && !isRegex(validationData)\n ? validationData\n : {\n value: validationData,\n message: '',\n };\n","import { INPUT_VALIDATION_RULES } from '../constants';\nimport {\n Field,\n FieldError,\n InternalFieldErrors,\n Message,\n NativeFieldValue,\n} from '../types';\nimport isBoolean from '../utils/isBoolean';\nimport isCheckBoxInput from '../utils/isCheckBoxInput';\nimport isEmptyObject from '../utils/isEmptyObject';\nimport isFileInput from '../utils/isFileInput';\nimport isFunction from '../utils/isFunction';\nimport isHTMLElement from '../utils/isHTMLElement';\nimport isMessage from '../utils/isMessage';\nimport isNullOrUndefined from '../utils/isNullOrUndefined';\nimport isObject from '../utils/isObject';\nimport isRadioInput from '../utils/isRadioInput';\nimport isRegex from '../utils/isRegex';\nimport isString from '../utils/isString';\nimport isUndefined from '../utils/isUndefined';\n\nimport appendErrors from './appendErrors';\nimport getCheckboxValue from './getCheckboxValue';\nimport getRadioValue from './getRadioValue';\nimport getValidateError from './getValidateError';\nimport getValueAndMessage from './getValueAndMessage';\n\nexport default async <T extends NativeFieldValue>(\n field: Field,\n inputValue: T,\n validateAllFieldCriteria: boolean,\n shouldUseNativeValidation?: boolean,\n isFieldArray?: boolean,\n): Promise<InternalFieldErrors> => {\n const {\n ref,\n refs,\n required,\n maxLength,\n minLength,\n min,\n max,\n pattern,\n validate,\n name,\n valueAsNumber,\n mount,\n disabled,\n } = field._f;\n if (!mount || disabled) {\n return {};\n }\n const inputRef: HTMLInputElement = refs ? refs[0] : (ref as HTMLInputElement);\n const setCustomValidity = (message?: string | boolean) => {\n if (shouldUseNativeValidation && inputRef.reportValidity) {\n inputRef.setCustomValidity(isBoolean(message) ? '' : message || '');\n inputRef.reportValidity();\n }\n };\n const error: InternalFieldErrors = {};\n const isRadio = isRadioInput(ref);\n const isCheckBox = isCheckBoxInput(ref);\n const isRadioOrCheckbox = isRadio || isCheckBox;\n const isEmpty =\n ((valueAsNumber || isFileInput(ref)) &&\n isUndefined(ref.value) &&\n isUndefined(inputValue)) ||\n (isHTMLElement(ref) && ref.value === '') ||\n inputValue === '' ||\n (Array.isArray(inputValue) && !inputValue.length);\n const appendErrorsCurry = appendErrors.bind(\n null,\n name,\n validateAllFieldCriteria,\n error,\n );\n const getMinMaxMessage = (\n exceedMax: boolean,\n maxLengthMessage: Message,\n minLengthMessage: Message,\n maxType = INPUT_VALIDATION_RULES.maxLength,\n minType = INPUT_VALIDATION_RULES.minLength,\n ) => {\n const message = exceedMax ? maxLengthMessage : minLengthMessage;\n error[name] = {\n type: exceedMax ? maxType : minType,\n message,\n ref,\n ...appendErrorsCurry(exceedMax ? maxType : minType, message),\n };\n };\n\n if (\n isFieldArray\n ? !Array.isArray(inputValue) || !inputValue.length\n : required &&\n ((!isRadioOrCheckbox && (isEmpty || isNullOrUndefined(inputValue))) ||\n (isBoolean(inputValue) && !inputValue) ||\n (isCheckBox && !getCheckboxValue(refs).isValid) ||\n (isRadio && !getRadioValue(refs).isValid))\n ) {\n const { value, message } = isMessage(required)\n ? { value: !!required, message: required }\n : getValueAndMessage(required);\n\n if (value) {\n error[name] = {\n type: INPUT_VALIDATION_RULES.required,\n message,\n ref: inputRef,\n ...appendErrorsCurry(INPUT_VALIDATION_RULES.required, message),\n };\n if (!validateAllFieldCriteria) {\n setCustomValidity(message);\n return error;\n }\n }\n }\n\n if (!isEmpty && (!isNullOrUndefined(min) || !isNullOrUndefined(max))) {\n let exceedMax;\n let exceedMin;\n const maxOutput = getValueAndMessage(max);\n const minOutput = getValueAndMessage(min);\n\n if (!isNullOrUndefined(inputValue) && !isNaN(inputValue as number)) {\n const valueNumber =\n (ref as HTMLInputElement).valueAsNumber ||\n (inputValue ? +inputValue : inputValue);\n if (!isNullOrUndefined(maxOutput.value)) {\n exceedMax = valueNumber > maxOutput.value;\n }\n if (!isNullOrUndefined(minOutput.value)) {\n exceedMin = valueNumber < minOutput.value;\n }\n } else {\n const valueDate =\n (ref as HTMLInputElement).valueAsDate || new Date(inputValue as string);\n const convertTimeToDate = (time: unknown) =>\n new Date(new Date().toDateString() + ' ' + time);\n const isTime = ref.type == 'time';\n const isWeek = ref.type == 'week';\n\n if (isString(maxOutput.value) && inputValue) {\n exceedMax = isTime\n ? convertTimeToDate(inputValue) > convertTimeToDate(maxOutput.value)\n : isWeek\n ? inputValue > maxOutput.value\n : valueDate > new Date(maxOutput.value);\n }\n\n if (isString(minOutput.value) && inputValue) {\n exceedMin = isTime\n ? convertTimeToDate(inputValue) < convertTimeToDate(minOutput.value)\n : isWeek\n ? inputValue < minOutput.value\n : valueDate < new Date(minOutput.value);\n }\n }\n\n if (exceedMax || exceedMin) {\n getMinMaxMessage(\n !!exceedMax,\n maxOutput.message,\n minOutput.message,\n INPUT_VALIDATION_RULES.max,\n INPUT_VALIDATION_RULES.min,\n );\n if (!validateAllFieldCriteria) {\n setCustomValidity(error[name]!.message);\n return error;\n }\n }\n }\n\n if (\n (maxLength || minLength) &&\n !isEmpty &&\n (isString(inputValue) || (isFieldArray && Array.isArray(inputValue)))\n ) {\n const maxLengthOutput = getValueAndMessage(maxLength);\n const minLengthOutput = getValueAndMessage(minLength);\n const exceedMax =\n !isNullOrUndefined(maxLengthOutput.value) &&\n inputValue.length > maxLengthOutput.value;\n const exceedMin =\n !isNullOrUndefined(minLengthOutput.value) &&\n inputValue.length < minLengthOutput.value;\n\n if (exceedMax || exceedMin) {\n getMinMaxMessage(\n exceedMax,\n maxLengthOutput.message,\n minLengthOutput.message,\n );\n if (!validateAllFieldCriteria) {\n setCustomValidity(error[name]!.message);\n return error;\n }\n }\n }\n\n if (pattern && !isEmpty && isString(inputValue)) {\n const { value: patternValue, message } = getValueAndMessage(pattern);\n\n if (isRegex(patternValue) && !inputValue.match(patternValue)) {\n error[name] = {\n type: INPUT_VALIDATION_RULES.pattern,\n message,\n ref,\n ...appendErrorsCurry(INPUT_VALIDATION_RULES.pattern, message),\n };\n if (!validateAllFieldCriteria) {\n setCustomValidity(message);\n return error;\n }\n }\n }\n\n if (validate) {\n if (isFunction(validate)) {\n const result = await validate(inputValue);\n const validateError = getValidateError(result, inputRef);\n\n if (validateError) {\n error[name] = {\n ...validateError,\n ...appendErrorsCurry(\n INPUT_VALIDATION_RULES.validate,\n validateError.message,\n ),\n };\n if (!validateAllFieldCriteria) {\n setCustomValidity(validateError.message);\n return error;\n }\n }\n } else if (isObject(validate)) {\n let validationResult = {} as FieldError;\n\n for (const key in validate) {\n if (!isEmptyObject(validationResult) && !validateAllFieldCriteria) {\n break;\n }\n\n const validateError = getValidateError(\n await validate[key](inputValue),\n inputRef,\n key,\n );\n\n if (validateError) {\n validationResult = {\n ...validateError,\n ...appendErrorsCurry(key, validateError.message),\n };\n\n setCustomValidity(validateError.message);\n\n if (validateAllFieldCriteria) {\n error[name] = validationResult;\n }\n }\n }\n\n if (!isEmptyObject(validationResult)) {\n error[name] = {\n ref: inputRef,\n ...validationResult,\n };\n if (!validateAllFieldCriteria) {\n return error;\n }\n }\n }\n }\n\n setCustomValidity(true);\n return error;\n};\n","import isEmptyObject from './isEmptyObject';\nimport isKey from './isKey';\nimport isObject from './isObject';\nimport isUndefined from './isUndefined';\nimport stringToPath from './stringToPath';\n\nfunction baseGet(object: any, updatePath: (string | number)[]) {\n const length = updatePath.slice(0, -1).length;\n let index = 0;\n\n while (index < length) {\n object = isUndefined(object) ? index++ : object[updatePath[index++]];\n }\n\n return object;\n}\n\nfunction isEmptyArray(obj: unknown[]) {\n for (const key in obj) {\n if (!isUndefined(obj[key])) {\n return false;\n }\n }\n return true;\n}\n\nexport default function unset(object: any, path: string) {\n const updatePath = isKey(path) ? [path] : stringToPath(path);\n const childObject =\n updatePath.length == 1 ? object : baseGet(object, updatePath);\n const key = updatePath[updatePath.length - 1];\n let previousObjRef;\n\n if (childObject) {\n delete childObject[key];\n }\n\n for (let k = 0; k < updatePath.slice(0, -1).length; k++) {\n let index = -1;\n let objectRef;\n const currentPaths = updatePath.slice(0, -(k + 1));\n const currentPathsLength = currentPaths.length - 1;\n\n if (k > 0) {\n previousObjRef = object;\n }\n\n while (++index < currentPaths.length) {\n const item = currentPaths[index];\n objectRef = objectRef ? objectRef[item] : object[item];\n\n if (\n currentPathsLength === index &&\n ((isObject(objectRef) && isEmptyObject(objectRef)) ||\n (Array.isArray(objectRef) && isEmptyArray(objectRef)))\n ) {\n previousObjRef ? delete previousObjRef[item] : delete object[item];\n }\n\n previousObjRef = objectRef;\n }\n }\n\n return object;\n}\n","import { Noop } from '../types';\n\nexport type Observer<T> = {\n next: (value: T) => void;\n};\n\nexport type Subscription = {\n unsubscribe: Noop;\n};\n\nexport type Subject<T> = {\n readonly observers: Observer<T>[];\n subscribe: (value: Observer<T>) => Subscription;\n unsubscribe: Noop;\n} & Observer<T>;\n\nexport default function createSubject<T>(): Subject<T> {\n let _observers: Observer<T>[] = [];\n\n const next = (value: T) => {\n for (const observer of _observers) {\n observer.next(value);\n }\n };\n\n const subscribe = (observer: Observer<T>): Subscription => {\n _observers.push(observer);\n return {\n unsubscribe: () => {\n _observers = _observers.filter((o) => o !== observer);\n },\n };\n };\n\n const unsubscribe = () => {\n _observers = [];\n };\n\n return {\n get observers() {\n return _observers;\n },\n next,\n subscribe,\n unsubscribe,\n };\n}\n","import { Primitive } from '../types';\n\nimport isNullOrUndefined from './isNullOrUndefined';\nimport { isObjectType } from './isObject';\n\nexport default (value: unknown): value is Primitive =>\n isNullOrUndefined(value) || !isObjectType(value);\n","import isObject from '../utils/isObject';\n\nimport isDateObject from './isDateObject';\nimport isPrimitive from './isPrimitive';\n\nexport default function deepEqual(object1: any, object2: any) {\n if (isPrimitive(object1) || isPrimitive(object2)) {\n return object1 === object2;\n }\n\n if (isDateObject(object1) && isDateObject(object2)) {\n return object1.getTime() === object2.getTime();\n }\n\n const keys1 = Object.keys(object1);\n const keys2 = Object.keys(object2);\n\n if (keys1.length !== keys2.length) {\n return false;\n }\n\n for (const key of keys1) {\n const val1 = object1[key];\n\n if (!keys2.includes(key)) {\n return false;\n }\n\n if (key !== 'ref') {\n const val2 = object2[key];\n\n if (\n (isDateObject(val1) && isDateObject(val2)) ||\n (isObject(val1) && isObject(val2)) ||\n (Array.isArray(val1) && Array.isArray(val2))\n ? !deepEqual(val1, val2)\n : val1 !== val2\n ) {\n return false;\n }\n }\n }\n\n return true;\n}\n","import { FieldElement } from '../types';\n\nexport default (element: FieldElement): element is HTMLSelectElement =>\n element.type === `select-multiple`;\n","import { FieldElement } from '../types';\n\nimport isCheckBoxInput from './isCheckBoxInput';\nimport isRadioInput from './isRadioInput';\n\nexport default (ref: FieldElement): ref is HTMLInputElement =>\n isRadioInput(ref) || isCheckBoxInput(ref);\n","import { Ref } from '../types';\n\nimport isHTMLElement from './isHTMLElement';\n\nexport default (ref: Ref) => isHTMLElement(ref) && ref.isConnected;\n","import isFunction from './isFunction';\n\nexport default <T>(data: T): boolean => {\n for (const key in data) {\n if (isFunction(data[key])) {\n return true;\n }\n }\n return false;\n};\n","import deepEqual from '../utils/deepEqual';\nimport isNullOrUndefined from '../utils/isNullOrUndefined';\nimport isObject from '../utils/isObject';\nimport isPrimitive from '../utils/isPrimitive';\nimport isUndefined from '../utils/isUndefined';\nimport objectHasFunction from '../utils/objectHasFunction';\n\nfunction markFieldsDirty<U>(data: U, fields: Record<string, any> = {}) {\n const isParentNodeArray = Array.isArray(data);\n\n if (isObject(data) || isParentNodeArray) {\n for (const key in data) {\n if (\n Array.isArray(data[key]) ||\n (isObject(data[key]) && !objectHasFunction(data[key]))\n ) {\n fields[key] = Array.isArray(data[key]) ? [] : {};\n markFieldsDirty(data[key], fields[key]);\n } else if (!isNullOrUndefined(data[key])) {\n fields[key] = true;\n }\n }\n }\n\n return fields;\n}\n\nfunction getDirtyFieldsFromDefaultValues<T>(\n data: T,\n formValues: T,\n dirtyFieldsFromValues: any,\n) {\n const isParentNodeArray = Array.isArray(data);\n\n if (isObject(data) || isParentNodeArray) {\n for (const key in data) {\n if (\n Array.isArray(data[key]) ||\n (isObject(data[key]) && !objectHasFunction(data[key]))\n ) {\n if (\n isUndefined(formValues) ||\n isPrimitive(dirtyFieldsFromValues[key])\n ) {\n dirtyFieldsFromValues[key] = Array.isArray(data[key])\n ? markFieldsDirty(data[key], [])\n : { ...markFieldsDirty(data[key]) };\n } else {\n getDirtyFieldsFromDefaultValues(\n data[key],\n isNullOrUndefined(formValues) ? {} : formValues[key],\n dirtyFieldsFromValues[key],\n );\n }\n } else {\n deepEqual(data[key], formValues[key])\n ? delete dirtyFieldsFromValues[key]\n : (dirtyFieldsFromValues[key] = true);\n }\n }\n }\n\n return dirtyFieldsFromValues;\n}\n\nexport default <T>(defaultValues: T, formValues: T) =>\n getDirtyFieldsFromDefaultValues(\n defaultValues,\n formValues,\n markFieldsDirty(formValues),\n );\n","import { Field, NativeFieldValue } from '../types';\nimport isString from '../utils/isString';\nimport isUndefined from '../utils/isUndefined';\n\nexport default <T extends NativeFieldValue>(\n value: T,\n { valueAsNumber, valueAsDate, setValueAs }: Field['_f'],\n) =>\n isUndefined(value)\n ? value\n : valueAsNumber\n ? value === ''\n ? NaN\n : value\n ? +value\n : value\n : valueAsDate && isString(value)\n ? new Date(value)\n : setValueAs\n ? setValueAs(value)\n : value;\n","import { Field } from '../types';\nimport isCheckBox from '../utils/isCheckBoxInput';\nimport isFileInput from '../utils/isFileInput';\nimport isMultipleSelect from '../utils/isMultipleSelect';\nimport isRadioInput from '../utils/isRadioInput';\nimport isUndefined from '../utils/isUndefined';\n\nimport getCheckboxValue from './getCheckboxValue';\nimport getFieldValueAs from './getFieldValueAs';\nimport getRadioValue from './getRadioValue';\n\nexport default function getFieldValue(_f: Field['_f']) {\n const ref = _f.ref;\n\n if (_f.refs ? _f.refs.every((ref) => ref.disabled) : ref.disabled) {\n return;\n }\n\n if (isFileInput(ref)) {\n return ref.files;\n }\n\n if (isRadioInput(ref)) {\n return getRadioValue(_f.refs).value;\n }\n\n if (isMultipleSelect(ref)) {\n return [...ref.selectedOptions].map(({ value }) => value);\n }\n\n if (isCheckBox(ref)) {\n return getCheckboxValue(_f.refs).value;\n }\n\n return getFieldValueAs(isUndefined(ref.value) ? _f.ref.value : ref.value, _f);\n}\n","import {\n CriteriaMode,\n Field,\n FieldName,\n FieldRefs,\n FieldValues,\n InternalFieldName,\n} from '../types';\nimport { get } from '../utils';\nimport set from '../utils/set';\n\nexport default <TFieldValues extends FieldValues>(\n fieldsNames: Set<InternalFieldName> | InternalFieldName[],\n _fields: FieldRefs,\n criteriaMode?: CriteriaMode,\n shouldUseNativeValidation?: boolean | undefined,\n) => {\n const fields: Record<InternalFieldName, Field['_f']> = {};\n\n for (const name of fieldsNames) {\n const field: Field = get(_fields, name);\n\n field && set(fields, name, field._f);\n }\n\n return {\n criteriaMode,\n names: [...fieldsNames] as FieldName<TFieldValues>[],\n fields,\n shouldUseNativeValidation,\n };\n};\n","import {\n ValidationRule,\n ValidationValue,\n ValidationValueMessage,\n} from '../types';\nimport isObject from '../utils/isObject';\nimport isRegex from '../utils/isRegex';\nimport isUndefined from '../utils/isUndefined';\n\nexport default <T extends ValidationValue>(\n rule?: ValidationRule<T> | ValidationValueMessage<T>,\n) =>\n isUndefined(rule)\n ? rule\n : isRegex(rule)\n ? rule.source\n : isObject(rule)\n ? isRegex(rule.value)\n ? rule.value.source\n : rule.value\n : rule;\n","import { Field } from '../types';\n\nexport default (options: Field['_f']) =>\n options.mount &&\n (options.required ||\n options.min ||\n options.max ||\n options.maxLength ||\n options.minLength ||\n options.pattern ||\n options.validate);\n","import { FieldError, FieldErrors, FieldValues } from '../types';\nimport get from '../utils/get';\nimport isKey from '../utils/isKey';\n\nexport default function schemaErrorLookup<T extends FieldValues = FieldValues>(\n errors: FieldErrors<T>,\n _fields: FieldValues,\n name: string,\n): {\n error?: FieldError;\n name: string;\n} {\n const error = get(errors, name);\n\n if (error || isKey(name)) {\n return {\n error,\n name,\n };\n }\n\n const names = name.split('.');\n\n while (names.length) {\n const fieldName = names.join('.');\n const field = get(_fields, fieldName);\n const foundError = get(errors, fieldName);\n\n if (field && !Array.isArray(field) && name !== fieldName) {\n return { name };\n }\n\n if (foundError && foundError.type) {\n return {\n name: fieldName,\n error: foundError,\n };\n }\n\n names.pop();\n }\n\n return {\n name,\n };\n}\n","export default (\n isBlurEvent: boolean,\n isTouched: boolean,\n isSubmitted: boolean,\n reValidateMode: {\n isOnBlur: boolean;\n isOnChange: boolean;\n },\n mode: Partial<{\n isOnSubmit: boolean;\n isOnBlur: boolean;\n isOnChange: boolean;\n isOnTouch: boolean;\n isOnAll: boolean;\n }>,\n) => {\n if (mode.isOnAll) {\n return false;\n } else if (!isSubmitted && mode.isOnTouch) {\n return !(isTouched || isBlurEvent);\n } else if (isSubmitted ? reValidateMode.isOnBlur : mode.isOnBlur) {\n return !isBlurEvent;\n } else if (isSubmitted ? reValidateMode.isOnChange : mode.isOnChange) {\n return isBlurEvent;\n }\n return true;\n};\n","import compact from '../utils/compact';\nimport get from '../utils/get';\nimport unset from '../utils/unset';\n\nexport default <T>(ref: T, name: string) =>\n !compact(get(ref, name)).length && unset(ref, name);\n","import { EVENTS, VALIDATION_MODE } from '../constants';\nimport {\n BatchFieldArrayUpdate,\n ChangeHandler,\n DeepPartial,\n DelayCallback,\n EventType,\n Field,\n FieldError,\n FieldNamesMarkedBoolean,\n FieldPath,\n FieldRefs,\n FieldValues,\n FormState,\n GetIsDirty,\n InternalFieldName,\n Names,\n Path,\n Ref,\n SetFieldValue,\n SetValueConfig,\n Subjects,\n UseFormClearErrors,\n UseFormGetFieldState,\n UseFormGetValues,\n UseFormHandleSubmit,\n UseFormProps,\n UseFormRegister,\n UseFormReset,\n UseFormResetField,\n UseFormReturn,\n UseFormSetError,\n UseFormSetFocus,\n UseFormSetValue,\n UseFormTrigger,\n UseFormUnregister,\n UseFormWatch,\n WatchInternal,\n WatchObserver,\n} from '../types';\nimport cloneObject from '../utils/cloneObject';\nimport compact from '../utils/compact';\nimport convertToArrayPayload from '../utils/convertToArrayPayload';\nimport createSubject from '../utils/createSubject';\nimport deepEqual from '../utils/deepEqual';\nimport get from '../utils/get';\nimport isBoolean from '../utils/isBoolean';\nimport isCheckBoxInput from '../utils/isCheckBoxInput';\nimport isDateObject from '../utils/isDateObject';\nimport isEmptyObject from '../utils/isEmptyObject';\nimport isFileInput from '../utils/isFileInput';\nimport isFunction from '../utils/isFunction';\nimport isHTMLElement from '../utils/isHTMLElement';\nimport isMultipleSelect from '../utils/isMultipleSelect';\nimport isNullOrUndefined from '../utils/isNullOrUndefined';\nimport isObject from '../utils/isObject';\nimport isPrimitive from '../utils/isPrimitive';\nimport isRadioOrCheckbox from '../utils/isRadioOrCheckbox';\nimport isString from '../utils/isString';\nimport isUndefined from '../utils/isUndefined';\nimport isWeb from '../utils/isWeb';\nimport live from '../utils/live';\nimport set from '../utils/set';\nimport unset from '../utils/unset';\n\nimport focusFieldBy from './focusFieldBy';\nimport generateWatchOutput from './generateWatchOutput';\nimport getDirtyFields from './getDirtyFields';\nimport getEventValue from './getEventValue';\nimport getFieldValue from './getFieldValue';\nimport getFieldValueAs from './getFieldValueAs';\nimport getResolverOptions from './getResolverOptions';\nimport getRuleValue from './getRuleValue';\nimport getValidationModes from './getValidationModes';\nimport hasValidation from './hasValidation';\nimport isNameInFieldArray from './isNameInFieldArray';\nimport isWatched from './isWatched';\nimport schemaErrorLookup from './schemaErrorLookup';\nimport skipValidation from './skipValidation';\nimport unsetEmptyArray from './unsetEmptyArray';\nimport updateFieldArrayRootError from './updateFieldArrayRootError';\nimport validateField from './validateField';\n\nconst defaultOptions = {\n mode: VALIDATION_MODE.onSubmit,\n reValidateMode: VALIDATION_MODE.onChange,\n shouldFocusError: true,\n} as const;\n\nexport function createFormControl<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n>(\n props: UseFormProps<TFieldValues, TContext> = {},\n flushRootRender: () => void,\n): Omit<UseFormReturn<TFieldValues, TContext>, 'formState'> {\n let _options = {\n ...defaultOptions,\n ...props,\n };\n const shouldCaptureDirtyFields =\n props.resetOptions && props.resetOptions.keepDirtyValues;\n let _formState: FormState<TFieldValues> = {\n submitCount: 0,\n isDirty: false,\n isLoading: true,\n isValidating: false,\n isSubmitted: false,\n isSubmitting: false,\n isSubmitSuccessful: false,\n isValid: false,\n touchedFields: {},\n dirtyFields: {},\n errors: {},\n };\n let _fields = {};\n let _defaultValues = isObject(_options.defaultValues)\n ? cloneObject(_options.defaultValues) || {}\n : {};\n let _formValues = _options.shouldUnregister\n ? {}\n : cloneObject(_defaultValues);\n let _stateFlags = {\n action: false,\n mount: false,\n watch: false,\n };\n let _names: Names = {\n mount: new Set(),\n unMount: new Set(),\n array: new Set(),\n watch: new Set(),\n };\n let delayErrorCallback: DelayCallback | null;\n let timer = 0;\n const _proxyFormState = {\n isDirty: false,\n dirtyFields: false,\n touchedFields: false,\n isValidating: false,\n isValid: false,\n errors: false,\n };\n const _subjects: Subjects<TFieldValues> = {\n watch: createSubject(),\n array: createSubject(),\n state: createSubject(),\n };\n const validationModeBeforeSubmit = getValidationModes(_options.mode);\n const validationModeAfterSubmit = getValidationModes(_options.reValidateMode);\n const shouldDisplayAllAssociatedErrors =\n _options.criteriaMode === VALIDATION_MODE.all;\n\n const debounce =\n <T extends Function>(callback: T) =>\n (wait: number) => {\n clearTimeout(timer);\n timer = window.setTimeout(callback, wait);\n };\n\n const _updateValid = async () => {\n if (_proxyFormState.isValid) {\n const isValid = _options.resolver\n ? isEmptyObject((await _executeSchema()).errors)\n : await executeBuiltInValidation(_fields, true);\n\n if (isValid !== _formState.isValid) {\n _formState.isValid = isValid;\n _subjects.state.next({\n isValid,\n });\n }\n }\n };\n\n const _updateIsValidating = (value: boolean) =>\n _proxyFormState.isValidating &&\n _subjects.state.next({\n isValidating: value,\n });\n\n const _updateFieldArray: BatchFieldArrayUpdate = (\n name,\n values = [],\n method,\n args,\n shouldSetValues = true,\n shouldUpdateFieldsAndState = true,\n ) => {\n if (args && method) {\n _stateFlags.action = true;\n if (shouldUpdateFieldsAndState && Array.isArray(get(_fields, name))) {\n const fieldValues = method(get(_fields, name), args.argA, args.argB);\n shouldSetValues && set(_fields, name, fieldValues);\n }\n\n if (\n shouldUpdateFieldsAndState &&\n Array.isArray(get(_formState.errors, name))\n ) {\n const errors = method(\n get(_formState.errors, name),\n args.argA,\n args.argB,\n );\n shouldSetValues && set(_formState.errors, name, errors);\n unsetEmptyArray(_formState.errors, name);\n }\n\n if (\n _proxyFormState.touchedFields &&\n shouldUpdateFieldsAndState &&\n Array.isArray(get(_formState.touchedFields, name))\n ) {\n const touchedFields = method(\n get(_formState.touchedFields, name),\n args.argA,\n args.argB,\n );\n shouldSetValues && set(_formState.touchedFields, name, touchedFields);\n }\n\n if (_proxyFormState.dirtyFields) {\n _formState.dirtyFields = getDirtyFields(_defaultValues, _formValues);\n }\n\n _subjects.state.next({\n name,\n isDirty: _getDirty(name, values),\n dirtyFields: _formState.dirtyFields,\n errors: _formState.errors,\n isValid: _formState.isValid,\n });\n } else {\n set(_formValues, name, values);\n }\n };\n\n const updateErrors = (name: InternalFieldName, error: FieldError) => {\n set(_formState.errors, name, error);\n _subjects.state.next({\n errors: _formState.errors,\n });\n };\n\n const updateValidAndValue = (\n name: InternalFieldName,\n shouldSkipSetValueAs: boolean,\n value?: unknown,\n ref?: Ref,\n ) => {\n const field: Field = get(_fields, name);\n\n if (field) {\n const defaultValue = get(\n _formValues,\n name,\n isUndefined(value) ? get(_defaultValues, name) : value,\n );\n\n isUndefined(defaultValue) ||\n (ref && (ref as HTMLInputElement).defaultChecked) ||\n shouldSkipSetValueAs\n ? set(\n _formValues,\n name,\n shouldSkipSetValueAs ? defaultValue : getFieldValue(field._f),\n )\n : setFieldValue(name, defaultValue);\n\n _stateFlags.mount && _updateValid();\n }\n };\n\n const updateTouchAndDirty = (\n name: InternalFieldName,\n fieldValue: unknown,\n isBlurEvent?: boolean,\n shouldDirty?: boolean,\n shouldRender?: boolean,\n ): Partial<\n Pick<FormState<TFieldValues>, 'dirtyFields' | 'isDirty' | 'touchedFields'>\n > => {\n let shouldUpdateField = false;\n let isPreviousDirty = false;\n const output: Partial<FormState<TFieldValues>> & { name: string } = {\n name,\n };\n\n if (!isBlurEvent || shouldDirty) {\n if (_proxyFormState.isDirty) {\n isPreviousDirty = _formState.isDirty;\n _formState.isDirty = output.isDirty = _getDirty();\n shouldUpdateField = isPreviousDirty !== output.isDirty;\n }\n\n const isCurrentFieldPristine = deepEqual(\n get(_defaultValues, name),\n fieldValue,\n );\n\n isPreviousDirty = get(_formState.dirtyFields, name);\n isCurrentFieldPristine\n ? unset(_formState.dirtyFields, name)\n : set(_formState.dirtyFields, name, true);\n output.dirtyFields = _formState.dirtyFields;\n shouldUpdateField =\n shouldUpdateField ||\n (_proxyFormState.dirtyFields &&\n isPreviousDirty !== !isCurrentFieldPristine);\n }\n\n if (isBlurEvent) {\n const isPreviousFieldTouched = get(_formState.touchedFields, name);\n\n if (!isPreviousFieldTouched) {\n set(_formState.touchedFields, name, isBlurEvent);\n output.touchedFields = _formState.touchedFields;\n shouldUpdateField =\n shouldUpdateField ||\n (_proxyFormState.touchedFields &&\n isPreviousFieldTouched !== isBlurEvent);\n }\n }\n\n shouldUpdateField && shouldRender && _subjects.state.next(output);\n\n return shouldUpdateField ? output : {};\n };\n\n const shouldRenderByError = (\n name: InternalFieldName,\n isValid?: boolean,\n error?: FieldError,\n fieldState?: {\n dirty?: FieldNamesMarkedBoolean<TFieldValues>;\n isDirty?: boolean;\n touched?: FieldNamesMarkedBoolean<TFieldValues>;\n },\n ) => {\n const previousFieldError = get(_formState.errors, name);\n const shouldUpdateValid =\n _proxyFormState.isValid &&\n isBoolean(isValid) &&\n _formState.isValid !== isValid;\n\n if (props.delayError && error) {\n delayErrorCallback = debounce(() => updateErrors(name, error));\n delayErrorCallback(props.delayError);\n } else {\n clearTimeout(timer);\n delayErrorCallback = null;\n error\n ? set(_formState.errors, name, error)\n : unset(_formState.errors, name);\n }\n\n if (\n (error ? !deepEqual(previousFieldError, error) : previousFieldError) ||\n !isEmptyObject(fieldState) ||\n shouldUpdateValid\n ) {\n const updatedFormState = {\n ...fieldState,\n ...(shouldUpdateValid && isBoolean(isValid) ? { isValid } : {}),\n errors: _formState.errors,\n name,\n };\n\n _formState = {\n ..._formState,\n ...updatedFormState,\n };\n\n _subjects.state.next(updatedFormState);\n }\n\n _updateIsValidating(false);\n };\n\n const _executeSchema = async (name?: InternalFieldName[]) =>\n await _options.resolver!(\n _formValues as TFieldValues,\n _options.context,\n getResolverOptions(\n name || _names.mount,\n _fields,\n _options.criteriaMode,\n _options.shouldUseNativeValidation,\n ),\n );\n\n const executeSchemaAndUpdateState = async (names?: InternalFieldName[]) => {\n const { errors } = await _executeSchema();\n\n if (names) {\n for (const name of names) {\n const error = get(errors, name);\n error\n ? set(_formState.errors, name, error)\n : unset(_formState.errors, name);\n }\n } else {\n _formState.errors = errors;\n }\n\n return errors;\n };\n\n const executeBuiltInValidation = async (\n fields: FieldRefs,\n shouldOnlyCheckValid?: boolean,\n context: {\n valid: boolean;\n } = {\n valid: true,\n },\n ) => {\n for (const name in fields) {\n const field = fields[name];\n\n if (field) {\n const { _f, ...fieldValue } = field;\n\n if (_f) {\n const isFieldArrayRoot = _names.array.has(_f.name);\n const fieldError = await validateField(\n field,\n get(_formValues, _f.name),\n shouldDisplayAllAssociatedErrors,\n _options.shouldUseNativeValidation,\n isFieldArrayRoot,\n );\n\n if (fieldError[_f.name]) {\n context.valid = false;\n if (shouldOnlyCheckValid) {\n break;\n }\n }\n\n !shouldOnlyCheckValid &&\n (get(fieldError, _f.name)\n ? isFieldArrayRoot\n ? updateFieldArrayRootError(\n _formState.errors,\n fieldError,\n _f.name,\n )\n : set(_formState.errors, _f.name, fieldError[_f.name])\n : unset(_formState.errors, _f.name));\n }\n\n fieldValue &&\n (await executeBuiltInValidation(\n fieldValue,\n shouldOnlyCheckValid,\n context,\n ));\n }\n }\n\n return context.valid;\n };\n\n const _removeUnmounted = () => {\n for (const name of _names.unMount) {\n const field: Field = get(_fields, name);\n\n field &&\n (field._f.refs\n ? field._f.refs.every((ref) => !live(ref))\n : !live(field._f.ref)) &&\n unregister(name as FieldPath<TFieldValues>);\n }\n\n _names.unMount = new Set();\n };\n\n const _getDirty: GetIsDirty = (name, data) => (\n name && data && set(_formValues, name, data),\n !deepEqual(getValues(), _defaultValues)\n );\n\n const _getWatch: WatchInternal<TFieldValues> = (\n names,\n defaultValue,\n isGlobal,\n ) =>\n generateWatchOutput(\n names,\n _names,\n {\n ...(_stateFlags.mount\n ? _formValues\n : isUndefined(defaultValue)\n ? _defaultValues\n : isString(names)\n ? { [names]: defaultValue }\n : defaultValue),\n },\n isGlobal,\n defaultValue,\n );\n\n const _getFieldArray = <TFieldArrayValues>(\n name: InternalFieldName,\n ): Partial<TFieldArrayValues>[] =>\n compact(\n get(\n _stateFlags.mount ? _formValues : _defaultValues,\n name,\n props.shouldUnregister ? get(_defaultValues, name, []) : [],\n ),\n );\n\n const setFieldValue = (\n name: InternalFieldName,\n value: SetFieldValue<TFieldValues>,\n options: SetValueConfig = {},\n ) => {\n const field: Field = get(_fields, name);\n let fieldValue: unknown = value;\n\n if (field) {\n const fieldReference = field._f;\n\n if (fieldReference) {\n !fieldReference.disabled &&\n set(_formValues, name, getFieldValueAs(value, fieldReference));\n\n fieldValue =\n isHTMLElement(fieldReference.ref) && isNullOrUndefined(value)\n ? ''\n : value;\n\n if (isMultipleSelect(fieldReference.ref)) {\n [...fieldReference.ref.options].forEach(\n (optionRef) =>\n (optionRef.selected = (\n fieldValue as InternalFieldName[]\n ).includes(optionRef.value)),\n );\n } else if (fieldReference.refs) {\n if (isCheckBoxInput(fieldReference.ref)) {\n fieldReference.refs.length > 1\n ? fieldReference.refs.forEach(\n (checkboxRef) =>\n (!checkboxRef.defaultChecked || !checkboxRef.disabled) &&\n (checkboxRef.checked = Array.isArray(fieldValue)\n ? !!(fieldValue as []).find(\n (data: string) => data === checkboxRef.value,\n )\n : fieldValue === checkboxRef.value),\n )\n : fieldReference.refs[0] &&\n (fieldReference.refs[0].checked = !!fieldValue);\n } else {\n fieldReference.refs.forEach(\n (radioRef: HTMLInputElement) =>\n (radioRef.checked = radioRef.value === fieldValue),\n );\n }\n } else if (isFileInput(fieldReference.ref)) {\n fieldReference.ref.value = '';\n } else {\n fieldReference.ref.value = fieldValue;\n\n if (!fieldReference.ref.type) {\n _subjects.watch.next({\n name,\n });\n }\n }\n }\n }\n\n (options.shouldDirty || options.shouldTouch) &&\n updateTouchAndDirty(\n name,\n fieldValue,\n options.shouldTouch,\n options.shouldDirty,\n true,\n );\n\n options.shouldValidate && trigger(name as Path<TFieldValues>);\n };\n\n const setValues = <\n T extends InternalFieldName,\n K extends SetFieldValue<TFieldValues>,\n U extends SetValueConfig,\n >(\n name: T,\n value: K,\n options: U,\n ) => {\n for (const fieldKey in value) {\n const fieldValue = value[fieldKey];\n const fieldName = `${name}.${fieldKey}`;\n const field = get(_fields, fieldName);\n\n (_names.array.has(name) ||\n !isPrimitive(fieldValue) ||\n (field && !field._f)) &&\n !isDateObject(fieldValue)\n ? setValues(fieldName, fieldValue, options)\n : setFieldValue(fieldName, fieldValue, options);\n }\n };\n\n const setValue: UseFormSetValue<TFieldValues> = (\n name,\n value,\n options = {},\n ) => {\n const field = get(_fields, name);\n const isFieldArray = _names.array.has(name);\n const cloneValue = cloneObject(value);\n\n set(_formValues, name, cloneValue);\n\n if (isFieldArray) {\n _subjects.array.next({\n name,\n values: _formValues,\n });\n\n if (\n (_proxyFormState.isDirty || _proxyFormState.dirtyFields) &&\n options.shouldDirty\n ) {\n _formState.dirtyFields = getDirtyFields(_defaultValues, _formValues);\n\n _subjects.state.next({\n name,\n dirtyFields: _formState.dirtyFields,\n isDirty: _getDirty(name, cloneValue),\n });\n }\n } else {\n field && !field._f && !isNullOrUndefined(cloneValue)\n ? setValues(name, cloneValue, options)\n : setFieldValue(name, cloneValue, options);\n }\n\n isWatched(name, _names) && _subjects.state.next({});\n _subjects.watch.next({\n name,\n });\n !_stateFlags.mount && flushRootRender();\n };\n\n const onChange: ChangeHandler = async (event) => {\n const target = event.target;\n let name = target.name;\n const field: Field = get(_fields, name);\n const getCurrentFieldValue = () =>\n target.type ? getFieldValue(field._f) : getEventValue(event);\n\n if (field) {\n let error;\n let isValid;\n const fieldValue = getCurrentFieldValue();\n const isBlurEvent =\n event.type === EVENTS.BLUR || event.type === EVENTS.FOCUS_OUT;\n const shouldSkipValidation =\n (!hasValidation(field._f) &&\n !_options.resolver &&\n !get(_formState.errors, name) &&\n !field._f.deps) ||\n skipValidation(\n isBlurEvent,\n get(_formState.touchedFields, name),\n _formState.isSubmitted,\n validationModeAfterSubmit,\n validationModeBeforeSubmit,\n );\n const watched = isWatched(name, _names, isBlurEvent);\n\n set(_formValues, name, fieldValue);\n\n if (isBlurEvent) {\n field._f.onBlur && field._f.onBlur(event);\n delayErrorCallback && delayErrorCallback(0);\n } else if (field._f.onChange) {\n field._f.onChange(event);\n }\n\n const fieldState = updateTouchAndDirty(\n name,\n fieldValue,\n isBlurEvent,\n false,\n );\n\n const shouldRender = !isEmptyObject(fieldState) || watched;\n\n !isBlurEvent &&\n _subjects.watch.next({\n name,\n type: event.type,\n });\n\n if (shouldSkipValidation) {\n _proxyFormState.isValid && _updateValid();\n\n return (\n shouldRender &&\n _subjects.state.next({ name, ...(watched ? {} : fieldState) })\n );\n }\n\n !isBlurEvent && watched && _subjects.state.next({});\n\n _updateIsValidating(true);\n\n if (_options.resolver) {\n const { errors } = await _executeSchema([name]);\n const previousErrorLookupResult = schemaErrorLookup(\n _formState.errors,\n _fields,\n name,\n );\n const errorLookupResult = schemaErrorLookup(\n errors,\n _fields,\n previousErrorLookupResult.name || name,\n );\n\n error = errorLookupResult.error;\n name = errorLookupResult.name;\n\n isValid = isEmptyObject(errors);\n } else {\n error = (\n await validateField(\n field,\n get(_formValues, name),\n shouldDisplayAllAssociatedErrors,\n _options.shouldUseNativeValidation,\n )\n )[name];\n\n if (error) {\n isValid = false;\n } else if (_proxyFormState.isValid) {\n isValid = await executeBuiltInValidation(_fields, true);\n }\n }\n\n field._f.deps &&\n trigger(\n field._f.deps as FieldPath<TFieldValues> | FieldPath<TFieldValues>[],\n );\n shouldRenderByError(name, isValid, error, fieldState);\n }\n };\n\n const trigger: UseFormTrigger<TFieldValues> = async (name, options = {}) => {\n let isValid;\n let validationResult;\n const fieldNames = convertToArrayPayload(name) as InternalFieldName[];\n\n _updateIsValidating(true);\n\n if (_options.resolver) {\n const errors = await executeSchemaAndUpdateState(\n isUndefined(name) ? name : fieldNames,\n );\n\n isValid = isEmptyObject(errors);\n validationResult = name\n ? !fieldNames.some((name) => get(errors, name))\n : isValid;\n } else if (name) {\n validationResult = (\n await Promise.all(\n fieldNames.map(async (fieldName) => {\n const field = get(_fields, fieldName);\n return await executeBuiltInValidation(\n field && field._f ? { [fieldName]: field } : field,\n );\n }),\n )\n ).every(Boolean);\n !(!validationResult && !_formState.isValid) && _updateValid();\n } else {\n validationResult = isValid = await executeBuiltInValidation(_fields);\n }\n\n _subjects.state.next({\n ...(!isString(name) ||\n (_proxyFormState.isValid && isValid !== _formState.isValid)\n ? {}\n : { name }),\n ...(_options.resolver || !name ? { isValid } : {}),\n errors: _formState.errors,\n isValidating: false,\n });\n\n options.shouldFocus &&\n !validationResult &&\n focusFieldBy(\n _fields,\n (key) => key && get(_formState.errors, key),\n name ? fieldNames : _names.mount,\n );\n\n return validationResult;\n };\n\n const getValues: UseFormGetValues<TFieldValues> = (\n fieldNames?:\n | FieldPath<TFieldValues>\n | ReadonlyArray<FieldPath<TFieldValues>>,\n ) => {\n const values = {\n ..._defaultValues,\n ...(_stateFlags.mount ? _formValues : {}),\n };\n\n return isUndefined(fieldNames)\n ? values\n : isString(fieldNames)\n ? get(values, fieldNames)\n : fieldNames.map((name) => get(values, name));\n };\n\n const getFieldState: UseFormGetFieldState<TFieldValues> = (\n name,\n formState,\n ) => ({\n invalid: !!get((formState || _formState).errors, name),\n isDirty: !!get((formState || _formState).dirtyFields, name),\n isTouched: !!get((formState || _formState).touchedFields, name),\n error: get((formState || _formState).errors, name),\n });\n\n const clearErrors: UseFormClearErrors<TFieldValues> = (name) => {\n name\n ? convertToArrayPayload(name).forEach((inputName) =>\n unset(_formState.errors, inputName),\n )\n : (_formState.errors = {});\n\n _subjects.state.next({\n errors: _formState.errors,\n });\n };\n\n const setError: UseFormSetError<TFieldValues> = (name, error, options) => {\n const ref = (get(_fields, name, { _f: {} })._f || {}).ref;\n\n set(_formState.errors, name, {\n ...error,\n ref,\n });\n\n _subjects.state.next({\n name,\n errors: _formState.errors,\n isValid: false,\n });\n\n options && options.shouldFocus && ref && ref.focus && ref.focus();\n };\n\n const watch: UseFormWatch<TFieldValues> = (\n name?:\n | FieldPath<TFieldValues>\n | ReadonlyArray<FieldPath<TFieldValues>>\n | WatchObserver<TFieldValues>,\n defaultValue?: DeepPartial<TFieldValues>,\n ) =>\n isFunction(name)\n ? _subjects.watch.subscribe({\n next: (payload) =>\n name(\n _getWatch(undefined, defaultValue),\n payload as {\n name?: FieldPath<TFieldValues>;\n type?: EventType;\n value?: unknown;\n },\n ),\n })\n : _getWatch(\n name as InternalFieldName | InternalFieldName[],\n defaultValue,\n true,\n );\n\n const unregister: UseFormUnregister<TFieldValues> = (name, options = {}) => {\n for (const fieldName of name ? convertToArrayPayload(name) : _names.mount) {\n _names.mount.delete(fieldName);\n _names.array.delete(fieldName);\n\n if (get(_fields, fieldName)) {\n if (!options.keepValue) {\n unset(_fields, fieldName);\n unset(_formValues, fieldName);\n }\n\n !options.keepError && unset(_formState.errors, fieldName);\n !options.keepDirty && unset(_formState.dirtyFields, fieldName);\n !options.keepTouched && unset(_formState.touchedFields, fieldName);\n !_options.shouldUnregister &&\n !options.keepDefaultValue &&\n unset(_defaultValues, fieldName);\n }\n }\n\n _subjects.watch.next({});\n\n _subjects.state.next({\n ..._formState,\n ...(!options.keepDirty ? {} : { isDirty: _getDirty() }),\n });\n\n !options.keepIsValid && _updateValid();\n };\n\n const register: UseFormRegister<TFieldValues> = (name, options = {}) => {\n let field = get(_fields, name);\n const disabledIsDefined = isBoolean(options.disabled);\n\n set(_fields, name, {\n ...(field || {}),\n _f: {\n ...(field && field._f ? field._f : { ref: { name } }),\n name,\n mount: true,\n ...options,\n },\n });\n _names.mount.add(name);\n\n field\n ? disabledIsDefined &&\n set(\n _formValues,\n name,\n options.disabled\n ? undefined\n : get(_formValues, name, getFieldValue(field._f)),\n )\n : updateValidAndValue(name, true, options.value);\n\n return {\n ...(disabledIsDefined ? { disabled: options.disabled } : {}),\n ...(_options.shouldUseNativeValidation\n ? {\n required: !!options.required,\n min: getRuleValue(options.min),\n max: getRuleValue(options.max),\n minLength: getRuleValue<number>(options.minLength) as number,\n maxLength: getRuleValue(options.maxLength) as number,\n pattern: getRuleValue(options.pattern) as string,\n }\n : {}),\n name,\n onChange,\n onBlur: onChange,\n ref: (ref: HTMLInputElement | null): void => {\n if (ref) {\n register(name, options);\n field = get(_fields, name);\n\n const fieldRef = isUndefined(ref.value)\n ? ref.querySelectorAll\n ? (ref.querySelectorAll('input,select,textarea')[0] as Ref) || ref\n : ref\n : ref;\n const radioOrCheckbox = isRadioOrCheckbox(fieldRef);\n const refs = field._f.refs || [];\n\n if (\n radioOrCheckbox\n ? refs.find((option: Ref) => option === fieldRef)\n : fieldRef === field._f.ref\n ) {\n return;\n }\n\n set(_fields, name, {\n _f: {\n ...field._f,\n ...(radioOrCheckbox\n ? {\n refs: [\n ...refs.filter(live),\n fieldRef,\n ...(Array.isArray(get(_defaultValues, name)) ? [{}] : []),\n ],\n ref: { type: fieldRef.type, name },\n }\n : { ref: fieldRef }),\n },\n });\n\n updateValidAndValue(name, false, undefined, fieldRef);\n } else {\n field = get(_fields, name, {});\n\n if (field._f) {\n field._f.mount = false;\n }\n\n (_options.shouldUnregister || options.shouldUnregister) &&\n !(isNameInFieldArray(_names.array, name) && _stateFlags.action) &&\n _names.unMount.add(name);\n }\n },\n };\n };\n\n const _focusError = () =>\n _options.shouldFocusError &&\n focusFieldBy(\n _fields,\n (key) => key && get(_formState.errors, key),\n _names.mount,\n );\n\n const handleSubmit: UseFormHandleSubmit<TFieldValues> =\n (onValid, onInvalid) => async (e) => {\n if (e) {\n e.preventDefault && e.preventDefault();\n e.persist && e.persist();\n }\n let hasNoPromiseError = true;\n let fieldValues: any = cloneObject(_formValues);\n\n _subjects.state.next({\n isSubmitting: true,\n });\n\n try {\n if (_options.resolver) {\n const { errors, values } = await _executeSchema();\n _formState.errors = errors;\n fieldValues = values;\n } else {\n await executeBuiltInValidation(_fields);\n }\n\n if (isEmptyObject(_formState.errors)) {\n _subjects.state.next({\n errors: {},\n isSubmitting: true,\n });\n await onValid(fieldValues, e);\n } else {\n if (onInvalid) {\n await onInvalid({ ..._formState.errors }, e);\n }\n\n _focusError();\n }\n } catch (err) {\n hasNoPromiseError = false;\n throw err;\n } finally {\n _formState.isSubmitted = true;\n _subjects.state.next({\n isSubmitted: true,\n isSubmitting: false,\n isSubmitSuccessful:\n isEmptyObject(_formState.errors) && hasNoPromiseError,\n submitCount: _formState.submitCount + 1,\n errors: _formState.errors,\n });\n }\n };\n\n const resetField: UseFormResetField<TFieldValues> = (name, options = {}) => {\n if (get(_fields, name)) {\n if (isUndefined(options.defaultValue)) {\n setValue(name, get(_defaultValues, name));\n } else {\n setValue(name, options.defaultValue);\n set(_defaultValues, name, options.defaultValue);\n }\n\n if (!options.keepTouched) {\n unset(_formState.touchedFields, name);\n }\n\n if (!options.keepDirty) {\n unset(_formState.dirtyFields, name);\n _formState.isDirty = options.defaultValue\n ? _getDirty(name, get(_defaultValues, name))\n : _getDirty();\n }\n\n if (!options.keepError) {\n unset(_formState.errors, name);\n _proxyFormState.isValid && _updateValid();\n }\n\n _subjects.state.next({ ..._formState });\n }\n };\n\n const _reset: UseFormReset<TFieldValues> = (\n formValues,\n keepStateOptions = {},\n ) => {\n const updatedValues = formValues || _defaultValues;\n const cloneUpdatedValues = cloneObject(updatedValues);\n const values =\n formValues && !isEmptyObject(formValues)\n ? cloneUpdatedValues\n : _defaultValues;\n\n if (!keepStateOptions.keepDefaultValues) {\n _defaultValues = updatedValues;\n }\n\n if (!keepStateOptions.keepValues) {\n if (keepStateOptions.keepDirtyValues || shouldCaptureDirtyFields) {\n for (const fieldName of _names.mount) {\n get(_formState.dirtyFields, fieldName)\n ? set(values, fieldName, get(_formValues, fieldName))\n : setValue(\n fieldName as FieldPath<TFieldValues>,\n get(values, fieldName),\n );\n }\n } else {\n if (isWeb && isUndefined(formValues)) {\n for (const name of _names.mount) {\n const field = get(_fields, name);\n if (field && field._f) {\n const fieldReference = Array.isArray(field._f.refs)\n ? field._f.refs[0]\n : field._f.ref;\n\n if (isHTMLElement(fieldReference)) {\n const form = fieldReference.closest('form');\n if (form) {\n form.reset();\n break;\n }\n }\n }\n }\n }\n\n _fields = {};\n }\n\n _formValues = props.shouldUnregister\n ? keepStateOptions.keepDefaultValues\n ? cloneObject(_defaultValues)\n : {}\n : cloneUpdatedValues;\n\n _subjects.array.next({\n values,\n });\n\n _subjects.watch.next({\n values,\n });\n }\n\n _names = {\n mount: new Set(),\n unMount: new Set(),\n array: new Set(),\n watch: new Set(),\n watchAll: false,\n focus: '',\n };\n\n !_stateFlags.mount && flushRootRender();\n\n _stateFlags.mount =\n !_proxyFormState.isValid || !!keepStateOptions.keepIsValid;\n\n _stateFlags.watch = !!props.shouldUnregister;\n\n _subjects.state.next({\n submitCount: keepStateOptions.keepSubmitCount\n ? _formState.submitCount\n : 0,\n isDirty:\n keepStateOptions.keepDirty || keepStateOptions.keepDirtyValues\n ? _formState.isDirty\n : !!(\n keepStateOptions.keepDefaultValues &&\n !deepEqual(formValues, _defaultValues)\n ),\n isSubmitted: keepStateOptions.keepIsSubmitted\n ? _formState.isSubmitted\n : false,\n dirtyFields:\n keepStateOptions.keepDirty || keepStateOptions.keepDirtyValues\n ? _formState.dirtyFields\n : keepStateOptions.keepDefaultValues && formValues\n ? getDirtyFields(_defaultValues, formValues)\n : {},\n touchedFields: keepStateOptions.keepTouched\n ? _formState.touchedFields\n : {},\n errors: keepStateOptions.keepErrors ? _formState.errors : {},\n isSubmitting: false,\n isSubmitSuccessful: false,\n });\n };\n\n const reset: UseFormReset<TFieldValues> = (formValues, keepStateOptions) =>\n _reset(\n isFunction(formValues)\n ? formValues(_formValues as TFieldValues)\n : formValues,\n keepStateOptions,\n );\n\n const setFocus: UseFormSetFocus<TFieldValues> = (name, options = {}) => {\n const field = get(_fields, name);\n const fieldReference = field && field._f;\n\n if (fieldReference) {\n const fieldRef = fieldReference.refs\n ? fieldReference.refs[0]\n : fieldReference.ref;\n\n if (fieldRef.focus) {\n fieldRef.focus();\n options.shouldSelect && fieldRef.select();\n }\n }\n };\n\n if (isFunction(_options.defaultValues)) {\n _options.defaultValues().then((values) => {\n reset(values, _options.resetOptions);\n _subjects.state.next({\n isLoading: false,\n });\n });\n }\n\n return {\n control: {\n register,\n unregister,\n getFieldState,\n _executeSchema,\n _focusError,\n _getWatch,\n _getDirty,\n _updateValid,\n _removeUnmounted,\n _updateFieldArray,\n _getFieldArray,\n _reset,\n _subjects,\n _proxyFormState,\n get _fields() {\n return _fields;\n },\n get _formValues() {\n return _formValues;\n },\n get _stateFlags() {\n return _stateFlags;\n },\n set _stateFlags(value) {\n _stateFlags = value;\n },\n get _defaultValues() {\n return _defaultValues;\n },\n get _names() {\n return _names;\n },\n set _names(value) {\n _names = value;\n },\n get _formState() {\n return _formState;\n },\n set _formState(value) {\n _formState = value;\n },\n get _options() {\n return _options;\n },\n set _options(value) {\n _options = {\n ..._options,\n ...value,\n };\n },\n },\n trigger,\n register,\n handleSubmit,\n watch,\n setValue,\n getValues,\n reset,\n resetField,\n clearErrors,\n unregister,\n setError,\n setFocus,\n getFieldState,\n };\n}\n","import { useFormAlarmClock } from '@hooks/useFormAlarmClock'\nimport { useGlobalModal } from '@hooks/useGlobalModal'\nimport { phone, pxToRem, tablet } from '@libs/index'\nimport { useState } from 'react'\nimport { SubmitHandler, useForm } from 'react-hook-form'\nimport { useTranslation } from 'react-i18next'\nimport styled, { css } from 'styled-components'\nimport { CustomButton, CustomLink } from './Button'\n\ntype Inputs = {\n name: string,\n email: string,\n message: string,\n privacy: boolean\n};\n\nconst ContactModal = styled.div`\n max-width: ${pxToRem(800)};\n width: 100%;\n ${tablet(`\n width: min(${pxToRem(800)}, 100%);\n `)}\n`\n\nconst commonInputStyles = css`\n background: transparent;\n color: ${({ theme }) => theme.colors.text};\n border: 1px solid ${({ theme }) => theme.colors.text};\n border-radius: ${pxToRem(4)};\n padding: ${pxToRem(12)};\n font-size: ${pxToRem(21)};\n font-family: Poppins, Sans-Serif;\n &:focus {\n border-color: ${({ theme }) => theme.colors.primary}; \n outline: 1px solid ${({ theme }) => theme.colors.primary};\n background: ${({ theme }) => theme.colors.badgeBackground};\n }\n`\n\nconst CustomInput = styled.input`\n ${commonInputStyles}\n`\nconst CustomTextArea = styled.textarea`\n ${commonInputStyles}\n resize: vertical;\n min-height: ${pxToRem(200)};\n column-span: 2;\n\n`\n\nconst CustomCheckbox = styled.input`\n height: ${pxToRem(20)};\n width: ${pxToRem(20)};\n margin-right: ${pxToRem(8)};\n`\n\nconst CustomBlock = styled.div<{ shouldSpan?: boolean }>`\n display: flex;\n flex-direction: column;\n gap: ${pxToRem(8)};\n ${({ shouldSpan }) => shouldSpan ? 'grid-column: 1 / -1' : null}\n ${tablet('grid-column: unset')}\n\n`\n\nconst CustomLabel = styled.label`\n${phone(`\n font-size: ${pxToRem(18)}; \n `)}\n&:after {\n content: '*';\n margin-left: ${pxToRem(3)};\n color: ${({ theme }) => theme.colors.error};\n}\n`\n\nconst FormFooter = styled.div`\n display: flex;\n align-items: center;\n justify-content: space-between;\n ${tablet('grid-column: 1 / -1;')}\n ${phone(`\n flex-direction: column;\n row-gap: ${pxToRem(16)};\n `)}\n`\n\nconst ErrorLabel = styled.span`\n color: ${({ theme }) => theme.colors.error};\n font-size: ${pxToRem(18)};\n grid-column: 1 / -1;\n ${phone(`\n font-size: ${pxToRem(14)}; \n `)}\n`\n\nconst ContactForm = styled.form`\n display: grid;\n color: ${({ theme }) => theme.colors.text};\n grid-template-columns: repeat(auto-fit, minMax(320px, 1fr));\n gap: ${pxToRem(20)};\n row-gap: ${pxToRem(40)};\n padding: ${pxToRem(40)} ${pxToRem(20)};\n`\n\nconst PrivacyPolicyBlock = styled.div`\n display: grid;\n align-items: flex-start;\n grid-template-columns: 40px 1fr;\n justify-content: flex-start;\n ${tablet('grid-column: 1 / -1;')}\n \n & > * { cursor: pointer;margin-bottom: ${pxToRem(5)};}\n\n line-height: 1rem;\n`\n\nexport const BaseModal = () => {\n return <div></div>\n}\n\ninterface FormFeedbackStatus {\n status: FormStatus;\n}\n\nconst FormFeedback = ({ status }: FormFeedbackStatus) => {\n switch (status) {\n case 'LOADING':\n return <div>âœ‰ï¸ Sending email...</div>\n case 'SUCCESS':\n return <div>🚀 Congratulations! Your message has been sent!</div>\n case 'FAILED':\n return <div>🤯 Oh Snap! Something went wrong!</div>\n default:\n return null\n }\n}\n\ntype FormStatus = 'SUCCESS' | 'FAILED' | 'LOADING' | null;\n\nexport const Modal = () => {\n const { t } = useTranslation()\n useFormAlarmClock()\n const [formState, setFormState] = useState<FormStatus>(null)\n const { close } = useGlobalModal()\n const { register, handleSubmit, formState: { errors } } = useForm<Inputs>()\n\n const onSubmit: SubmitHandler<Inputs> = data => {\n\n setFormState('LOADING')\n const body = {\n to: 'info@nicholaslazzerini.com',\n subject: 'Informazioni dal form del sito',\n form: data,\n }\n\n fetch('https://backend-utils.onrender.com/mailer/sendMessage', {\n method: 'POST',\n mode: 'cors',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify(body),\n })\n .then(() => {\n setFormState('SUCCESS')\n })\n .catch(() => {\n setFormState('FAILED')\n })\n }\n\n const handleValidationErrors = (field: keyof Inputs) => {\n const error = errors[field]\n\n if (!error) return null\n\n switch (error.type) {\n case 'required':\n return <ErrorLabel>{t(`form.${field}.required`)}</ErrorLabel>\n case 'minLength':\n return <ErrorLabel>{t(`form.${field}.minLength`)}</ErrorLabel>\n case 'pattern':\n return <ErrorLabel >{t(`form.${field}.pattern`)}</ErrorLabel>\n }\n }\n\n // useEffect(() => {\n // Object.keys(errors).length > 0 && setFormState('FAILED')\n // }, [errors])\n\n return <ContactModal>\n <ContactForm onSubmit={handleSubmit(onSubmit)}>\n {/* include validation with required or other standard HTML validation rules */}\n <CustomBlock>\n <CustomLabel htmlFor='name'>{t('form.name.label')}</CustomLabel>\n <CustomInput id='name' {...register('name',\n {\n required: true,\n minLength: 4\n }\n )} />\n {handleValidationErrors('name')}\n </CustomBlock>\n\n <CustomBlock>\n <CustomLabel htmlFor='email'>{t('form.email.label')}</CustomLabel>\n <CustomInput id='email' {...register('email', {\n required: true,\n pattern: /^[a-zA-Z0-9.!#$%&’*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:\\.[a-zA-Z0-9-]+)*$/i\n })} />\n {handleValidationErrors('email')}\n </CustomBlock>\n\n <CustomBlock shouldSpan>\n <CustomLabel htmlFor='message'>{t('form.message.label')}</CustomLabel>\n <CustomTextArea id='message' {...register('message', {\n required: true,\n minLength: 10\n })} />\n {handleValidationErrors('message')}\n </CustomBlock>\n <PrivacyPolicyBlock>\n <CustomCheckbox id='privacy' type='checkbox' {...register('privacy', { required: true })}></CustomCheckbox>\n <CustomLabel htmlFor='privacy'>{t('form.privacy.label')}</CustomLabel>\n {handleValidationErrors('privacy')}\n </PrivacyPolicyBlock>\n\n {formState && <FormFeedback status={formState} />}\n <FormFooter>\n <CustomLink to={''} onClick={() => close()}>{t('form.close')}</CustomLink>\n <CustomButton>{t('form.send')}</CustomButton>\n </FormFooter>\n\n </ContactForm>\n </ContactModal>\n}\n\n","import { useEffect } from 'react'\n\nexport const useFormAlarmClock = () =>\n\tuseEffect(() => {\n\t\tfetch('https://backend-utils.onrender.com/wakeup', {\n\t\t\tmethod: 'GET',\n\t\t\tmode: 'cors',\n\t\t\theaders: {\n\t\t\t\t'Content-Type': 'application/json',\n\t\t\t},\n\t\t})\n\t}, [])","import React from 'react';\n\nimport { createFormControl } from './logic/createFormControl';\nimport getProxyFormState from './logic/getProxyFormState';\nimport shouldRenderFormState from './logic/shouldRenderFormState';\nimport deepEqual from './utils/deepEqual';\nimport isFunction from './utils/isFunction';\nimport { FieldValues, FormState, UseFormProps, UseFormReturn } from './types';\nimport { useSubscribe } from './useSubscribe';\n\n/**\n * Custom hook to manage the entire form.\n *\n * @remarks\n * [API](https://react-hook-form.com/api/useform) • [Demo](https://codesandbox.io/s/react-hook-form-get-started-ts-5ksmm) • [Video](https://www.youtube.com/watch?v=RkXv4AXXC_4)\n *\n * @param props - form configuration and validation parameters.\n *\n * @returns methods - individual functions to manage the form state. {@link UseFormReturn}\n *\n * @example\n * ```tsx\n * function App() {\n * const { register, handleSubmit, watch, formState: { errors } } = useForm();\n * const onSubmit = data => console.log(data);\n *\n * console.log(watch(\"example\"));\n *\n * return (\n * <form onSubmit={handleSubmit(onSubmit)}>\n * <input defaultValue=\"test\" {...register(\"example\")} />\n * <input {...register(\"exampleRequired\", { required: true })} />\n * {errors.exampleRequired && <span>This field is required</span>}\n * <input type=\"submit\" />\n * </form>\n * );\n * }\n * ```\n */\nexport function useForm<\n TFieldValues extends FieldValues = FieldValues,\n TContext = any,\n>(\n props: UseFormProps<TFieldValues, TContext> = {},\n): UseFormReturn<TFieldValues, TContext> {\n const _formControl = React.useRef<\n UseFormReturn<TFieldValues, TContext> | undefined\n >();\n const [formState, updateFormState] = React.useState<FormState<TFieldValues>>({\n isDirty: false,\n isValidating: false,\n isLoading: true,\n isSubmitted: false,\n isSubmitting: false,\n isSubmitSuccessful: false,\n isValid: false,\n submitCount: 0,\n dirtyFields: {},\n touchedFields: {},\n errors: {},\n defaultValues: isFunction(props.defaultValues)\n ? undefined\n : props.defaultValues,\n });\n\n if (!_formControl.current) {\n _formControl.current = {\n ...createFormControl(props, () =>\n updateFormState((formState) => ({ ...formState })),\n ),\n formState,\n };\n }\n\n const control = _formControl.current.control;\n control._options = props;\n\n useSubscribe({\n subject: control._subjects.state,\n next: (value: FieldValues) => {\n if (shouldRenderFormState(value, control._proxyFormState, true)) {\n control._formState = {\n ...control._formState,\n ...value,\n };\n\n updateFormState({ ...control._formState });\n }\n },\n });\n\n React.useEffect(() => {\n if (!control._stateFlags.mount) {\n control._proxyFormState.isValid && control._updateValid();\n control._stateFlags.mount = true;\n }\n\n if (control._stateFlags.watch) {\n control._stateFlags.watch = false;\n control._subjects.state.next({});\n }\n\n control._removeUnmounted();\n });\n\n React.useEffect(() => {\n if (props.values && !deepEqual(props.values, control._defaultValues)) {\n control._reset(props.values, control._options.resetOptions);\n }\n }, [props.values, control]);\n\n React.useEffect(() => {\n formState.submitCount && control._focusError();\n }, [control, formState.submitCount]);\n\n _formControl.current.formState = getProxyFormState(formState, control);\n\n return _formControl.current;\n}\n","import { Modal } from '@components/Modal'\nimport { GlobalModal } from 'react-global-modal'\n\nexport const useGlobalModal = () => {\n const open = () => GlobalModal.push({\n component: Modal,\n className: 'contact-modal',\n modalSize: 'md',\n hideHeader: true,\n hideCloseIcon: true\n })\n\n const close = () => GlobalModal.pop()\n\n return {\n open,\n close\n }\n\n}\n","interface ConfigInterface {\n FONT_SIZE: number;\n PAGE_PADDING: number;\n AVAILABLE_FOR_HIRE: boolean;\n}\n\nconst config: ConfigInterface = {\n FONT_SIZE: 21,\n PAGE_PADDING: 50,\n AVAILABLE_FOR_HIRE: true,\n}\n\nexport default config\n","import { debounce } from 'lodash'\nimport { useEffect, useState } from 'react'\nimport config from '../config'\n\nexport interface WindowDimensions {\n height: number\n width: number\n}\n\nexport const pxToRem = (pxValue: number) => {\n const ratio = config.FONT_SIZE\n\n if (Array.isArray(pxValue)) {\n pxValue = pxValue[0]\n }\n\n return `${pxValue / ratio}rem`\n}\n\nexport const BREAKPOINTS = {\n tablet: '@media (max-width: 980px)',\n mobile: '@media (max-width: 768px)',\n}\n\nexport const useMediaQuery = (query: string) => {\n const [queryMatch, setQueryMatch] = useState<boolean | null>(null)\n\n useEffect(() => {\n const handleQueryListener = debounce(() => {\n const updatedMatches = window.matchMedia(query)\n setQueryMatch(updatedMatches.matches)\n }, 250)\n\n handleQueryListener()\n window.addEventListener('resize', handleQueryListener)\n\n return () => {\n window.removeEventListener('resize', handleQueryListener)\n }\n }, [query])\n\n return queryMatch\n}\n\n\nexport const uniqueArray = (a: any) => new Set(a.map((o: any) => o[0]))\n\nexport const useWindowResizeListener = () => {\n const [windowDimensions, setWindowDimensions] = useState<WindowDimensions>({\n height: 0,\n width: 0,\n })\n\n useEffect(() => {\n const handleWindowResize = debounce(() => {\n const width = window.innerWidth\n const height = window.innerHeight\n setWindowDimensions({\n height,\n width,\n })\n }, 250)\n\n handleWindowResize()\n window.addEventListener('resize', handleWindowResize)\n\n return () => {\n window.removeEventListener('resize', handleWindowResize)\n }\n }, [])\n\n return windowDimensions\n}\n\n// todo: change to 16 when html font-size is changed\nconst PXTOREM_RATIO = 22\n\nexport const clampBuilder = (\n minWidthPx: number,\n maxWidthPx: number,\n minPxSize: number,\n maxPxSize: number\n) => {\n const minWidth = minWidthPx / PXTOREM_RATIO\n const maxWidth = maxWidthPx / PXTOREM_RATIO\n\n const minRemWidth = minPxSize / PXTOREM_RATIO\n const maxRemWidth = maxPxSize / PXTOREM_RATIO\n\n const slope = (maxRemWidth - minRemWidth) / (maxWidth - minWidth)\n const yAxisIntersection = -minWidth * slope + minRemWidth\n\n const calculatedPreferredValue = `${yAxisIntersection.toFixed(4)}rem + ${(slope * 100).toFixed(\n 4\n )}vw`\n\n return `clamp(${minRemWidth}rem, ${calculatedPreferredValue}, ${maxRemWidth}rem)`\n}\n\nexport const clampValues = (min: number, max: number) => {\n return clampBuilder(300, 1920, min, max)\n}\n\nexport const clampValuesLandscape = (min: number, max: number) => {\n return clampBuilder(1024, 1366, min, max)\n}\n\nexport enum Device {\n fullhd = 'fullhd',\n tablet = 'tablet',\n tabletMini = 'tabletMini',\n phone = 'phone',\n}\nexport const DeviceMap: { [key in keyof typeof Device]: string } = {\n [Device.fullhd]: '(max-width: 1199.98px)',\n [Device.tablet]: '(max-width: 991.98px)',\n [Device.tabletMini]: '(max-width: 767.98px)',\n [Device.phone]: '(max-width: 575.98px)'\n}\n\nexport function landscape(device: Device, css: string): string\nexport function landscape(css: string): string\nexport function landscape(cssOrDevice: Device | string, css?: string): string {\n if (Object.values(Device).indexOf(cssOrDevice as Device) > -1) {\n return `\n body.landscape-navigation & {\n @media ${DeviceMap[cssOrDevice as Device]} {${css}}\n }\n `\n } else {\n return `body.landscape-navigation & {${cssOrDevice}}`\n }\n}\n\nexport function tabletPortrait(css: string): string\nexport function tabletPortrait(device: Device, css: string): string\nexport function tabletPortrait(cssOrDevice: Device | string, css?: string): string {\n const mediaQuery =\n cssOrDevice in Device ? DeviceMap[cssOrDevice as Device] : DeviceMap[Device.tablet]\n\n const cssProperties = css || cssOrDevice\n\n return `\n @media ${mediaQuery} and (orientation: portrait) {\n ${cssProperties}\n }\n`\n}\n\nexport function tablet(device: string, css: string): string\nexport function tablet(css: string): string\nexport function tablet(cssOrDevice: string, css?: string): string {\n const mediaQuery =\n cssOrDevice in Device ? DeviceMap[cssOrDevice as Device] : DeviceMap[Device.tablet]\n\n const cssProperties = css || cssOrDevice\n\n return `\n @media ${mediaQuery} {\n ${cssProperties}\n }\n `\n}\nexport function phone(device: string, css: string): string\nexport function phone(css: string): string\nexport function phone(cssOrDevice: string, css?: string): string {\n const mediaQuery =\n cssOrDevice in Device ? DeviceMap[cssOrDevice as Device] : DeviceMap[Device.phone]\n\n const cssProperties = css || cssOrDevice\n\n return `\n @media ${mediaQuery} {\n ${cssProperties}\n }\n `\n}","import { phone, pxToRem, tablet } from '@libs/index'\nimport styled, { css } from 'styled-components'\n\nexport const scrollbar = css`\n ::-webkit-scrollbar {\n display: initial !important;\n width: 5px;\n height: 5px;\n }\n ::-webkit-scrollbar-track {\n background-color: ${({ theme }) => theme.colors.badgeBackground};\n border-radius: 5px;\n }\n ::-webkit-scrollbar-thumb {\n background: ${({ theme }) => theme.colors.primary};\n border-radius: 5px;\n }\n`\n\nexport const Title = styled.h1`\n font-size: ${pxToRem(36)};\n ${phone(`\n font-size: ${pxToRem(20)}; \n `)}\n`\nexport const SecondaryTitle = styled.h2`\n font-size: ${pxToRem(28)};\n ${phone(`\n font-size: ${pxToRem(18)}; \n `)}\n`\n\nexport const modalStyle = css`\n .contact-modal {\n background-color: #0009 !important;\n .modal-wrapper {\n width: min(${pxToRem(800)}, 100%) !important;\n ${tablet(`\n width: max(400px, 80%)!important;\n `)}\n ${phone(`\n width: max(300px, 100%)!important;\n `)}\n }\n .modal-wrapper .modalContent {\n background: ${({ theme }) => theme.colors.body};\n border-radius: ${pxToRem(12)};\n ${phone(`\n max-height: 100vh;\n height: 100vh;\n `)}\n }\n .modal-body {\n width: 100% !important;\n }\n }\n`\n","import { pxToRem } from '@libs/index'\nimport { createGlobalStyle, DefaultTheme } from 'styled-components'\nimport { modalStyle, scrollbar } from './common'\n\nexport const PAGE_PADDING_REM = pxToRem(50)\n\nconst commonTheme = {\n\tfontSize: 21,\n\tcolors: {\n\t\tsecondary: '#B24670',\n\t\tbuttonText: '#F7FBFD',\n\t\terror: '#c95056'\n\n\t},\n}\n\nexport const lightMode: DefaultTheme = {\n\t...commonTheme,\n\tcolors: {\n\t\t...commonTheme.colors,\n\t\tpageBorder: '#e8ebec',\n\t\tprimary: '#2c738b',\n\t\ttext: '#121213',\n\t\tbody: '#F7FBFD',\n\t\ticons: '#121213',\n\t\tprojectCardBackground: '#ffffff',\n\t\tbadgeBackground: '#c9dee6'\n\t},\n}\n\nexport const darkMode: DefaultTheme = {\n\t...commonTheme,\n\tcolors: {\n\t\t...commonTheme.colors,\n\t\tpageBorder: '#000',\n\t\tprimary: '#42859e',\n\t\tbody: '#121213',\n\t\ttext: '#F7FBFD',\n\t\ticons: '#F7FBFD',\n\t\tbuttonText: '#101315',\n\t\tprojectCardBackground: '#202020',\n\t\tbadgeBackground: '#222222'\n\t},\n}\n\nexport const GlobalStyles = createGlobalStyle`\n\t${scrollbar}\n\t${modalStyle}\n\t@font-face {\n\tfont-family: \"Poppins\";\n\tsrc: local(\"Poppins\"),\n\t\turl(./assets/fonts/Poppins-Regular.ttf) format(\"truetype\");\n\t}\n\n\t@font-face {\n\tfont-family: \"PoppinsBold\";\n\tsrc: local(\"Poppins\"),\n\t\turl(./assets/fonts/Poppins-SemiBold.ttf) format(\"truetype\");\n\t}\n\n\t* {\n \tbox-sizing: border-box;\n\t\t&:focus {\n\t\t\tbox-shadow: ${props => `inset 0 0 0 1px ${props.theme.colors.primary}`};\n\t\t\toutline: 0;\n\t\t}\n \t}\n \n\n\thtml, body {\n\t\tmargin: 0;\n\t\tpadding: 0;\n\t\tfont-size: ${({ theme }) => theme.fontSize}px;\n\t\tfont-family: Poppins, Sans-Serif;\n\t\tbackground: ${({ theme }) => theme.colors.body};\n\t\tcolor: ${({ theme }) => theme.colors.text}\n\t}\n\n\thtml, body, #root {\n\t\theight: 100%;\n\t\twidth: 100%;\n\t\toverflow: hidden;\n\t}\n\n\t#root {\n\t\n\t\theight: 100dvh;\n \t\twidth: 100dvw;\n\t\t\n\t}\n\n\toutline {\n\t\t\n\t}\n\n\t.highlighted{\n\t\tcolor: ${({ theme }) => theme.colors.primary}\n\t}\n\n\ta {\n\t\theight: initial;\n\t\tdisplay: flex;\n\t\ttext-decoration: none;\n\t}\n\n\tp {\n\t\tmargin: 0\n\t}\n\n\n`\n","const { toString, hasOwnProperty } = Object.prototype;\nconst fnToStr = Function.prototype.toString;\nconst previousComparisons = new Map<object, Set<object>>();\n\n/**\n * Performs a deep equality check on two JavaScript values, tolerating cycles.\n */\nexport function equal(a: any, b: any): boolean {\n try {\n return check(a, b);\n } finally {\n previousComparisons.clear();\n }\n}\n\n// Allow default imports as well.\nexport default equal;\n\nfunction check(a: any, b: any): boolean {\n // If the two values are strictly equal, our job is easy.\n if (a === b) {\n return true;\n }\n\n // Object.prototype.toString returns a representation of the runtime type of\n // the given value that is considerably more precise than typeof.\n const aTag = toString.call(a);\n const bTag = toString.call(b);\n\n // If the runtime types of a and b are different, they could maybe be equal\n // under some interpretation of equality, but for simplicity and performance\n // we just return false instead.\n if (aTag !== bTag) {\n return false;\n }\n\n switch (aTag) {\n case '[object Array]':\n // Arrays are a lot like other objects, but we can cheaply compare their\n // lengths as a short-cut before comparing their elements.\n if (a.length !== b.length) return false;\n // Fall through to object case...\n case '[object Object]': {\n if (previouslyCompared(a, b)) return true;\n\n const aKeys = definedKeys(a);\n const bKeys = definedKeys(b);\n\n // If `a` and `b` have a different number of enumerable keys, they\n // must be different.\n const keyCount = aKeys.length;\n if (keyCount !== bKeys.length) return false;\n\n // Now make sure they have the same keys.\n for (let k = 0; k < keyCount; ++k) {\n if (!hasOwnProperty.call(b, aKeys[k])) {\n return false;\n }\n }\n\n // Finally, check deep equality of all child properties.\n for (let k = 0; k < keyCount; ++k) {\n const key = aKeys[k];\n if (!check(a[key], b[key])) {\n return false;\n }\n }\n\n return true;\n }\n\n case '[object Error]':\n return a.name === b.name && a.message === b.message;\n\n case '[object Number]':\n // Handle NaN, which is !== itself.\n if (a !== a) return b !== b;\n // Fall through to shared +a === +b case...\n case '[object Boolean]':\n case '[object Date]':\n return +a === +b;\n\n case '[object RegExp]':\n case '[object String]':\n return a == `${b}`;\n\n case '[object Map]':\n case '[object Set]': {\n if (a.size !== b.size) return false;\n if (previouslyCompared(a, b)) return true;\n\n const aIterator = a.entries();\n const isMap = aTag === '[object Map]';\n\n while (true) {\n const info = aIterator.next();\n if (info.done) break;\n\n // If a instanceof Set, aValue === aKey.\n const [aKey, aValue] = info.value;\n\n // So this works the same way for both Set and Map.\n if (!b.has(aKey)) {\n return false;\n }\n\n // However, we care about deep equality of values only when dealing\n // with Map structures.\n if (isMap && !check(aValue, b.get(aKey))) {\n return false;\n }\n }\n\n return true;\n }\n\n case '[object Uint16Array]':\n case '[object Uint8Array]': // Buffer, in Node.js.\n case '[object Uint32Array]':\n case '[object Int32Array]':\n case '[object Int8Array]':\n case '[object Int16Array]':\n case '[object ArrayBuffer]':\n // DataView doesn't need these conversions, but the equality check is\n // otherwise the same.\n a = new Uint8Array(a);\n b = new Uint8Array(b);\n // Fall through...\n case '[object DataView]': {\n let len = a.byteLength;\n if (len === b.byteLength) {\n while (len-- && a[len] === b[len]) {\n // Keep looping as long as the bytes are equal.\n }\n }\n return len === -1;\n }\n\n case '[object AsyncFunction]':\n case '[object GeneratorFunction]':\n case '[object AsyncGeneratorFunction]':\n case '[object Function]': {\n const aCode = fnToStr.call(a);\n if (aCode !== fnToStr.call(b)) {\n return false;\n }\n\n // We consider non-native functions equal if they have the same code\n // (native functions require === because their code is censored).\n // Note that this behavior is not entirely sound, since !== function\n // objects with the same code can behave differently depending on\n // their closure scope. However, any function can behave differently\n // depending on the values of its input arguments (including this)\n // and its calling context (including its closure scope), even\n // though the function object is === to itself; and it is entirely\n // possible for functions that are not === to behave exactly the\n // same under all conceivable circumstances. Because none of these\n // factors are statically decidable in JavaScript, JS function\n // equality is not well-defined. This ambiguity allows us to\n // consider the best possible heuristic among various imperfect\n // options, and equating non-native functions that have the same\n // code has enormous practical benefits, such as when comparing\n // functions that are repeatedly passed as fresh function\n // expressions within objects that are otherwise deeply equal. Since\n // any function created from the same syntactic expression (in the\n // same code location) will always stringify to the same code\n // according to fnToStr.call, we can reasonably expect these\n // repeatedly passed function expressions to have the same code, and\n // thus behave \"the same\" (with all the caveats mentioned above),\n // even though the runtime function objects are !== to one another.\n return !endsWith(aCode, nativeCodeSuffix);\n }\n }\n\n // Otherwise the values are not equal.\n return false;\n}\n\nfunction definedKeys<TObject extends object>(obj: TObject) {\n // Remember that the second argument to Array.prototype.filter will be\n // used as `this` within the callback function.\n return Object.keys(obj).filter(isDefinedKey, obj);\n}\nfunction isDefinedKey<TObject extends object>(\n this: TObject,\n key: keyof TObject,\n) {\n return this[key] !== void 0;\n}\n\nconst nativeCodeSuffix = \"{ [native code] }\";\n\nfunction endsWith(full: string, suffix: string) {\n const fromIndex = full.length - suffix.length;\n return fromIndex >= 0 &&\n full.indexOf(suffix, fromIndex) === fromIndex;\n}\n\nfunction previouslyCompared(a: object, b: object): boolean {\n // Though cyclic references can make an object graph appear infinite from the\n // perspective of a depth-first traversal, the graph still contains a finite\n // number of distinct object references. We use the previousComparisons cache\n // to avoid comparing the same pair of object references more than once, which\n // guarantees termination (even if we end up comparing every object in one\n // graph to every object in the other graph, which is extremely unlikely),\n // while still allowing weird isomorphic structures (like rings with different\n // lengths) a chance to pass the equality test.\n let bSet = previousComparisons.get(a);\n if (bSet) {\n // Return true here because we can be sure false will be returned somewhere\n // else if the objects are not equivalent.\n if (bSet.has(b)) return true;\n } else {\n previousComparisons.set(a, bSet = new Set);\n }\n bSet.add(b);\n return false;\n}\n","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","function valueOf(obj) {\n return obj.valueOf ? obj.valueOf() : Object.prototype.valueOf.call(obj);\n}\n\nfunction valueEqual(a, b) {\n // Test for strict equality first.\n if (a === b) return true;\n\n // Otherwise, if either of them == null they are not equal.\n if (a == null || b == null) return false;\n\n if (Array.isArray(a)) {\n return (\n Array.isArray(b) &&\n a.length === b.length &&\n a.every(function(item, index) {\n return valueEqual(item, b[index]);\n })\n );\n }\n\n if (typeof a === 'object' || typeof b === 'object') {\n var aValue = valueOf(a);\n var bValue = valueOf(b);\n\n if (aValue !== a || bValue !== b) return valueEqual(aValue, bValue);\n\n return Object.keys(Object.assign({}, a, b)).every(function(key) {\n return valueEqual(a[key], b[key]);\n });\n }\n\n return false;\n}\n\nexport default valueEqual;\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","module.exports = Array.isArray || function (arr) {\n return Object.prototype.toString.call(arr) == '[object Array]';\n};\n","/**\n * @license\n * Lodash <https://lodash.com/>\n * Copyright OpenJS Foundation and other contributors <https://openjsf.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\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 '<p>' + func(text) + '</p>';\n * });\n *\n * p('fred, barney, & pebbles');\n * // => '<p>fred, barney, & pebbles</p>'\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('<body>');\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('<b><%- value %></b>');\n * compiled({ 'value': '<script>' });\n * // => '<b><script></b>'\n *\n * // Use the \"evaluate\" delimiter to execute JavaScript and generate HTML.\n * var compiled = _.template('<% _.forEach(users, function(user) { %><li><%- user %></li><% }); %>');\n * compiled({ 'users': ['fred', 'barney'] });\n * // => '<li>fred</li><li>barney</li>'\n *\n * // Use the internal `print` function in \"evaluate\" delimiters.\n * var compiled = _.template('<% print(\"hello \" + user); %>!');\n * compiled({ 'user': 'barney' });\n * // => 'hello barney!'\n *\n * // Use the ES template literal delimiter as an \"interpolate\" delimiter.\n * // Disable support by replacing the \"interpolate\" delimiter.\n * var compiled = _.template('hello ${ user }!');\n * compiled({ 'user': 'pebbles' });\n * // => 'hello pebbles!'\n *\n * // Use backslashes to treat delimiters as plain text.\n * var compiled = _.template('<%= \"\\\\<%- value %\\\\>\" %>');\n * compiled({ 'value': 'ignored' });\n * // => '<%- value %>'\n *\n * // Use the `imports` option to import `jQuery` as `jq`.\n * var text = '<% jq.each(users, function(user) { %><li><%- user %></li><% }); %>';\n * var compiled = _.template(text, { 'imports': { 'jq': jQuery } });\n * compiled({ 'users': ['fred', 'barney'] });\n * // => '<li>fred</li><li>barney</li>'\n *\n * // Use the `sourceURL` option to specify a custom sourceURL for the template.\n * var compiled = _.template('hello <%= user %>!', { 'sourceURL': '/basic/greeting.jst' });\n * compiled(data);\n * // => Find the source of \"greeting.jst\" under the Sources tab or Resources panel of the web inspector.\n *\n * // Use the `variable` option to ensure a with-statement isn't used in the compiled template.\n * var compiled = _.template('hi <%= data.user %>!', { 'variable': 'data' });\n * compiled.source;\n * // => function(data) {\n * // var __t, __p = '';\n * // __p += 'hi ' + ((__t = ( data.user )) == null ? '' : __t) + '!';\n * // return __p;\n * // }\n *\n * // Use custom template delimiters.\n * _.templateSettings.interpolate = /{{([\\s\\S]+?)}}/g;\n * var compiled = _.template('hello {{ user }}!');\n * compiled({ 'user': 'mustache' });\n * // => 'hello mustache!'\n *\n * // Use the `source` property to inline compiled templates for meaningful\n * // line numbers in error messages and stack traces.\n * fs.writeFileSync(path.join(process.cwd(), 'jst.js'), '\\\n * var JST = {\\\n * \"main\": ' + _.template(mainText).source + '\\\n * };\\\n * ');\n */\n function template(string, options, guard) {\n // Based on John Resig's `tmpl` implementation\n // (http://ejohn.org/blog/javascript-micro-templating/)\n // and Laura Doktorova's doT.js (https://github.com/olado/doT).\n var settings = lodash.templateSettings;\n\n if (guard && isIterateeCall(string, options, guard)) {\n options = undefined;\n }\n string = toString(string);\n options = assignInWith({}, options, settings, customDefaultsAssignIn);\n\n var imports = assignInWith({}, options.imports, settings.imports, customDefaultsAssignIn),\n importsKeys = keys(imports),\n importsValues = baseValues(imports, importsKeys);\n\n var isEscaping,\n isEvaluating,\n index = 0,\n interpolate = options.interpolate || reNoMatch,\n source = \"__p += '\";\n\n // Compile the regexp to match each delimiter.\n var reDelimiters = RegExp(\n (options.escape || reNoMatch).source + '|' +\n interpolate.source + '|' +\n (interpolate === reInterpolate ? reEsTemplate : reNoMatch).source + '|' +\n (options.evaluate || reNoMatch).source + '|$'\n , 'g');\n\n // Use a sourceURL for easier debugging.\n // The sourceURL gets injected into the source that's eval-ed, so be careful\n // to normalize all kinds of whitespace, so e.g. newlines (and unicode versions of it) can't sneak in\n // and escape the comment, thus injecting code that gets evaled.\n var sourceURL = '//# sourceURL=' +\n (hasOwnProperty.call(options, 'sourceURL')\n ? (options.sourceURL + '').replace(/\\s/g, ' ')\n : ('lodash.templateSources[' + (++templateCounter) + ']')\n ) + '\\n';\n\n string.replace(reDelimiters, function(match, escapeValue, interpolateValue, esTemplateValue, evaluateValue, offset) {\n interpolateValue || (interpolateValue = esTemplateValue);\n\n // Escape characters that can't be included in string literals.\n source += string.slice(index, offset).replace(reUnescapedString, escapeStringChar);\n\n // Replace delimiters with snippets.\n if (escapeValue) {\n isEscaping = true;\n source += \"' +\\n__e(\" + escapeValue + \") +\\n'\";\n }\n if (evaluateValue) {\n isEvaluating = true;\n source += \"';\\n\" + evaluateValue + \";\\n__p += '\";\n }\n if (interpolateValue) {\n source += \"' +\\n((__t = (\" + interpolateValue + \")) == null ? '' : __t) +\\n'\";\n }\n index = offset + match.length;\n\n // The JS engine embedded in Adobe products needs `match` returned in\n // order to produce the correct `offset` value.\n return match;\n });\n\n source += \"';\\n\";\n\n // If `variable` is not specified wrap a with-statement around the generated\n // code to add the data object to the top of the scope chain.\n var variable = hasOwnProperty.call(options, 'variable') && options.variable;\n if (!variable) {\n source = 'with (obj) {\\n' + source + '\\n}\\n';\n }\n // Throw an error if a forbidden character was found in `variable`, to prevent\n // potential command injection attacks.\n else if (reForbiddenIdentifierChars.test(variable)) {\n throw new Error(INVALID_TEMPL_VAR_ERROR_TEXT);\n }\n\n // Cleanup code by stripping empty strings.\n source = (isEvaluating ? source.replace(reEmptyStringLeading, '') : source)\n .replace(reEmptyStringMiddle, '$1')\n .replace(reEmptyStringTrailing, '$1;');\n\n // Frame code as the function body.\n source = 'function(' + (variable || 'obj') + ') {\\n' +\n (variable\n ? ''\n : 'obj || (obj = {});\\n'\n ) +\n \"var __t, __p = ''\" +\n (isEscaping\n ? ', __e = _.escape'\n : ''\n ) +\n (isEvaluating\n ? ', __j = Array.prototype.join;\\n' +\n \"function print() { __p += __j.call(arguments, '') }\\n\"\n : ';\\n'\n ) +\n source +\n 'return __p\\n}';\n\n var result = attempt(function() {\n return Function(importsKeys, sourceURL + 'return ' + source)\n .apply(undefined, importsValues);\n });\n\n // Provide the compiled function's source by its `toString` method or\n // the `source` property as a convenience for inlining compiled templates.\n result.source = source;\n if (isError(result)) {\n throw result;\n }\n return result;\n }\n\n /**\n * Converts `string`, as a whole, to lower case just like\n * [String#toLowerCase](https://mdn.io/toLowerCase).\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 * _.toLower('--Foo-Bar--');\n * // => '--foo-bar--'\n *\n * _.toLower('fooBar');\n * // => 'foobar'\n *\n * _.toLower('__FOO_BAR__');\n * // => '__foo_bar__'\n */\n function toLower(value) {\n return toString(value).toLowerCase();\n }\n\n /**\n * Converts `string`, as a whole, to upper case just like\n * [String#toUpperCase](https://mdn.io/toUpperCase).\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 upper cased string.\n * @example\n *\n * _.toUpper('--foo-bar--');\n * // => '--FOO-BAR--'\n *\n * _.toUpper('fooBar');\n * // => 'FOOBAR'\n *\n * _.toUpper('__foo_bar__');\n * // => '__FOO_BAR__'\n */\n function toUpper(value) {\n return toString(value).toUpperCase();\n }\n\n /**\n * Removes leading and trailing whitespace or specified characters from `string`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to trim.\n * @param {string} [chars=whitespace] The characters to trim.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {string} Returns the trimmed string.\n * @example\n *\n * _.trim(' abc ');\n * // => 'abc'\n *\n * _.trim('-_-abc-_-', '_-');\n * // => 'abc'\n *\n * _.map([' foo ', ' bar '], _.trim);\n * // => ['foo', 'bar']\n */\n function trim(string, chars, guard) {\n string = toString(string);\n if (string && (guard || chars === undefined)) {\n return baseTrim(string);\n }\n if (!string || !(chars = baseToString(chars))) {\n return string;\n }\n var strSymbols = stringToArray(string),\n chrSymbols = stringToArray(chars),\n start = charsStartIndex(strSymbols, chrSymbols),\n end = charsEndIndex(strSymbols, chrSymbols) + 1;\n\n return castSlice(strSymbols, start, end).join('');\n }\n\n /**\n * Removes trailing whitespace or specified characters from `string`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to trim.\n * @param {string} [chars=whitespace] The characters to trim.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {string} Returns the trimmed string.\n * @example\n *\n * _.trimEnd(' abc ');\n * // => ' abc'\n *\n * _.trimEnd('-_-abc-_-', '_-');\n * // => '-_-abc'\n */\n function trimEnd(string, chars, guard) {\n string = toString(string);\n if (string && (guard || chars === undefined)) {\n return string.slice(0, trimmedEndIndex(string) + 1);\n }\n if (!string || !(chars = baseToString(chars))) {\n return string;\n }\n var strSymbols = stringToArray(string),\n end = charsEndIndex(strSymbols, stringToArray(chars)) + 1;\n\n return castSlice(strSymbols, 0, end).join('');\n }\n\n /**\n * Removes leading whitespace or specified characters from `string`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to trim.\n * @param {string} [chars=whitespace] The characters to trim.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {string} Returns the trimmed string.\n * @example\n *\n * _.trimStart(' abc ');\n * // => 'abc '\n *\n * _.trimStart('-_-abc-_-', '_-');\n * // => 'abc-_-'\n */\n function trimStart(string, chars, guard) {\n string = toString(string);\n if (string && (guard || chars === undefined)) {\n return string.replace(reTrimStart, '');\n }\n if (!string || !(chars = baseToString(chars))) {\n return string;\n }\n var strSymbols = stringToArray(string),\n start = charsStartIndex(strSymbols, stringToArray(chars));\n\n return castSlice(strSymbols, start).join('');\n }\n\n /**\n * Truncates `string` if it's longer than the given maximum string length.\n * The last characters of the truncated string are replaced with the omission\n * string which defaults to \"...\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category String\n * @param {string} [string=''] The string to truncate.\n * @param {Object} [options={}] The options object.\n * @param {number} [options.length=30] The maximum string length.\n * @param {string} [options.omission='...'] The string to indicate text is omitted.\n * @param {RegExp|string} [options.separator] The separator pattern to truncate to.\n * @returns {string} Returns the truncated string.\n * @example\n *\n * _.truncate('hi-diddly-ho there, neighborino');\n * // => 'hi-diddly-ho there, neighbo...'\n *\n * _.truncate('hi-diddly-ho there, neighborino', {\n * 'length': 24,\n * 'separator': ' '\n * });\n * // => 'hi-diddly-ho there,...'\n *\n * _.truncate('hi-diddly-ho there, neighborino', {\n * 'length': 24,\n * 'separator': /,? +/\n * });\n * // => 'hi-diddly-ho there...'\n *\n * _.truncate('hi-diddly-ho there, neighborino', {\n * 'omission': ' [...]'\n * });\n * // => 'hi-diddly-ho there, neig [...]'\n */\n function truncate(string, options) {\n var length = DEFAULT_TRUNC_LENGTH,\n omission = DEFAULT_TRUNC_OMISSION;\n\n if (isObject(options)) {\n var separator = 'separator' in options ? options.separator : separator;\n length = 'length' in options ? toInteger(options.length) : length;\n omission = 'omission' in options ? baseToString(options.omission) : omission;\n }\n string = toString(string);\n\n var strLength = string.length;\n if (hasUnicode(string)) {\n var strSymbols = stringToArray(string);\n strLength = strSymbols.length;\n }\n if (length >= strLength) {\n return string;\n }\n var end = length - stringSize(omission);\n if (end < 1) {\n return omission;\n }\n var result = strSymbols\n ? castSlice(strSymbols, 0, end).join('')\n : string.slice(0, end);\n\n if (separator === undefined) {\n return result + omission;\n }\n if (strSymbols) {\n end += (result.length - end);\n }\n if (isRegExp(separator)) {\n if (string.slice(end).search(separator)) {\n var match,\n substring = result;\n\n if (!separator.global) {\n separator = RegExp(separator.source, toString(reFlags.exec(separator)) + 'g');\n }\n separator.lastIndex = 0;\n while ((match = separator.exec(substring))) {\n var newEnd = match.index;\n }\n result = result.slice(0, newEnd === undefined ? end : newEnd);\n }\n } else if (string.indexOf(baseToString(separator), end) != end) {\n var index = result.lastIndexOf(separator);\n if (index > -1) {\n result = result.slice(0, index);\n }\n }\n return result + omission;\n }\n\n /**\n * The inverse of `_.escape`; this method converts the HTML entities\n * `&`, `<`, `>`, `"`, and `'` in `string` to\n * their corresponding characters.\n *\n * **Note:** No other HTML entities are unescaped. To unescape additional\n * HTML entities use a third-party library like [_he_](https://mths.be/he).\n *\n * @static\n * @memberOf _\n * @since 0.6.0\n * @category String\n * @param {string} [string=''] The string to unescape.\n * @returns {string} Returns the unescaped string.\n * @example\n *\n * _.unescape('fred, barney, & pebbles');\n * // => 'fred, barney, & pebbles'\n */\n function unescape(string) {\n string = toString(string);\n return (string && reHasEscapedHtml.test(string))\n ? string.replace(reEscapedHtml, unescapeHtmlChar)\n : string;\n }\n\n /**\n * Converts `string`, as space separated words, to upper 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 upper cased string.\n * @example\n *\n * _.upperCase('--foo-bar');\n * // => 'FOO BAR'\n *\n * _.upperCase('fooBar');\n * // => 'FOO BAR'\n *\n * _.upperCase('__foo_bar__');\n * // => 'FOO BAR'\n */\n var upperCase = createCompounder(function(result, word, index) {\n return result + (index ? ' ' : '') + word.toUpperCase();\n });\n\n /**\n * Converts the first character of `string` to upper 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 * _.upperFirst('fred');\n * // => 'Fred'\n *\n * _.upperFirst('FRED');\n * // => 'FRED'\n */\n var upperFirst = createCaseFirst('toUpperCase');\n\n /**\n * Splits `string` into an array of its words.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category String\n * @param {string} [string=''] The string to inspect.\n * @param {RegExp|string} [pattern] The pattern to match words.\n * @param- {Object} [guard] Enables use as an iteratee for methods like `_.map`.\n * @returns {Array} Returns the words of `string`.\n * @example\n *\n * _.words('fred, barney, & pebbles');\n * // => ['fred', 'barney', 'pebbles']\n *\n * _.words('fred, barney, & pebbles', /[^, ]+/g);\n * // => ['fred', 'barney', '&', 'pebbles']\n */\n function words(string, pattern, guard) {\n string = toString(string);\n pattern = guard ? undefined : pattern;\n\n if (pattern === undefined) {\n return hasUnicodeWord(string) ? unicodeWords(string) : asciiWords(string);\n }\n return string.match(pattern) || [];\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Attempts to invoke `func`, returning either the result or the caught error\n * object. Any additional arguments are provided to `func` when it's invoked.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Util\n * @param {Function} func The function to attempt.\n * @param {...*} [args] The arguments to invoke `func` with.\n * @returns {*} Returns the `func` result or error object.\n * @example\n *\n * // Avoid throwing errors for invalid selectors.\n * var elements = _.attempt(function(selector) {\n * return document.querySelectorAll(selector);\n * }, '>_>');\n *\n * if (_.isError(elements)) {\n * elements = [];\n * }\n */\n var attempt = baseRest(function(func, args) {\n try {\n return apply(func, undefined, args);\n } catch (e) {\n return isError(e) ? e : new Error(e);\n }\n });\n\n /**\n * Binds methods of an object to the object itself, overwriting the existing\n * method.\n *\n * **Note:** This method doesn't set the \"length\" property of bound functions.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {Object} object The object to bind and assign the bound methods to.\n * @param {...(string|string[])} methodNames The object method names to bind.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var view = {\n * 'label': 'docs',\n * 'click': function() {\n * console.log('clicked ' + this.label);\n * }\n * };\n *\n * _.bindAll(view, ['click']);\n * jQuery(element).on('click', view.click);\n * // => Logs 'clicked docs' when clicked.\n */\n var bindAll = flatRest(function(object, methodNames) {\n arrayEach(methodNames, function(key) {\n key = toKey(key);\n baseAssignValue(object, key, bind(object[key], object));\n });\n return object;\n });\n\n /**\n * Creates a function that iterates over `pairs` and invokes the corresponding\n * function of the first predicate to return truthy. The predicate-function\n * pairs are invoked with the `this` binding and arguments of the created\n * function.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {Array} pairs The predicate-function pairs.\n * @returns {Function} Returns the new composite function.\n * @example\n *\n * var func = _.cond([\n * [_.matches({ 'a': 1 }), _.constant('matches A')],\n * [_.conforms({ 'b': _.isNumber }), _.constant('matches B')],\n * [_.stubTrue, _.constant('no match')]\n * ]);\n *\n * func({ 'a': 1, 'b': 2 });\n * // => 'matches A'\n *\n * func({ 'a': 0, 'b': 1 });\n * // => 'matches B'\n *\n * func({ 'a': '1', 'b': '2' });\n * // => 'no match'\n */\n function cond(pairs) {\n var length = pairs == null ? 0 : pairs.length,\n toIteratee = getIteratee();\n\n pairs = !length ? [] : arrayMap(pairs, function(pair) {\n if (typeof pair[1] != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n return [toIteratee(pair[0]), pair[1]];\n });\n\n return baseRest(function(args) {\n var index = -1;\n while (++index < length) {\n var pair = pairs[index];\n if (apply(pair[0], this, args)) {\n return apply(pair[1], this, args);\n }\n }\n });\n }\n\n /**\n * Creates a function that invokes the predicate properties of `source` with\n * the corresponding property values of a given object, returning `true` if\n * all predicates return truthy, else `false`.\n *\n * **Note:** The created function is equivalent to `_.conformsTo` with\n * `source` partially applied.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {Object} source The object of property predicates to conform to.\n * @returns {Function} Returns the new spec function.\n * @example\n *\n * var objects = [\n * { 'a': 2, 'b': 1 },\n * { 'a': 1, 'b': 2 }\n * ];\n *\n * _.filter(objects, _.conforms({ 'b': function(n) { return n > 1; } }));\n * // => [{ 'a': 1, 'b': 2 }]\n */\n function conforms(source) {\n return baseConforms(baseClone(source, CLONE_DEEP_FLAG));\n }\n\n /**\n * Creates a function that returns `value`.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {*} value The value to return from the new function.\n * @returns {Function} Returns the new constant function.\n * @example\n *\n * var objects = _.times(2, _.constant({ 'a': 1 }));\n *\n * console.log(objects);\n * // => [{ 'a': 1 }, { 'a': 1 }]\n *\n * console.log(objects[0] === objects[1]);\n * // => true\n */\n function constant(value) {\n return function() {\n return value;\n };\n }\n\n /**\n * Checks `value` to determine whether a default value should be returned in\n * its place. The `defaultValue` is returned if `value` is `NaN`, `null`,\n * or `undefined`.\n *\n * @static\n * @memberOf _\n * @since 4.14.0\n * @category Util\n * @param {*} value The value to check.\n * @param {*} defaultValue The default value.\n * @returns {*} Returns the resolved value.\n * @example\n *\n * _.defaultTo(1, 10);\n * // => 1\n *\n * _.defaultTo(undefined, 10);\n * // => 10\n */\n function defaultTo(value, defaultValue) {\n return (value == null || value !== value) ? defaultValue : value;\n }\n\n /**\n * Creates a function that returns the result of invoking the given functions\n * with the `this` binding of the created function, where each successive\n * invocation is supplied the return value of the previous.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Util\n * @param {...(Function|Function[])} [funcs] The functions to invoke.\n * @returns {Function} Returns the new composite function.\n * @see _.flowRight\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var addSquare = _.flow([_.add, square]);\n * addSquare(1, 2);\n * // => 9\n */\n var flow = createFlow();\n\n /**\n * This method is like `_.flow` except that it creates a function that\n * invokes the given functions from right to left.\n *\n * @static\n * @since 3.0.0\n * @memberOf _\n * @category Util\n * @param {...(Function|Function[])} [funcs] The functions to invoke.\n * @returns {Function} Returns the new composite function.\n * @see _.flow\n * @example\n *\n * function square(n) {\n * return n * n;\n * }\n *\n * var addSquare = _.flowRight([square, _.add]);\n * addSquare(1, 2);\n * // => 9\n */\n var flowRight = createFlow(true);\n\n /**\n * This method returns the first argument it receives.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {*} value Any value.\n * @returns {*} Returns `value`.\n * @example\n *\n * var object = { 'a': 1 };\n *\n * console.log(_.identity(object) === object);\n * // => true\n */\n function identity(value) {\n return value;\n }\n\n /**\n * Creates a function that invokes `func` with the arguments of the created\n * function. If `func` is a property name, the created function returns the\n * property value for a given element. If `func` is an array or object, the\n * created function returns `true` for elements that contain the equivalent\n * source properties, otherwise it returns `false`.\n *\n * @static\n * @since 4.0.0\n * @memberOf _\n * @category Util\n * @param {*} [func=_.identity] The value to convert to a callback.\n * @returns {Function} Returns the callback.\n * @example\n *\n * var users = [\n * { 'user': 'barney', 'age': 36, 'active': true },\n * { 'user': 'fred', 'age': 40, 'active': false }\n * ];\n *\n * // The `_.matches` iteratee shorthand.\n * _.filter(users, _.iteratee({ 'user': 'barney', 'active': true }));\n * // => [{ 'user': 'barney', 'age': 36, 'active': true }]\n *\n * // The `_.matchesProperty` iteratee shorthand.\n * _.filter(users, _.iteratee(['user', 'fred']));\n * // => [{ 'user': 'fred', 'age': 40 }]\n *\n * // The `_.property` iteratee shorthand.\n * _.map(users, _.iteratee('user'));\n * // => ['barney', 'fred']\n *\n * // Create custom iteratee shorthands.\n * _.iteratee = _.wrap(_.iteratee, function(iteratee, func) {\n * return !_.isRegExp(func) ? iteratee(func) : function(string) {\n * return func.test(string);\n * };\n * });\n *\n * _.filter(['abc', 'def'], /ef/);\n * // => ['def']\n */\n function iteratee(func) {\n return baseIteratee(typeof func == 'function' ? func : baseClone(func, CLONE_DEEP_FLAG));\n }\n\n /**\n * Creates a function that performs a partial deep comparison between a given\n * object and `source`, returning `true` if the given object has equivalent\n * property values, else `false`.\n *\n * **Note:** The created function is equivalent to `_.isMatch` with `source`\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 * **Note:** Multiple values can be checked by combining several matchers\n * using `_.overSome`\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Util\n * @param {Object} source The object of property values to match.\n * @returns {Function} Returns the new spec function.\n * @example\n *\n * var objects = [\n * { 'a': 1, 'b': 2, 'c': 3 },\n * { 'a': 4, 'b': 5, 'c': 6 }\n * ];\n *\n * _.filter(objects, _.matches({ 'a': 4, 'c': 6 }));\n * // => [{ 'a': 4, 'b': 5, 'c': 6 }]\n *\n * // Checking for several possible values\n * _.filter(objects, _.overSome([_.matches({ 'a': 1 }), _.matches({ 'a': 4 })]));\n * // => [{ 'a': 1, 'b': 2, 'c': 3 }, { 'a': 4, 'b': 5, 'c': 6 }]\n */\n function matches(source) {\n return baseMatches(baseClone(source, CLONE_DEEP_FLAG));\n }\n\n /**\n * Creates a function that performs a partial deep comparison between the\n * value at `path` of a given object to `srcValue`, returning `true` if the\n * object value is equivalent, else `false`.\n *\n * **Note:** Partial comparisons will match empty array and empty object\n * `srcValue` values against any array or object value, respectively. See\n * `_.isEqual` for a list of supported value comparisons.\n *\n * **Note:** Multiple values can be checked by combining several matchers\n * using `_.overSome`\n *\n * @static\n * @memberOf _\n * @since 3.2.0\n * @category Util\n * @param {Array|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 * @example\n *\n * var objects = [\n * { 'a': 1, 'b': 2, 'c': 3 },\n * { 'a': 4, 'b': 5, 'c': 6 }\n * ];\n *\n * _.find(objects, _.matchesProperty('a', 4));\n * // => { 'a': 4, 'b': 5, 'c': 6 }\n *\n * // Checking for several possible values\n * _.filter(objects, _.overSome([_.matchesProperty('a', 1), _.matchesProperty('a', 4)]));\n * // => [{ 'a': 1, 'b': 2, 'c': 3 }, { 'a': 4, 'b': 5, 'c': 6 }]\n */\n function matchesProperty(path, srcValue) {\n return baseMatchesProperty(path, baseClone(srcValue, CLONE_DEEP_FLAG));\n }\n\n /**\n * Creates a function that invokes the method at `path` of a given object.\n * Any additional arguments are provided to the invoked method.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Util\n * @param {Array|string} path The path of the method to invoke.\n * @param {...*} [args] The arguments to invoke the method with.\n * @returns {Function} Returns the new invoker function.\n * @example\n *\n * var objects = [\n * { 'a': { 'b': _.constant(2) } },\n * { 'a': { 'b': _.constant(1) } }\n * ];\n *\n * _.map(objects, _.method('a.b'));\n * // => [2, 1]\n *\n * _.map(objects, _.method(['a', 'b']));\n * // => [2, 1]\n */\n var method = baseRest(function(path, args) {\n return function(object) {\n return baseInvoke(object, path, args);\n };\n });\n\n /**\n * The opposite of `_.method`; this method creates a function that invokes\n * the method at a given path of `object`. Any additional arguments are\n * provided to the invoked method.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Util\n * @param {Object} object The object to query.\n * @param {...*} [args] The arguments to invoke the method with.\n * @returns {Function} Returns the new invoker function.\n * @example\n *\n * var array = _.times(3, _.constant),\n * object = { 'a': array, 'b': array, 'c': array };\n *\n * _.map(['a[2]', 'c[0]'], _.methodOf(object));\n * // => [2, 0]\n *\n * _.map([['a', '2'], ['c', '0']], _.methodOf(object));\n * // => [2, 0]\n */\n var methodOf = baseRest(function(object, args) {\n return function(path) {\n return baseInvoke(object, path, args);\n };\n });\n\n /**\n * Adds all own enumerable string keyed function properties of a source\n * object to the destination object. If `object` is a function, then methods\n * are added to its prototype as well.\n *\n * **Note:** Use `_.runInContext` to create a pristine `lodash` function to\n * avoid conflicts caused by modifying the original.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {Function|Object} [object=lodash] The destination object.\n * @param {Object} source The object of functions to add.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.chain=true] Specify whether mixins are chainable.\n * @returns {Function|Object} Returns `object`.\n * @example\n *\n * function vowels(string) {\n * return _.filter(string, function(v) {\n * return /[aeiou]/i.test(v);\n * });\n * }\n *\n * _.mixin({ 'vowels': vowels });\n * _.vowels('fred');\n * // => ['e']\n *\n * _('fred').vowels().value();\n * // => ['e']\n *\n * _.mixin({ 'vowels': vowels }, { 'chain': false });\n * _('fred').vowels();\n * // => ['e']\n */\n function mixin(object, source, options) {\n var props = keys(source),\n methodNames = baseFunctions(source, props);\n\n if (options == null &&\n !(isObject(source) && (methodNames.length || !props.length))) {\n options = source;\n source = object;\n object = this;\n methodNames = baseFunctions(source, keys(source));\n }\n var chain = !(isObject(options) && 'chain' in options) || !!options.chain,\n isFunc = isFunction(object);\n\n arrayEach(methodNames, function(methodName) {\n var func = source[methodName];\n object[methodName] = func;\n if (isFunc) {\n object.prototype[methodName] = function() {\n var chainAll = this.__chain__;\n if (chain || chainAll) {\n var result = object(this.__wrapped__),\n actions = result.__actions__ = copyArray(this.__actions__);\n\n actions.push({ 'func': func, 'args': arguments, 'thisArg': object });\n result.__chain__ = chainAll;\n return result;\n }\n return func.apply(object, arrayPush([this.value()], arguments));\n };\n }\n });\n\n return object;\n }\n\n /**\n * Reverts the `_` variable to its previous value and returns a reference to\n * the `lodash` function.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @returns {Function} Returns the `lodash` function.\n * @example\n *\n * var lodash = _.noConflict();\n */\n function noConflict() {\n if (root._ === this) {\n root._ = oldDash;\n }\n return this;\n }\n\n /**\n * This method returns `undefined`.\n *\n * @static\n * @memberOf _\n * @since 2.3.0\n * @category Util\n * @example\n *\n * _.times(2, _.noop);\n * // => [undefined, undefined]\n */\n function noop() {\n // No operation performed.\n }\n\n /**\n * Creates a function that gets the argument at index `n`. If `n` is negative,\n * the nth argument from the end is returned.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {number} [n=0] The index of the argument to return.\n * @returns {Function} Returns the new pass-thru function.\n * @example\n *\n * var func = _.nthArg(1);\n * func('a', 'b', 'c', 'd');\n * // => 'b'\n *\n * var func = _.nthArg(-2);\n * func('a', 'b', 'c', 'd');\n * // => 'c'\n */\n function nthArg(n) {\n n = toInteger(n);\n return baseRest(function(args) {\n return baseNth(args, n);\n });\n }\n\n /**\n * Creates a function that invokes `iteratees` with the arguments it receives\n * and returns their results.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {...(Function|Function[])} [iteratees=[_.identity]]\n * The iteratees to invoke.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var func = _.over([Math.max, Math.min]);\n *\n * func(1, 2, 3, 4);\n * // => [4, 1]\n */\n var over = createOver(arrayMap);\n\n /**\n * Creates a function that checks if **all** of the `predicates` return\n * truthy when invoked with the arguments it receives.\n *\n * Following shorthands are possible for providing predicates.\n * Pass an `Object` and it will be used as an parameter for `_.matches` to create the predicate.\n * Pass an `Array` of parameters for `_.matchesProperty` and the predicate will be created using them.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {...(Function|Function[])} [predicates=[_.identity]]\n * The predicates to check.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var func = _.overEvery([Boolean, isFinite]);\n *\n * func('1');\n * // => true\n *\n * func(null);\n * // => false\n *\n * func(NaN);\n * // => false\n */\n var overEvery = createOver(arrayEvery);\n\n /**\n * Creates a function that checks if **any** of the `predicates` return\n * truthy when invoked with the arguments it receives.\n *\n * Following shorthands are possible for providing predicates.\n * Pass an `Object` and it will be used as an parameter for `_.matches` to create the predicate.\n * Pass an `Array` of parameters for `_.matchesProperty` and the predicate will be created using them.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {...(Function|Function[])} [predicates=[_.identity]]\n * The predicates to check.\n * @returns {Function} Returns the new function.\n * @example\n *\n * var func = _.overSome([Boolean, isFinite]);\n *\n * func('1');\n * // => true\n *\n * func(null);\n * // => true\n *\n * func(NaN);\n * // => false\n *\n * var matchesFunc = _.overSome([{ 'a': 1 }, { 'a': 2 }])\n * var matchesPropertyFunc = _.overSome([['a', 1], ['a', 2]])\n */\n var overSome = createOver(arraySome);\n\n /**\n * Creates a function that returns the value at `path` of a given object.\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Util\n * @param {Array|string} path The path of the property to get.\n * @returns {Function} Returns the new accessor function.\n * @example\n *\n * var objects = [\n * { 'a': { 'b': 2 } },\n * { 'a': { 'b': 1 } }\n * ];\n *\n * _.map(objects, _.property('a.b'));\n * // => [2, 1]\n *\n * _.map(_.sortBy(objects, _.property(['a', 'b'])), 'a.b');\n * // => [1, 2]\n */\n function property(path) {\n return isKey(path) ? baseProperty(toKey(path)) : basePropertyDeep(path);\n }\n\n /**\n * The opposite of `_.property`; this method creates a function that returns\n * the value at a given path of `object`.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Util\n * @param {Object} object The object to query.\n * @returns {Function} Returns the new accessor function.\n * @example\n *\n * var array = [0, 1, 2],\n * object = { 'a': array, 'b': array, 'c': array };\n *\n * _.map(['a[2]', 'c[0]'], _.propertyOf(object));\n * // => [2, 0]\n *\n * _.map([['a', '2'], ['c', '0']], _.propertyOf(object));\n * // => [2, 0]\n */\n function propertyOf(object) {\n return function(path) {\n return object == null ? undefined : baseGet(object, path);\n };\n }\n\n /**\n * Creates an array of numbers (positive and/or negative) progressing from\n * `start` up to, but not including, `end`. A step of `-1` is used if a negative\n * `start` is specified without an `end` or `step`. If `end` is not specified,\n * it's set to `start` with `start` then set to `0`.\n *\n * **Note:** JavaScript follows the IEEE-754 standard for resolving\n * floating-point values which can produce unexpected results.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {number} [start=0] The start of the range.\n * @param {number} end The end of the range.\n * @param {number} [step=1] The value to increment or decrement by.\n * @returns {Array} Returns the range of numbers.\n * @see _.inRange, _.rangeRight\n * @example\n *\n * _.range(4);\n * // => [0, 1, 2, 3]\n *\n * _.range(-4);\n * // => [0, -1, -2, -3]\n *\n * _.range(1, 5);\n * // => [1, 2, 3, 4]\n *\n * _.range(0, 20, 5);\n * // => [0, 5, 10, 15]\n *\n * _.range(0, -4, -1);\n * // => [0, -1, -2, -3]\n *\n * _.range(1, 4, 0);\n * // => [1, 1, 1]\n *\n * _.range(0);\n * // => []\n */\n var range = createRange();\n\n /**\n * This method is like `_.range` except that it populates values in\n * descending order.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {number} [start=0] The start of the range.\n * @param {number} end The end of the range.\n * @param {number} [step=1] The value to increment or decrement by.\n * @returns {Array} Returns the range of numbers.\n * @see _.inRange, _.range\n * @example\n *\n * _.rangeRight(4);\n * // => [3, 2, 1, 0]\n *\n * _.rangeRight(-4);\n * // => [-3, -2, -1, 0]\n *\n * _.rangeRight(1, 5);\n * // => [4, 3, 2, 1]\n *\n * _.rangeRight(0, 20, 5);\n * // => [15, 10, 5, 0]\n *\n * _.rangeRight(0, -4, -1);\n * // => [-3, -2, -1, 0]\n *\n * _.rangeRight(1, 4, 0);\n * // => [1, 1, 1]\n *\n * _.rangeRight(0);\n * // => []\n */\n var rangeRight = createRange(true);\n\n /**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\n function stubArray() {\n return [];\n }\n\n /**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\n function stubFalse() {\n return false;\n }\n\n /**\n * This method returns a new empty object.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Object} Returns the new empty object.\n * @example\n *\n * var objects = _.times(2, _.stubObject);\n *\n * console.log(objects);\n * // => [{}, {}]\n *\n * console.log(objects[0] === objects[1]);\n * // => false\n */\n function stubObject() {\n return {};\n }\n\n /**\n * This method returns an empty string.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {string} Returns the empty string.\n * @example\n *\n * _.times(2, _.stubString);\n * // => ['', '']\n */\n function stubString() {\n return '';\n }\n\n /**\n * This method returns `true`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `true`.\n * @example\n *\n * _.times(2, _.stubTrue);\n * // => [true, true]\n */\n function stubTrue() {\n return true;\n }\n\n /**\n * Invokes the iteratee `n` times, returning an array of the results of\n * each invocation. The iteratee is invoked with one argument; (index).\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} [iteratee=_.identity] The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n * @example\n *\n * _.times(3, String);\n * // => ['0', '1', '2']\n *\n * _.times(4, _.constant(0));\n * // => [0, 0, 0, 0]\n */\n function times(n, iteratee) {\n n = toInteger(n);\n if (n < 1 || n > MAX_SAFE_INTEGER) {\n return [];\n }\n var index = MAX_ARRAY_LENGTH,\n length = nativeMin(n, MAX_ARRAY_LENGTH);\n\n iteratee = getIteratee(iteratee);\n n -= MAX_ARRAY_LENGTH;\n\n var result = baseTimes(length, iteratee);\n while (++index < n) {\n iteratee(index);\n }\n return result;\n }\n\n /**\n * Converts `value` to a property path array.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Util\n * @param {*} value The value to convert.\n * @returns {Array} Returns the new property path array.\n * @example\n *\n * _.toPath('a.b.c');\n * // => ['a', 'b', 'c']\n *\n * _.toPath('a[0].b.c');\n * // => ['a', '0', 'b', 'c']\n */\n function toPath(value) {\n if (isArray(value)) {\n return arrayMap(value, toKey);\n }\n return isSymbol(value) ? [value] : copyArray(stringToPath(toString(value)));\n }\n\n /**\n * Generates a unique ID. If `prefix` is given, the ID is appended to it.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Util\n * @param {string} [prefix=''] The value to prefix the ID with.\n * @returns {string} Returns the unique ID.\n * @example\n *\n * _.uniqueId('contact_');\n * // => 'contact_104'\n *\n * _.uniqueId();\n * // => '105'\n */\n function uniqueId(prefix) {\n var id = ++idCounter;\n return toString(prefix) + id;\n }\n\n /*------------------------------------------------------------------------*/\n\n /**\n * Adds two numbers.\n *\n * @static\n * @memberOf _\n * @since 3.4.0\n * @category Math\n * @param {number} augend The first number in an addition.\n * @param {number} addend The second number in an addition.\n * @returns {number} Returns the total.\n * @example\n *\n * _.add(6, 4);\n * // => 10\n */\n var add = createMathOperation(function(augend, addend) {\n return augend + addend;\n }, 0);\n\n /**\n * Computes `number` rounded up to `precision`.\n *\n * @static\n * @memberOf _\n * @since 3.10.0\n * @category Math\n * @param {number} number The number to round up.\n * @param {number} [precision=0] The precision to round up to.\n * @returns {number} Returns the rounded up number.\n * @example\n *\n * _.ceil(4.006);\n * // => 5\n *\n * _.ceil(6.004, 2);\n * // => 6.01\n *\n * _.ceil(6040, -2);\n * // => 6100\n */\n var ceil = createRound('ceil');\n\n /**\n * Divide two numbers.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Math\n * @param {number} dividend The first number in a division.\n * @param {number} divisor The second number in a division.\n * @returns {number} Returns the quotient.\n * @example\n *\n * _.divide(6, 4);\n * // => 1.5\n */\n var divide = createMathOperation(function(dividend, divisor) {\n return dividend / divisor;\n }, 1);\n\n /**\n * Computes `number` rounded down to `precision`.\n *\n * @static\n * @memberOf _\n * @since 3.10.0\n * @category Math\n * @param {number} number The number to round down.\n * @param {number} [precision=0] The precision to round down to.\n * @returns {number} Returns the rounded down number.\n * @example\n *\n * _.floor(4.006);\n * // => 4\n *\n * _.floor(0.046, 2);\n * // => 0.04\n *\n * _.floor(4060, -2);\n * // => 4000\n */\n var floor = createRound('floor');\n\n /**\n * Computes the maximum value of `array`. If `array` is empty or falsey,\n * `undefined` is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {*} Returns the maximum value.\n * @example\n *\n * _.max([4, 2, 8, 6]);\n * // => 8\n *\n * _.max([]);\n * // => undefined\n */\n function max(array) {\n return (array && array.length)\n ? baseExtremum(array, identity, baseGt)\n : undefined;\n }\n\n /**\n * This method is like `_.max` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the criterion by which\n * the value is ranked. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {*} Returns the maximum value.\n * @example\n *\n * var objects = [{ 'n': 1 }, { 'n': 2 }];\n *\n * _.maxBy(objects, function(o) { return o.n; });\n * // => { 'n': 2 }\n *\n * // The `_.property` iteratee shorthand.\n * _.maxBy(objects, 'n');\n * // => { 'n': 2 }\n */\n function maxBy(array, iteratee) {\n return (array && array.length)\n ? baseExtremum(array, getIteratee(iteratee, 2), baseGt)\n : undefined;\n }\n\n /**\n * Computes the mean of the values in `array`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {number} Returns the mean.\n * @example\n *\n * _.mean([4, 2, 8, 6]);\n * // => 5\n */\n function mean(array) {\n return baseMean(array, identity);\n }\n\n /**\n * This method is like `_.mean` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the value to be averaged.\n * The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the mean.\n * @example\n *\n * var objects = [{ 'n': 4 }, { 'n': 2 }, { 'n': 8 }, { 'n': 6 }];\n *\n * _.meanBy(objects, function(o) { return o.n; });\n * // => 5\n *\n * // The `_.property` iteratee shorthand.\n * _.meanBy(objects, 'n');\n * // => 5\n */\n function meanBy(array, iteratee) {\n return baseMean(array, getIteratee(iteratee, 2));\n }\n\n /**\n * Computes the minimum value of `array`. If `array` is empty or falsey,\n * `undefined` is returned.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {*} Returns the minimum value.\n * @example\n *\n * _.min([4, 2, 8, 6]);\n * // => 2\n *\n * _.min([]);\n * // => undefined\n */\n function min(array) {\n return (array && array.length)\n ? baseExtremum(array, identity, baseLt)\n : undefined;\n }\n\n /**\n * This method is like `_.min` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the criterion by which\n * the value is ranked. The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {*} Returns the minimum value.\n * @example\n *\n * var objects = [{ 'n': 1 }, { 'n': 2 }];\n *\n * _.minBy(objects, function(o) { return o.n; });\n * // => { 'n': 1 }\n *\n * // The `_.property` iteratee shorthand.\n * _.minBy(objects, 'n');\n * // => { 'n': 1 }\n */\n function minBy(array, iteratee) {\n return (array && array.length)\n ? baseExtremum(array, getIteratee(iteratee, 2), baseLt)\n : undefined;\n }\n\n /**\n * Multiply two numbers.\n *\n * @static\n * @memberOf _\n * @since 4.7.0\n * @category Math\n * @param {number} multiplier The first number in a multiplication.\n * @param {number} multiplicand The second number in a multiplication.\n * @returns {number} Returns the product.\n * @example\n *\n * _.multiply(6, 4);\n * // => 24\n */\n var multiply = createMathOperation(function(multiplier, multiplicand) {\n return multiplier * multiplicand;\n }, 1);\n\n /**\n * Computes `number` rounded to `precision`.\n *\n * @static\n * @memberOf _\n * @since 3.10.0\n * @category Math\n * @param {number} number The number to round.\n * @param {number} [precision=0] The precision to round to.\n * @returns {number} Returns the rounded number.\n * @example\n *\n * _.round(4.006);\n * // => 4\n *\n * _.round(4.006, 2);\n * // => 4.01\n *\n * _.round(4060, -2);\n * // => 4100\n */\n var round = createRound('round');\n\n /**\n * Subtract two numbers.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {number} minuend The first number in a subtraction.\n * @param {number} subtrahend The second number in a subtraction.\n * @returns {number} Returns the difference.\n * @example\n *\n * _.subtract(6, 4);\n * // => 2\n */\n var subtract = createMathOperation(function(minuend, subtrahend) {\n return minuend - subtrahend;\n }, 0);\n\n /**\n * Computes the sum of the values in `array`.\n *\n * @static\n * @memberOf _\n * @since 3.4.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @returns {number} Returns the sum.\n * @example\n *\n * _.sum([4, 2, 8, 6]);\n * // => 20\n */\n function sum(array) {\n return (array && array.length)\n ? baseSum(array, identity)\n : 0;\n }\n\n /**\n * This method is like `_.sum` except that it accepts `iteratee` which is\n * invoked for each element in `array` to generate the value to be summed.\n * The iteratee is invoked with one argument: (value).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Math\n * @param {Array} array The array to iterate over.\n * @param {Function} [iteratee=_.identity] The iteratee invoked per element.\n * @returns {number} Returns the sum.\n * @example\n *\n * var objects = [{ 'n': 4 }, { 'n': 2 }, { 'n': 8 }, { 'n': 6 }];\n *\n * _.sumBy(objects, function(o) { return o.n; });\n * // => 20\n *\n * // The `_.property` iteratee shorthand.\n * _.sumBy(objects, 'n');\n * // => 20\n */\n function sumBy(array, iteratee) {\n return (array && array.length)\n ? baseSum(array, getIteratee(iteratee, 2))\n : 0;\n }\n\n /*------------------------------------------------------------------------*/\n\n // Add methods that return wrapped values in chain sequences.\n lodash.after = after;\n lodash.ary = ary;\n lodash.assign = assign;\n lodash.assignIn = assignIn;\n lodash.assignInWith = assignInWith;\n lodash.assignWith = assignWith;\n lodash.at = at;\n lodash.before = before;\n lodash.bind = bind;\n lodash.bindAll = bindAll;\n lodash.bindKey = bindKey;\n lodash.castArray = castArray;\n lodash.chain = chain;\n lodash.chunk = chunk;\n lodash.compact = compact;\n lodash.concat = concat;\n lodash.cond = cond;\n lodash.conforms = conforms;\n lodash.constant = constant;\n lodash.countBy = countBy;\n lodash.create = create;\n lodash.curry = curry;\n lodash.curryRight = curryRight;\n lodash.debounce = debounce;\n lodash.defaults = defaults;\n lodash.defaultsDeep = defaultsDeep;\n lodash.defer = defer;\n lodash.delay = delay;\n lodash.difference = difference;\n lodash.differenceBy = differenceBy;\n lodash.differenceWith = differenceWith;\n lodash.drop = drop;\n lodash.dropRight = dropRight;\n lodash.dropRightWhile = dropRightWhile;\n lodash.dropWhile = dropWhile;\n lodash.fill = fill;\n lodash.filter = filter;\n lodash.flatMap = flatMap;\n lodash.flatMapDeep = flatMapDeep;\n lodash.flatMapDepth = flatMapDepth;\n lodash.flatten = flatten;\n lodash.flattenDeep = flattenDeep;\n lodash.flattenDepth = flattenDepth;\n lodash.flip = flip;\n lodash.flow = flow;\n lodash.flowRight = flowRight;\n lodash.fromPairs = fromPairs;\n lodash.functions = functions;\n lodash.functionsIn = functionsIn;\n lodash.groupBy = groupBy;\n lodash.initial = initial;\n lodash.intersection = intersection;\n lodash.intersectionBy = intersectionBy;\n lodash.intersectionWith = intersectionWith;\n lodash.invert = invert;\n lodash.invertBy = invertBy;\n lodash.invokeMap = invokeMap;\n lodash.iteratee = iteratee;\n lodash.keyBy = keyBy;\n lodash.keys = keys;\n lodash.keysIn = keysIn;\n lodash.map = map;\n lodash.mapKeys = mapKeys;\n lodash.mapValues = mapValues;\n lodash.matches = matches;\n lodash.matchesProperty = matchesProperty;\n lodash.memoize = memoize;\n lodash.merge = merge;\n lodash.mergeWith = mergeWith;\n lodash.method = method;\n lodash.methodOf = methodOf;\n lodash.mixin = mixin;\n lodash.negate = negate;\n lodash.nthArg = nthArg;\n lodash.omit = omit;\n lodash.omitBy = omitBy;\n lodash.once = once;\n lodash.orderBy = orderBy;\n lodash.over = over;\n lodash.overArgs = overArgs;\n lodash.overEvery = overEvery;\n lodash.overSome = overSome;\n lodash.partial = partial;\n lodash.partialRight = partialRight;\n lodash.partition = partition;\n lodash.pick = pick;\n lodash.pickBy = pickBy;\n lodash.property = property;\n lodash.propertyOf = propertyOf;\n lodash.pull = pull;\n lodash.pullAll = pullAll;\n lodash.pullAllBy = pullAllBy;\n lodash.pullAllWith = pullAllWith;\n lodash.pullAt = pullAt;\n lodash.range = range;\n lodash.rangeRight = rangeRight;\n lodash.rearg = rearg;\n lodash.reject = reject;\n lodash.remove = remove;\n lodash.rest = rest;\n lodash.reverse = reverse;\n lodash.sampleSize = sampleSize;\n lodash.set = set;\n lodash.setWith = setWith;\n lodash.shuffle = shuffle;\n lodash.slice = slice;\n lodash.sortBy = sortBy;\n lodash.sortedUniq = sortedUniq;\n lodash.sortedUniqBy = sortedUniqBy;\n lodash.split = split;\n lodash.spread = spread;\n lodash.tail = tail;\n lodash.take = take;\n lodash.takeRight = takeRight;\n lodash.takeRightWhile = takeRightWhile;\n lodash.takeWhile = takeWhile;\n lodash.tap = tap;\n lodash.throttle = throttle;\n lodash.thru = thru;\n lodash.toArray = toArray;\n lodash.toPairs = toPairs;\n lodash.toPairsIn = toPairsIn;\n lodash.toPath = toPath;\n lodash.toPlainObject = toPlainObject;\n lodash.transform = transform;\n lodash.unary = unary;\n lodash.union = union;\n lodash.unionBy = unionBy;\n lodash.unionWith = unionWith;\n lodash.uniq = uniq;\n lodash.uniqBy = uniqBy;\n lodash.uniqWith = uniqWith;\n lodash.unset = unset;\n lodash.unzip = unzip;\n lodash.unzipWith = unzipWith;\n lodash.update = update;\n lodash.updateWith = updateWith;\n lodash.values = values;\n lodash.valuesIn = valuesIn;\n lodash.without = without;\n lodash.words = words;\n lodash.wrap = wrap;\n lodash.xor = xor;\n lodash.xorBy = xorBy;\n lodash.xorWith = xorWith;\n lodash.zip = zip;\n lodash.zipObject = zipObject;\n lodash.zipObjectDeep = zipObjectDeep;\n lodash.zipWith = zipWith;\n\n // Add aliases.\n lodash.entries = toPairs;\n lodash.entriesIn = toPairsIn;\n lodash.extend = assignIn;\n lodash.extendWith = assignInWith;\n\n // Add methods to `lodash.prototype`.\n mixin(lodash, lodash);\n\n /*------------------------------------------------------------------------*/\n\n // Add methods that return unwrapped values in chain sequences.\n lodash.add = add;\n lodash.attempt = attempt;\n lodash.camelCase = camelCase;\n lodash.capitalize = capitalize;\n lodash.ceil = ceil;\n lodash.clamp = clamp;\n lodash.clone = clone;\n lodash.cloneDeep = cloneDeep;\n lodash.cloneDeepWith = cloneDeepWith;\n lodash.cloneWith = cloneWith;\n lodash.conformsTo = conformsTo;\n lodash.deburr = deburr;\n lodash.defaultTo = defaultTo;\n lodash.divide = divide;\n lodash.endsWith = endsWith;\n lodash.eq = eq;\n lodash.escape = escape;\n lodash.escapeRegExp = escapeRegExp;\n lodash.every = every;\n lodash.find = find;\n lodash.findIndex = findIndex;\n lodash.findKey = findKey;\n lodash.findLast = findLast;\n lodash.findLastIndex = findLastIndex;\n lodash.findLastKey = findLastKey;\n lodash.floor = floor;\n lodash.forEach = forEach;\n lodash.forEachRight = forEachRight;\n lodash.forIn = forIn;\n lodash.forInRight = forInRight;\n lodash.forOwn = forOwn;\n lodash.forOwnRight = forOwnRight;\n lodash.get = get;\n lodash.gt = gt;\n lodash.gte = gte;\n lodash.has = has;\n lodash.hasIn = hasIn;\n lodash.head = head;\n lodash.identity = identity;\n lodash.includes = includes;\n lodash.indexOf = indexOf;\n lodash.inRange = inRange;\n lodash.invoke = invoke;\n lodash.isArguments = isArguments;\n lodash.isArray = isArray;\n lodash.isArrayBuffer = isArrayBuffer;\n lodash.isArrayLike = isArrayLike;\n lodash.isArrayLikeObject = isArrayLikeObject;\n lodash.isBoolean = isBoolean;\n lodash.isBuffer = isBuffer;\n lodash.isDate = isDate;\n lodash.isElement = isElement;\n lodash.isEmpty = isEmpty;\n lodash.isEqual = isEqual;\n lodash.isEqualWith = isEqualWith;\n lodash.isError = isError;\n lodash.isFinite = isFinite;\n lodash.isFunction = isFunction;\n lodash.isInteger = isInteger;\n lodash.isLength = isLength;\n lodash.isMap = isMap;\n lodash.isMatch = isMatch;\n lodash.isMatchWith = isMatchWith;\n lodash.isNaN = isNaN;\n lodash.isNative = isNative;\n lodash.isNil = isNil;\n lodash.isNull = isNull;\n lodash.isNumber = isNumber;\n lodash.isObject = isObject;\n lodash.isObjectLike = isObjectLike;\n lodash.isPlainObject = isPlainObject;\n lodash.isRegExp = isRegExp;\n lodash.isSafeInteger = isSafeInteger;\n lodash.isSet = isSet;\n lodash.isString = isString;\n lodash.isSymbol = isSymbol;\n lodash.isTypedArray = isTypedArray;\n lodash.isUndefined = isUndefined;\n lodash.isWeakMap = isWeakMap;\n lodash.isWeakSet = isWeakSet;\n lodash.join = join;\n lodash.kebabCase = kebabCase;\n lodash.last = last;\n lodash.lastIndexOf = lastIndexOf;\n lodash.lowerCase = lowerCase;\n lodash.lowerFirst = lowerFirst;\n lodash.lt = lt;\n lodash.lte = lte;\n lodash.max = max;\n lodash.maxBy = maxBy;\n lodash.mean = mean;\n lodash.meanBy = meanBy;\n lodash.min = min;\n lodash.minBy = minBy;\n lodash.stubArray = stubArray;\n lodash.stubFalse = stubFalse;\n lodash.stubObject = stubObject;\n lodash.stubString = stubString;\n lodash.stubTrue = stubTrue;\n lodash.multiply = multiply;\n lodash.nth = nth;\n lodash.noConflict = noConflict;\n lodash.noop = noop;\n lodash.now = now;\n lodash.pad = pad;\n lodash.padEnd = padEnd;\n lodash.padStart = padStart;\n lodash.parseInt = parseInt;\n lodash.random = random;\n lodash.reduce = reduce;\n lodash.reduceRight = reduceRight;\n lodash.repeat = repeat;\n lodash.replace = replace;\n lodash.result = result;\n lodash.round = round;\n lodash.runInContext = runInContext;\n lodash.sample = sample;\n lodash.size = size;\n lodash.snakeCase = snakeCase;\n lodash.some = some;\n lodash.sortedIndex = sortedIndex;\n lodash.sortedIndexBy = sortedIndexBy;\n lodash.sortedIndexOf = sortedIndexOf;\n lodash.sortedLastIndex = sortedLastIndex;\n lodash.sortedLastIndexBy = sortedLastIndexBy;\n lodash.sortedLastIndexOf = sortedLastIndexOf;\n lodash.startCase = startCase;\n lodash.startsWith = startsWith;\n lodash.subtract = subtract;\n lodash.sum = sum;\n lodash.sumBy = sumBy;\n lodash.template = template;\n lodash.times = times;\n lodash.toFinite = toFinite;\n lodash.toInteger = toInteger;\n lodash.toLength = toLength;\n lodash.toLower = toLower;\n lodash.toNumber = toNumber;\n lodash.toSafeInteger = toSafeInteger;\n lodash.toString = toString;\n lodash.toUpper = toUpper;\n lodash.trim = trim;\n lodash.trimEnd = trimEnd;\n lodash.trimStart = trimStart;\n lodash.truncate = truncate;\n lodash.unescape = unescape;\n lodash.uniqueId = uniqueId;\n lodash.upperCase = upperCase;\n lodash.upperFirst = upperFirst;\n\n // Add aliases.\n lodash.each = forEach;\n lodash.eachRight = forEachRight;\n lodash.first = head;\n\n mixin(lodash, (function() {\n var source = {};\n baseForOwn(lodash, function(func, methodName) {\n if (!hasOwnProperty.call(lodash.prototype, methodName)) {\n source[methodName] = func;\n }\n });\n return source;\n }()), { 'chain': false });\n\n /*------------------------------------------------------------------------*/\n\n /**\n * The semantic version number.\n *\n * @static\n * @memberOf _\n * @type {string}\n */\n lodash.VERSION = VERSION;\n\n // Assign default placeholders.\n arrayEach(['bind', 'bindKey', 'curry', 'curryRight', 'partial', 'partialRight'], function(methodName) {\n lodash[methodName].placeholder = lodash;\n });\n\n // Add `LazyWrapper` methods for `_.drop` and `_.take` variants.\n arrayEach(['drop', 'take'], function(methodName, index) {\n LazyWrapper.prototype[methodName] = function(n) {\n n = n === undefined ? 1 : nativeMax(toInteger(n), 0);\n\n var result = (this.__filtered__ && !index)\n ? new LazyWrapper(this)\n : this.clone();\n\n if (result.__filtered__) {\n result.__takeCount__ = nativeMin(n, result.__takeCount__);\n } else {\n result.__views__.push({\n 'size': nativeMin(n, MAX_ARRAY_LENGTH),\n 'type': methodName + (result.__dir__ < 0 ? 'Right' : '')\n });\n }\n return result;\n };\n\n LazyWrapper.prototype[methodName + 'Right'] = function(n) {\n return this.reverse()[methodName](n).reverse();\n };\n });\n\n // Add `LazyWrapper` methods that accept an `iteratee` value.\n arrayEach(['filter', 'map', 'takeWhile'], function(methodName, index) {\n var type = index + 1,\n isFilter = type == LAZY_FILTER_FLAG || type == LAZY_WHILE_FLAG;\n\n LazyWrapper.prototype[methodName] = function(iteratee) {\n var result = this.clone();\n result.__iteratees__.push({\n 'iteratee': getIteratee(iteratee, 3),\n 'type': type\n });\n result.__filtered__ = result.__filtered__ || isFilter;\n return result;\n };\n });\n\n // Add `LazyWrapper` methods for `_.head` and `_.last`.\n arrayEach(['head', 'last'], function(methodName, index) {\n var takeName = 'take' + (index ? 'Right' : '');\n\n LazyWrapper.prototype[methodName] = function() {\n return this[takeName](1).value()[0];\n };\n });\n\n // Add `LazyWrapper` methods for `_.initial` and `_.tail`.\n arrayEach(['initial', 'tail'], function(methodName, index) {\n var dropName = 'drop' + (index ? '' : 'Right');\n\n LazyWrapper.prototype[methodName] = function() {\n return this.__filtered__ ? new LazyWrapper(this) : this[dropName](1);\n };\n });\n\n LazyWrapper.prototype.compact = function() {\n return this.filter(identity);\n };\n\n LazyWrapper.prototype.find = function(predicate) {\n return this.filter(predicate).head();\n };\n\n LazyWrapper.prototype.findLast = function(predicate) {\n return this.reverse().find(predicate);\n };\n\n LazyWrapper.prototype.invokeMap = baseRest(function(path, args) {\n if (typeof path == 'function') {\n return new LazyWrapper(this);\n }\n return this.map(function(value) {\n return baseInvoke(value, path, args);\n });\n });\n\n LazyWrapper.prototype.reject = function(predicate) {\n return this.filter(negate(getIteratee(predicate)));\n };\n\n LazyWrapper.prototype.slice = function(start, end) {\n start = toInteger(start);\n\n var result = this;\n if (result.__filtered__ && (start > 0 || end < 0)) {\n return new LazyWrapper(result);\n }\n if (start < 0) {\n result = result.takeRight(-start);\n } else if (start) {\n result = result.drop(start);\n }\n if (end !== undefined) {\n end = toInteger(end);\n result = end < 0 ? result.dropRight(-end) : result.take(end - start);\n }\n return result;\n };\n\n LazyWrapper.prototype.takeRightWhile = function(predicate) {\n return this.reverse().takeWhile(predicate).reverse();\n };\n\n LazyWrapper.prototype.toArray = function() {\n return this.take(MAX_ARRAY_LENGTH);\n };\n\n // Add `LazyWrapper` methods to `lodash.prototype`.\n baseForOwn(LazyWrapper.prototype, function(func, methodName) {\n var checkIteratee = /^(?:filter|find|map|reject)|While$/.test(methodName),\n isTaker = /^(?:head|last)$/.test(methodName),\n lodashFunc = lodash[isTaker ? ('take' + (methodName == 'last' ? 'Right' : '')) : methodName],\n retUnwrapped = isTaker || /^find/.test(methodName);\n\n if (!lodashFunc) {\n return;\n }\n lodash.prototype[methodName] = function() {\n var value = this.__wrapped__,\n args = isTaker ? [1] : arguments,\n isLazy = value instanceof LazyWrapper,\n iteratee = args[0],\n useLazy = isLazy || isArray(value);\n\n var interceptor = function(value) {\n var result = lodashFunc.apply(lodash, arrayPush([value], args));\n return (isTaker && chainAll) ? result[0] : result;\n };\n\n if (useLazy && checkIteratee && typeof iteratee == 'function' && iteratee.length != 1) {\n // Avoid lazy use if the iteratee has a \"length\" value other than `1`.\n isLazy = useLazy = false;\n }\n var chainAll = this.__chain__,\n isHybrid = !!this.__actions__.length,\n isUnwrapped = retUnwrapped && !chainAll,\n onlyLazy = isLazy && !isHybrid;\n\n if (!retUnwrapped && useLazy) {\n value = onlyLazy ? value : new LazyWrapper(this);\n var result = func.apply(value, args);\n result.__actions__.push({ 'func': thru, 'args': [interceptor], 'thisArg': undefined });\n return new LodashWrapper(result, chainAll);\n }\n if (isUnwrapped && onlyLazy) {\n return func.apply(this, args);\n }\n result = this.thru(interceptor);\n return isUnwrapped ? (isTaker ? result.value()[0] : result.value()) : result;\n };\n });\n\n // Add `Array` methods to `lodash.prototype`.\n arrayEach(['pop', 'push', 'shift', 'sort', 'splice', 'unshift'], function(methodName) {\n var func = arrayProto[methodName],\n chainName = /^(?:push|sort|unshift)$/.test(methodName) ? 'tap' : 'thru',\n retUnwrapped = /^(?:pop|shift)$/.test(methodName);\n\n lodash.prototype[methodName] = function() {\n var args = arguments;\n if (retUnwrapped && !this.__chain__) {\n var value = this.value();\n return func.apply(isArray(value) ? value : [], args);\n }\n return this[chainName](function(value) {\n return func.apply(isArray(value) ? value : [], args);\n });\n };\n });\n\n // Map minified method names to their real names.\n baseForOwn(LazyWrapper.prototype, function(func, methodName) {\n var lodashFunc = lodash[methodName];\n if (lodashFunc) {\n var key = lodashFunc.name + '';\n if (!hasOwnProperty.call(realNames, key)) {\n realNames[key] = [];\n }\n realNames[key].push({ 'name': methodName, 'func': lodashFunc });\n }\n });\n\n realNames[createHybrid(undefined, WRAP_BIND_KEY_FLAG).name] = [{\n 'name': 'wrapper',\n 'func': undefined\n }];\n\n // Add methods to `LazyWrapper`.\n LazyWrapper.prototype.clone = lazyClone;\n LazyWrapper.prototype.reverse = lazyReverse;\n LazyWrapper.prototype.value = lazyValue;\n\n // Add chain sequence methods to the `lodash` wrapper.\n lodash.prototype.at = wrapperAt;\n lodash.prototype.chain = wrapperChain;\n lodash.prototype.commit = wrapperCommit;\n lodash.prototype.next = wrapperNext;\n lodash.prototype.plant = wrapperPlant;\n lodash.prototype.reverse = wrapperReverse;\n lodash.prototype.toJSON = lodash.prototype.valueOf = lodash.prototype.value = wrapperValue;\n\n // Add lazy aliases.\n lodash.prototype.first = lodash.prototype.head;\n\n if (symIterator) {\n lodash.prototype[symIterator] = wrapperToIterator;\n }\n return lodash;\n });\n\n /*--------------------------------------------------------------------------*/\n\n // Export lodash.\n var _ = runInContext();\n\n // Some AMD build optimizers, like r.js, check for condition patterns like:\n if (typeof define == 'function' && typeof define.amd == 'object' && define.amd) {\n // Expose Lodash on the global object to prevent errors when Lodash is\n // loaded by a script tag in the presence of an AMD loader.\n // See http://requirejs.org/docs/errors.html#mismatch for more details.\n // Use `_.noConflict` to remove Lodash from the global object.\n root._ = _;\n\n // Define as an anonymous module so, through path mapping, it can be\n // referenced as the \"underscore\" module.\n define(function() {\n return _;\n });\n }\n // Check for `exports` after `define` in case a build optimizer adds it.\n else if (freeModule) {\n // Export for Node.js.\n (freeModule.exports = _)._ = _;\n // Export for CommonJS support.\n freeExports._ = _;\n }\n else {\n // Export to the global object.\n root._ = _;\n }\n}.call(this));\n","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","var isarray = require('isarray')\n\n/**\n * Expose `pathToRegexp`.\n */\nmodule.exports = pathToRegexp\nmodule.exports.parse = parse\nmodule.exports.compile = compile\nmodule.exports.tokensToFunction = tokensToFunction\nmodule.exports.tokensToRegExp = tokensToRegExp\n\n/**\n * The main path matching regexp utility.\n *\n * @type {RegExp}\n */\nvar PATH_REGEXP = new RegExp([\n // Match escaped characters that would otherwise appear in future matches.\n // This allows the user to escape special characters that won't transform.\n '(\\\\\\\\.)',\n // Match Express-style parameters and un-named parameters with a prefix\n // and optional suffixes. Matches appear as:\n //\n // \"/:test(\\\\d+)?\" => [\"/\", \"test\", \"\\d+\", undefined, \"?\", undefined]\n // \"/route(\\\\d+)\" => [undefined, undefined, undefined, \"\\d+\", undefined, undefined]\n // \"/*\" => [\"/\", undefined, undefined, undefined, undefined, \"*\"]\n '([\\\\/.])?(?:(?:\\\\:(\\\\w+)(?:\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))?|\\\\(((?:\\\\\\\\.|[^\\\\\\\\()])+)\\\\))([+*?])?|(\\\\*))'\n].join('|'), 'g')\n\n/**\n * Parse a string for the raw tokens.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!Array}\n */\nfunction parse (str, options) {\n var tokens = []\n var key = 0\n var index = 0\n var path = ''\n var defaultDelimiter = options && options.delimiter || '/'\n var res\n\n while ((res = PATH_REGEXP.exec(str)) != null) {\n var m = res[0]\n var escaped = res[1]\n var offset = res.index\n path += str.slice(index, offset)\n index = offset + m.length\n\n // Ignore already escaped sequences.\n if (escaped) {\n path += escaped[1]\n continue\n }\n\n var next = str[index]\n var prefix = res[2]\n var name = res[3]\n var capture = res[4]\n var group = res[5]\n var modifier = res[6]\n var asterisk = res[7]\n\n // Push the current path onto the tokens.\n if (path) {\n tokens.push(path)\n path = ''\n }\n\n var partial = prefix != null && next != null && next !== prefix\n var repeat = modifier === '+' || modifier === '*'\n var optional = modifier === '?' || modifier === '*'\n var delimiter = res[2] || defaultDelimiter\n var pattern = capture || group\n\n tokens.push({\n name: name || key++,\n prefix: prefix || '',\n delimiter: delimiter,\n optional: optional,\n repeat: repeat,\n partial: partial,\n asterisk: !!asterisk,\n pattern: pattern ? escapeGroup(pattern) : (asterisk ? '.*' : '[^' + escapeString(delimiter) + ']+?')\n })\n }\n\n // Match any characters still remaining.\n if (index < str.length) {\n path += str.substr(index)\n }\n\n // If the path exists, push it onto the end.\n if (path) {\n tokens.push(path)\n }\n\n return tokens\n}\n\n/**\n * Compile a string to a template function for the path.\n *\n * @param {string} str\n * @param {Object=} options\n * @return {!function(Object=, Object=)}\n */\nfunction compile (str, options) {\n return tokensToFunction(parse(str, options), options)\n}\n\n/**\n * Prettier encoding of URI path segments.\n *\n * @param {string}\n * @return {string}\n */\nfunction encodeURIComponentPretty (str) {\n return encodeURI(str).replace(/[\\/?#]/g, function (c) {\n return '%' + c.charCodeAt(0).toString(16).toUpperCase()\n })\n}\n\n/**\n * Encode the asterisk parameter. Similar to `pretty`, but allows slashes.\n *\n * @param {string}\n * @return {string}\n */\nfunction encodeAsterisk (str) {\n return encodeURI(str).replace(/[?#]/g, function (c) {\n return '%' + c.charCodeAt(0).toString(16).toUpperCase()\n })\n}\n\n/**\n * Expose a method for transforming tokens into the path function.\n */\nfunction tokensToFunction (tokens, options) {\n // Compile all the tokens into regexps.\n var matches = new Array(tokens.length)\n\n // Compile all the patterns before compilation.\n for (var i = 0; i < tokens.length; i++) {\n if (typeof tokens[i] === 'object') {\n matches[i] = new RegExp('^(?:' + tokens[i].pattern + ')$', flags(options))\n }\n }\n\n return function (obj, opts) {\n var path = ''\n var data = obj || {}\n var options = opts || {}\n var encode = options.pretty ? encodeURIComponentPretty : encodeURIComponent\n\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i]\n\n if (typeof token === 'string') {\n path += token\n\n continue\n }\n\n var value = data[token.name]\n var segment\n\n if (value == null) {\n if (token.optional) {\n // Prepend partial segment prefixes.\n if (token.partial) {\n path += token.prefix\n }\n\n continue\n } else {\n throw new TypeError('Expected \"' + token.name + '\" to be defined')\n }\n }\n\n if (isarray(value)) {\n if (!token.repeat) {\n throw new TypeError('Expected \"' + token.name + '\" to not repeat, but received `' + JSON.stringify(value) + '`')\n }\n\n if (value.length === 0) {\n if (token.optional) {\n continue\n } else {\n throw new TypeError('Expected \"' + token.name + '\" to not be empty')\n }\n }\n\n for (var j = 0; j < value.length; j++) {\n segment = encode(value[j])\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected all \"' + token.name + '\" to match \"' + token.pattern + '\", but received `' + JSON.stringify(segment) + '`')\n }\n\n path += (j === 0 ? token.prefix : token.delimiter) + segment\n }\n\n continue\n }\n\n segment = token.asterisk ? encodeAsterisk(value) : encode(value)\n\n if (!matches[i].test(segment)) {\n throw new TypeError('Expected \"' + token.name + '\" to match \"' + token.pattern + '\", but received \"' + segment + '\"')\n }\n\n path += token.prefix + segment\n }\n\n return path\n }\n}\n\n/**\n * Escape a regular expression string.\n *\n * @param {string} str\n * @return {string}\n */\nfunction escapeString (str) {\n return str.replace(/([.+*?=^!:${}()[\\]|\\/\\\\])/g, '\\\\$1')\n}\n\n/**\n * Escape the capturing group by escaping special characters and meaning.\n *\n * @param {string} group\n * @return {string}\n */\nfunction escapeGroup (group) {\n return group.replace(/([=!:$\\/()])/g, '\\\\$1')\n}\n\n/**\n * Attach the keys as a property of the regexp.\n *\n * @param {!RegExp} re\n * @param {Array} keys\n * @return {!RegExp}\n */\nfunction attachKeys (re, keys) {\n re.keys = keys\n return re\n}\n\n/**\n * Get the flags for a regexp from the options.\n *\n * @param {Object} options\n * @return {string}\n */\nfunction flags (options) {\n return options && options.sensitive ? '' : 'i'\n}\n\n/**\n * Pull out keys from a regexp.\n *\n * @param {!RegExp} path\n * @param {!Array} keys\n * @return {!RegExp}\n */\nfunction regexpToRegexp (path, keys) {\n // Use a negative lookahead to match only capturing groups.\n var groups = path.source.match(/\\((?!\\?)/g)\n\n if (groups) {\n for (var i = 0; i < groups.length; i++) {\n keys.push({\n name: i,\n prefix: null,\n delimiter: null,\n optional: false,\n repeat: false,\n partial: false,\n asterisk: false,\n pattern: null\n })\n }\n }\n\n return attachKeys(path, keys)\n}\n\n/**\n * Transform an array into a regexp.\n *\n * @param {!Array} path\n * @param {Array} keys\n * @param {!Object} options\n * @return {!RegExp}\n */\nfunction arrayToRegexp (path, keys, options) {\n var parts = []\n\n for (var i = 0; i < path.length; i++) {\n parts.push(pathToRegexp(path[i], keys, options).source)\n }\n\n var regexp = new RegExp('(?:' + parts.join('|') + ')', flags(options))\n\n return attachKeys(regexp, keys)\n}\n\n/**\n * Create a path regexp from string input.\n *\n * @param {string} path\n * @param {!Array} keys\n * @param {!Object} options\n * @return {!RegExp}\n */\nfunction stringToRegexp (path, keys, options) {\n return tokensToRegExp(parse(path, options), keys, options)\n}\n\n/**\n * Expose a function for taking tokens and returning a RegExp.\n *\n * @param {!Array} tokens\n * @param {(Array|Object)=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction tokensToRegExp (tokens, keys, options) {\n if (!isarray(keys)) {\n options = /** @type {!Object} */ (keys || options)\n keys = []\n }\n\n options = options || {}\n\n var strict = options.strict\n var end = options.end !== false\n var route = ''\n\n // Iterate over the tokens and create our regexp string.\n for (var i = 0; i < tokens.length; i++) {\n var token = tokens[i]\n\n if (typeof token === 'string') {\n route += escapeString(token)\n } else {\n var prefix = escapeString(token.prefix)\n var capture = '(?:' + token.pattern + ')'\n\n keys.push(token)\n\n if (token.repeat) {\n capture += '(?:' + prefix + capture + ')*'\n }\n\n if (token.optional) {\n if (!token.partial) {\n capture = '(?:' + prefix + '(' + capture + '))?'\n } else {\n capture = prefix + '(' + capture + ')?'\n }\n } else {\n capture = prefix + '(' + capture + ')'\n }\n\n route += capture\n }\n }\n\n var delimiter = escapeString(options.delimiter || '/')\n var endsWithDelimiter = route.slice(-delimiter.length) === delimiter\n\n // In non-strict mode we allow a slash at the end of match. If the path to\n // match already ends with a slash, we remove it for consistency. The slash\n // is valid at the end of a path match, not in the middle. This is important\n // in non-ending mode, where \"/test/\" shouldn't match \"/test//route\".\n if (!strict) {\n route = (endsWithDelimiter ? route.slice(0, -delimiter.length) : route) + '(?:' + delimiter + '(?=$))?'\n }\n\n if (end) {\n route += '$'\n } else {\n // In non-ending mode, we need the capturing groups to match as much as\n // possible by using a positive lookahead to the end or next path segment.\n route += strict && endsWithDelimiter ? '' : '(?=' + delimiter + '|$)'\n }\n\n return attachKeys(new RegExp('^' + route, flags(options)), keys)\n}\n\n/**\n * Normalize the given path string, returning a regular expression.\n *\n * An empty array can be passed in for the keys, which will hold the\n * placeholder key descriptions. For example, using `/user/:id`, `keys` will\n * contain `[{ name: 'id', delimiter: '/', optional: false, repeat: false }]`.\n *\n * @param {(string|RegExp|Array)} path\n * @param {(Array|Object)=} keys\n * @param {Object=} options\n * @return {!RegExp}\n */\nfunction pathToRegexp (path, keys, options) {\n if (!isarray(keys)) {\n options = /** @type {!Object} */ (keys || options)\n keys = []\n }\n\n options = options || {}\n\n if (path instanceof RegExp) {\n return regexpToRegexp(path, /** @type {!Array} */ (keys))\n }\n\n if (isarray(path)) {\n return arrayToRegexp(/** @type {!Array} */ (path), /** @type {!Array} */ (keys), options)\n }\n\n return stringToRegexp(/** @type {string} */ (path), /** @type {!Array} */ (keys), options)\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","/** @license React v17.0.2\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),m=require(\"object-assign\"),r=require(\"scheduler\");function y(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;c<arguments.length;c++)b+=\"&args[]=\"+encodeURIComponent(arguments[c]);return\"Minified React error #\"+a+\"; visit \"+b+\" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\"}if(!aa)throw Error(y(227));var ba=new Set,ca={};function da(a,b){ea(a,b);ea(a+\"Capture\",b)}\nfunction ea(a,b){ca[a]=b;for(a=0;a<b.length;a++)ba.add(b[a])}\nvar fa=!(\"undefined\"===typeof window||\"undefined\"===typeof window.document||\"undefined\"===typeof window.document.createElement),ha=/^[:A-Z_a-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD][:A-Z_a-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD\\-.0-9\\u00B7\\u0300-\\u036F\\u203F-\\u2040]*$/,ia=Object.prototype.hasOwnProperty,\nja={},ka={};function la(a){if(ia.call(ka,a))return!0;if(ia.call(ja,a))return!1;if(ha.test(a))return ka[a]=!0;ja[a]=!0;return!1}function ma(a,b,c,d){if(null!==c&&0===c.type)return!1;switch(typeof b){case \"function\":case \"symbol\":return!0;case \"boolean\":if(d)return!1;if(null!==c)return!c.acceptsBooleans;a=a.toLowerCase().slice(0,5);return\"data-\"!==a&&\"aria-\"!==a;default:return!1}}\nfunction na(a,b,c,d){if(null===b||\"undefined\"===typeof b||ma(a,b,c,d))return!0;if(d)return!1;if(null!==c)switch(c.type){case 3:return!b;case 4:return!1===b;case 5:return isNaN(b);case 6:return isNaN(b)||1>b}return!1}function B(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var D={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){D[a]=new B(a,0,!1,a,null,!1,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];D[b]=new B(b,1,!1,a[1],null,!1,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){D[a]=new B(a,2,!1,a.toLowerCase(),null,!1,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){D[a]=new B(a,2,!1,a,null,!1,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){D[a]=new B(a,3,!1,a.toLowerCase(),null,!1,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){D[a]=new B(a,3,!0,a,null,!1,!1)});[\"capture\",\"download\"].forEach(function(a){D[a]=new B(a,4,!1,a,null,!1,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){D[a]=new B(a,6,!1,a,null,!1,!1)});[\"rowSpan\",\"start\"].forEach(function(a){D[a]=new B(a,5,!1,a.toLowerCase(),null,!1,!1)});var oa=/[\\-:]([a-z])/g;function pa(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(oa,\npa);D[b]=new B(b,1,!1,a,null,!1,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(oa,pa);D[b]=new B(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1,!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(oa,pa);D[b]=new B(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1,!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){D[a]=new B(a,1,!1,a.toLowerCase(),null,!1,!1)});\nD.xlinkHref=new B(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0,!1);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){D[a]=new B(a,1,!1,a.toLowerCase(),null,!0,!0)});\nfunction qa(a,b,c,d){var e=D.hasOwnProperty(b)?D[b]:null;var f=null!==e?0===e.type:d?!1:!(2<b.length)||\"o\"!==b[0]&&\"O\"!==b[0]||\"n\"!==b[1]&&\"N\"!==b[1]?!1:!0;f||(na(b,c,e,d)&&(c=null),d||null===e?la(b)&&(null===c?a.removeAttribute(b):a.setAttribute(b,\"\"+c)):e.mustUseProperty?a[e.propertyName]=null===c?3===e.type?!1:\"\":c:(b=e.attributeName,d=e.attributeNamespace,null===c?a.removeAttribute(b):(e=e.type,c=3===e||4===e&&!0===c?\"\":\"\"+c,d?a.setAttributeNS(d,b,c):a.setAttribute(b,c))))}\nvar ra=aa.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED,sa=60103,ta=60106,ua=60107,wa=60108,xa=60114,ya=60109,za=60110,Aa=60112,Ba=60113,Ca=60120,Da=60115,Ea=60116,Fa=60121,Ga=60128,Ha=60129,Ia=60130,Ja=60131;\nif(\"function\"===typeof Symbol&&Symbol.for){var E=Symbol.for;sa=E(\"react.element\");ta=E(\"react.portal\");ua=E(\"react.fragment\");wa=E(\"react.strict_mode\");xa=E(\"react.profiler\");ya=E(\"react.provider\");za=E(\"react.context\");Aa=E(\"react.forward_ref\");Ba=E(\"react.suspense\");Ca=E(\"react.suspense_list\");Da=E(\"react.memo\");Ea=E(\"react.lazy\");Fa=E(\"react.block\");E(\"react.scope\");Ga=E(\"react.opaque.id\");Ha=E(\"react.debug_trace_mode\");Ia=E(\"react.offscreen\");Ja=E(\"react.legacy_hidden\")}\nvar Ka=\"function\"===typeof Symbol&&Symbol.iterator;function La(a){if(null===a||\"object\"!==typeof a)return null;a=Ka&&a[Ka]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}var Ma;function Na(a){if(void 0===Ma)try{throw Error();}catch(c){var b=c.stack.trim().match(/\\n( *(at )?)/);Ma=b&&b[1]||\"\"}return\"\\n\"+Ma+a}var Oa=!1;\nfunction Pa(a,b){if(!a||Oa)return\"\";Oa=!0;var c=Error.prepareStackTrace;Error.prepareStackTrace=void 0;try{if(b)if(b=function(){throw Error();},Object.defineProperty(b.prototype,\"props\",{set:function(){throw Error();}}),\"object\"===typeof Reflect&&Reflect.construct){try{Reflect.construct(b,[])}catch(k){var d=k}Reflect.construct(a,[],b)}else{try{b.call()}catch(k){d=k}a.call(b.prototype)}else{try{throw Error();}catch(k){d=k}a()}}catch(k){if(k&&d&&\"string\"===typeof k.stack){for(var e=k.stack.split(\"\\n\"),\nf=d.stack.split(\"\\n\"),g=e.length-1,h=f.length-1;1<=g&&0<=h&&e[g]!==f[h];)h--;for(;1<=g&&0<=h;g--,h--)if(e[g]!==f[h]){if(1!==g||1!==h){do if(g--,h--,0>h||e[g]!==f[h])return\"\\n\"+e[g].replace(\" at new \",\" at \");while(1<=g&&0<=h)}break}}}finally{Oa=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:\"\")?Na(a):\"\"}\nfunction Qa(a){switch(a.tag){case 5:return Na(a.type);case 16:return Na(\"Lazy\");case 13:return Na(\"Suspense\");case 19:return Na(\"SuspenseList\");case 0:case 2:case 15:return a=Pa(a.type,!1),a;case 11:return a=Pa(a.type.render,!1),a;case 22:return a=Pa(a.type._render,!1),a;case 1:return a=Pa(a.type,!0),a;default:return\"\"}}\nfunction Ra(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case ua:return\"Fragment\";case ta:return\"Portal\";case xa:return\"Profiler\";case wa:return\"StrictMode\";case Ba:return\"Suspense\";case Ca:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case za:return(a.displayName||\"Context\")+\".Consumer\";case ya:return(a._context.displayName||\"Context\")+\".Provider\";case Aa:var b=a.render;b=b.displayName||b.name||\"\";\nreturn a.displayName||(\"\"!==b?\"ForwardRef(\"+b+\")\":\"ForwardRef\");case Da:return Ra(a.type);case Fa:return Ra(a._render);case Ea:b=a._payload;a=a._init;try{return Ra(a(b))}catch(c){}}return null}function Sa(a){switch(typeof a){case \"boolean\":case \"number\":case \"object\":case \"string\":case \"undefined\":return a;default:return\"\"}}function Ta(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction Ua(a){var b=Ta(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=Ta(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}\nfunction Ya(a,b){var c=b.checked;return m({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function $a(a,b){b=b.checked;null!=b&&qa(a,\"checked\",b,!1)}\nfunction ab(a,b){$a(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?bb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&bb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction cb(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction bb(a,b,c){if(\"number\"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}function db(a){var b=\"\";aa.Children.forEach(a,function(a){null!=a&&(b+=a)});return b}function eb(a,b){a=m({children:void 0},b);if(b=db(b.children))a.children=b;return a}\nfunction fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e<c.length;e++)b[\"$\"+c[e]]=!0;for(c=0;c<a.length;c++)e=b.hasOwnProperty(\"$\"+a[c].value),a[c].selected!==e&&(a[c].selected=e),e&&d&&(a[c].defaultSelected=!0)}else{c=\"\"+Sa(c);b=null;for(e=0;e<a.length;e++){if(a[e].value===c){a[e].selected=!0;d&&(a[e].defaultSelected=!0);return}null!==b||a[e].disabled||(b=a[e])}null!==b&&(b.selected=!0)}}\nfunction gb(a,b){if(null!=b.dangerouslySetInnerHTML)throw Error(y(91));return m({},b,{value:void 0,defaultValue:void 0,children:\"\"+a._wrapperState.initialValue})}function hb(a,b){var c=b.value;if(null==c){c=b.children;b=b.defaultValue;if(null!=c){if(null!=b)throw Error(y(92));if(Array.isArray(c)){if(!(1>=c.length))throw Error(y(93));c=c[0]}b=c}null==b&&(b=\"\");c=b}a._wrapperState={initialValue:Sa(c)}}\nfunction ib(a,b){var c=Sa(b.value),d=Sa(b.defaultValue);null!=c&&(c=\"\"+c,c!==a.value&&(a.value=c),null==b.defaultValue&&a.defaultValue!==c&&(a.defaultValue=c));null!=d&&(a.defaultValue=\"\"+d)}function jb(a){var b=a.textContent;b===a._wrapperState.initialValue&&\"\"!==b&&null!==b&&(a.value=b)}var kb={html:\"http://www.w3.org/1999/xhtml\",mathml:\"http://www.w3.org/1998/Math/MathML\",svg:\"http://www.w3.org/2000/svg\"};\nfunction lb(a){switch(a){case \"svg\":return\"http://www.w3.org/2000/svg\";case \"math\":return\"http://www.w3.org/1998/Math/MathML\";default:return\"http://www.w3.org/1999/xhtml\"}}function mb(a,b){return null==a||\"http://www.w3.org/1999/xhtml\"===a?lb(b):\"http://www.w3.org/2000/svg\"===a&&\"foreignObject\"===b?\"http://www.w3.org/1999/xhtml\":a}\nvar nb,ob=function(a){return\"undefined\"!==typeof MSApp&&MSApp.execUnsafeLocalFunction?function(b,c,d,e){MSApp.execUnsafeLocalFunction(function(){return a(b,c,d,e)})}:a}(function(a,b){if(a.namespaceURI!==kb.svg||\"innerHTML\"in a)a.innerHTML=b;else{nb=nb||document.createElement(\"div\");nb.innerHTML=\"<svg>\"+b.valueOf().toString()+\"</svg>\";for(b=nb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction pb(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}\nvar qb={animationIterationCount:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,\nfloodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},rb=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(qb).forEach(function(a){rb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);qb[b]=qb[a]})});function sb(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||qb.hasOwnProperty(a)&&qb[a]?(\"\"+b).trim():b+\"px\"}\nfunction tb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=sb(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var ub=m({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction vb(a,b){if(b){if(ub[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(y(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(y(60));if(!(\"object\"===typeof b.dangerouslySetInnerHTML&&\"__html\"in b.dangerouslySetInnerHTML))throw Error(y(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(y(62));}}\nfunction wb(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;\nfunction Bb(a){if(a=Cb(a)){if(\"function\"!==typeof yb)throw Error(y(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;a<b.length;a++)Bb(b[a])}}function Gb(a,b){return a(b)}function Hb(a,b,c,d,e){return a(b,c,d,e)}function Ib(){}var Jb=Gb,Kb=!1,Lb=!1;function Mb(){if(null!==zb||null!==Ab)Ib(),Fb()}\nfunction Nb(a,b,c){if(Lb)return a(b,c);Lb=!0;try{return Jb(a,b,c)}finally{Lb=!1,Mb()}}\nfunction Ob(a,b){var c=a.stateNode;if(null===c)return null;var d=Db(c);if(null===d)return null;c=d[b];a:switch(b){case \"onClick\":case \"onClickCapture\":case \"onDoubleClick\":case \"onDoubleClickCapture\":case \"onMouseDown\":case \"onMouseDownCapture\":case \"onMouseMove\":case \"onMouseMoveCapture\":case \"onMouseUp\":case \"onMouseUpCapture\":case \"onMouseEnter\":(d=!d.disabled)||(a=a.type,d=!(\"button\"===a||\"input\"===a||\"select\"===a||\"textarea\"===a));a=!d;break a;default:a=!1}if(a)return null;if(c&&\"function\"!==\ntypeof c)throw Error(y(231,b,typeof c));return c}var Pb=!1;if(fa)try{var Qb={};Object.defineProperty(Qb,\"passive\",{get:function(){Pb=!0}});window.addEventListener(\"test\",Qb,Qb);window.removeEventListener(\"test\",Qb,Qb)}catch(a){Pb=!1}function Rb(a,b,c,d,e,f,g,h,k){var l=Array.prototype.slice.call(arguments,3);try{b.apply(c,l)}catch(n){this.onError(n)}}var Sb=!1,Tb=null,Ub=!1,Vb=null,Wb={onError:function(a){Sb=!0;Tb=a}};function Xb(a,b,c,d,e,f,g,h,k){Sb=!1;Tb=null;Rb.apply(Wb,arguments)}\nfunction Yb(a,b,c,d,e,f,g,h,k){Xb.apply(this,arguments);if(Sb){if(Sb){var l=Tb;Sb=!1;Tb=null}else throw Error(y(198));Ub||(Ub=!0,Vb=l)}}function Zb(a){var b=a,c=a;if(a.alternate)for(;b.return;)b=b.return;else{a=b;do b=a,0!==(b.flags&1026)&&(c=b.return),a=b.return;while(a)}return 3===b.tag?c:null}function $b(a){if(13===a.tag){var b=a.memoizedState;null===b&&(a=a.alternate,null!==a&&(b=a.memoizedState));if(null!==b)return b.dehydrated}return null}function ac(a){if(Zb(a)!==a)throw Error(y(188));}\nfunction bc(a){var b=a.alternate;if(!b){b=Zb(a);if(null===b)throw Error(y(188));return b!==a?null:a}for(var c=a,d=b;;){var e=c.return;if(null===e)break;var f=e.alternate;if(null===f){d=e.return;if(null!==d){c=d;continue}break}if(e.child===f.child){for(f=e.child;f;){if(f===c)return ac(e),a;if(f===d)return ac(e),b;f=f.sibling}throw Error(y(188));}if(c.return!==d.return)c=e,d=f;else{for(var g=!1,h=e.child;h;){if(h===c){g=!0;c=e;d=f;break}if(h===d){g=!0;d=e;c=f;break}h=h.sibling}if(!g){for(h=f.child;h;){if(h===\nc){g=!0;c=f;d=e;break}if(h===d){g=!0;d=f;c=e;break}h=h.sibling}if(!g)throw Error(y(189));}}if(c.alternate!==d)throw Error(y(190));}if(3!==c.tag)throw Error(y(188));return c.stateNode.current===c?a:b}function cc(a){a=bc(a);if(!a)return null;for(var b=a;;){if(5===b.tag||6===b.tag)return b;if(b.child)b.child.return=b,b=b.child;else{if(b===a)break;for(;!b.sibling;){if(!b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}}return null}\nfunction dc(a,b){for(var c=a.alternate;null!==b;){if(b===a||b===c)return!0;b=b.return}return!1}var ec,fc,gc,hc,ic=!1,jc=[],kc=null,lc=null,mc=null,nc=new Map,oc=new Map,pc=[],qc=\"mousedown mouseup touchcancel touchend touchstart auxclick dblclick pointercancel pointerdown pointerup dragend dragstart drop compositionend compositionstart keydown keypress keyup input textInput copy cut paste click change contextmenu reset submit\".split(\" \");\nfunction rc(a,b,c,d,e){return{blockedOn:a,domEventName:b,eventSystemFlags:c|16,nativeEvent:e,targetContainers:[d]}}function sc(a,b){switch(a){case \"focusin\":case \"focusout\":kc=null;break;case \"dragenter\":case \"dragleave\":lc=null;break;case \"mouseover\":case \"mouseout\":mc=null;break;case \"pointerover\":case \"pointerout\":nc.delete(b.pointerId);break;case \"gotpointercapture\":case \"lostpointercapture\":oc.delete(b.pointerId)}}\nfunction tc(a,b,c,d,e,f){if(null===a||a.nativeEvent!==f)return a=rc(b,c,d,e,f),null!==b&&(b=Cb(b),null!==b&&fc(b)),a;a.eventSystemFlags|=d;b=a.targetContainers;null!==e&&-1===b.indexOf(e)&&b.push(e);return a}\nfunction uc(a,b,c,d,e){switch(b){case \"focusin\":return kc=tc(kc,a,b,c,d,e),!0;case \"dragenter\":return lc=tc(lc,a,b,c,d,e),!0;case \"mouseover\":return mc=tc(mc,a,b,c,d,e),!0;case \"pointerover\":var f=e.pointerId;nc.set(f,tc(nc.get(f)||null,a,b,c,d,e));return!0;case \"gotpointercapture\":return f=e.pointerId,oc.set(f,tc(oc.get(f)||null,a,b,c,d,e)),!0}return!1}\nfunction vc(a){var b=wc(a.target);if(null!==b){var c=Zb(b);if(null!==c)if(b=c.tag,13===b){if(b=$b(c),null!==b){a.blockedOn=b;hc(a.lanePriority,function(){r.unstable_runWithPriority(a.priority,function(){gc(c)})});return}}else if(3===b&&c.stateNode.hydrate){a.blockedOn=3===c.tag?c.stateNode.containerInfo:null;return}}a.blockedOn=null}\nfunction xc(a){if(null!==a.blockedOn)return!1;for(var b=a.targetContainers;0<b.length;){var c=yc(a.domEventName,a.eventSystemFlags,b[0],a.nativeEvent);if(null!==c)return b=Cb(c),null!==b&&fc(b),a.blockedOn=c,!1;b.shift()}return!0}function zc(a,b,c){xc(a)&&c.delete(b)}\nfunction Ac(){for(ic=!1;0<jc.length;){var a=jc[0];if(null!==a.blockedOn){a=Cb(a.blockedOn);null!==a&&ec(a);break}for(var b=a.targetContainers;0<b.length;){var c=yc(a.domEventName,a.eventSystemFlags,b[0],a.nativeEvent);if(null!==c){a.blockedOn=c;break}b.shift()}null===a.blockedOn&&jc.shift()}null!==kc&&xc(kc)&&(kc=null);null!==lc&&xc(lc)&&(lc=null);null!==mc&&xc(mc)&&(mc=null);nc.forEach(zc);oc.forEach(zc)}\nfunction Bc(a,b){a.blockedOn===b&&(a.blockedOn=null,ic||(ic=!0,r.unstable_scheduleCallback(r.unstable_NormalPriority,Ac)))}\nfunction Cc(a){function b(b){return Bc(b,a)}if(0<jc.length){Bc(jc[0],a);for(var c=1;c<jc.length;c++){var d=jc[c];d.blockedOn===a&&(d.blockedOn=null)}}null!==kc&&Bc(kc,a);null!==lc&&Bc(lc,a);null!==mc&&Bc(mc,a);nc.forEach(b);oc.forEach(b);for(c=0;c<pc.length;c++)d=pc[c],d.blockedOn===a&&(d.blockedOn=null);for(;0<pc.length&&(c=pc[0],null===c.blockedOn);)vc(c),null===c.blockedOn&&pc.shift()}\nfunction Dc(a,b){var c={};c[a.toLowerCase()]=b.toLowerCase();c[\"Webkit\"+a]=\"webkit\"+b;c[\"Moz\"+a]=\"moz\"+b;return c}var Ec={animationend:Dc(\"Animation\",\"AnimationEnd\"),animationiteration:Dc(\"Animation\",\"AnimationIteration\"),animationstart:Dc(\"Animation\",\"AnimationStart\"),transitionend:Dc(\"Transition\",\"TransitionEnd\")},Fc={},Gc={};\nfa&&(Gc=document.createElement(\"div\").style,\"AnimationEvent\"in window||(delete Ec.animationend.animation,delete Ec.animationiteration.animation,delete Ec.animationstart.animation),\"TransitionEvent\"in window||delete Ec.transitionend.transition);function Hc(a){if(Fc[a])return Fc[a];if(!Ec[a])return a;var b=Ec[a],c;for(c in b)if(b.hasOwnProperty(c)&&c in Gc)return Fc[a]=b[c];return a}\nvar Ic=Hc(\"animationend\"),Jc=Hc(\"animationiteration\"),Kc=Hc(\"animationstart\"),Lc=Hc(\"transitionend\"),Mc=new Map,Nc=new Map,Oc=[\"abort\",\"abort\",Ic,\"animationEnd\",Jc,\"animationIteration\",Kc,\"animationStart\",\"canplay\",\"canPlay\",\"canplaythrough\",\"canPlayThrough\",\"durationchange\",\"durationChange\",\"emptied\",\"emptied\",\"encrypted\",\"encrypted\",\"ended\",\"ended\",\"error\",\"error\",\"gotpointercapture\",\"gotPointerCapture\",\"load\",\"load\",\"loadeddata\",\"loadedData\",\"loadedmetadata\",\"loadedMetadata\",\"loadstart\",\"loadStart\",\n\"lostpointercapture\",\"lostPointerCapture\",\"playing\",\"playing\",\"progress\",\"progress\",\"seeking\",\"seeking\",\"stalled\",\"stalled\",\"suspend\",\"suspend\",\"timeupdate\",\"timeUpdate\",Lc,\"transitionEnd\",\"waiting\",\"waiting\"];function Pc(a,b){for(var c=0;c<a.length;c+=2){var d=a[c],e=a[c+1];e=\"on\"+(e[0].toUpperCase()+e.slice(1));Nc.set(d,b);Mc.set(d,e);da(e,[d])}}var Qc=r.unstable_now;Qc();var F=8;\nfunction Rc(a){if(0!==(1&a))return F=15,1;if(0!==(2&a))return F=14,2;if(0!==(4&a))return F=13,4;var b=24&a;if(0!==b)return F=12,b;if(0!==(a&32))return F=11,32;b=192&a;if(0!==b)return F=10,b;if(0!==(a&256))return F=9,256;b=3584&a;if(0!==b)return F=8,b;if(0!==(a&4096))return F=7,4096;b=4186112&a;if(0!==b)return F=6,b;b=62914560&a;if(0!==b)return F=5,b;if(a&67108864)return F=4,67108864;if(0!==(a&134217728))return F=3,134217728;b=805306368&a;if(0!==b)return F=2,b;if(0!==(1073741824&a))return F=1,1073741824;\nF=8;return a}function Sc(a){switch(a){case 99:return 15;case 98:return 10;case 97:case 96:return 8;case 95:return 2;default:return 0}}function Tc(a){switch(a){case 15:case 14:return 99;case 13:case 12:case 11:case 10:return 98;case 9:case 8:case 7:case 6:case 4:case 5:return 97;case 3:case 2:case 1:return 95;case 0:return 90;default:throw Error(y(358,a));}}\nfunction Uc(a,b){var c=a.pendingLanes;if(0===c)return F=0;var d=0,e=0,f=a.expiredLanes,g=a.suspendedLanes,h=a.pingedLanes;if(0!==f)d=f,e=F=15;else if(f=c&134217727,0!==f){var k=f&~g;0!==k?(d=Rc(k),e=F):(h&=f,0!==h&&(d=Rc(h),e=F))}else f=c&~g,0!==f?(d=Rc(f),e=F):0!==h&&(d=Rc(h),e=F);if(0===d)return 0;d=31-Vc(d);d=c&((0>d?0:1<<d)<<1)-1;if(0!==b&&b!==d&&0===(b&g)){Rc(b);if(e<=F)return b;F=e}b=a.entangledLanes;if(0!==b)for(a=a.entanglements,b&=d;0<b;)c=31-Vc(b),e=1<<c,d|=a[c],b&=~e;return d}\nfunction Wc(a){a=a.pendingLanes&-1073741825;return 0!==a?a:a&1073741824?1073741824:0}function Xc(a,b){switch(a){case 15:return 1;case 14:return 2;case 12:return a=Yc(24&~b),0===a?Xc(10,b):a;case 10:return a=Yc(192&~b),0===a?Xc(8,b):a;case 8:return a=Yc(3584&~b),0===a&&(a=Yc(4186112&~b),0===a&&(a=512)),a;case 2:return b=Yc(805306368&~b),0===b&&(b=268435456),b}throw Error(y(358,a));}function Yc(a){return a&-a}function Zc(a){for(var b=[],c=0;31>c;c++)b.push(a);return b}\nfunction $c(a,b,c){a.pendingLanes|=b;var d=b-1;a.suspendedLanes&=d;a.pingedLanes&=d;a=a.eventTimes;b=31-Vc(b);a[b]=c}var Vc=Math.clz32?Math.clz32:ad,bd=Math.log,cd=Math.LN2;function ad(a){return 0===a?32:31-(bd(a)/cd|0)|0}var dd=r.unstable_UserBlockingPriority,ed=r.unstable_runWithPriority,fd=!0;function gd(a,b,c,d){Kb||Ib();var e=hd,f=Kb;Kb=!0;try{Hb(e,a,b,c,d)}finally{(Kb=f)||Mb()}}function id(a,b,c,d){ed(dd,hd.bind(null,a,b,c,d))}\nfunction hd(a,b,c,d){if(fd){var e;if((e=0===(b&4))&&0<jc.length&&-1<qc.indexOf(a))a=rc(null,a,b,c,d),jc.push(a);else{var f=yc(a,b,c,d);if(null===f)e&&sc(a,d);else{if(e){if(-1<qc.indexOf(a)){a=rc(f,a,b,c,d);jc.push(a);return}if(uc(f,a,b,c,d))return;sc(a,d)}jd(a,b,d,null,c)}}}}\nfunction yc(a,b,c,d){var e=xb(d);e=wc(e);if(null!==e){var f=Zb(e);if(null===f)e=null;else{var g=f.tag;if(13===g){e=$b(f);if(null!==e)return e;e=null}else if(3===g){if(f.stateNode.hydrate)return 3===f.tag?f.stateNode.containerInfo:null;e=null}else f!==e&&(e=null)}}jd(a,b,d,e,c);return null}var kd=null,ld=null,md=null;\nfunction nd(){if(md)return md;var a,b=ld,c=b.length,d,e=\"value\"in kd?kd.value:kd.textContent,f=e.length;for(a=0;a<c&&b[a]===e[a];a++);var g=c-a;for(d=1;d<=g&&b[c-d]===e[f-d];d++);return md=e.slice(a,1<d?1-d:void 0)}function od(a){var b=a.keyCode;\"charCode\"in a?(a=a.charCode,0===a&&13===b&&(a=13)):a=b;10===a&&(a=13);return 32<=a||13===a?a:0}function pd(){return!0}function qd(){return!1}\nfunction rd(a){function b(b,d,e,f,g){this._reactName=b;this._targetInst=e;this.type=d;this.nativeEvent=f;this.target=g;this.currentTarget=null;for(var c in a)a.hasOwnProperty(c)&&(b=a[c],this[c]=b?b(f):f[c]);this.isDefaultPrevented=(null!=f.defaultPrevented?f.defaultPrevented:!1===f.returnValue)?pd:qd;this.isPropagationStopped=qd;return this}m(b.prototype,{preventDefault:function(){this.defaultPrevented=!0;var a=this.nativeEvent;a&&(a.preventDefault?a.preventDefault():\"unknown\"!==typeof a.returnValue&&\n(a.returnValue=!1),this.isDefaultPrevented=pd)},stopPropagation:function(){var a=this.nativeEvent;a&&(a.stopPropagation?a.stopPropagation():\"unknown\"!==typeof a.cancelBubble&&(a.cancelBubble=!0),this.isPropagationStopped=pd)},persist:function(){},isPersistent:pd});return b}\nvar sd={eventPhase:0,bubbles:0,cancelable:0,timeStamp:function(a){return a.timeStamp||Date.now()},defaultPrevented:0,isTrusted:0},td=rd(sd),ud=m({},sd,{view:0,detail:0}),vd=rd(ud),wd,xd,yd,Ad=m({},ud,{screenX:0,screenY:0,clientX:0,clientY:0,pageX:0,pageY:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,getModifierState:zd,button:0,buttons:0,relatedTarget:function(a){return void 0===a.relatedTarget?a.fromElement===a.srcElement?a.toElement:a.fromElement:a.relatedTarget},movementX:function(a){if(\"movementX\"in\na)return a.movementX;a!==yd&&(yd&&\"mousemove\"===a.type?(wd=a.screenX-yd.screenX,xd=a.screenY-yd.screenY):xd=wd=0,yd=a);return wd},movementY:function(a){return\"movementY\"in a?a.movementY:xd}}),Bd=rd(Ad),Cd=m({},Ad,{dataTransfer:0}),Dd=rd(Cd),Ed=m({},ud,{relatedTarget:0}),Fd=rd(Ed),Gd=m({},sd,{animationName:0,elapsedTime:0,pseudoElement:0}),Hd=rd(Gd),Id=m({},sd,{clipboardData:function(a){return\"clipboardData\"in a?a.clipboardData:window.clipboardData}}),Jd=rd(Id),Kd=m({},sd,{data:0}),Ld=rd(Kd),Md={Esc:\"Escape\",\nSpacebar:\" \",Left:\"ArrowLeft\",Up:\"ArrowUp\",Right:\"ArrowRight\",Down:\"ArrowDown\",Del:\"Delete\",Win:\"OS\",Menu:\"ContextMenu\",Apps:\"ContextMenu\",Scroll:\"ScrollLock\",MozPrintableKey:\"Unidentified\"},Nd={8:\"Backspace\",9:\"Tab\",12:\"Clear\",13:\"Enter\",16:\"Shift\",17:\"Control\",18:\"Alt\",19:\"Pause\",20:\"CapsLock\",27:\"Escape\",32:\" \",33:\"PageUp\",34:\"PageDown\",35:\"End\",36:\"Home\",37:\"ArrowLeft\",38:\"ArrowUp\",39:\"ArrowRight\",40:\"ArrowDown\",45:\"Insert\",46:\"Delete\",112:\"F1\",113:\"F2\",114:\"F3\",115:\"F4\",116:\"F5\",117:\"F6\",118:\"F7\",\n119:\"F8\",120:\"F9\",121:\"F10\",122:\"F11\",123:\"F12\",144:\"NumLock\",145:\"ScrollLock\",224:\"Meta\"},Od={Alt:\"altKey\",Control:\"ctrlKey\",Meta:\"metaKey\",Shift:\"shiftKey\"};function Pd(a){var b=this.nativeEvent;return b.getModifierState?b.getModifierState(a):(a=Od[a])?!!b[a]:!1}function zd(){return Pd}\nvar Qd=m({},ud,{key:function(a){if(a.key){var b=Md[a.key]||a.key;if(\"Unidentified\"!==b)return b}return\"keypress\"===a.type?(a=od(a),13===a?\"Enter\":String.fromCharCode(a)):\"keydown\"===a.type||\"keyup\"===a.type?Nd[a.keyCode]||\"Unidentified\":\"\"},code:0,location:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,repeat:0,locale:0,getModifierState:zd,charCode:function(a){return\"keypress\"===a.type?od(a):0},keyCode:function(a){return\"keydown\"===a.type||\"keyup\"===a.type?a.keyCode:0},which:function(a){return\"keypress\"===\na.type?od(a):\"keydown\"===a.type||\"keyup\"===a.type?a.keyCode:0}}),Rd=rd(Qd),Sd=m({},Ad,{pointerId:0,width:0,height:0,pressure:0,tangentialPressure:0,tiltX:0,tiltY:0,twist:0,pointerType:0,isPrimary:0}),Td=rd(Sd),Ud=m({},ud,{touches:0,targetTouches:0,changedTouches:0,altKey:0,metaKey:0,ctrlKey:0,shiftKey:0,getModifierState:zd}),Vd=rd(Ud),Wd=m({},sd,{propertyName:0,elapsedTime:0,pseudoElement:0}),Xd=rd(Wd),Yd=m({},Ad,{deltaX:function(a){return\"deltaX\"in a?a.deltaX:\"wheelDeltaX\"in a?-a.wheelDeltaX:0},\ndeltaY:function(a){return\"deltaY\"in a?a.deltaY:\"wheelDeltaY\"in a?-a.wheelDeltaY:\"wheelDelta\"in a?-a.wheelDelta:0},deltaZ:0,deltaMode:0}),Zd=rd(Yd),$d=[9,13,27,32],ae=fa&&\"CompositionEvent\"in window,be=null;fa&&\"documentMode\"in document&&(be=document.documentMode);var ce=fa&&\"TextEvent\"in window&&!be,de=fa&&(!ae||be&&8<be&&11>=be),ee=String.fromCharCode(32),fe=!1;\nfunction ge(a,b){switch(a){case \"keyup\":return-1!==$d.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"focusout\":return!0;default:return!1}}function he(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case \"compositionend\":return he(b);case \"keypress\":if(32!==b.which)return null;fe=!0;return ee;case \"textInput\":return a=b.data,a===ee&&fe?null:a;default:return null}}\nfunction ke(a,b){if(ie)return\"compositionend\"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1<b.char.length)return b.char;if(b.which)return String.fromCharCode(b.which)}return null;case \"compositionend\":return de&&\"ko\"!==b.locale?null:b.data;default:return null}}\nvar le={color:!0,date:!0,datetime:!0,\"datetime-local\":!0,email:!0,month:!0,number:!0,password:!0,range:!0,search:!0,tel:!0,text:!0,time:!0,url:!0,week:!0};function me(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return\"input\"===b?!!le[a.type]:\"textarea\"===b?!0:!1}function ne(a,b,c,d){Eb(d);b=oe(b,\"onChange\");0<b.length&&(c=new td(\"onChange\",\"change\",null,c,d),a.push({event:c,listeners:b}))}var pe=null,qe=null;function re(a){se(a,0)}function te(a){var b=ue(a);if(Wa(b))return a}\nfunction ve(a,b){if(\"change\"===a)return b}var we=!1;if(fa){var xe;if(fa){var ye=\"oninput\"in document;if(!ye){var ze=document.createElement(\"div\");ze.setAttribute(\"oninput\",\"return;\");ye=\"function\"===typeof ze.oninput}xe=ye}else xe=!1;we=xe&&(!document.documentMode||9<document.documentMode)}function Ae(){pe&&(pe.detachEvent(\"onpropertychange\",Be),qe=pe=null)}function Be(a){if(\"value\"===a.propertyName&&te(qe)){var b=[];ne(b,qe,a,xb(a));a=re;if(Kb)a(b);else{Kb=!0;try{Gb(a,b)}finally{Kb=!1,Mb()}}}}\nfunction Ce(a,b,c){\"focusin\"===a?(Ae(),pe=b,qe=c,pe.attachEvent(\"onpropertychange\",Be)):\"focusout\"===a&&Ae()}function De(a){if(\"selectionchange\"===a||\"keyup\"===a||\"keydown\"===a)return te(qe)}function Ee(a,b){if(\"click\"===a)return te(b)}function Fe(a,b){if(\"input\"===a||\"change\"===a)return te(b)}function Ge(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var He=\"function\"===typeof Object.is?Object.is:Ge,Ie=Object.prototype.hasOwnProperty;\nfunction Je(a,b){if(He(a,b))return!0;if(\"object\"!==typeof a||null===a||\"object\"!==typeof b||null===b)return!1;var c=Object.keys(a),d=Object.keys(b);if(c.length!==d.length)return!1;for(d=0;d<c.length;d++)if(!Ie.call(b,c[d])||!He(a[c[d]],b[c[d]]))return!1;return!0}function Ke(a){for(;a&&a.firstChild;)a=a.firstChild;return a}\nfunction Le(a,b){var c=Ke(a);a=0;for(var d;c;){if(3===c.nodeType){d=a+c.textContent.length;if(a<=b&&d>=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Ke(c)}}function Me(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Me(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}\nfunction Ne(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Oe(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}\nvar Pe=fa&&\"documentMode\"in document&&11>=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;\nfunction Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,\"selectionStart\"in d&&Oe(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Je(Se,d)||(Se=d,d=oe(Re,\"onSelect\"),0<d.length&&(b=new td(\"onSelect\",\"select\",null,b,c),a.push({event:b,listeners:d}),b.target=Qe)))}\nPc(\"cancel cancel click click close close contextmenu contextMenu copy copy cut cut auxclick auxClick dblclick doubleClick dragend dragEnd dragstart dragStart drop drop focusin focus focusout blur input input invalid invalid keydown keyDown keypress keyPress keyup keyUp mousedown mouseDown mouseup mouseUp paste paste pause pause play play pointercancel pointerCancel pointerdown pointerDown pointerup pointerUp ratechange rateChange reset reset seeked seeked submit submit touchcancel touchCancel touchend touchEnd touchstart touchStart volumechange volumeChange\".split(\" \"),\n0);Pc(\"drag drag dragenter dragEnter dragexit dragExit dragleave dragLeave dragover dragOver mousemove mouseMove mouseout mouseOut mouseover mouseOver pointermove pointerMove pointerout pointerOut pointerover pointerOver scroll scroll toggle toggle touchmove touchMove wheel wheel\".split(\" \"),1);Pc(Oc,2);for(var Ve=\"change selectionchange textInput compositionstart compositionend compositionupdate\".split(\" \"),We=0;We<Ve.length;We++)Nc.set(Ve[We],0);ea(\"onMouseEnter\",[\"mouseout\",\"mouseover\"]);\nea(\"onMouseLeave\",[\"mouseout\",\"mouseover\"]);ea(\"onPointerEnter\",[\"pointerout\",\"pointerover\"]);ea(\"onPointerLeave\",[\"pointerout\",\"pointerover\"]);da(\"onChange\",\"change click focusin focusout input keydown keyup selectionchange\".split(\" \"));da(\"onSelect\",\"focusout contextmenu dragend focusin keydown keyup mousedown mouseup selectionchange\".split(\" \"));da(\"onBeforeInput\",[\"compositionend\",\"keypress\",\"textInput\",\"paste\"]);da(\"onCompositionEnd\",\"compositionend focusout keydown keypress keyup mousedown\".split(\" \"));\nda(\"onCompositionStart\",\"compositionstart focusout keydown keypress keyup mousedown\".split(\" \"));da(\"onCompositionUpdate\",\"compositionupdate focusout keydown keypress keyup mousedown\".split(\" \"));var Xe=\"abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange seeked seeking stalled suspend timeupdate volumechange waiting\".split(\" \"),Ye=new Set(\"cancel close invalid load scroll toggle\".split(\" \").concat(Xe));\nfunction Ze(a,b,c){var d=a.type||\"unknown-event\";a.currentTarget=c;Yb(d,b,void 0,a);a.currentTarget=null}\nfunction se(a,b){b=0!==(b&4);for(var c=0;c<a.length;c++){var d=a[c],e=d.event;d=d.listeners;a:{var f=void 0;if(b)for(var g=d.length-1;0<=g;g--){var h=d[g],k=h.instance,l=h.currentTarget;h=h.listener;if(k!==f&&e.isPropagationStopped())break a;Ze(e,h,l);f=k}else for(g=0;g<d.length;g++){h=d[g];k=h.instance;l=h.currentTarget;h=h.listener;if(k!==f&&e.isPropagationStopped())break a;Ze(e,h,l);f=k}}}if(Ub)throw a=Vb,Ub=!1,Vb=null,a;}\nfunction G(a,b){var c=$e(b),d=a+\"__bubble\";c.has(d)||(af(b,a,2,!1),c.add(d))}var bf=\"_reactListening\"+Math.random().toString(36).slice(2);function cf(a){a[bf]||(a[bf]=!0,ba.forEach(function(b){Ye.has(b)||df(b,!1,a,null);df(b,!0,a,null)}))}\nfunction df(a,b,c,d){var e=4<arguments.length&&void 0!==arguments[4]?arguments[4]:0,f=c;\"selectionchange\"===a&&9!==c.nodeType&&(f=c.ownerDocument);if(null!==d&&!b&&Ye.has(a)){if(\"scroll\"!==a)return;e|=2;f=d}var g=$e(f),h=a+\"__\"+(b?\"capture\":\"bubble\");g.has(h)||(b&&(e|=4),af(f,a,e,b),g.add(h))}\nfunction af(a,b,c,d){var e=Nc.get(b);switch(void 0===e?2:e){case 0:e=gd;break;case 1:e=id;break;default:e=hd}c=e.bind(null,b,c,a);e=void 0;!Pb||\"touchstart\"!==b&&\"touchmove\"!==b&&\"wheel\"!==b||(e=!0);d?void 0!==e?a.addEventListener(b,c,{capture:!0,passive:e}):a.addEventListener(b,c,!0):void 0!==e?a.addEventListener(b,c,{passive:e}):a.addEventListener(b,c,!1)}\nfunction jd(a,b,c,d,e){var f=d;if(0===(b&1)&&0===(b&2)&&null!==d)a:for(;;){if(null===d)return;var g=d.tag;if(3===g||4===g){var h=d.stateNode.containerInfo;if(h===e||8===h.nodeType&&h.parentNode===e)break;if(4===g)for(g=d.return;null!==g;){var k=g.tag;if(3===k||4===k)if(k=g.stateNode.containerInfo,k===e||8===k.nodeType&&k.parentNode===e)return;g=g.return}for(;null!==h;){g=wc(h);if(null===g)return;k=g.tag;if(5===k||6===k){d=f=g;continue a}h=h.parentNode}}d=d.return}Nb(function(){var d=f,e=xb(c),g=[];\na:{var h=Mc.get(a);if(void 0!==h){var k=td,x=a;switch(a){case \"keypress\":if(0===od(c))break a;case \"keydown\":case \"keyup\":k=Rd;break;case \"focusin\":x=\"focus\";k=Fd;break;case \"focusout\":x=\"blur\";k=Fd;break;case \"beforeblur\":case \"afterblur\":k=Fd;break;case \"click\":if(2===c.button)break a;case \"auxclick\":case \"dblclick\":case \"mousedown\":case \"mousemove\":case \"mouseup\":case \"mouseout\":case \"mouseover\":case \"contextmenu\":k=Bd;break;case \"drag\":case \"dragend\":case \"dragenter\":case \"dragexit\":case \"dragleave\":case \"dragover\":case \"dragstart\":case \"drop\":k=\nDd;break;case \"touchcancel\":case \"touchend\":case \"touchmove\":case \"touchstart\":k=Vd;break;case Ic:case Jc:case Kc:k=Hd;break;case Lc:k=Xd;break;case \"scroll\":k=vd;break;case \"wheel\":k=Zd;break;case \"copy\":case \"cut\":case \"paste\":k=Jd;break;case \"gotpointercapture\":case \"lostpointercapture\":case \"pointercancel\":case \"pointerdown\":case \"pointermove\":case \"pointerout\":case \"pointerover\":case \"pointerup\":k=Td}var w=0!==(b&4),z=!w&&\"scroll\"===a,u=w?null!==h?h+\"Capture\":null:h;w=[];for(var t=d,q;null!==\nt;){q=t;var v=q.stateNode;5===q.tag&&null!==v&&(q=v,null!==u&&(v=Ob(t,u),null!=v&&w.push(ef(t,v,q))));if(z)break;t=t.return}0<w.length&&(h=new k(h,x,null,c,e),g.push({event:h,listeners:w}))}}if(0===(b&7)){a:{h=\"mouseover\"===a||\"pointerover\"===a;k=\"mouseout\"===a||\"pointerout\"===a;if(h&&0===(b&16)&&(x=c.relatedTarget||c.fromElement)&&(wc(x)||x[ff]))break a;if(k||h){h=e.window===e?e:(h=e.ownerDocument)?h.defaultView||h.parentWindow:window;if(k){if(x=c.relatedTarget||c.toElement,k=d,x=x?wc(x):null,null!==\nx&&(z=Zb(x),x!==z||5!==x.tag&&6!==x.tag))x=null}else k=null,x=d;if(k!==x){w=Bd;v=\"onMouseLeave\";u=\"onMouseEnter\";t=\"mouse\";if(\"pointerout\"===a||\"pointerover\"===a)w=Td,v=\"onPointerLeave\",u=\"onPointerEnter\",t=\"pointer\";z=null==k?h:ue(k);q=null==x?h:ue(x);h=new w(v,t+\"leave\",k,c,e);h.target=z;h.relatedTarget=q;v=null;wc(e)===d&&(w=new w(u,t+\"enter\",x,c,e),w.target=q,w.relatedTarget=z,v=w);z=v;if(k&&x)b:{w=k;u=x;t=0;for(q=w;q;q=gf(q))t++;q=0;for(v=u;v;v=gf(v))q++;for(;0<t-q;)w=gf(w),t--;for(;0<q-t;)u=\ngf(u),q--;for(;t--;){if(w===u||null!==u&&w===u.alternate)break b;w=gf(w);u=gf(u)}w=null}else w=null;null!==k&&hf(g,h,k,w,!1);null!==x&&null!==z&&hf(g,z,x,w,!0)}}}a:{h=d?ue(d):window;k=h.nodeName&&h.nodeName.toLowerCase();if(\"select\"===k||\"input\"===k&&\"file\"===h.type)var J=ve;else if(me(h))if(we)J=Fe;else{J=De;var K=Ce}else(k=h.nodeName)&&\"input\"===k.toLowerCase()&&(\"checkbox\"===h.type||\"radio\"===h.type)&&(J=Ee);if(J&&(J=J(a,d))){ne(g,J,c,e);break a}K&&K(a,h,d);\"focusout\"===a&&(K=h._wrapperState)&&\nK.controlled&&\"number\"===h.type&&bb(h,\"number\",h.value)}K=d?ue(d):window;switch(a){case \"focusin\":if(me(K)||\"true\"===K.contentEditable)Qe=K,Re=d,Se=null;break;case \"focusout\":Se=Re=Qe=null;break;case \"mousedown\":Te=!0;break;case \"contextmenu\":case \"mouseup\":case \"dragend\":Te=!1;Ue(g,c,e);break;case \"selectionchange\":if(Pe)break;case \"keydown\":case \"keyup\":Ue(g,c,e)}var Q;if(ae)b:{switch(a){case \"compositionstart\":var L=\"onCompositionStart\";break b;case \"compositionend\":L=\"onCompositionEnd\";break b;\ncase \"compositionupdate\":L=\"onCompositionUpdate\";break b}L=void 0}else ie?ge(a,c)&&(L=\"onCompositionEnd\"):\"keydown\"===a&&229===c.keyCode&&(L=\"onCompositionStart\");L&&(de&&\"ko\"!==c.locale&&(ie||\"onCompositionStart\"!==L?\"onCompositionEnd\"===L&&ie&&(Q=nd()):(kd=e,ld=\"value\"in kd?kd.value:kd.textContent,ie=!0)),K=oe(d,L),0<K.length&&(L=new Ld(L,a,null,c,e),g.push({event:L,listeners:K}),Q?L.data=Q:(Q=he(c),null!==Q&&(L.data=Q))));if(Q=ce?je(a,c):ke(a,c))d=oe(d,\"onBeforeInput\"),0<d.length&&(e=new Ld(\"onBeforeInput\",\n\"beforeinput\",null,c,e),g.push({event:e,listeners:d}),e.data=Q)}se(g,b)})}function ef(a,b,c){return{instance:a,listener:b,currentTarget:c}}function oe(a,b){for(var c=b+\"Capture\",d=[];null!==a;){var e=a,f=e.stateNode;5===e.tag&&null!==f&&(e=f,f=Ob(a,c),null!=f&&d.unshift(ef(a,f,e)),f=Ob(a,b),null!=f&&d.push(ef(a,f,e)));a=a.return}return d}function gf(a){if(null===a)return null;do a=a.return;while(a&&5!==a.tag);return a?a:null}\nfunction hf(a,b,c,d,e){for(var f=b._reactName,g=[];null!==c&&c!==d;){var h=c,k=h.alternate,l=h.stateNode;if(null!==k&&k===d)break;5===h.tag&&null!==l&&(h=l,e?(k=Ob(c,f),null!=k&&g.unshift(ef(c,k,h))):e||(k=Ob(c,f),null!=k&&g.push(ef(c,k,h))));c=c.return}0!==g.length&&a.push({event:b,listeners:g})}function jf(){}var kf=null,lf=null;function mf(a,b){switch(a){case \"button\":case \"input\":case \"select\":case \"textarea\":return!!b.autoFocus}return!1}\nfunction nf(a,b){return\"textarea\"===a||\"option\"===a||\"noscript\"===a||\"string\"===typeof b.children||\"number\"===typeof b.children||\"object\"===typeof b.dangerouslySetInnerHTML&&null!==b.dangerouslySetInnerHTML&&null!=b.dangerouslySetInnerHTML.__html}var of=\"function\"===typeof setTimeout?setTimeout:void 0,pf=\"function\"===typeof clearTimeout?clearTimeout:void 0;function qf(a){1===a.nodeType?a.textContent=\"\":9===a.nodeType&&(a=a.body,null!=a&&(a.textContent=\"\"))}\nfunction rf(a){for(;null!=a;a=a.nextSibling){var b=a.nodeType;if(1===b||3===b)break}return a}function sf(a){a=a.previousSibling;for(var b=0;a;){if(8===a.nodeType){var c=a.data;if(\"$\"===c||\"$!\"===c||\"$?\"===c){if(0===b)return a;b--}else\"/$\"===c&&b++}a=a.previousSibling}return null}var tf=0;function uf(a){return{$$typeof:Ga,toString:a,valueOf:a}}var vf=Math.random().toString(36).slice(2),wf=\"__reactFiber$\"+vf,xf=\"__reactProps$\"+vf,ff=\"__reactContainer$\"+vf,yf=\"__reactEvents$\"+vf;\nfunction wc(a){var b=a[wf];if(b)return b;for(var c=a.parentNode;c;){if(b=c[ff]||c[wf]){c=b.alternate;if(null!==b.child||null!==c&&null!==c.child)for(a=sf(a);null!==a;){if(c=a[wf])return c;a=sf(a)}return b}a=c;c=a.parentNode}return null}function Cb(a){a=a[wf]||a[ff];return!a||5!==a.tag&&6!==a.tag&&13!==a.tag&&3!==a.tag?null:a}function ue(a){if(5===a.tag||6===a.tag)return a.stateNode;throw Error(y(33));}function Db(a){return a[xf]||null}\nfunction $e(a){var b=a[yf];void 0===b&&(b=a[yf]=new Set);return b}var zf=[],Af=-1;function Bf(a){return{current:a}}function H(a){0>Af||(a.current=zf[Af],zf[Af]=null,Af--)}function I(a,b){Af++;zf[Af]=a.current;a.current=b}var Cf={},M=Bf(Cf),N=Bf(!1),Df=Cf;\nfunction Ef(a,b){var c=a.type.contextTypes;if(!c)return Cf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}function Ff(a){a=a.childContextTypes;return null!==a&&void 0!==a}function Gf(){H(N);H(M)}function Hf(a,b,c){if(M.current!==Cf)throw Error(y(168));I(M,b);I(N,c)}\nfunction If(a,b,c){var d=a.stateNode;a=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in a))throw Error(y(108,Ra(b)||\"Unknown\",e));return m({},c,d)}function Jf(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Cf;Df=M.current;I(M,a);I(N,N.current);return!0}function Kf(a,b,c){var d=a.stateNode;if(!d)throw Error(y(169));c?(a=If(a,b,Df),d.__reactInternalMemoizedMergedChildContext=a,H(N),H(M),I(M,a)):H(N);I(N,c)}\nvar Lf=null,Mf=null,Nf=r.unstable_runWithPriority,Of=r.unstable_scheduleCallback,Pf=r.unstable_cancelCallback,Qf=r.unstable_shouldYield,Rf=r.unstable_requestPaint,Sf=r.unstable_now,Tf=r.unstable_getCurrentPriorityLevel,Uf=r.unstable_ImmediatePriority,Vf=r.unstable_UserBlockingPriority,Wf=r.unstable_NormalPriority,Xf=r.unstable_LowPriority,Yf=r.unstable_IdlePriority,Zf={},$f=void 0!==Rf?Rf:function(){},ag=null,bg=null,cg=!1,dg=Sf(),O=1E4>dg?Sf:function(){return Sf()-dg};\nfunction eg(){switch(Tf()){case Uf:return 99;case Vf:return 98;case Wf:return 97;case Xf:return 96;case Yf:return 95;default:throw Error(y(332));}}function fg(a){switch(a){case 99:return Uf;case 98:return Vf;case 97:return Wf;case 96:return Xf;case 95:return Yf;default:throw Error(y(332));}}function gg(a,b){a=fg(a);return Nf(a,b)}function hg(a,b,c){a=fg(a);return Of(a,b,c)}function ig(){if(null!==bg){var a=bg;bg=null;Pf(a)}jg()}\nfunction jg(){if(!cg&&null!==ag){cg=!0;var a=0;try{var b=ag;gg(99,function(){for(;a<b.length;a++){var c=b[a];do c=c(!0);while(null!==c)}});ag=null}catch(c){throw null!==ag&&(ag=ag.slice(a+1)),Of(Uf,ig),c;}finally{cg=!1}}}var kg=ra.ReactCurrentBatchConfig;function lg(a,b){if(a&&a.defaultProps){b=m({},b);a=a.defaultProps;for(var c in a)void 0===b[c]&&(b[c]=a[c]);return b}return b}var mg=Bf(null),ng=null,og=null,pg=null;function qg(){pg=og=ng=null}\nfunction rg(a){var b=mg.current;H(mg);a.type._context._currentValue=b}function sg(a,b){for(;null!==a;){var c=a.alternate;if((a.childLanes&b)===b)if(null===c||(c.childLanes&b)===b)break;else c.childLanes|=b;else a.childLanes|=b,null!==c&&(c.childLanes|=b);a=a.return}}function tg(a,b){ng=a;pg=og=null;a=a.dependencies;null!==a&&null!==a.firstContext&&(0!==(a.lanes&b)&&(ug=!0),a.firstContext=null)}\nfunction vg(a,b){if(pg!==a&&!1!==b&&0!==b){if(\"number\"!==typeof b||1073741823===b)pg=a,b=1073741823;b={context:a,observedBits:b,next:null};if(null===og){if(null===ng)throw Error(y(308));og=b;ng.dependencies={lanes:0,firstContext:b,responders:null}}else og=og.next=b}return a._currentValue}var wg=!1;function xg(a){a.updateQueue={baseState:a.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null},effects:null}}\nfunction yg(a,b){a=a.updateQueue;b.updateQueue===a&&(b.updateQueue={baseState:a.baseState,firstBaseUpdate:a.firstBaseUpdate,lastBaseUpdate:a.lastBaseUpdate,shared:a.shared,effects:a.effects})}function zg(a,b){return{eventTime:a,lane:b,tag:0,payload:null,callback:null,next:null}}function Ag(a,b){a=a.updateQueue;if(null!==a){a=a.shared;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}}\nfunction Bg(a,b){var c=a.updateQueue,d=a.alternate;if(null!==d&&(d=d.updateQueue,c===d)){var e=null,f=null;c=c.firstBaseUpdate;if(null!==c){do{var g={eventTime:c.eventTime,lane:c.lane,tag:c.tag,payload:c.payload,callback:c.callback,next:null};null===f?e=f=g:f=f.next=g;c=c.next}while(null!==c);null===f?e=f=b:f=f.next=b}else e=f=b;c={baseState:d.baseState,firstBaseUpdate:e,lastBaseUpdate:f,shared:d.shared,effects:d.effects};a.updateQueue=c;return}a=c.lastBaseUpdate;null===a?c.firstBaseUpdate=b:a.next=\nb;c.lastBaseUpdate=b}\nfunction Cg(a,b,c,d){var e=a.updateQueue;wg=!1;var f=e.firstBaseUpdate,g=e.lastBaseUpdate,h=e.shared.pending;if(null!==h){e.shared.pending=null;var k=h,l=k.next;k.next=null;null===g?f=l:g.next=l;g=k;var n=a.alternate;if(null!==n){n=n.updateQueue;var A=n.lastBaseUpdate;A!==g&&(null===A?n.firstBaseUpdate=l:A.next=l,n.lastBaseUpdate=k)}}if(null!==f){A=e.baseState;g=0;n=l=k=null;do{h=f.lane;var p=f.eventTime;if((d&h)===h){null!==n&&(n=n.next={eventTime:p,lane:0,tag:f.tag,payload:f.payload,callback:f.callback,\nnext:null});a:{var C=a,x=f;h=b;p=c;switch(x.tag){case 1:C=x.payload;if(\"function\"===typeof C){A=C.call(p,A,h);break a}A=C;break a;case 3:C.flags=C.flags&-4097|64;case 0:C=x.payload;h=\"function\"===typeof C?C.call(p,A,h):C;if(null===h||void 0===h)break a;A=m({},A,h);break a;case 2:wg=!0}}null!==f.callback&&(a.flags|=32,h=e.effects,null===h?e.effects=[f]:h.push(f))}else p={eventTime:p,lane:h,tag:f.tag,payload:f.payload,callback:f.callback,next:null},null===n?(l=n=p,k=A):n=n.next=p,g|=h;f=f.next;if(null===\nf)if(h=e.shared.pending,null===h)break;else f=h.next,h.next=null,e.lastBaseUpdate=h,e.shared.pending=null}while(1);null===n&&(k=A);e.baseState=k;e.firstBaseUpdate=l;e.lastBaseUpdate=n;Dg|=g;a.lanes=g;a.memoizedState=A}}function Eg(a,b,c){a=b.effects;b.effects=null;if(null!==a)for(b=0;b<a.length;b++){var d=a[b],e=d.callback;if(null!==e){d.callback=null;d=c;if(\"function\"!==typeof e)throw Error(y(191,e));e.call(d)}}}var Fg=(new aa.Component).refs;\nfunction Gg(a,b,c,d){b=a.memoizedState;c=c(d,b);c=null===c||void 0===c?b:m({},b,c);a.memoizedState=c;0===a.lanes&&(a.updateQueue.baseState=c)}\nvar Kg={isMounted:function(a){return(a=a._reactInternals)?Zb(a)===a:!1},enqueueSetState:function(a,b,c){a=a._reactInternals;var d=Hg(),e=Ig(a),f=zg(d,e);f.payload=b;void 0!==c&&null!==c&&(f.callback=c);Ag(a,f);Jg(a,e,d)},enqueueReplaceState:function(a,b,c){a=a._reactInternals;var d=Hg(),e=Ig(a),f=zg(d,e);f.tag=1;f.payload=b;void 0!==c&&null!==c&&(f.callback=c);Ag(a,f);Jg(a,e,d)},enqueueForceUpdate:function(a,b){a=a._reactInternals;var c=Hg(),d=Ig(a),e=zg(c,d);e.tag=2;void 0!==b&&null!==b&&(e.callback=\nb);Ag(a,e);Jg(a,d,c)}};function Lg(a,b,c,d,e,f,g){a=a.stateNode;return\"function\"===typeof a.shouldComponentUpdate?a.shouldComponentUpdate(d,f,g):b.prototype&&b.prototype.isPureReactComponent?!Je(c,d)||!Je(e,f):!0}\nfunction Mg(a,b,c){var d=!1,e=Cf;var f=b.contextType;\"object\"===typeof f&&null!==f?f=vg(f):(e=Ff(b)?Df:M.current,d=b.contextTypes,f=(d=null!==d&&void 0!==d)?Ef(a,e):Cf);b=new b(c,f);a.memoizedState=null!==b.state&&void 0!==b.state?b.state:null;b.updater=Kg;a.stateNode=b;b._reactInternals=a;d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=e,a.__reactInternalMemoizedMaskedChildContext=f);return b}\nfunction Ng(a,b,c,d){a=b.state;\"function\"===typeof b.componentWillReceiveProps&&b.componentWillReceiveProps(c,d);\"function\"===typeof b.UNSAFE_componentWillReceiveProps&&b.UNSAFE_componentWillReceiveProps(c,d);b.state!==a&&Kg.enqueueReplaceState(b,b.state,null)}\nfunction Og(a,b,c,d){var e=a.stateNode;e.props=c;e.state=a.memoizedState;e.refs=Fg;xg(a);var f=b.contextType;\"object\"===typeof f&&null!==f?e.context=vg(f):(f=Ff(b)?Df:M.current,e.context=Ef(a,f));Cg(a,c,e,d);e.state=a.memoizedState;f=b.getDerivedStateFromProps;\"function\"===typeof f&&(Gg(a,b,f,c),e.state=a.memoizedState);\"function\"===typeof b.getDerivedStateFromProps||\"function\"===typeof e.getSnapshotBeforeUpdate||\"function\"!==typeof e.UNSAFE_componentWillMount&&\"function\"!==typeof e.componentWillMount||\n(b=e.state,\"function\"===typeof e.componentWillMount&&e.componentWillMount(),\"function\"===typeof e.UNSAFE_componentWillMount&&e.UNSAFE_componentWillMount(),b!==e.state&&Kg.enqueueReplaceState(e,e.state,null),Cg(a,c,e,d),e.state=a.memoizedState);\"function\"===typeof e.componentDidMount&&(a.flags|=4)}var Pg=Array.isArray;\nfunction Qg(a,b,c){a=c.ref;if(null!==a&&\"function\"!==typeof a&&\"object\"!==typeof a){if(c._owner){c=c._owner;if(c){if(1!==c.tag)throw Error(y(309));var d=c.stateNode}if(!d)throw Error(y(147,a));var e=\"\"+a;if(null!==b&&null!==b.ref&&\"function\"===typeof b.ref&&b.ref._stringRef===e)return b.ref;b=function(a){var b=d.refs;b===Fg&&(b=d.refs={});null===a?delete b[e]:b[e]=a};b._stringRef=e;return b}if(\"string\"!==typeof a)throw Error(y(284));if(!c._owner)throw Error(y(290,a));}return a}\nfunction Rg(a,b){if(\"textarea\"!==a.type)throw Error(y(31,\"[object Object]\"===Object.prototype.toString.call(b)?\"object with keys {\"+Object.keys(b).join(\", \")+\"}\":b));}\nfunction Sg(a){function b(b,c){if(a){var d=b.lastEffect;null!==d?(d.nextEffect=c,b.lastEffect=c):b.firstEffect=b.lastEffect=c;c.nextEffect=null;c.flags=8}}function c(c,d){if(!a)return null;for(;null!==d;)b(c,d),d=d.sibling;return null}function d(a,b){for(a=new Map;null!==b;)null!==b.key?a.set(b.key,b):a.set(b.index,b),b=b.sibling;return a}function e(a,b){a=Tg(a,b);a.index=0;a.sibling=null;return a}function f(b,c,d){b.index=d;if(!a)return c;d=b.alternate;if(null!==d)return d=d.index,d<c?(b.flags=2,\nc):d;b.flags=2;return c}function g(b){a&&null===b.alternate&&(b.flags=2);return b}function h(a,b,c,d){if(null===b||6!==b.tag)return b=Ug(c,a.mode,d),b.return=a,b;b=e(b,c);b.return=a;return b}function k(a,b,c,d){if(null!==b&&b.elementType===c.type)return d=e(b,c.props),d.ref=Qg(a,b,c),d.return=a,d;d=Vg(c.type,c.key,c.props,null,a.mode,d);d.ref=Qg(a,b,c);d.return=a;return d}function l(a,b,c,d){if(null===b||4!==b.tag||b.stateNode.containerInfo!==c.containerInfo||b.stateNode.implementation!==c.implementation)return b=\nWg(c,a.mode,d),b.return=a,b;b=e(b,c.children||[]);b.return=a;return b}function n(a,b,c,d,f){if(null===b||7!==b.tag)return b=Xg(c,a.mode,d,f),b.return=a,b;b=e(b,c);b.return=a;return b}function A(a,b,c){if(\"string\"===typeof b||\"number\"===typeof b)return b=Ug(\"\"+b,a.mode,c),b.return=a,b;if(\"object\"===typeof b&&null!==b){switch(b.$$typeof){case sa:return c=Vg(b.type,b.key,b.props,null,a.mode,c),c.ref=Qg(a,null,b),c.return=a,c;case ta:return b=Wg(b,a.mode,c),b.return=a,b}if(Pg(b)||La(b))return b=Xg(b,\na.mode,c,null),b.return=a,b;Rg(a,b)}return null}function p(a,b,c,d){var e=null!==b?b.key:null;if(\"string\"===typeof c||\"number\"===typeof c)return null!==e?null:h(a,b,\"\"+c,d);if(\"object\"===typeof c&&null!==c){switch(c.$$typeof){case sa:return c.key===e?c.type===ua?n(a,b,c.props.children,d,e):k(a,b,c,d):null;case ta:return c.key===e?l(a,b,c,d):null}if(Pg(c)||La(c))return null!==e?null:n(a,b,c,d,null);Rg(a,c)}return null}function C(a,b,c,d,e){if(\"string\"===typeof d||\"number\"===typeof d)return a=a.get(c)||\nnull,h(b,a,\"\"+d,e);if(\"object\"===typeof d&&null!==d){switch(d.$$typeof){case sa:return a=a.get(null===d.key?c:d.key)||null,d.type===ua?n(b,a,d.props.children,e,d.key):k(b,a,d,e);case ta:return a=a.get(null===d.key?c:d.key)||null,l(b,a,d,e)}if(Pg(d)||La(d))return a=a.get(c)||null,n(b,a,d,e,null);Rg(b,d)}return null}function x(e,g,h,k){for(var l=null,t=null,u=g,z=g=0,q=null;null!==u&&z<h.length;z++){u.index>z?(q=u,u=null):q=u.sibling;var n=p(e,u,h[z],k);if(null===n){null===u&&(u=q);break}a&&u&&null===\nn.alternate&&b(e,u);g=f(n,g,z);null===t?l=n:t.sibling=n;t=n;u=q}if(z===h.length)return c(e,u),l;if(null===u){for(;z<h.length;z++)u=A(e,h[z],k),null!==u&&(g=f(u,g,z),null===t?l=u:t.sibling=u,t=u);return l}for(u=d(e,u);z<h.length;z++)q=C(u,e,z,h[z],k),null!==q&&(a&&null!==q.alternate&&u.delete(null===q.key?z:q.key),g=f(q,g,z),null===t?l=q:t.sibling=q,t=q);a&&u.forEach(function(a){return b(e,a)});return l}function w(e,g,h,k){var l=La(h);if(\"function\"!==typeof l)throw Error(y(150));h=l.call(h);if(null==\nh)throw Error(y(151));for(var t=l=null,u=g,z=g=0,q=null,n=h.next();null!==u&&!n.done;z++,n=h.next()){u.index>z?(q=u,u=null):q=u.sibling;var w=p(e,u,n.value,k);if(null===w){null===u&&(u=q);break}a&&u&&null===w.alternate&&b(e,u);g=f(w,g,z);null===t?l=w:t.sibling=w;t=w;u=q}if(n.done)return c(e,u),l;if(null===u){for(;!n.done;z++,n=h.next())n=A(e,n.value,k),null!==n&&(g=f(n,g,z),null===t?l=n:t.sibling=n,t=n);return l}for(u=d(e,u);!n.done;z++,n=h.next())n=C(u,e,z,n.value,k),null!==n&&(a&&null!==n.alternate&&\nu.delete(null===n.key?z:n.key),g=f(n,g,z),null===t?l=n:t.sibling=n,t=n);a&&u.forEach(function(a){return b(e,a)});return l}return function(a,d,f,h){var k=\"object\"===typeof f&&null!==f&&f.type===ua&&null===f.key;k&&(f=f.props.children);var l=\"object\"===typeof f&&null!==f;if(l)switch(f.$$typeof){case sa:a:{l=f.key;for(k=d;null!==k;){if(k.key===l){switch(k.tag){case 7:if(f.type===ua){c(a,k.sibling);d=e(k,f.props.children);d.return=a;a=d;break a}break;default:if(k.elementType===f.type){c(a,k.sibling);\nd=e(k,f.props);d.ref=Qg(a,k,f);d.return=a;a=d;break a}}c(a,k);break}else b(a,k);k=k.sibling}f.type===ua?(d=Xg(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=Vg(f.type,f.key,f.props,null,a.mode,h),h.ref=Qg(a,d,f),h.return=a,a=h)}return g(a);case ta:a:{for(k=f.key;null!==d;){if(d.key===k)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=\nWg(f,a.mode,h);d.return=a;a=d}return g(a)}if(\"string\"===typeof f||\"number\"===typeof f)return f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):(c(a,d),d=Ug(f,a.mode,h),d.return=a,a=d),g(a);if(Pg(f))return x(a,d,f,h);if(La(f))return w(a,d,f,h);l&&Rg(a,f);if(\"undefined\"===typeof f&&!k)switch(a.tag){case 1:case 22:case 0:case 11:case 15:throw Error(y(152,Ra(a.type)||\"Component\"));}return c(a,d)}}var Yg=Sg(!0),Zg=Sg(!1),$g={},ah=Bf($g),bh=Bf($g),ch=Bf($g);\nfunction dh(a){if(a===$g)throw Error(y(174));return a}function eh(a,b){I(ch,b);I(bh,a);I(ah,$g);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:mb(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=mb(b,a)}H(ah);I(ah,b)}function fh(){H(ah);H(bh);H(ch)}function gh(a){dh(ch.current);var b=dh(ah.current);var c=mb(b,a.type);b!==c&&(I(bh,a),I(ah,c))}function hh(a){bh.current===a&&(H(ah),H(bh))}var P=Bf(0);\nfunction ih(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||\"$?\"===c.data||\"$!\"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&64))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var jh=null,kh=null,lh=!1;\nfunction mh(a,b){var c=nh(5,null,null,0);c.elementType=\"DELETED\";c.type=\"DELETED\";c.stateNode=b;c.return=a;c.flags=8;null!==a.lastEffect?(a.lastEffect.nextEffect=c,a.lastEffect=c):a.firstEffect=a.lastEffect=c}function oh(a,b){switch(a.tag){case 5:var c=a.type;b=1!==b.nodeType||c.toLowerCase()!==b.nodeName.toLowerCase()?null:b;return null!==b?(a.stateNode=b,!0):!1;case 6:return b=\"\"===a.pendingProps||3!==b.nodeType?null:b,null!==b?(a.stateNode=b,!0):!1;case 13:return!1;default:return!1}}\nfunction ph(a){if(lh){var b=kh;if(b){var c=b;if(!oh(a,b)){b=rf(c.nextSibling);if(!b||!oh(a,b)){a.flags=a.flags&-1025|2;lh=!1;jh=a;return}mh(jh,c)}jh=a;kh=rf(b.firstChild)}else a.flags=a.flags&-1025|2,lh=!1,jh=a}}function qh(a){for(a=a.return;null!==a&&5!==a.tag&&3!==a.tag&&13!==a.tag;)a=a.return;jh=a}\nfunction rh(a){if(a!==jh)return!1;if(!lh)return qh(a),lh=!0,!1;var b=a.type;if(5!==a.tag||\"head\"!==b&&\"body\"!==b&&!nf(b,a.memoizedProps))for(b=kh;b;)mh(a,b),b=rf(b.nextSibling);qh(a);if(13===a.tag){a=a.memoizedState;a=null!==a?a.dehydrated:null;if(!a)throw Error(y(317));a:{a=a.nextSibling;for(b=0;a;){if(8===a.nodeType){var c=a.data;if(\"/$\"===c){if(0===b){kh=rf(a.nextSibling);break a}b--}else\"$\"!==c&&\"$!\"!==c&&\"$?\"!==c||b++}a=a.nextSibling}kh=null}}else kh=jh?rf(a.stateNode.nextSibling):null;return!0}\nfunction sh(){kh=jh=null;lh=!1}var th=[];function uh(){for(var a=0;a<th.length;a++)th[a]._workInProgressVersionPrimary=null;th.length=0}var vh=ra.ReactCurrentDispatcher,wh=ra.ReactCurrentBatchConfig,xh=0,R=null,S=null,T=null,yh=!1,zh=!1;function Ah(){throw Error(y(321));}function Bh(a,b){if(null===b)return!1;for(var c=0;c<b.length&&c<a.length;c++)if(!He(a[c],b[c]))return!1;return!0}\nfunction Ch(a,b,c,d,e,f){xh=f;R=b;b.memoizedState=null;b.updateQueue=null;b.lanes=0;vh.current=null===a||null===a.memoizedState?Dh:Eh;a=c(d,e);if(zh){f=0;do{zh=!1;if(!(25>f))throw Error(y(301));f+=1;T=S=null;b.updateQueue=null;vh.current=Fh;a=c(d,e)}while(zh)}vh.current=Gh;b=null!==S&&null!==S.next;xh=0;T=S=R=null;yh=!1;if(b)throw Error(y(300));return a}function Hh(){var a={memoizedState:null,baseState:null,baseQueue:null,queue:null,next:null};null===T?R.memoizedState=T=a:T=T.next=a;return T}\nfunction Ih(){if(null===S){var a=R.alternate;a=null!==a?a.memoizedState:null}else a=S.next;var b=null===T?R.memoizedState:T.next;if(null!==b)T=b,S=a;else{if(null===a)throw Error(y(310));S=a;a={memoizedState:S.memoizedState,baseState:S.baseState,baseQueue:S.baseQueue,queue:S.queue,next:null};null===T?R.memoizedState=T=a:T=T.next=a}return T}function Jh(a,b){return\"function\"===typeof b?b(a):b}\nfunction Kh(a){var b=Ih(),c=b.queue;if(null===c)throw Error(y(311));c.lastRenderedReducer=a;var d=S,e=d.baseQueue,f=c.pending;if(null!==f){if(null!==e){var g=e.next;e.next=f.next;f.next=g}d.baseQueue=e=f;c.pending=null}if(null!==e){e=e.next;d=d.baseState;var h=g=f=null,k=e;do{var l=k.lane;if((xh&l)===l)null!==h&&(h=h.next={lane:0,action:k.action,eagerReducer:k.eagerReducer,eagerState:k.eagerState,next:null}),d=k.eagerReducer===a?k.eagerState:a(d,k.action);else{var n={lane:l,action:k.action,eagerReducer:k.eagerReducer,\neagerState:k.eagerState,next:null};null===h?(g=h=n,f=d):h=h.next=n;R.lanes|=l;Dg|=l}k=k.next}while(null!==k&&k!==e);null===h?f=d:h.next=g;He(d,b.memoizedState)||(ug=!0);b.memoizedState=d;b.baseState=f;b.baseQueue=h;c.lastRenderedState=d}return[b.memoizedState,c.dispatch]}\nfunction Lh(a){var b=Ih(),c=b.queue;if(null===c)throw Error(y(311));c.lastRenderedReducer=a;var d=c.dispatch,e=c.pending,f=b.memoizedState;if(null!==e){c.pending=null;var g=e=e.next;do f=a(f,g.action),g=g.next;while(g!==e);He(f,b.memoizedState)||(ug=!0);b.memoizedState=f;null===b.baseQueue&&(b.baseState=f);c.lastRenderedState=f}return[f,d]}\nfunction Mh(a,b,c){var d=b._getVersion;d=d(b._source);var e=b._workInProgressVersionPrimary;if(null!==e)a=e===d;else if(a=a.mutableReadLanes,a=(xh&a)===a)b._workInProgressVersionPrimary=d,th.push(b);if(a)return c(b._source);th.push(b);throw Error(y(350));}\nfunction Nh(a,b,c,d){var e=U;if(null===e)throw Error(y(349));var f=b._getVersion,g=f(b._source),h=vh.current,k=h.useState(function(){return Mh(e,b,c)}),l=k[1],n=k[0];k=T;var A=a.memoizedState,p=A.refs,C=p.getSnapshot,x=A.source;A=A.subscribe;var w=R;a.memoizedState={refs:p,source:b,subscribe:d};h.useEffect(function(){p.getSnapshot=c;p.setSnapshot=l;var a=f(b._source);if(!He(g,a)){a=c(b._source);He(n,a)||(l(a),a=Ig(w),e.mutableReadLanes|=a&e.pendingLanes);a=e.mutableReadLanes;e.entangledLanes|=a;for(var d=\ne.entanglements,h=a;0<h;){var k=31-Vc(h),v=1<<k;d[k]|=a;h&=~v}}},[c,b,d]);h.useEffect(function(){return d(b._source,function(){var a=p.getSnapshot,c=p.setSnapshot;try{c(a(b._source));var d=Ig(w);e.mutableReadLanes|=d&e.pendingLanes}catch(q){c(function(){throw q;})}})},[b,d]);He(C,c)&&He(x,b)&&He(A,d)||(a={pending:null,dispatch:null,lastRenderedReducer:Jh,lastRenderedState:n},a.dispatch=l=Oh.bind(null,R,a),k.queue=a,k.baseQueue=null,n=Mh(e,b,c),k.memoizedState=k.baseState=n);return n}\nfunction Ph(a,b,c){var d=Ih();return Nh(d,a,b,c)}function Qh(a){var b=Hh();\"function\"===typeof a&&(a=a());b.memoizedState=b.baseState=a;a=b.queue={pending:null,dispatch:null,lastRenderedReducer:Jh,lastRenderedState:a};a=a.dispatch=Oh.bind(null,R,a);return[b.memoizedState,a]}\nfunction Rh(a,b,c,d){a={tag:a,create:b,destroy:c,deps:d,next:null};b=R.updateQueue;null===b?(b={lastEffect:null},R.updateQueue=b,b.lastEffect=a.next=a):(c=b.lastEffect,null===c?b.lastEffect=a.next=a:(d=c.next,c.next=a,a.next=d,b.lastEffect=a));return a}function Sh(a){var b=Hh();a={current:a};return b.memoizedState=a}function Th(){return Ih().memoizedState}function Uh(a,b,c,d){var e=Hh();R.flags|=a;e.memoizedState=Rh(1|b,c,void 0,void 0===d?null:d)}\nfunction Vh(a,b,c,d){var e=Ih();d=void 0===d?null:d;var f=void 0;if(null!==S){var g=S.memoizedState;f=g.destroy;if(null!==d&&Bh(d,g.deps)){Rh(b,c,f,d);return}}R.flags|=a;e.memoizedState=Rh(1|b,c,f,d)}function Wh(a,b){return Uh(516,4,a,b)}function Xh(a,b){return Vh(516,4,a,b)}function Yh(a,b){return Vh(4,2,a,b)}function Zh(a,b){if(\"function\"===typeof b)return a=a(),b(a),function(){b(null)};if(null!==b&&void 0!==b)return a=a(),b.current=a,function(){b.current=null}}\nfunction $h(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return Vh(4,2,Zh.bind(null,b,a),c)}function ai(){}function bi(a,b){var c=Ih();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&Bh(b,d[1]))return d[0];c.memoizedState=[a,b];return a}function ci(a,b){var c=Ih();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&Bh(b,d[1]))return d[0];a=a();c.memoizedState=[a,b];return a}\nfunction di(a,b){var c=eg();gg(98>c?98:c,function(){a(!0)});gg(97<c?97:c,function(){var c=wh.transition;wh.transition=1;try{a(!1),b()}finally{wh.transition=c}})}\nfunction Oh(a,b,c){var d=Hg(),e=Ig(a),f={lane:e,action:c,eagerReducer:null,eagerState:null,next:null},g=b.pending;null===g?f.next=f:(f.next=g.next,g.next=f);b.pending=f;g=a.alternate;if(a===R||null!==g&&g===R)zh=yh=!0;else{if(0===a.lanes&&(null===g||0===g.lanes)&&(g=b.lastRenderedReducer,null!==g))try{var h=b.lastRenderedState,k=g(h,c);f.eagerReducer=g;f.eagerState=k;if(He(k,h))return}catch(l){}finally{}Jg(a,e,d)}}\nvar Gh={readContext:vg,useCallback:Ah,useContext:Ah,useEffect:Ah,useImperativeHandle:Ah,useLayoutEffect:Ah,useMemo:Ah,useReducer:Ah,useRef:Ah,useState:Ah,useDebugValue:Ah,useDeferredValue:Ah,useTransition:Ah,useMutableSource:Ah,useOpaqueIdentifier:Ah,unstable_isNewReconciler:!1},Dh={readContext:vg,useCallback:function(a,b){Hh().memoizedState=[a,void 0===b?null:b];return a},useContext:vg,useEffect:Wh,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return Uh(4,2,Zh.bind(null,\nb,a),c)},useLayoutEffect:function(a,b){return Uh(4,2,a,b)},useMemo:function(a,b){var c=Hh();b=void 0===b?null:b;a=a();c.memoizedState=[a,b];return a},useReducer:function(a,b,c){var d=Hh();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a=d.queue={pending:null,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};a=a.dispatch=Oh.bind(null,R,a);return[d.memoizedState,a]},useRef:Sh,useState:Qh,useDebugValue:ai,useDeferredValue:function(a){var b=Qh(a),c=b[0],d=b[1];Wh(function(){var b=wh.transition;\nwh.transition=1;try{d(a)}finally{wh.transition=b}},[a]);return c},useTransition:function(){var a=Qh(!1),b=a[0];a=di.bind(null,a[1]);Sh(a);return[a,b]},useMutableSource:function(a,b,c){var d=Hh();d.memoizedState={refs:{getSnapshot:b,setSnapshot:null},source:a,subscribe:c};return Nh(d,a,b,c)},useOpaqueIdentifier:function(){if(lh){var a=!1,b=uf(function(){a||(a=!0,c(\"r:\"+(tf++).toString(36)));throw Error(y(355));}),c=Qh(b)[1];0===(R.mode&2)&&(R.flags|=516,Rh(5,function(){c(\"r:\"+(tf++).toString(36))},\nvoid 0,null));return b}b=\"r:\"+(tf++).toString(36);Qh(b);return b},unstable_isNewReconciler:!1},Eh={readContext:vg,useCallback:bi,useContext:vg,useEffect:Xh,useImperativeHandle:$h,useLayoutEffect:Yh,useMemo:ci,useReducer:Kh,useRef:Th,useState:function(){return Kh(Jh)},useDebugValue:ai,useDeferredValue:function(a){var b=Kh(Jh),c=b[0],d=b[1];Xh(function(){var b=wh.transition;wh.transition=1;try{d(a)}finally{wh.transition=b}},[a]);return c},useTransition:function(){var a=Kh(Jh)[0];return[Th().current,\na]},useMutableSource:Ph,useOpaqueIdentifier:function(){return Kh(Jh)[0]},unstable_isNewReconciler:!1},Fh={readContext:vg,useCallback:bi,useContext:vg,useEffect:Xh,useImperativeHandle:$h,useLayoutEffect:Yh,useMemo:ci,useReducer:Lh,useRef:Th,useState:function(){return Lh(Jh)},useDebugValue:ai,useDeferredValue:function(a){var b=Lh(Jh),c=b[0],d=b[1];Xh(function(){var b=wh.transition;wh.transition=1;try{d(a)}finally{wh.transition=b}},[a]);return c},useTransition:function(){var a=Lh(Jh)[0];return[Th().current,\na]},useMutableSource:Ph,useOpaqueIdentifier:function(){return Lh(Jh)[0]},unstable_isNewReconciler:!1},ei=ra.ReactCurrentOwner,ug=!1;function fi(a,b,c,d){b.child=null===a?Zg(b,null,c,d):Yg(b,a.child,c,d)}function gi(a,b,c,d,e){c=c.render;var f=b.ref;tg(b,e);d=Ch(a,b,c,d,f,e);if(null!==a&&!ug)return b.updateQueue=a.updateQueue,b.flags&=-517,a.lanes&=~e,hi(a,b,e);b.flags|=1;fi(a,b,d,e);return b.child}\nfunction ii(a,b,c,d,e,f){if(null===a){var g=c.type;if(\"function\"===typeof g&&!ji(g)&&void 0===g.defaultProps&&null===c.compare&&void 0===c.defaultProps)return b.tag=15,b.type=g,ki(a,b,g,d,e,f);a=Vg(c.type,null,d,b,b.mode,f);a.ref=b.ref;a.return=b;return b.child=a}g=a.child;if(0===(e&f)&&(e=g.memoizedProps,c=c.compare,c=null!==c?c:Je,c(e,d)&&a.ref===b.ref))return hi(a,b,f);b.flags|=1;a=Tg(g,d);a.ref=b.ref;a.return=b;return b.child=a}\nfunction ki(a,b,c,d,e,f){if(null!==a&&Je(a.memoizedProps,d)&&a.ref===b.ref)if(ug=!1,0!==(f&e))0!==(a.flags&16384)&&(ug=!0);else return b.lanes=a.lanes,hi(a,b,f);return li(a,b,c,d,f)}\nfunction mi(a,b,c){var d=b.pendingProps,e=d.children,f=null!==a?a.memoizedState:null;if(\"hidden\"===d.mode||\"unstable-defer-without-hiding\"===d.mode)if(0===(b.mode&4))b.memoizedState={baseLanes:0},ni(b,c);else if(0!==(c&1073741824))b.memoizedState={baseLanes:0},ni(b,null!==f?f.baseLanes:c);else return a=null!==f?f.baseLanes|c:c,b.lanes=b.childLanes=1073741824,b.memoizedState={baseLanes:a},ni(b,a),null;else null!==f?(d=f.baseLanes|c,b.memoizedState=null):d=c,ni(b,d);fi(a,b,e,c);return b.child}\nfunction oi(a,b){var c=b.ref;if(null===a&&null!==c||null!==a&&a.ref!==c)b.flags|=128}function li(a,b,c,d,e){var f=Ff(c)?Df:M.current;f=Ef(b,f);tg(b,e);c=Ch(a,b,c,d,f,e);if(null!==a&&!ug)return b.updateQueue=a.updateQueue,b.flags&=-517,a.lanes&=~e,hi(a,b,e);b.flags|=1;fi(a,b,c,e);return b.child}\nfunction pi(a,b,c,d,e){if(Ff(c)){var f=!0;Jf(b)}else f=!1;tg(b,e);if(null===b.stateNode)null!==a&&(a.alternate=null,b.alternate=null,b.flags|=2),Mg(b,c,d),Og(b,c,d,e),d=!0;else if(null===a){var g=b.stateNode,h=b.memoizedProps;g.props=h;var k=g.context,l=c.contextType;\"object\"===typeof l&&null!==l?l=vg(l):(l=Ff(c)?Df:M.current,l=Ef(b,l));var n=c.getDerivedStateFromProps,A=\"function\"===typeof n||\"function\"===typeof g.getSnapshotBeforeUpdate;A||\"function\"!==typeof g.UNSAFE_componentWillReceiveProps&&\n\"function\"!==typeof g.componentWillReceiveProps||(h!==d||k!==l)&&Ng(b,g,d,l);wg=!1;var p=b.memoizedState;g.state=p;Cg(b,d,g,e);k=b.memoizedState;h!==d||p!==k||N.current||wg?(\"function\"===typeof n&&(Gg(b,c,n,d),k=b.memoizedState),(h=wg||Lg(b,c,h,d,p,k,l))?(A||\"function\"!==typeof g.UNSAFE_componentWillMount&&\"function\"!==typeof g.componentWillMount||(\"function\"===typeof g.componentWillMount&&g.componentWillMount(),\"function\"===typeof g.UNSAFE_componentWillMount&&g.UNSAFE_componentWillMount()),\"function\"===\ntypeof g.componentDidMount&&(b.flags|=4)):(\"function\"===typeof g.componentDidMount&&(b.flags|=4),b.memoizedProps=d,b.memoizedState=k),g.props=d,g.state=k,g.context=l,d=h):(\"function\"===typeof g.componentDidMount&&(b.flags|=4),d=!1)}else{g=b.stateNode;yg(a,b);h=b.memoizedProps;l=b.type===b.elementType?h:lg(b.type,h);g.props=l;A=b.pendingProps;p=g.context;k=c.contextType;\"object\"===typeof k&&null!==k?k=vg(k):(k=Ff(c)?Df:M.current,k=Ef(b,k));var C=c.getDerivedStateFromProps;(n=\"function\"===typeof C||\n\"function\"===typeof g.getSnapshotBeforeUpdate)||\"function\"!==typeof g.UNSAFE_componentWillReceiveProps&&\"function\"!==typeof g.componentWillReceiveProps||(h!==A||p!==k)&&Ng(b,g,d,k);wg=!1;p=b.memoizedState;g.state=p;Cg(b,d,g,e);var x=b.memoizedState;h!==A||p!==x||N.current||wg?(\"function\"===typeof C&&(Gg(b,c,C,d),x=b.memoizedState),(l=wg||Lg(b,c,l,d,p,x,k))?(n||\"function\"!==typeof g.UNSAFE_componentWillUpdate&&\"function\"!==typeof g.componentWillUpdate||(\"function\"===typeof g.componentWillUpdate&&g.componentWillUpdate(d,\nx,k),\"function\"===typeof g.UNSAFE_componentWillUpdate&&g.UNSAFE_componentWillUpdate(d,x,k)),\"function\"===typeof g.componentDidUpdate&&(b.flags|=4),\"function\"===typeof g.getSnapshotBeforeUpdate&&(b.flags|=256)):(\"function\"!==typeof g.componentDidUpdate||h===a.memoizedProps&&p===a.memoizedState||(b.flags|=4),\"function\"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&p===a.memoizedState||(b.flags|=256),b.memoizedProps=d,b.memoizedState=x),g.props=d,g.state=x,g.context=k,d=l):(\"function\"!==typeof g.componentDidUpdate||\nh===a.memoizedProps&&p===a.memoizedState||(b.flags|=4),\"function\"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&p===a.memoizedState||(b.flags|=256),d=!1)}return qi(a,b,c,d,f,e)}\nfunction qi(a,b,c,d,e,f){oi(a,b);var g=0!==(b.flags&64);if(!d&&!g)return e&&Kf(b,c,!1),hi(a,b,f);d=b.stateNode;ei.current=b;var h=g&&\"function\"!==typeof c.getDerivedStateFromError?null:d.render();b.flags|=1;null!==a&&g?(b.child=Yg(b,a.child,null,f),b.child=Yg(b,null,h,f)):fi(a,b,h,f);b.memoizedState=d.state;e&&Kf(b,c,!0);return b.child}function ri(a){var b=a.stateNode;b.pendingContext?Hf(a,b.pendingContext,b.pendingContext!==b.context):b.context&&Hf(a,b.context,!1);eh(a,b.containerInfo)}\nvar si={dehydrated:null,retryLane:0};\nfunction ti(a,b,c){var d=b.pendingProps,e=P.current,f=!1,g;(g=0!==(b.flags&64))||(g=null!==a&&null===a.memoizedState?!1:0!==(e&2));g?(f=!0,b.flags&=-65):null!==a&&null===a.memoizedState||void 0===d.fallback||!0===d.unstable_avoidThisFallback||(e|=1);I(P,e&1);if(null===a){void 0!==d.fallback&&ph(b);a=d.children;e=d.fallback;if(f)return a=ui(b,a,e,c),b.child.memoizedState={baseLanes:c},b.memoizedState=si,a;if(\"number\"===typeof d.unstable_expectedLoadTime)return a=ui(b,a,e,c),b.child.memoizedState={baseLanes:c},\nb.memoizedState=si,b.lanes=33554432,a;c=vi({mode:\"visible\",children:a},b.mode,c,null);c.return=b;return b.child=c}if(null!==a.memoizedState){if(f)return d=wi(a,b,d.children,d.fallback,c),f=b.child,e=a.child.memoizedState,f.memoizedState=null===e?{baseLanes:c}:{baseLanes:e.baseLanes|c},f.childLanes=a.childLanes&~c,b.memoizedState=si,d;c=xi(a,b,d.children,c);b.memoizedState=null;return c}if(f)return d=wi(a,b,d.children,d.fallback,c),f=b.child,e=a.child.memoizedState,f.memoizedState=null===e?{baseLanes:c}:\n{baseLanes:e.baseLanes|c},f.childLanes=a.childLanes&~c,b.memoizedState=si,d;c=xi(a,b,d.children,c);b.memoizedState=null;return c}function ui(a,b,c,d){var e=a.mode,f=a.child;b={mode:\"hidden\",children:b};0===(e&2)&&null!==f?(f.childLanes=0,f.pendingProps=b):f=vi(b,e,0,null);c=Xg(c,e,d,null);f.return=a;c.return=a;f.sibling=c;a.child=f;return c}\nfunction xi(a,b,c,d){var e=a.child;a=e.sibling;c=Tg(e,{mode:\"visible\",children:c});0===(b.mode&2)&&(c.lanes=d);c.return=b;c.sibling=null;null!==a&&(a.nextEffect=null,a.flags=8,b.firstEffect=b.lastEffect=a);return b.child=c}\nfunction wi(a,b,c,d,e){var f=b.mode,g=a.child;a=g.sibling;var h={mode:\"hidden\",children:c};0===(f&2)&&b.child!==g?(c=b.child,c.childLanes=0,c.pendingProps=h,g=c.lastEffect,null!==g?(b.firstEffect=c.firstEffect,b.lastEffect=g,g.nextEffect=null):b.firstEffect=b.lastEffect=null):c=Tg(g,h);null!==a?d=Tg(a,d):(d=Xg(d,f,e,null),d.flags|=2);d.return=b;c.return=b;c.sibling=d;b.child=c;return d}function yi(a,b){a.lanes|=b;var c=a.alternate;null!==c&&(c.lanes|=b);sg(a.return,b)}\nfunction zi(a,b,c,d,e,f){var g=a.memoizedState;null===g?a.memoizedState={isBackwards:b,rendering:null,renderingStartTime:0,last:d,tail:c,tailMode:e,lastEffect:f}:(g.isBackwards=b,g.rendering=null,g.renderingStartTime=0,g.last=d,g.tail=c,g.tailMode=e,g.lastEffect=f)}\nfunction Ai(a,b,c){var d=b.pendingProps,e=d.revealOrder,f=d.tail;fi(a,b,d.children,c);d=P.current;if(0!==(d&2))d=d&1|2,b.flags|=64;else{if(null!==a&&0!==(a.flags&64))a:for(a=b.child;null!==a;){if(13===a.tag)null!==a.memoizedState&&yi(a,c);else if(19===a.tag)yi(a,c);else if(null!==a.child){a.child.return=a;a=a.child;continue}if(a===b)break a;for(;null===a.sibling;){if(null===a.return||a.return===b)break a;a=a.return}a.sibling.return=a.return;a=a.sibling}d&=1}I(P,d);if(0===(b.mode&2))b.memoizedState=\nnull;else switch(e){case \"forwards\":c=b.child;for(e=null;null!==c;)a=c.alternate,null!==a&&null===ih(a)&&(e=c),c=c.sibling;c=e;null===c?(e=b.child,b.child=null):(e=c.sibling,c.sibling=null);zi(b,!1,e,c,f,b.lastEffect);break;case \"backwards\":c=null;e=b.child;for(b.child=null;null!==e;){a=e.alternate;if(null!==a&&null===ih(a)){b.child=e;break}a=e.sibling;e.sibling=c;c=e;e=a}zi(b,!0,c,null,f,b.lastEffect);break;case \"together\":zi(b,!1,null,null,void 0,b.lastEffect);break;default:b.memoizedState=null}return b.child}\nfunction hi(a,b,c){null!==a&&(b.dependencies=a.dependencies);Dg|=b.lanes;if(0!==(c&b.childLanes)){if(null!==a&&b.child!==a.child)throw Error(y(153));if(null!==b.child){a=b.child;c=Tg(a,a.pendingProps);b.child=c;for(c.return=b;null!==a.sibling;)a=a.sibling,c=c.sibling=Tg(a,a.pendingProps),c.return=b;c.sibling=null}return b.child}return null}var Bi,Ci,Di,Ei;\nBi=function(a,b){for(var c=b.child;null!==c;){if(5===c.tag||6===c.tag)a.appendChild(c.stateNode);else if(4!==c.tag&&null!==c.child){c.child.return=c;c=c.child;continue}if(c===b)break;for(;null===c.sibling;){if(null===c.return||c.return===b)return;c=c.return}c.sibling.return=c.return;c=c.sibling}};Ci=function(){};\nDi=function(a,b,c,d){var e=a.memoizedProps;if(e!==d){a=b.stateNode;dh(ah.current);var f=null;switch(c){case \"input\":e=Ya(a,e);d=Ya(a,d);f=[];break;case \"option\":e=eb(a,e);d=eb(a,d);f=[];break;case \"select\":e=m({},e,{value:void 0});d=m({},d,{value:void 0});f=[];break;case \"textarea\":e=gb(a,e);d=gb(a,d);f=[];break;default:\"function\"!==typeof e.onClick&&\"function\"===typeof d.onClick&&(a.onclick=jf)}vb(c,d);var g;c=null;for(l in e)if(!d.hasOwnProperty(l)&&e.hasOwnProperty(l)&&null!=e[l])if(\"style\"===\nl){var h=e[l];for(g in h)h.hasOwnProperty(g)&&(c||(c={}),c[g]=\"\")}else\"dangerouslySetInnerHTML\"!==l&&\"children\"!==l&&\"suppressContentEditableWarning\"!==l&&\"suppressHydrationWarning\"!==l&&\"autoFocus\"!==l&&(ca.hasOwnProperty(l)?f||(f=[]):(f=f||[]).push(l,null));for(l in d){var k=d[l];h=null!=e?e[l]:void 0;if(d.hasOwnProperty(l)&&k!==h&&(null!=k||null!=h))if(\"style\"===l)if(h){for(g in h)!h.hasOwnProperty(g)||k&&k.hasOwnProperty(g)||(c||(c={}),c[g]=\"\");for(g in k)k.hasOwnProperty(g)&&h[g]!==k[g]&&(c||\n(c={}),c[g]=k[g])}else c||(f||(f=[]),f.push(l,c)),c=k;else\"dangerouslySetInnerHTML\"===l?(k=k?k.__html:void 0,h=h?h.__html:void 0,null!=k&&h!==k&&(f=f||[]).push(l,k)):\"children\"===l?\"string\"!==typeof k&&\"number\"!==typeof k||(f=f||[]).push(l,\"\"+k):\"suppressContentEditableWarning\"!==l&&\"suppressHydrationWarning\"!==l&&(ca.hasOwnProperty(l)?(null!=k&&\"onScroll\"===l&&G(\"scroll\",a),f||h===k||(f=[])):\"object\"===typeof k&&null!==k&&k.$$typeof===Ga?k.toString():(f=f||[]).push(l,k))}c&&(f=f||[]).push(\"style\",\nc);var l=f;if(b.updateQueue=l)b.flags|=4}};Ei=function(a,b,c,d){c!==d&&(b.flags|=4)};function Fi(a,b){if(!lh)switch(a.tailMode){case \"hidden\":b=a.tail;for(var c=null;null!==b;)null!==b.alternate&&(c=b),b=b.sibling;null===c?a.tail=null:c.sibling=null;break;case \"collapsed\":c=a.tail;for(var d=null;null!==c;)null!==c.alternate&&(d=c),c=c.sibling;null===d?b||null===a.tail?a.tail=null:a.tail.sibling=null:d.sibling=null}}\nfunction Gi(a,b,c){var d=b.pendingProps;switch(b.tag){case 2:case 16:case 15:case 0:case 11:case 7:case 8:case 12:case 9:case 14:return null;case 1:return Ff(b.type)&&Gf(),null;case 3:fh();H(N);H(M);uh();d=b.stateNode;d.pendingContext&&(d.context=d.pendingContext,d.pendingContext=null);if(null===a||null===a.child)rh(b)?b.flags|=4:d.hydrate||(b.flags|=256);Ci(b);return null;case 5:hh(b);var e=dh(ch.current);c=b.type;if(null!==a&&null!=b.stateNode)Di(a,b,c,d,e),a.ref!==b.ref&&(b.flags|=128);else{if(!d){if(null===\nb.stateNode)throw Error(y(166));return null}a=dh(ah.current);if(rh(b)){d=b.stateNode;c=b.type;var f=b.memoizedProps;d[wf]=b;d[xf]=f;switch(c){case \"dialog\":G(\"cancel\",d);G(\"close\",d);break;case \"iframe\":case \"object\":case \"embed\":G(\"load\",d);break;case \"video\":case \"audio\":for(a=0;a<Xe.length;a++)G(Xe[a],d);break;case \"source\":G(\"error\",d);break;case \"img\":case \"image\":case \"link\":G(\"error\",d);G(\"load\",d);break;case \"details\":G(\"toggle\",d);break;case \"input\":Za(d,f);G(\"invalid\",d);break;case \"select\":d._wrapperState=\n{wasMultiple:!!f.multiple};G(\"invalid\",d);break;case \"textarea\":hb(d,f),G(\"invalid\",d)}vb(c,f);a=null;for(var g in f)f.hasOwnProperty(g)&&(e=f[g],\"children\"===g?\"string\"===typeof e?d.textContent!==e&&(a=[\"children\",e]):\"number\"===typeof e&&d.textContent!==\"\"+e&&(a=[\"children\",\"\"+e]):ca.hasOwnProperty(g)&&null!=e&&\"onScroll\"===g&&G(\"scroll\",d));switch(c){case \"input\":Va(d);cb(d,f,!0);break;case \"textarea\":Va(d);jb(d);break;case \"select\":case \"option\":break;default:\"function\"===typeof f.onClick&&(d.onclick=\njf)}d=a;b.updateQueue=d;null!==d&&(b.flags|=4)}else{g=9===e.nodeType?e:e.ownerDocument;a===kb.html&&(a=lb(c));a===kb.html?\"script\"===c?(a=g.createElement(\"div\"),a.innerHTML=\"<script>\\x3c/script>\",a=a.removeChild(a.firstChild)):\"string\"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),\"select\"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[wf]=b;a[xf]=d;Bi(a,b,!1,!1);b.stateNode=a;g=wb(c,d);switch(c){case \"dialog\":G(\"cancel\",a);G(\"close\",a);\ne=d;break;case \"iframe\":case \"object\":case \"embed\":G(\"load\",a);e=d;break;case \"video\":case \"audio\":for(e=0;e<Xe.length;e++)G(Xe[e],a);e=d;break;case \"source\":G(\"error\",a);e=d;break;case \"img\":case \"image\":case \"link\":G(\"error\",a);G(\"load\",a);e=d;break;case \"details\":G(\"toggle\",a);e=d;break;case \"input\":Za(a,d);e=Ya(a,d);G(\"invalid\",a);break;case \"option\":e=eb(a,d);break;case \"select\":a._wrapperState={wasMultiple:!!d.multiple};e=m({},d,{value:void 0});G(\"invalid\",a);break;case \"textarea\":hb(a,d);e=\ngb(a,d);G(\"invalid\",a);break;default:e=d}vb(c,e);var h=e;for(f in h)if(h.hasOwnProperty(f)){var k=h[f];\"style\"===f?tb(a,k):\"dangerouslySetInnerHTML\"===f?(k=k?k.__html:void 0,null!=k&&ob(a,k)):\"children\"===f?\"string\"===typeof k?(\"textarea\"!==c||\"\"!==k)&&pb(a,k):\"number\"===typeof k&&pb(a,\"\"+k):\"suppressContentEditableWarning\"!==f&&\"suppressHydrationWarning\"!==f&&\"autoFocus\"!==f&&(ca.hasOwnProperty(f)?null!=k&&\"onScroll\"===f&&G(\"scroll\",a):null!=k&&qa(a,f,k,g))}switch(c){case \"input\":Va(a);cb(a,d,!1);\nbreak;case \"textarea\":Va(a);jb(a);break;case \"option\":null!=d.value&&a.setAttribute(\"value\",\"\"+Sa(d.value));break;case \"select\":a.multiple=!!d.multiple;f=d.value;null!=f?fb(a,!!d.multiple,f,!1):null!=d.defaultValue&&fb(a,!!d.multiple,d.defaultValue,!0);break;default:\"function\"===typeof e.onClick&&(a.onclick=jf)}mf(c,d)&&(b.flags|=4)}null!==b.ref&&(b.flags|=128)}return null;case 6:if(a&&null!=b.stateNode)Ei(a,b,a.memoizedProps,d);else{if(\"string\"!==typeof d&&null===b.stateNode)throw Error(y(166));\nc=dh(ch.current);dh(ah.current);rh(b)?(d=b.stateNode,c=b.memoizedProps,d[wf]=b,d.nodeValue!==c&&(b.flags|=4)):(d=(9===c.nodeType?c:c.ownerDocument).createTextNode(d),d[wf]=b,b.stateNode=d)}return null;case 13:H(P);d=b.memoizedState;if(0!==(b.flags&64))return b.lanes=c,b;d=null!==d;c=!1;null===a?void 0!==b.memoizedProps.fallback&&rh(b):c=null!==a.memoizedState;if(d&&!c&&0!==(b.mode&2))if(null===a&&!0!==b.memoizedProps.unstable_avoidThisFallback||0!==(P.current&1))0===V&&(V=3);else{if(0===V||3===V)V=\n4;null===U||0===(Dg&134217727)&&0===(Hi&134217727)||Ii(U,W)}if(d||c)b.flags|=4;return null;case 4:return fh(),Ci(b),null===a&&cf(b.stateNode.containerInfo),null;case 10:return rg(b),null;case 17:return Ff(b.type)&&Gf(),null;case 19:H(P);d=b.memoizedState;if(null===d)return null;f=0!==(b.flags&64);g=d.rendering;if(null===g)if(f)Fi(d,!1);else{if(0!==V||null!==a&&0!==(a.flags&64))for(a=b.child;null!==a;){g=ih(a);if(null!==g){b.flags|=64;Fi(d,!1);f=g.updateQueue;null!==f&&(b.updateQueue=f,b.flags|=4);\nnull===d.lastEffect&&(b.firstEffect=null);b.lastEffect=d.lastEffect;d=c;for(c=b.child;null!==c;)f=c,a=d,f.flags&=2,f.nextEffect=null,f.firstEffect=null,f.lastEffect=null,g=f.alternate,null===g?(f.childLanes=0,f.lanes=a,f.child=null,f.memoizedProps=null,f.memoizedState=null,f.updateQueue=null,f.dependencies=null,f.stateNode=null):(f.childLanes=g.childLanes,f.lanes=g.lanes,f.child=g.child,f.memoizedProps=g.memoizedProps,f.memoizedState=g.memoizedState,f.updateQueue=g.updateQueue,f.type=g.type,a=g.dependencies,\nf.dependencies=null===a?null:{lanes:a.lanes,firstContext:a.firstContext}),c=c.sibling;I(P,P.current&1|2);return b.child}a=a.sibling}null!==d.tail&&O()>Ji&&(b.flags|=64,f=!0,Fi(d,!1),b.lanes=33554432)}else{if(!f)if(a=ih(g),null!==a){if(b.flags|=64,f=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Fi(d,!0),null===d.tail&&\"hidden\"===d.tailMode&&!g.alternate&&!lh)return b=b.lastEffect=d.lastEffect,null!==b&&(b.nextEffect=null),null}else 2*O()-d.renderingStartTime>Ji&&1073741824!==c&&(b.flags|=\n64,f=!0,Fi(d,!1),b.lanes=33554432);d.isBackwards?(g.sibling=b.child,b.child=g):(c=d.last,null!==c?c.sibling=g:b.child=g,d.last=g)}return null!==d.tail?(c=d.tail,d.rendering=c,d.tail=c.sibling,d.lastEffect=b.lastEffect,d.renderingStartTime=O(),c.sibling=null,b=P.current,I(P,f?b&1|2:b&1),c):null;case 23:case 24:return Ki(),null!==a&&null!==a.memoizedState!==(null!==b.memoizedState)&&\"unstable-defer-without-hiding\"!==d.mode&&(b.flags|=4),null}throw Error(y(156,b.tag));}\nfunction Li(a){switch(a.tag){case 1:Ff(a.type)&&Gf();var b=a.flags;return b&4096?(a.flags=b&-4097|64,a):null;case 3:fh();H(N);H(M);uh();b=a.flags;if(0!==(b&64))throw Error(y(285));a.flags=b&-4097|64;return a;case 5:return hh(a),null;case 13:return H(P),b=a.flags,b&4096?(a.flags=b&-4097|64,a):null;case 19:return H(P),null;case 4:return fh(),null;case 10:return rg(a),null;case 23:case 24:return Ki(),null;default:return null}}\nfunction Mi(a,b){try{var c=\"\",d=b;do c+=Qa(d),d=d.return;while(d);var e=c}catch(f){e=\"\\nError generating stack: \"+f.message+\"\\n\"+f.stack}return{value:a,source:b,stack:e}}function Ni(a,b){try{console.error(b.value)}catch(c){setTimeout(function(){throw c;})}}var Oi=\"function\"===typeof WeakMap?WeakMap:Map;function Pi(a,b,c){c=zg(-1,c);c.tag=3;c.payload={element:null};var d=b.value;c.callback=function(){Qi||(Qi=!0,Ri=d);Ni(a,b)};return c}\nfunction Si(a,b,c){c=zg(-1,c);c.tag=3;var d=a.type.getDerivedStateFromError;if(\"function\"===typeof d){var e=b.value;c.payload=function(){Ni(a,b);return d(e)}}var f=a.stateNode;null!==f&&\"function\"===typeof f.componentDidCatch&&(c.callback=function(){\"function\"!==typeof d&&(null===Ti?Ti=new Set([this]):Ti.add(this),Ni(a,b));var c=b.stack;this.componentDidCatch(b.value,{componentStack:null!==c?c:\"\"})});return c}var Ui=\"function\"===typeof WeakSet?WeakSet:Set;\nfunction Vi(a){var b=a.ref;if(null!==b)if(\"function\"===typeof b)try{b(null)}catch(c){Wi(a,c)}else b.current=null}function Xi(a,b){switch(b.tag){case 0:case 11:case 15:case 22:return;case 1:if(b.flags&256&&null!==a){var c=a.memoizedProps,d=a.memoizedState;a=b.stateNode;b=a.getSnapshotBeforeUpdate(b.elementType===b.type?c:lg(b.type,c),d);a.__reactInternalSnapshotBeforeUpdate=b}return;case 3:b.flags&256&&qf(b.stateNode.containerInfo);return;case 5:case 6:case 4:case 17:return}throw Error(y(163));}\nfunction Yi(a,b,c){switch(c.tag){case 0:case 11:case 15:case 22:b=c.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){a=b=b.next;do{if(3===(a.tag&3)){var d=a.create;a.destroy=d()}a=a.next}while(a!==b)}b=c.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){a=b=b.next;do{var e=a;d=e.next;e=e.tag;0!==(e&4)&&0!==(e&1)&&(Zi(c,a),$i(c,a));a=d}while(a!==b)}return;case 1:a=c.stateNode;c.flags&4&&(null===b?a.componentDidMount():(d=c.elementType===c.type?b.memoizedProps:lg(c.type,b.memoizedProps),a.componentDidUpdate(d,\nb.memoizedState,a.__reactInternalSnapshotBeforeUpdate)));b=c.updateQueue;null!==b&&Eg(c,b,a);return;case 3:b=c.updateQueue;if(null!==b){a=null;if(null!==c.child)switch(c.child.tag){case 5:a=c.child.stateNode;break;case 1:a=c.child.stateNode}Eg(c,b,a)}return;case 5:a=c.stateNode;null===b&&c.flags&4&&mf(c.type,c.memoizedProps)&&a.focus();return;case 6:return;case 4:return;case 12:return;case 13:null===c.memoizedState&&(c=c.alternate,null!==c&&(c=c.memoizedState,null!==c&&(c=c.dehydrated,null!==c&&Cc(c))));\nreturn;case 19:case 17:case 20:case 21:case 23:case 24:return}throw Error(y(163));}\nfunction aj(a,b){for(var c=a;;){if(5===c.tag){var d=c.stateNode;if(b)d=d.style,\"function\"===typeof d.setProperty?d.setProperty(\"display\",\"none\",\"important\"):d.display=\"none\";else{d=c.stateNode;var e=c.memoizedProps.style;e=void 0!==e&&null!==e&&e.hasOwnProperty(\"display\")?e.display:null;d.style.display=sb(\"display\",e)}}else if(6===c.tag)c.stateNode.nodeValue=b?\"\":c.memoizedProps;else if((23!==c.tag&&24!==c.tag||null===c.memoizedState||c===a)&&null!==c.child){c.child.return=c;c=c.child;continue}if(c===\na)break;for(;null===c.sibling;){if(null===c.return||c.return===a)return;c=c.return}c.sibling.return=c.return;c=c.sibling}}\nfunction bj(a,b){if(Mf&&\"function\"===typeof Mf.onCommitFiberUnmount)try{Mf.onCommitFiberUnmount(Lf,b)}catch(f){}switch(b.tag){case 0:case 11:case 14:case 15:case 22:a=b.updateQueue;if(null!==a&&(a=a.lastEffect,null!==a)){var c=a=a.next;do{var d=c,e=d.destroy;d=d.tag;if(void 0!==e)if(0!==(d&4))Zi(b,c);else{d=b;try{e()}catch(f){Wi(d,f)}}c=c.next}while(c!==a)}break;case 1:Vi(b);a=b.stateNode;if(\"function\"===typeof a.componentWillUnmount)try{a.props=b.memoizedProps,a.state=b.memoizedState,a.componentWillUnmount()}catch(f){Wi(b,\nf)}break;case 5:Vi(b);break;case 4:cj(a,b)}}function dj(a){a.alternate=null;a.child=null;a.dependencies=null;a.firstEffect=null;a.lastEffect=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.return=null;a.updateQueue=null}function ej(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction fj(a){a:{for(var b=a.return;null!==b;){if(ej(b))break a;b=b.return}throw Error(y(160));}var c=b;b=c.stateNode;switch(c.tag){case 5:var d=!1;break;case 3:b=b.containerInfo;d=!0;break;case 4:b=b.containerInfo;d=!0;break;default:throw Error(y(161));}c.flags&16&&(pb(b,\"\"),c.flags&=-17);a:b:for(c=a;;){for(;null===c.sibling;){if(null===c.return||ej(c.return)){c=null;break a}c=c.return}c.sibling.return=c.return;for(c=c.sibling;5!==c.tag&&6!==c.tag&&18!==c.tag;){if(c.flags&2)continue b;if(null===\nc.child||4===c.tag)continue b;else c.child.return=c,c=c.child}if(!(c.flags&2)){c=c.stateNode;break a}}d?gj(a,c,b):hj(a,c,b)}\nfunction gj(a,b,c){var d=a.tag,e=5===d||6===d;if(e)a=e?a.stateNode:a.stateNode.instance,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=jf));else if(4!==d&&(a=a.child,null!==a))for(gj(a,b,c),a=a.sibling;null!==a;)gj(a,b,c),a=a.sibling}\nfunction hj(a,b,c){var d=a.tag,e=5===d||6===d;if(e)a=e?a.stateNode:a.stateNode.instance,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(hj(a,b,c),a=a.sibling;null!==a;)hj(a,b,c),a=a.sibling}\nfunction cj(a,b){for(var c=b,d=!1,e,f;;){if(!d){d=c.return;a:for(;;){if(null===d)throw Error(y(160));e=d.stateNode;switch(d.tag){case 5:f=!1;break a;case 3:e=e.containerInfo;f=!0;break a;case 4:e=e.containerInfo;f=!0;break a}d=d.return}d=!0}if(5===c.tag||6===c.tag){a:for(var g=a,h=c,k=h;;)if(bj(g,k),null!==k.child&&4!==k.tag)k.child.return=k,k=k.child;else{if(k===h)break a;for(;null===k.sibling;){if(null===k.return||k.return===h)break a;k=k.return}k.sibling.return=k.return;k=k.sibling}f?(g=e,h=c.stateNode,\n8===g.nodeType?g.parentNode.removeChild(h):g.removeChild(h)):e.removeChild(c.stateNode)}else if(4===c.tag){if(null!==c.child){e=c.stateNode.containerInfo;f=!0;c.child.return=c;c=c.child;continue}}else if(bj(a,c),null!==c.child){c.child.return=c;c=c.child;continue}if(c===b)break;for(;null===c.sibling;){if(null===c.return||c.return===b)return;c=c.return;4===c.tag&&(d=!1)}c.sibling.return=c.return;c=c.sibling}}\nfunction ij(a,b){switch(b.tag){case 0:case 11:case 14:case 15:case 22:var c=b.updateQueue;c=null!==c?c.lastEffect:null;if(null!==c){var d=c=c.next;do 3===(d.tag&3)&&(a=d.destroy,d.destroy=void 0,void 0!==a&&a()),d=d.next;while(d!==c)}return;case 1:return;case 5:c=b.stateNode;if(null!=c){d=b.memoizedProps;var e=null!==a?a.memoizedProps:d;a=b.type;var f=b.updateQueue;b.updateQueue=null;if(null!==f){c[xf]=d;\"input\"===a&&\"radio\"===d.type&&null!=d.name&&$a(c,d);wb(a,e);b=wb(a,d);for(e=0;e<f.length;e+=\n2){var g=f[e],h=f[e+1];\"style\"===g?tb(c,h):\"dangerouslySetInnerHTML\"===g?ob(c,h):\"children\"===g?pb(c,h):qa(c,g,h,b)}switch(a){case \"input\":ab(c,d);break;case \"textarea\":ib(c,d);break;case \"select\":a=c._wrapperState.wasMultiple,c._wrapperState.wasMultiple=!!d.multiple,f=d.value,null!=f?fb(c,!!d.multiple,f,!1):a!==!!d.multiple&&(null!=d.defaultValue?fb(c,!!d.multiple,d.defaultValue,!0):fb(c,!!d.multiple,d.multiple?[]:\"\",!1))}}}return;case 6:if(null===b.stateNode)throw Error(y(162));b.stateNode.nodeValue=\nb.memoizedProps;return;case 3:c=b.stateNode;c.hydrate&&(c.hydrate=!1,Cc(c.containerInfo));return;case 12:return;case 13:null!==b.memoizedState&&(jj=O(),aj(b.child,!0));kj(b);return;case 19:kj(b);return;case 17:return;case 23:case 24:aj(b,null!==b.memoizedState);return}throw Error(y(163));}function kj(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Ui);b.forEach(function(b){var d=lj.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}\nfunction mj(a,b){return null!==a&&(a=a.memoizedState,null===a||null!==a.dehydrated)?(b=b.memoizedState,null!==b&&null===b.dehydrated):!1}var nj=Math.ceil,oj=ra.ReactCurrentDispatcher,pj=ra.ReactCurrentOwner,X=0,U=null,Y=null,W=0,qj=0,rj=Bf(0),V=0,sj=null,tj=0,Dg=0,Hi=0,uj=0,vj=null,jj=0,Ji=Infinity;function wj(){Ji=O()+500}var Z=null,Qi=!1,Ri=null,Ti=null,xj=!1,yj=null,zj=90,Aj=[],Bj=[],Cj=null,Dj=0,Ej=null,Fj=-1,Gj=0,Hj=0,Ij=null,Jj=!1;function Hg(){return 0!==(X&48)?O():-1!==Fj?Fj:Fj=O()}\nfunction Ig(a){a=a.mode;if(0===(a&2))return 1;if(0===(a&4))return 99===eg()?1:2;0===Gj&&(Gj=tj);if(0!==kg.transition){0!==Hj&&(Hj=null!==vj?vj.pendingLanes:0);a=Gj;var b=4186112&~Hj;b&=-b;0===b&&(a=4186112&~a,b=a&-a,0===b&&(b=8192));return b}a=eg();0!==(X&4)&&98===a?a=Xc(12,Gj):(a=Sc(a),a=Xc(a,Gj));return a}\nfunction Jg(a,b,c){if(50<Dj)throw Dj=0,Ej=null,Error(y(185));a=Kj(a,b);if(null===a)return null;$c(a,b,c);a===U&&(Hi|=b,4===V&&Ii(a,W));var d=eg();1===b?0!==(X&8)&&0===(X&48)?Lj(a):(Mj(a,c),0===X&&(wj(),ig())):(0===(X&4)||98!==d&&99!==d||(null===Cj?Cj=new Set([a]):Cj.add(a)),Mj(a,c));vj=a}function Kj(a,b){a.lanes|=b;var c=a.alternate;null!==c&&(c.lanes|=b);c=a;for(a=a.return;null!==a;)a.childLanes|=b,c=a.alternate,null!==c&&(c.childLanes|=b),c=a,a=a.return;return 3===c.tag?c.stateNode:null}\nfunction Mj(a,b){for(var c=a.callbackNode,d=a.suspendedLanes,e=a.pingedLanes,f=a.expirationTimes,g=a.pendingLanes;0<g;){var h=31-Vc(g),k=1<<h,l=f[h];if(-1===l){if(0===(k&d)||0!==(k&e)){l=b;Rc(k);var n=F;f[h]=10<=n?l+250:6<=n?l+5E3:-1}}else l<=b&&(a.expiredLanes|=k);g&=~k}d=Uc(a,a===U?W:0);b=F;if(0===d)null!==c&&(c!==Zf&&Pf(c),a.callbackNode=null,a.callbackPriority=0);else{if(null!==c){if(a.callbackPriority===b)return;c!==Zf&&Pf(c)}15===b?(c=Lj.bind(null,a),null===ag?(ag=[c],bg=Of(Uf,jg)):ag.push(c),\nc=Zf):14===b?c=hg(99,Lj.bind(null,a)):(c=Tc(b),c=hg(c,Nj.bind(null,a)));a.callbackPriority=b;a.callbackNode=c}}\nfunction Nj(a){Fj=-1;Hj=Gj=0;if(0!==(X&48))throw Error(y(327));var b=a.callbackNode;if(Oj()&&a.callbackNode!==b)return null;var c=Uc(a,a===U?W:0);if(0===c)return null;var d=c;var e=X;X|=16;var f=Pj();if(U!==a||W!==d)wj(),Qj(a,d);do try{Rj();break}catch(h){Sj(a,h)}while(1);qg();oj.current=f;X=e;null!==Y?d=0:(U=null,W=0,d=V);if(0!==(tj&Hi))Qj(a,0);else if(0!==d){2===d&&(X|=64,a.hydrate&&(a.hydrate=!1,qf(a.containerInfo)),c=Wc(a),0!==c&&(d=Tj(a,c)));if(1===d)throw b=sj,Qj(a,0),Ii(a,c),Mj(a,O()),b;a.finishedWork=\na.current.alternate;a.finishedLanes=c;switch(d){case 0:case 1:throw Error(y(345));case 2:Uj(a);break;case 3:Ii(a,c);if((c&62914560)===c&&(d=jj+500-O(),10<d)){if(0!==Uc(a,0))break;e=a.suspendedLanes;if((e&c)!==c){Hg();a.pingedLanes|=a.suspendedLanes&e;break}a.timeoutHandle=of(Uj.bind(null,a),d);break}Uj(a);break;case 4:Ii(a,c);if((c&4186112)===c)break;d=a.eventTimes;for(e=-1;0<c;){var g=31-Vc(c);f=1<<g;g=d[g];g>e&&(e=g);c&=~f}c=e;c=O()-c;c=(120>c?120:480>c?480:1080>c?1080:1920>c?1920:3E3>c?3E3:4320>\nc?4320:1960*nj(c/1960))-c;if(10<c){a.timeoutHandle=of(Uj.bind(null,a),c);break}Uj(a);break;case 5:Uj(a);break;default:throw Error(y(329));}}Mj(a,O());return a.callbackNode===b?Nj.bind(null,a):null}function Ii(a,b){b&=~uj;b&=~Hi;a.suspendedLanes|=b;a.pingedLanes&=~b;for(a=a.expirationTimes;0<b;){var c=31-Vc(b),d=1<<c;a[c]=-1;b&=~d}}\nfunction Lj(a){if(0!==(X&48))throw Error(y(327));Oj();if(a===U&&0!==(a.expiredLanes&W)){var b=W;var c=Tj(a,b);0!==(tj&Hi)&&(b=Uc(a,b),c=Tj(a,b))}else b=Uc(a,0),c=Tj(a,b);0!==a.tag&&2===c&&(X|=64,a.hydrate&&(a.hydrate=!1,qf(a.containerInfo)),b=Wc(a),0!==b&&(c=Tj(a,b)));if(1===c)throw c=sj,Qj(a,0),Ii(a,b),Mj(a,O()),c;a.finishedWork=a.current.alternate;a.finishedLanes=b;Uj(a);Mj(a,O());return null}\nfunction Vj(){if(null!==Cj){var a=Cj;Cj=null;a.forEach(function(a){a.expiredLanes|=24&a.pendingLanes;Mj(a,O())})}ig()}function Wj(a,b){var c=X;X|=1;try{return a(b)}finally{X=c,0===X&&(wj(),ig())}}function Xj(a,b){var c=X;X&=-2;X|=8;try{return a(b)}finally{X=c,0===X&&(wj(),ig())}}function ni(a,b){I(rj,qj);qj|=b;tj|=b}function Ki(){qj=rj.current;H(rj)}\nfunction Qj(a,b){a.finishedWork=null;a.finishedLanes=0;var c=a.timeoutHandle;-1!==c&&(a.timeoutHandle=-1,pf(c));if(null!==Y)for(c=Y.return;null!==c;){var d=c;switch(d.tag){case 1:d=d.type.childContextTypes;null!==d&&void 0!==d&&Gf();break;case 3:fh();H(N);H(M);uh();break;case 5:hh(d);break;case 4:fh();break;case 13:H(P);break;case 19:H(P);break;case 10:rg(d);break;case 23:case 24:Ki()}c=c.return}U=a;Y=Tg(a.current,null);W=qj=tj=b;V=0;sj=null;uj=Hi=Dg=0}\nfunction Sj(a,b){do{var c=Y;try{qg();vh.current=Gh;if(yh){for(var d=R.memoizedState;null!==d;){var e=d.queue;null!==e&&(e.pending=null);d=d.next}yh=!1}xh=0;T=S=R=null;zh=!1;pj.current=null;if(null===c||null===c.return){V=1;sj=b;Y=null;break}a:{var f=a,g=c.return,h=c,k=b;b=W;h.flags|=2048;h.firstEffect=h.lastEffect=null;if(null!==k&&\"object\"===typeof k&&\"function\"===typeof k.then){var l=k;if(0===(h.mode&2)){var n=h.alternate;n?(h.updateQueue=n.updateQueue,h.memoizedState=n.memoizedState,h.lanes=n.lanes):\n(h.updateQueue=null,h.memoizedState=null)}var A=0!==(P.current&1),p=g;do{var C;if(C=13===p.tag){var x=p.memoizedState;if(null!==x)C=null!==x.dehydrated?!0:!1;else{var w=p.memoizedProps;C=void 0===w.fallback?!1:!0!==w.unstable_avoidThisFallback?!0:A?!1:!0}}if(C){var z=p.updateQueue;if(null===z){var u=new Set;u.add(l);p.updateQueue=u}else z.add(l);if(0===(p.mode&2)){p.flags|=64;h.flags|=16384;h.flags&=-2981;if(1===h.tag)if(null===h.alternate)h.tag=17;else{var t=zg(-1,1);t.tag=2;Ag(h,t)}h.lanes|=1;break a}k=\nvoid 0;h=b;var q=f.pingCache;null===q?(q=f.pingCache=new Oi,k=new Set,q.set(l,k)):(k=q.get(l),void 0===k&&(k=new Set,q.set(l,k)));if(!k.has(h)){k.add(h);var v=Yj.bind(null,f,l,h);l.then(v,v)}p.flags|=4096;p.lanes=b;break a}p=p.return}while(null!==p);k=Error((Ra(h.type)||\"A React component\")+\" suspended while rendering, but no fallback UI was specified.\\n\\nAdd a <Suspense fallback=...> component higher in the tree to provide a loading indicator or placeholder to display.\")}5!==V&&(V=2);k=Mi(k,h);p=\ng;do{switch(p.tag){case 3:f=k;p.flags|=4096;b&=-b;p.lanes|=b;var J=Pi(p,f,b);Bg(p,J);break a;case 1:f=k;var K=p.type,Q=p.stateNode;if(0===(p.flags&64)&&(\"function\"===typeof K.getDerivedStateFromError||null!==Q&&\"function\"===typeof Q.componentDidCatch&&(null===Ti||!Ti.has(Q)))){p.flags|=4096;b&=-b;p.lanes|=b;var L=Si(p,f,b);Bg(p,L);break a}}p=p.return}while(null!==p)}Zj(c)}catch(va){b=va;Y===c&&null!==c&&(Y=c=c.return);continue}break}while(1)}\nfunction Pj(){var a=oj.current;oj.current=Gh;return null===a?Gh:a}function Tj(a,b){var c=X;X|=16;var d=Pj();U===a&&W===b||Qj(a,b);do try{ak();break}catch(e){Sj(a,e)}while(1);qg();X=c;oj.current=d;if(null!==Y)throw Error(y(261));U=null;W=0;return V}function ak(){for(;null!==Y;)bk(Y)}function Rj(){for(;null!==Y&&!Qf();)bk(Y)}function bk(a){var b=ck(a.alternate,a,qj);a.memoizedProps=a.pendingProps;null===b?Zj(a):Y=b;pj.current=null}\nfunction Zj(a){var b=a;do{var c=b.alternate;a=b.return;if(0===(b.flags&2048)){c=Gi(c,b,qj);if(null!==c){Y=c;return}c=b;if(24!==c.tag&&23!==c.tag||null===c.memoizedState||0!==(qj&1073741824)||0===(c.mode&4)){for(var d=0,e=c.child;null!==e;)d|=e.lanes|e.childLanes,e=e.sibling;c.childLanes=d}null!==a&&0===(a.flags&2048)&&(null===a.firstEffect&&(a.firstEffect=b.firstEffect),null!==b.lastEffect&&(null!==a.lastEffect&&(a.lastEffect.nextEffect=b.firstEffect),a.lastEffect=b.lastEffect),1<b.flags&&(null!==\na.lastEffect?a.lastEffect.nextEffect=b:a.firstEffect=b,a.lastEffect=b))}else{c=Li(b);if(null!==c){c.flags&=2047;Y=c;return}null!==a&&(a.firstEffect=a.lastEffect=null,a.flags|=2048)}b=b.sibling;if(null!==b){Y=b;return}Y=b=a}while(null!==b);0===V&&(V=5)}function Uj(a){var b=eg();gg(99,dk.bind(null,a,b));return null}\nfunction dk(a,b){do Oj();while(null!==yj);if(0!==(X&48))throw Error(y(327));var c=a.finishedWork;if(null===c)return null;a.finishedWork=null;a.finishedLanes=0;if(c===a.current)throw Error(y(177));a.callbackNode=null;var d=c.lanes|c.childLanes,e=d,f=a.pendingLanes&~e;a.pendingLanes=e;a.suspendedLanes=0;a.pingedLanes=0;a.expiredLanes&=e;a.mutableReadLanes&=e;a.entangledLanes&=e;e=a.entanglements;for(var g=a.eventTimes,h=a.expirationTimes;0<f;){var k=31-Vc(f),l=1<<k;e[k]=0;g[k]=-1;h[k]=-1;f&=~l}null!==\nCj&&0===(d&24)&&Cj.has(a)&&Cj.delete(a);a===U&&(Y=U=null,W=0);1<c.flags?null!==c.lastEffect?(c.lastEffect.nextEffect=c,d=c.firstEffect):d=c:d=c.firstEffect;if(null!==d){e=X;X|=32;pj.current=null;kf=fd;g=Ne();if(Oe(g)){if(\"selectionStart\"in g)h={start:g.selectionStart,end:g.selectionEnd};else a:if(h=(h=g.ownerDocument)&&h.defaultView||window,(l=h.getSelection&&h.getSelection())&&0!==l.rangeCount){h=l.anchorNode;f=l.anchorOffset;k=l.focusNode;l=l.focusOffset;try{h.nodeType,k.nodeType}catch(va){h=null;\nbreak a}var n=0,A=-1,p=-1,C=0,x=0,w=g,z=null;b:for(;;){for(var u;;){w!==h||0!==f&&3!==w.nodeType||(A=n+f);w!==k||0!==l&&3!==w.nodeType||(p=n+l);3===w.nodeType&&(n+=w.nodeValue.length);if(null===(u=w.firstChild))break;z=w;w=u}for(;;){if(w===g)break b;z===h&&++C===f&&(A=n);z===k&&++x===l&&(p=n);if(null!==(u=w.nextSibling))break;w=z;z=w.parentNode}w=u}h=-1===A||-1===p?null:{start:A,end:p}}else h=null;h=h||{start:0,end:0}}else h=null;lf={focusedElem:g,selectionRange:h};fd=!1;Ij=null;Jj=!1;Z=d;do try{ek()}catch(va){if(null===\nZ)throw Error(y(330));Wi(Z,va);Z=Z.nextEffect}while(null!==Z);Ij=null;Z=d;do try{for(g=a;null!==Z;){var t=Z.flags;t&16&&pb(Z.stateNode,\"\");if(t&128){var q=Z.alternate;if(null!==q){var v=q.ref;null!==v&&(\"function\"===typeof v?v(null):v.current=null)}}switch(t&1038){case 2:fj(Z);Z.flags&=-3;break;case 6:fj(Z);Z.flags&=-3;ij(Z.alternate,Z);break;case 1024:Z.flags&=-1025;break;case 1028:Z.flags&=-1025;ij(Z.alternate,Z);break;case 4:ij(Z.alternate,Z);break;case 8:h=Z;cj(g,h);var J=h.alternate;dj(h);null!==\nJ&&dj(J)}Z=Z.nextEffect}}catch(va){if(null===Z)throw Error(y(330));Wi(Z,va);Z=Z.nextEffect}while(null!==Z);v=lf;q=Ne();t=v.focusedElem;g=v.selectionRange;if(q!==t&&t&&t.ownerDocument&&Me(t.ownerDocument.documentElement,t)){null!==g&&Oe(t)&&(q=g.start,v=g.end,void 0===v&&(v=q),\"selectionStart\"in t?(t.selectionStart=q,t.selectionEnd=Math.min(v,t.value.length)):(v=(q=t.ownerDocument||document)&&q.defaultView||window,v.getSelection&&(v=v.getSelection(),h=t.textContent.length,J=Math.min(g.start,h),g=void 0===\ng.end?J:Math.min(g.end,h),!v.extend&&J>g&&(h=g,g=J,J=h),h=Le(t,J),f=Le(t,g),h&&f&&(1!==v.rangeCount||v.anchorNode!==h.node||v.anchorOffset!==h.offset||v.focusNode!==f.node||v.focusOffset!==f.offset)&&(q=q.createRange(),q.setStart(h.node,h.offset),v.removeAllRanges(),J>g?(v.addRange(q),v.extend(f.node,f.offset)):(q.setEnd(f.node,f.offset),v.addRange(q))))));q=[];for(v=t;v=v.parentNode;)1===v.nodeType&&q.push({element:v,left:v.scrollLeft,top:v.scrollTop});\"function\"===typeof t.focus&&t.focus();for(t=\n0;t<q.length;t++)v=q[t],v.element.scrollLeft=v.left,v.element.scrollTop=v.top}fd=!!kf;lf=kf=null;a.current=c;Z=d;do try{for(t=a;null!==Z;){var K=Z.flags;K&36&&Yi(t,Z.alternate,Z);if(K&128){q=void 0;var Q=Z.ref;if(null!==Q){var L=Z.stateNode;switch(Z.tag){case 5:q=L;break;default:q=L}\"function\"===typeof Q?Q(q):Q.current=q}}Z=Z.nextEffect}}catch(va){if(null===Z)throw Error(y(330));Wi(Z,va);Z=Z.nextEffect}while(null!==Z);Z=null;$f();X=e}else a.current=c;if(xj)xj=!1,yj=a,zj=b;else for(Z=d;null!==Z;)b=\nZ.nextEffect,Z.nextEffect=null,Z.flags&8&&(K=Z,K.sibling=null,K.stateNode=null),Z=b;d=a.pendingLanes;0===d&&(Ti=null);1===d?a===Ej?Dj++:(Dj=0,Ej=a):Dj=0;c=c.stateNode;if(Mf&&\"function\"===typeof Mf.onCommitFiberRoot)try{Mf.onCommitFiberRoot(Lf,c,void 0,64===(c.current.flags&64))}catch(va){}Mj(a,O());if(Qi)throw Qi=!1,a=Ri,Ri=null,a;if(0!==(X&8))return null;ig();return null}\nfunction ek(){for(;null!==Z;){var a=Z.alternate;Jj||null===Ij||(0!==(Z.flags&8)?dc(Z,Ij)&&(Jj=!0):13===Z.tag&&mj(a,Z)&&dc(Z,Ij)&&(Jj=!0));var b=Z.flags;0!==(b&256)&&Xi(a,Z);0===(b&512)||xj||(xj=!0,hg(97,function(){Oj();return null}));Z=Z.nextEffect}}function Oj(){if(90!==zj){var a=97<zj?97:zj;zj=90;return gg(a,fk)}return!1}function $i(a,b){Aj.push(b,a);xj||(xj=!0,hg(97,function(){Oj();return null}))}function Zi(a,b){Bj.push(b,a);xj||(xj=!0,hg(97,function(){Oj();return null}))}\nfunction fk(){if(null===yj)return!1;var a=yj;yj=null;if(0!==(X&48))throw Error(y(331));var b=X;X|=32;var c=Bj;Bj=[];for(var d=0;d<c.length;d+=2){var e=c[d],f=c[d+1],g=e.destroy;e.destroy=void 0;if(\"function\"===typeof g)try{g()}catch(k){if(null===f)throw Error(y(330));Wi(f,k)}}c=Aj;Aj=[];for(d=0;d<c.length;d+=2){e=c[d];f=c[d+1];try{var h=e.create;e.destroy=h()}catch(k){if(null===f)throw Error(y(330));Wi(f,k)}}for(h=a.current.firstEffect;null!==h;)a=h.nextEffect,h.nextEffect=null,h.flags&8&&(h.sibling=\nnull,h.stateNode=null),h=a;X=b;ig();return!0}function gk(a,b,c){b=Mi(c,b);b=Pi(a,b,1);Ag(a,b);b=Hg();a=Kj(a,1);null!==a&&($c(a,1,b),Mj(a,b))}\nfunction Wi(a,b){if(3===a.tag)gk(a,a,b);else for(var c=a.return;null!==c;){if(3===c.tag){gk(c,a,b);break}else if(1===c.tag){var d=c.stateNode;if(\"function\"===typeof c.type.getDerivedStateFromError||\"function\"===typeof d.componentDidCatch&&(null===Ti||!Ti.has(d))){a=Mi(b,a);var e=Si(c,a,1);Ag(c,e);e=Hg();c=Kj(c,1);if(null!==c)$c(c,1,e),Mj(c,e);else if(\"function\"===typeof d.componentDidCatch&&(null===Ti||!Ti.has(d)))try{d.componentDidCatch(b,a)}catch(f){}break}}c=c.return}}\nfunction Yj(a,b,c){var d=a.pingCache;null!==d&&d.delete(b);b=Hg();a.pingedLanes|=a.suspendedLanes&c;U===a&&(W&c)===c&&(4===V||3===V&&(W&62914560)===W&&500>O()-jj?Qj(a,0):uj|=c);Mj(a,b)}function lj(a,b){var c=a.stateNode;null!==c&&c.delete(b);b=0;0===b&&(b=a.mode,0===(b&2)?b=1:0===(b&4)?b=99===eg()?1:2:(0===Gj&&(Gj=tj),b=Yc(62914560&~Gj),0===b&&(b=4194304)));c=Hg();a=Kj(a,b);null!==a&&($c(a,b,c),Mj(a,c))}var ck;\nck=function(a,b,c){var d=b.lanes;if(null!==a)if(a.memoizedProps!==b.pendingProps||N.current)ug=!0;else if(0!==(c&d))ug=0!==(a.flags&16384)?!0:!1;else{ug=!1;switch(b.tag){case 3:ri(b);sh();break;case 5:gh(b);break;case 1:Ff(b.type)&&Jf(b);break;case 4:eh(b,b.stateNode.containerInfo);break;case 10:d=b.memoizedProps.value;var e=b.type._context;I(mg,e._currentValue);e._currentValue=d;break;case 13:if(null!==b.memoizedState){if(0!==(c&b.child.childLanes))return ti(a,b,c);I(P,P.current&1);b=hi(a,b,c);return null!==\nb?b.sibling:null}I(P,P.current&1);break;case 19:d=0!==(c&b.childLanes);if(0!==(a.flags&64)){if(d)return Ai(a,b,c);b.flags|=64}e=b.memoizedState;null!==e&&(e.rendering=null,e.tail=null,e.lastEffect=null);I(P,P.current);if(d)break;else return null;case 23:case 24:return b.lanes=0,mi(a,b,c)}return hi(a,b,c)}else ug=!1;b.lanes=0;switch(b.tag){case 2:d=b.type;null!==a&&(a.alternate=null,b.alternate=null,b.flags|=2);a=b.pendingProps;e=Ef(b,M.current);tg(b,c);e=Ch(null,b,d,a,e,c);b.flags|=1;if(\"object\"===\ntypeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof){b.tag=1;b.memoizedState=null;b.updateQueue=null;if(Ff(d)){var f=!0;Jf(b)}else f=!1;b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null;xg(b);var g=d.getDerivedStateFromProps;\"function\"===typeof g&&Gg(b,d,g,a);e.updater=Kg;b.stateNode=e;e._reactInternals=b;Og(b,d,a,c);b=qi(null,b,d,!0,f,c)}else b.tag=0,fi(null,b,e,c),b=b.child;return b;case 16:e=b.elementType;a:{null!==a&&(a.alternate=null,b.alternate=null,b.flags|=2);\na=b.pendingProps;f=e._init;e=f(e._payload);b.type=e;f=b.tag=hk(e);a=lg(e,a);switch(f){case 0:b=li(null,b,e,a,c);break a;case 1:b=pi(null,b,e,a,c);break a;case 11:b=gi(null,b,e,a,c);break a;case 14:b=ii(null,b,e,lg(e.type,a),d,c);break a}throw Error(y(306,e,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:lg(d,e),li(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:lg(d,e),pi(a,b,d,e,c);case 3:ri(b);d=b.updateQueue;if(null===a||null===d)throw Error(y(282));\nd=b.pendingProps;e=b.memoizedState;e=null!==e?e.element:null;yg(a,b);Cg(b,d,null,c);d=b.memoizedState.element;if(d===e)sh(),b=hi(a,b,c);else{e=b.stateNode;if(f=e.hydrate)kh=rf(b.stateNode.containerInfo.firstChild),jh=b,f=lh=!0;if(f){a=e.mutableSourceEagerHydrationData;if(null!=a)for(e=0;e<a.length;e+=2)f=a[e],f._workInProgressVersionPrimary=a[e+1],th.push(f);c=Zg(b,null,d,c);for(b.child=c;c;)c.flags=c.flags&-3|1024,c=c.sibling}else fi(a,b,d,c),sh();b=b.child}return b;case 5:return gh(b),null===a&&\nph(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,nf(d,e)?g=null:null!==f&&nf(d,f)&&(b.flags|=16),oi(a,b),fi(a,b,g,c),b.child;case 6:return null===a&&ph(b),null;case 13:return ti(a,b,c);case 4:return eh(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Yg(b,null,d,c):fi(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:lg(d,e),gi(a,b,d,e,c);case 7:return fi(a,b,b.pendingProps,c),b.child;case 8:return fi(a,b,b.pendingProps.children,\nc),b.child;case 12:return fi(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;g=b.memoizedProps;f=e.value;var h=b.type._context;I(mg,h._currentValue);h._currentValue=f;if(null!==g)if(h=g.value,f=He(h,f)?0:(\"function\"===typeof d._calculateChangedBits?d._calculateChangedBits(h,f):1073741823)|0,0===f){if(g.children===e.children&&!N.current){b=hi(a,b,c);break a}}else for(h=b.child,null!==h&&(h.return=b);null!==h;){var k=h.dependencies;if(null!==k){g=h.child;for(var l=\nk.firstContext;null!==l;){if(l.context===d&&0!==(l.observedBits&f)){1===h.tag&&(l=zg(-1,c&-c),l.tag=2,Ag(h,l));h.lanes|=c;l=h.alternate;null!==l&&(l.lanes|=c);sg(h.return,c);k.lanes|=c;break}l=l.next}}else g=10===h.tag?h.type===b.type?null:h.child:h.child;if(null!==g)g.return=h;else for(g=h;null!==g;){if(g===b){g=null;break}h=g.sibling;if(null!==h){h.return=g.return;g=h;break}g=g.return}h=g}fi(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,f=b.pendingProps,d=f.children,tg(b,c),e=vg(e,\nf.unstable_observedBits),d=d(e),b.flags|=1,fi(a,b,d,c),b.child;case 14:return e=b.type,f=lg(e,b.pendingProps),f=lg(e.type,f),ii(a,b,e,f,d,c);case 15:return ki(a,b,b.type,b.pendingProps,d,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:lg(d,e),null!==a&&(a.alternate=null,b.alternate=null,b.flags|=2),b.tag=1,Ff(d)?(a=!0,Jf(b)):a=!1,tg(b,c),Mg(b,d,e),Og(b,d,e,c),qi(null,b,d,!0,a,c);case 19:return Ai(a,b,c);case 23:return mi(a,b,c);case 24:return mi(a,b,c)}throw Error(y(156,b.tag));\n};function ik(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.flags=0;this.lastEffect=this.firstEffect=this.nextEffect=null;this.childLanes=this.lanes=0;this.alternate=null}function nh(a,b,c,d){return new ik(a,b,c,d)}function ji(a){a=a.prototype;return!(!a||!a.isReactComponent)}\nfunction hk(a){if(\"function\"===typeof a)return ji(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Aa)return 11;if(a===Da)return 14}return 2}\nfunction Tg(a,b){var c=a.alternate;null===c?(c=nh(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.type=a.type,c.flags=0,c.nextEffect=null,c.firstEffect=null,c.lastEffect=null);c.childLanes=a.childLanes;c.lanes=a.lanes;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{lanes:b.lanes,firstContext:b.firstContext};\nc.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction Vg(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)ji(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case ua:return Xg(c.children,e,f,b);case Ha:g=8;e|=16;break;case wa:g=8;e|=1;break;case xa:return a=nh(12,c,b,e|8),a.elementType=xa,a.type=xa,a.lanes=f,a;case Ba:return a=nh(13,c,b,e),a.type=Ba,a.elementType=Ba,a.lanes=f,a;case Ca:return a=nh(19,c,b,e),a.elementType=Ca,a.lanes=f,a;case Ia:return vi(c,e,f,b);case Ja:return a=nh(24,c,b,e),a.elementType=Ja,a.lanes=f,a;default:if(\"object\"===\ntypeof a&&null!==a)switch(a.$$typeof){case ya:g=10;break a;case za:g=9;break a;case Aa:g=11;break a;case Da:g=14;break a;case Ea:g=16;d=null;break a;case Fa:g=22;break a}throw Error(y(130,null==a?a:typeof a,\"\"));}b=nh(g,c,b,e);b.elementType=a;b.type=d;b.lanes=f;return b}function Xg(a,b,c,d){a=nh(7,a,d,b);a.lanes=c;return a}function vi(a,b,c,d){a=nh(23,a,d,b);a.elementType=Ia;a.lanes=c;return a}function Ug(a,b,c){a=nh(6,a,null,b);a.lanes=c;return a}\nfunction Wg(a,b,c){b=nh(4,null!==a.children?a.children:[],a.key,b);b.lanes=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction jk(a,b,c){this.tag=b;this.containerInfo=a;this.finishedWork=this.pingCache=this.current=this.pendingChildren=null;this.timeoutHandle=-1;this.pendingContext=this.context=null;this.hydrate=c;this.callbackNode=null;this.callbackPriority=0;this.eventTimes=Zc(0);this.expirationTimes=Zc(-1);this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0;this.entanglements=Zc(0);this.mutableSourceEagerHydrationData=null}\nfunction kk(a,b,c){var d=3<arguments.length&&void 0!==arguments[3]?arguments[3]:null;return{$$typeof:ta,key:null==d?null:\"\"+d,children:a,containerInfo:b,implementation:c}}\nfunction lk(a,b,c,d){var e=b.current,f=Hg(),g=Ig(e);a:if(c){c=c._reactInternals;b:{if(Zb(c)!==c||1!==c.tag)throw Error(y(170));var h=c;do{switch(h.tag){case 3:h=h.stateNode.context;break b;case 1:if(Ff(h.type)){h=h.stateNode.__reactInternalMemoizedMergedChildContext;break b}}h=h.return}while(null!==h);throw Error(y(171));}if(1===c.tag){var k=c.type;if(Ff(k)){c=If(c,k,h);break a}}c=h}else c=Cf;null===b.context?b.context=c:b.pendingContext=c;b=zg(f,g);b.payload={element:a};d=void 0===d?null:d;null!==\nd&&(b.callback=d);Ag(e,b);Jg(e,g,f);return g}function mk(a){a=a.current;if(!a.child)return null;switch(a.child.tag){case 5:return a.child.stateNode;default:return a.child.stateNode}}function nk(a,b){a=a.memoizedState;if(null!==a&&null!==a.dehydrated){var c=a.retryLane;a.retryLane=0!==c&&c<b?c:b}}function ok(a,b){nk(a,b);(a=a.alternate)&&nk(a,b)}function pk(){return null}\nfunction qk(a,b,c){var d=null!=c&&null!=c.hydrationOptions&&c.hydrationOptions.mutableSources||null;c=new jk(a,b,null!=c&&!0===c.hydrate);b=nh(3,null,null,2===b?7:1===b?3:0);c.current=b;b.stateNode=c;xg(b);a[ff]=c.current;cf(8===a.nodeType?a.parentNode:a);if(d)for(a=0;a<d.length;a++){b=d[a];var e=b._getVersion;e=e(b._source);null==c.mutableSourceEagerHydrationData?c.mutableSourceEagerHydrationData=[b,e]:c.mutableSourceEagerHydrationData.push(b,e)}this._internalRoot=c}\nqk.prototype.render=function(a){lk(a,this._internalRoot,null,null)};qk.prototype.unmount=function(){var a=this._internalRoot,b=a.containerInfo;lk(null,a,null,function(){b[ff]=null})};function rk(a){return!(!a||1!==a.nodeType&&9!==a.nodeType&&11!==a.nodeType&&(8!==a.nodeType||\" react-mount-point-unstable \"!==a.nodeValue))}\nfunction sk(a,b){b||(b=a?9===a.nodeType?a.documentElement:a.firstChild:null,b=!(!b||1!==b.nodeType||!b.hasAttribute(\"data-reactroot\")));if(!b)for(var c;c=a.lastChild;)a.removeChild(c);return new qk(a,0,b?{hydrate:!0}:void 0)}\nfunction tk(a,b,c,d,e){var f=c._reactRootContainer;if(f){var g=f._internalRoot;if(\"function\"===typeof e){var h=e;e=function(){var a=mk(g);h.call(a)}}lk(b,g,a,e)}else{f=c._reactRootContainer=sk(c,d);g=f._internalRoot;if(\"function\"===typeof e){var k=e;e=function(){var a=mk(g);k.call(a)}}Xj(function(){lk(b,g,a,e)})}return mk(g)}ec=function(a){if(13===a.tag){var b=Hg();Jg(a,4,b);ok(a,4)}};fc=function(a){if(13===a.tag){var b=Hg();Jg(a,67108864,b);ok(a,67108864)}};\ngc=function(a){if(13===a.tag){var b=Hg(),c=Ig(a);Jg(a,c,b);ok(a,c)}};hc=function(a,b){return b()};\nyb=function(a,b,c){switch(b){case \"input\":ab(a,c);b=c.name;if(\"radio\"===c.type&&null!=b){for(c=a;c.parentNode;)c=c.parentNode;c=c.querySelectorAll(\"input[name=\"+JSON.stringify(\"\"+b)+'][type=\"radio\"]');for(b=0;b<c.length;b++){var d=c[b];if(d!==a&&d.form===a.form){var e=Db(d);if(!e)throw Error(y(90));Wa(d);ab(d,e)}}}break;case \"textarea\":ib(a,c);break;case \"select\":b=c.value,null!=b&&fb(a,!!c.multiple,b,!1)}};Gb=Wj;\nHb=function(a,b,c,d,e){var f=X;X|=4;try{return gg(98,a.bind(null,b,c,d,e))}finally{X=f,0===X&&(wj(),ig())}};Ib=function(){0===(X&49)&&(Vj(),Oj())};Jb=function(a,b){var c=X;X|=2;try{return a(b)}finally{X=c,0===X&&(wj(),ig())}};function uk(a,b){var c=2<arguments.length&&void 0!==arguments[2]?arguments[2]:null;if(!rk(b))throw Error(y(200));return kk(a,b,null,c)}var vk={Events:[Cb,ue,Db,Eb,Fb,Oj,{current:!1}]},wk={findFiberByHostInstance:wc,bundleType:0,version:\"17.0.2\",rendererPackageName:\"react-dom\"};\nvar xk={bundleType:wk.bundleType,version:wk.version,rendererPackageName:wk.rendererPackageName,rendererConfig:wk.rendererConfig,overrideHookState:null,overrideHookStateDeletePath:null,overrideHookStateRenamePath:null,overrideProps:null,overridePropsDeletePath:null,overridePropsRenamePath:null,setSuspenseHandler:null,scheduleUpdate:null,currentDispatcherRef:ra.ReactCurrentDispatcher,findHostInstanceByFiber:function(a){a=cc(a);return null===a?null:a.stateNode},findFiberByHostInstance:wk.findFiberByHostInstance||\npk,findHostInstancesForRefresh:null,scheduleRefresh:null,scheduleRoot:null,setRefreshHandler:null,getCurrentFiber:null};if(\"undefined\"!==typeof __REACT_DEVTOOLS_GLOBAL_HOOK__){var yk=__REACT_DEVTOOLS_GLOBAL_HOOK__;if(!yk.isDisabled&&yk.supportsFiber)try{Lf=yk.inject(xk),Mf=yk}catch(a){}}exports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=vk;exports.createPortal=uk;\nexports.findDOMNode=function(a){if(null==a)return null;if(1===a.nodeType)return a;var b=a._reactInternals;if(void 0===b){if(\"function\"===typeof a.render)throw Error(y(188));throw Error(y(268,Object.keys(a)));}a=cc(b);a=null===a?null:a.stateNode;return a};exports.flushSync=function(a,b){var c=X;if(0!==(c&48))return a(b);X|=1;try{if(a)return gg(99,a.bind(null,b))}finally{X=c,ig()}};exports.hydrate=function(a,b,c){if(!rk(b))throw Error(y(200));return tk(null,a,b,!0,c)};\nexports.render=function(a,b,c){if(!rk(b))throw Error(y(200));return tk(null,a,b,!1,c)};exports.unmountComponentAtNode=function(a){if(!rk(a))throw Error(y(40));return a._reactRootContainer?(Xj(function(){tk(null,null,a,!1,function(){a._reactRootContainer=null;a[ff]=null})}),!0):!1};exports.unstable_batchedUpdates=Wj;exports.unstable_createPortal=function(a,b){return uk(a,b,2<arguments.length&&void 0!==arguments[2]?arguments[2]:null)};\nexports.unstable_renderSubtreeIntoContainer=function(a,b,c,d){if(!rk(c))throw Error(y(200));if(null==a||void 0===a._reactInternals)throw Error(y(38));return tk(a,b,c,!1,d)};exports.version=\"17.0.2\";\n","'use strict';\n\nfunction checkDCE() {\n /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */\n if (\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined' ||\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE !== 'function'\n ) {\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\n // This branch is unreachable because this function is only called\n // in production, but the condition is true only in development.\n // Therefore if the branch is still here, dead code elimination wasn't\n // properly applied.\n // Don't change the message. React DevTools relies on it. Also make sure\n // this message doesn't occur elsewhere in this function, or it will cause\n // a false positive.\n throw new Error('^_^');\n }\n try {\n // Verify that the code above has been dead code eliminated (DCE'd).\n __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(checkDCE);\n } catch (err) {\n // DevTools shouldn't crash React, no matter what.\n // We should still report in case we break this code.\n console.error(err);\n }\n}\n\nif (process.env.NODE_ENV === 'production') {\n // DCE check should happen before ReactDOM bundle executes so that\n // DevTools can report bad minification during injection.\n checkDCE();\n module.exports = require('./cjs/react-dom.production.min.js');\n} else {\n module.exports = require('./cjs/react-dom.development.js');\n}\n","var __defProp = Object.defineProperty;\nvar __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;\nvar __publicField = (obj, key, value) => {\n __defNormalProp(obj, typeof key !== \"symbol\" ? key + \"\" : key, value);\n return value;\n};\nimport require$$0, { forwardRef, useEffect, Component } from \"react\";\nfunction r(e) {\n var t, f2, n2 = \"\";\n if (\"string\" == typeof e || \"number\" == typeof e)\n n2 += e;\n else if (\"object\" == typeof e)\n if (Array.isArray(e))\n for (t = 0; t < e.length; t++)\n e[t] && (f2 = r(e[t])) && (n2 && (n2 += \" \"), n2 += f2);\n else\n for (t in e)\n e[t] && (n2 && (n2 += \" \"), n2 += t);\n return n2;\n}\nfunction clsx() {\n for (var e, t, f2 = 0, n2 = \"\"; f2 < arguments.length; )\n (e = arguments[f2++]) && (t = r(e)) && (n2 && (n2 += \" \"), n2 += t);\n return n2;\n}\nvar jsxRuntime = { exports: {} };\nvar reactJsxRuntime_production_min = {};\n/**\n * @license React\n * react-jsx-runtime.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nvar f = require$$0, k = Symbol.for(\"react.element\"), l = Symbol.for(\"react.fragment\"), m = Object.prototype.hasOwnProperty, n = f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, p = { key: true, ref: true, __self: true, __source: true };\nfunction q(c, a, g) {\n var b, d = {}, e = null, h = null;\n void 0 !== g && (e = \"\" + g);\n void 0 !== a.key && (e = \"\" + a.key);\n void 0 !== a.ref && (h = a.ref);\n for (b in a)\n m.call(a, b) && !p.hasOwnProperty(b) && (d[b] = a[b]);\n if (c && c.defaultProps)\n for (b in a = c.defaultProps, a)\n void 0 === d[b] && (d[b] = a[b]);\n return { $$typeof: k, type: c, key: e, ref: h, props: d, _owner: n.current };\n}\nreactJsxRuntime_production_min.Fragment = l;\nreactJsxRuntime_production_min.jsx = q;\nreactJsxRuntime_production_min.jsxs = q;\n{\n jsxRuntime.exports = reactJsxRuntime_production_min;\n}\nconst jsx = jsxRuntime.exports.jsx;\nconst jsxs = jsxRuntime.exports.jsxs;\nconst Fragment = jsxRuntime.exports.Fragment;\nconst ModalActions = ({\n className = \"\",\n actions = []\n}) => {\n return /* @__PURE__ */ jsx(\"div\", {\n className: `modal-action ${className}`,\n children: actions.map((el, index) => /* @__PURE__ */ jsx(\"button\", {\n className: `btn ${el.className}`,\n onClick: el.onClick,\n ...el.props,\n children: el.title\n }, index))\n });\n};\nconst ModalHeader = ({\n children,\n className = \"\",\n onBackdropClick,\n hideCloseIcon = false,\n closeIconComponent\n}) => {\n return /* @__PURE__ */ jsxs(\"div\", {\n className: `modalHeader ${className}`,\n children: [/* @__PURE__ */ jsx(\"div\", {\n className: \"modal-header-title\",\n children\n }), !hideCloseIcon && (closeIconComponent ? closeIconComponent : /* @__PURE__ */ jsx(\"div\", {\n className: \"close-wrapper\",\n onClick: () => {\n onBackdropClick && onBackdropClick();\n },\n children: /* @__PURE__ */ jsx(\"div\", {\n className: \"icon\",\n children: \"x\"\n })\n }))]\n });\n};\nconst ModalComponent = forwardRef(({\n children,\n open,\n className = \"\",\n isCloseable = false,\n title = \"Modal Header\",\n hideHeader = false,\n headerComponent: HeaderComponent,\n headerClassName = \"\",\n actions = [],\n actionClassName = \"\",\n contentClassName = \"\",\n onModalClose = () => {\n },\n hideCloseIcon = false,\n isSlidePane = false,\n position = \"right\",\n modalSize = \"sm\",\n isDark = false,\n disableTheme = false,\n footer,\n closeIconComponent\n}, ref) => {\n useEffect(() => {\n if (!disableTheme) {\n const attri = document.documentElement.getAttributeNames();\n if (isDark && !attri.includes(\"dark\")) {\n document.documentElement.setAttribute(\"data-theme\", \"dark\");\n }\n if (attri.includes(\"dark\") && !isDark) {\n document.documentElement.setAttribute(\"data-theme\", \"dark\");\n }\n }\n }, [isDark, disableTheme]);\n const classes = clsx(\"modal\", \"modal-open\", className, {\n dark: isDark\n });\n const modalWrapper = clsx(\n {\n \"modal-wrapper\": !isSlidePane,\n \"slidepane-wrapper\": isSlidePane,\n right: isSlidePane && position === \"right\",\n left: isSlidePane && position === \"left\"\n }\n );\n const modalBody = clsx(\"modal-body\", {\n \"w-xs\": modalSize === \"xs\",\n \"w-sm\": modalSize === \"sm\",\n \"w-md\": modalSize === \"md\",\n \"w-lg\": modalSize === \"lg\"\n }, contentClassName);\n const modalContent = clsx(\"modalContent\");\n return /* @__PURE__ */ jsx(\"div\", {\n \"aria-hidden\": !open,\n \"aria-modal\": open,\n className: classes,\n \"dark-them\": \"light\",\n onClick: (e) => {\n e.stopPropagation();\n if (e.target === e.currentTarget) {\n e.stopPropagation();\n onModalClose();\n }\n },\n children: /* @__PURE__ */ jsx(\"div\", {\n className: modalWrapper,\n children: /* @__PURE__ */ jsxs(\"div\", {\n className: modalContent,\n children: [/* @__PURE__ */ jsx(\"div\", {\n className: \"position\",\n children: !hideHeader ? /* @__PURE__ */ jsx(ModalHeader, {\n className: headerClassName,\n onBackdropClick: onModalClose,\n hideCloseIcon,\n closeIconComponent,\n children: /* @__PURE__ */ jsxs(Fragment, {\n children: [title != null ? title : null, HeaderComponent != null ? HeaderComponent : null]\n })\n }) : !hideCloseIcon && /* @__PURE__ */ jsx(Fragment, {\n children: closeIconComponent ? closeIconComponent : /* @__PURE__ */ jsx(\"div\", {\n className: \"close-wrapper close\",\n onClick: () => {\n if (!isCloseable) {\n onModalClose();\n }\n },\n children: /* @__PURE__ */ jsx(\"div\", {\n className: \"icon\",\n children: \"x\"\n })\n })\n })\n }), /* @__PURE__ */ jsx(\"div\", {\n className: modalBody,\n children\n }), footer && footer, (actions == null ? void 0 : actions.length) > 0 && !footer && /* @__PURE__ */ jsx(ModalActions, {\n actions,\n className: actionClassName\n })]\n })\n })\n });\n});\nconst GlobalModalComponent = forwardRef(({\n isOpen,\n component: MainComponent,\n props,\n isCloseable = false,\n onClose = () => {\n },\n closeModal = () => {\n },\n width,\n customModal: CustomModal,\n ...args\n}, ref) => {\n const onModalClose = () => {\n if (isCloseable)\n return;\n closeModal();\n onClose();\n };\n if (CustomModal) {\n return /* @__PURE__ */ jsx(CustomModal, {\n open: isOpen || false,\n width,\n onModalClose,\n isCloseable,\n ...args,\n ref,\n children: MainComponent && /* @__PURE__ */ jsx(MainComponent, {\n ...props,\n isInModal: true\n })\n });\n }\n return /* @__PURE__ */ jsx(ModalComponent, {\n open: isOpen || false,\n width,\n onModalClose,\n ...args,\n ref,\n children: MainComponent && /* @__PURE__ */ jsx(MainComponent, {\n ...props,\n isInModal: true\n })\n });\n});\nclass GlobalModalWrapper extends Component {\n constructor() {\n super(...arguments);\n __publicField(this, \"state\", {\n modals: []\n });\n __publicField(this, \"totalIndex\", 0);\n __publicField(this, \"open\", ({\n ...args\n }) => {\n const sheet = {\n ...args\n };\n const {\n modals\n } = this.state;\n this.totalIndex++;\n sheet.isOpen = true;\n sheet.id = this.totalIndex;\n if (!sheet.ref) {\n sheet.ref = require$$0.createRef();\n }\n modals.push({\n ...sheet\n });\n this.setState({\n modals\n });\n });\n __publicField(this, \"close\", (index = this.state.modals.length - 1) => {\n const {\n modals\n } = this.state;\n setTimeout(() => {\n modals.splice(index, 1);\n this.setState({\n modals\n });\n }, 200);\n if (modals[index]) {\n modals[index].isOpen = false;\n this.setState({\n modals\n });\n }\n });\n __publicField(this, \"updateModalProps\", ({\n ...props\n }, index = this.state.modals.length - 1) => {\n var _a, _b;\n const {\n modals\n } = this.state;\n const modalRef = (_a = modals[index]) == null ? void 0 : _a.ref;\n if (modalRef) {\n (_b = modalRef.current) == null ? void 0 : _b.add(props);\n }\n });\n __publicField(this, \"closeAll\", () => {\n const {\n modals\n } = this.state;\n modals.forEach(() => {\n setTimeout(() => {\n modals.splice(modals.length - 1, 1);\n this.setState({\n modals\n });\n }, 200);\n if (modals[modals.length - 1]) {\n modals[modals.length - 1].isOpen = false;\n this.setState({\n modals\n });\n }\n });\n });\n }\n render() {\n const {\n modals\n } = this.state;\n const {\n customModal\n } = this.props;\n return modals.map((sheet, index) => {\n return /* @__PURE__ */ jsx(GlobalModalComponent, {\n closeModal: this.close.bind(this),\n ...sheet,\n customModal\n }, sheet.id + \"\" + index);\n });\n }\n}\nclass GlobalModal {\n constructor() {\n __publicField(this, \"_globalModalRef\", null);\n }\n static setUpModal(ref) {\n this._globalModalRef = ref;\n }\n static push({ ...args }) {\n if (this._globalModalRef) {\n this._globalModalRef.open({ ...args });\n }\n }\n static add({ props, modalIndex }) {\n if (this._globalModalRef) {\n this._globalModalRef.updateModalProps({ ...props }, modalIndex);\n }\n }\n static pop(index) {\n if (this._globalModalRef) {\n this._globalModalRef.close(index);\n }\n }\n static closeAll() {\n if (this._globalModalRef) {\n this._globalModalRef.closeAll();\n }\n }\n}\nconst AsyncConfirmationModal = ({\n cancelLabel = \"Cancel\",\n okayLabel = \"Confirm\",\n message = \"AsynConfirmation Modal message\",\n title = \"AsyncConfirmation Modal Title\",\n isClosable = true,\n confirmationBody: ConfirmationBody,\n confirmationClassName = \"\",\n className = \"\",\n actions,\n footer,\n okyActionProps,\n cancelActionProps,\n ...args\n}) => {\n return new Promise((resolve) => {\n const defaultAction = [{\n title: okayLabel,\n onClick: () => {\n resolve(true);\n GlobalModal.pop();\n },\n className: \"btn-primary\",\n ...okyActionProps\n }, {\n title: cancelLabel,\n onClick: () => {\n resolve(false);\n GlobalModal.pop();\n },\n className: \"btn-error\",\n ...cancelActionProps\n }];\n GlobalModal.push({\n component: ConfirmationBody != null ? ConfirmationBody : ConfirmationModalBody$1,\n actions: actions != null ? actions : defaultAction,\n title,\n isCloseable: isClosable,\n hideCloseIcon: true,\n modalSize: \"sm\",\n className,\n footer,\n props: {\n message,\n confirmationClassName\n },\n ...args\n });\n });\n};\nconst ConfirmationModalBody$1 = ({\n message,\n confirmationClassName = \"\"\n}) => {\n const classes = clsx(\"confirmation\", confirmationClassName);\n return /* @__PURE__ */ jsx(\"div\", {\n className: classes,\n children: message\n });\n};\nconst ConfirmationModal = ({\n title = \"Confirmation Modal Title\",\n cancelLabel = \"Cancel\",\n message = \"Confirmation Modal Message\",\n okayLabel = \"Okay\",\n onCancel = () => {\n },\n onOkay = () => {\n },\n isCloseable = true,\n confirmationBody: ConfirmationBody,\n confirmationClassName = \"\",\n className = \"\",\n actions,\n footer,\n okyActionProps,\n cancelActionProps,\n ...args\n}) => {\n const modalAction = [{\n title: okayLabel,\n onClick: () => {\n onOkay();\n GlobalModal.pop();\n },\n className: \"btn-primary\",\n ...okyActionProps\n }, {\n title: cancelLabel,\n onClick: () => {\n onCancel();\n GlobalModal.pop();\n },\n className: \"btn-error\",\n ...cancelActionProps\n }];\n GlobalModal.push({\n component: ConfirmationBody != null ? ConfirmationBody : ConfirmationModalBody,\n actions: actions != null ? actions : modalAction,\n title,\n isCloseable,\n hideCloseIcon: true,\n modalSize: \"sm\",\n className,\n footer,\n props: {\n message,\n confirmationClassName\n },\n ...args\n });\n};\nconst ConfirmationModalBody = ({\n message,\n confirmationClassName = \"\"\n}) => {\n const classes = clsx(\"confirmation\", confirmationClassName);\n return /* @__PURE__ */ jsx(\"div\", {\n className: classes,\n children: message\n });\n};\nvar Modal = \"\";\nexport { AsyncConfirmationModal, ConfirmationModal, GlobalModal, GlobalModalComponent, GlobalModalWrapper, ModalComponent };\n","var matchHtmlEntity = /&(?:amp|#38|lt|#60|gt|#62|apos|#39|quot|#34);/g;\nvar htmlEntities = {\n '&': '&',\n '&': '&',\n '<': '<',\n '<': '<',\n '>': '>',\n '>': '>',\n ''': \"'\",\n ''': \"'\",\n '"': '\"',\n '"': '\"'\n};\n\nvar unescapeHtmlEntity = function unescapeHtmlEntity(m) {\n return htmlEntities[m];\n};\n\nexport var unescape = function unescape(text) {\n return text.replace(matchHtmlEntity, unescapeHtmlEntity);\n};","import _classCallCheck from \"@babel/runtime/helpers/classCallCheck\";\nimport _createClass from \"@babel/runtime/helpers/createClass\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { createContext } from 'react';\nimport { unescape } from './unescape';\nvar defaultOptions = {\n bindI18n: 'languageChanged',\n bindI18nStore: '',\n transEmptyNodeValue: '',\n transSupportBasicHtmlNodes: true,\n transWrapTextNodes: '',\n transKeepBasicHtmlNodesFor: ['br', 'strong', 'i', 'p'],\n useSuspense: true,\n unescape: unescape\n};\nvar i18nInstance;\nexport var I18nContext = createContext();\nexport function setDefaults() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n defaultOptions = _objectSpread(_objectSpread({}, defaultOptions), options);\n}\nexport function getDefaults() {\n return defaultOptions;\n}\nexport var ReportNamespaces = function () {\n function ReportNamespaces() {\n _classCallCheck(this, ReportNamespaces);\n\n this.usedNamespaces = {};\n }\n\n _createClass(ReportNamespaces, [{\n key: \"addUsedNamespaces\",\n value: function addUsedNamespaces(namespaces) {\n var _this = this;\n\n namespaces.forEach(function (ns) {\n if (!_this.usedNamespaces[ns]) _this.usedNamespaces[ns] = true;\n });\n }\n }, {\n key: \"getUsedNamespaces\",\n value: function getUsedNamespaces() {\n return Object.keys(this.usedNamespaces);\n }\n }]);\n\n return ReportNamespaces;\n}();\nexport function setI18n(instance) {\n i18nInstance = instance;\n}\nexport function getI18n() {\n return i18nInstance;\n}\nexport var initReactI18next = {\n type: '3rdParty',\n init: function init(instance) {\n setDefaults(instance.options.react);\n setI18n(instance);\n }\n};\nexport function composeInitialProps(ForComponent) {\n return function (ctx) {\n return new Promise(function (resolve) {\n var i18nInitialProps = getInitialProps();\n\n if (ForComponent.getInitialProps) {\n ForComponent.getInitialProps(ctx).then(function (componentsInitialProps) {\n resolve(_objectSpread(_objectSpread({}, componentsInitialProps), i18nInitialProps));\n });\n } else {\n resolve(i18nInitialProps);\n }\n });\n };\n}\nexport function getInitialProps() {\n var i18n = getI18n();\n var namespaces = i18n.reportNamespaces ? i18n.reportNamespaces.getUsedNamespaces() : [];\n var ret = {};\n var initialI18nStore = {};\n i18n.languages.forEach(function (l) {\n initialI18nStore[l] = {};\n namespaces.forEach(function (ns) {\n initialI18nStore[l][ns] = i18n.getResourceBundle(l, ns) || {};\n });\n });\n ret.initialI18nStore = initialI18nStore;\n ret.initialLanguage = i18n.language;\n return ret;\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArrayLimit from \"./iterableToArrayLimit.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}","export function warn() {\n if (console && console.warn) {\n var _console;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n if (typeof args[0] === 'string') args[0] = \"react-i18next:: \".concat(args[0]);\n\n (_console = console).warn.apply(_console, args);\n }\n}\nvar alreadyWarned = {};\nexport function warnOnce() {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n if (typeof args[0] === 'string' && alreadyWarned[args[0]]) return;\n if (typeof args[0] === 'string') alreadyWarned[args[0]] = new Date();\n warn.apply(void 0, args);\n}\nexport function loadNamespaces(i18n, ns, cb) {\n i18n.loadNamespaces(ns, function () {\n if (i18n.isInitialized) {\n cb();\n } else {\n var initialized = function initialized() {\n setTimeout(function () {\n i18n.off('initialized', initialized);\n }, 0);\n cb();\n };\n\n i18n.on('initialized', initialized);\n }\n });\n}\n\nfunction oldI18nextHasLoadedNamespace(ns, i18n) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var lng = i18n.languages[0];\n var fallbackLng = i18n.options ? i18n.options.fallbackLng : false;\n var lastLng = i18n.languages[i18n.languages.length - 1];\n if (lng.toLowerCase() === 'cimode') return true;\n\n var loadNotPending = function loadNotPending(l, n) {\n var loadState = i18n.services.backendConnector.state[\"\".concat(l, \"|\").concat(n)];\n return loadState === -1 || loadState === 2;\n };\n\n if (options.bindI18n && options.bindI18n.indexOf('languageChanging') > -1 && i18n.services.backendConnector.backend && i18n.isLanguageChangingTo && !loadNotPending(i18n.isLanguageChangingTo, ns)) return false;\n if (i18n.hasResourceBundle(lng, ns)) return true;\n if (!i18n.services.backendConnector.backend || i18n.options.resources && !i18n.options.partialBundledLanguages) return true;\n if (loadNotPending(lng, ns) && (!fallbackLng || loadNotPending(lastLng, ns))) return true;\n return false;\n}\n\nexport function hasLoadedNamespace(ns, i18n) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n if (!i18n.languages || !i18n.languages.length) {\n warnOnce('i18n.languages were undefined or empty', i18n.languages);\n return true;\n }\n\n var isNewerI18next = i18n.options.ignoreJSONStructure !== undefined;\n\n if (!isNewerI18next) {\n return oldI18nextHasLoadedNamespace(ns, i18n, options);\n }\n\n return i18n.hasLoadedNamespace(ns, {\n precheck: function precheck(i18nInstance, loadNotPending) {\n if (options.bindI18n && options.bindI18n.indexOf('languageChanging') > -1 && i18nInstance.services.backendConnector.backend && i18nInstance.isLanguageChangingTo && !loadNotPending(i18nInstance.isLanguageChangingTo, ns)) return false;\n }\n });\n}\nexport function getDisplayName(Component) {\n return Component.displayName || Component.name || (typeof Component === 'string' && Component.length > 0 ? Component : 'Unknown');\n}","import _slicedToArray from \"@babel/runtime/helpers/slicedToArray\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { useState, useEffect, useContext, useRef } from 'react';\nimport { getI18n, getDefaults, ReportNamespaces, I18nContext } from './context';\nimport { warnOnce, loadNamespaces, hasLoadedNamespace } from './utils';\n\nvar usePrevious = function usePrevious(value, ignore) {\n var ref = useRef();\n useEffect(function () {\n ref.current = ignore ? ref.current : value;\n }, [value, ignore]);\n return ref.current;\n};\n\nexport function useTranslation(ns) {\n var props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var i18nFromProps = props.i18n;\n\n var _ref = useContext(I18nContext) || {},\n i18nFromContext = _ref.i18n,\n defaultNSFromContext = _ref.defaultNS;\n\n var i18n = i18nFromProps || i18nFromContext || getI18n();\n if (i18n && !i18n.reportNamespaces) i18n.reportNamespaces = new ReportNamespaces();\n\n if (!i18n) {\n warnOnce('You will need to pass in an i18next instance by using initReactI18next');\n\n var notReadyT = function notReadyT(k) {\n return Array.isArray(k) ? k[k.length - 1] : k;\n };\n\n var retNotReady = [notReadyT, {}, false];\n retNotReady.t = notReadyT;\n retNotReady.i18n = {};\n retNotReady.ready = false;\n return retNotReady;\n }\n\n if (i18n.options.react && i18n.options.react.wait !== undefined) warnOnce('It seems you are still using the old wait option, you may migrate to the new useSuspense behaviour.');\n\n var i18nOptions = _objectSpread(_objectSpread(_objectSpread({}, getDefaults()), i18n.options.react), props);\n\n var useSuspense = i18nOptions.useSuspense,\n keyPrefix = i18nOptions.keyPrefix;\n var namespaces = ns || defaultNSFromContext || i18n.options && i18n.options.defaultNS;\n namespaces = typeof namespaces === 'string' ? [namespaces] : namespaces || ['translation'];\n if (i18n.reportNamespaces.addUsedNamespaces) i18n.reportNamespaces.addUsedNamespaces(namespaces);\n var ready = (i18n.isInitialized || i18n.initializedStoreOnce) && namespaces.every(function (n) {\n return hasLoadedNamespace(n, i18n, i18nOptions);\n });\n\n function getT() {\n return i18n.getFixedT(null, i18nOptions.nsMode === 'fallback' ? namespaces : namespaces[0], keyPrefix);\n }\n\n var _useState = useState(getT),\n _useState2 = _slicedToArray(_useState, 2),\n t = _useState2[0],\n setT = _useState2[1];\n\n var joinedNS = namespaces.join();\n var previousJoinedNS = usePrevious(joinedNS);\n var isMounted = useRef(true);\n useEffect(function () {\n var bindI18n = i18nOptions.bindI18n,\n bindI18nStore = i18nOptions.bindI18nStore;\n isMounted.current = true;\n\n if (!ready && !useSuspense) {\n loadNamespaces(i18n, namespaces, function () {\n if (isMounted.current) setT(getT);\n });\n }\n\n if (ready && previousJoinedNS && previousJoinedNS !== joinedNS && isMounted.current) {\n setT(getT);\n }\n\n function boundReset() {\n if (isMounted.current) setT(getT);\n }\n\n if (bindI18n && i18n) i18n.on(bindI18n, boundReset);\n if (bindI18nStore && i18n) i18n.store.on(bindI18nStore, boundReset);\n return function () {\n isMounted.current = false;\n if (bindI18n && i18n) bindI18n.split(' ').forEach(function (e) {\n return i18n.off(e, boundReset);\n });\n if (bindI18nStore && i18n) bindI18nStore.split(' ').forEach(function (e) {\n return i18n.store.off(e, boundReset);\n });\n };\n }, [i18n, joinedNS]);\n var isInitial = useRef(true);\n useEffect(function () {\n if (isMounted.current && !isInitial.current) {\n setT(getT);\n }\n\n isInitial.current = false;\n }, [i18n]);\n var ret = [t, i18n, ready];\n ret.t = t;\n ret.i18n = i18n;\n ret.ready = ready;\n if (ready) return ret;\n if (!ready && !useSuspense) return ret;\n throw new Promise(function (resolve) {\n loadNamespaces(i18n, namespaces, function () {\n resolve();\n });\n });\n}","/** @license React v16.13.1\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';var b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?\nSymbol.for(\"react.suspense_list\"):60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.block\"):60121,w=b?Symbol.for(\"react.fundamental\"):60117,x=b?Symbol.for(\"react.responder\"):60118,y=b?Symbol.for(\"react.scope\"):60119;\nfunction z(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;\nexports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t};\nexports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","import React from \"react\";\nimport { Router } from \"react-router\";\nimport { createBrowserHistory as createHistory } from \"history\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\n/**\n * The public API for a <Router> that uses HTML5 history.\n */\nclass BrowserRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return <Router history={this.history} children={this.props.children} />;\n }\n}\n\nif (__DEV__) {\n BrowserRouter.propTypes = {\n basename: PropTypes.string,\n children: PropTypes.node,\n forceRefresh: PropTypes.bool,\n getUserConfirmation: PropTypes.func,\n keyLength: PropTypes.number\n };\n\n BrowserRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<BrowserRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { BrowserRouter as Router }`.\"\n );\n };\n}\n\nexport default BrowserRouter;\n","import React from \"react\";\nimport { Router } from \"react-router\";\nimport { createHashHistory as createHistory } from \"history\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\n/**\n * The public API for a <Router> that uses window.location.hash.\n */\nclass HashRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return <Router history={this.history} children={this.props.children} />;\n }\n}\n\nif (__DEV__) {\n HashRouter.propTypes = {\n basename: PropTypes.string,\n children: PropTypes.node,\n getUserConfirmation: PropTypes.func,\n hashType: PropTypes.oneOf([\"hashbang\", \"noslash\", \"slash\"])\n };\n\n HashRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<HashRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { HashRouter as Router }`.\"\n );\n };\n}\n\nexport default HashRouter;\n","import { createLocation } from \"history\";\n\nexport const resolveToLocation = (to, currentLocation) =>\n typeof to === \"function\" ? to(currentLocation) : to;\n\nexport const normalizeToLocation = (to, currentLocation) => {\n return typeof to === \"string\"\n ? createLocation(to, null, null, currentLocation)\n : to;\n};\n","import React from \"react\";\nimport { __RouterContext as RouterContext } from \"react-router\";\nimport { createPath } from 'history';\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport {\n resolveToLocation,\n normalizeToLocation\n} from \"./utils/locationUtils.js\";\n\n// React 15 compat\nconst forwardRefShim = C => C;\nlet { forwardRef } = React;\nif (typeof forwardRef === \"undefined\") {\n forwardRef = forwardRefShim;\n}\n\nfunction isModifiedEvent(event) {\n return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n}\n\nconst LinkAnchor = forwardRef(\n (\n {\n innerRef, // TODO: deprecate\n navigate,\n onClick,\n ...rest\n },\n forwardedRef\n ) => {\n const { target } = rest;\n\n let props = {\n ...rest,\n onClick: event => {\n try {\n if (onClick) onClick(event);\n } catch (ex) {\n event.preventDefault();\n throw ex;\n }\n\n if (\n !event.defaultPrevented && // onClick prevented default\n event.button === 0 && // ignore everything but left clicks\n (!target || target === \"_self\") && // let browser handle \"target=_blank\" etc.\n !isModifiedEvent(event) // ignore clicks with modifier keys\n ) {\n event.preventDefault();\n navigate();\n }\n }\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.ref = innerRef;\n }\n\n /* eslint-disable-next-line jsx-a11y/anchor-has-content */\n return <a {...props} />;\n }\n);\n\nif (__DEV__) {\n LinkAnchor.displayName = \"LinkAnchor\";\n}\n\n/**\n * The public API for rendering a history-aware <a>.\n */\nconst Link = forwardRef(\n (\n {\n component = LinkAnchor,\n replace,\n to,\n innerRef, // TODO: deprecate\n ...rest\n },\n forwardedRef\n ) => {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <Link> outside a <Router>\");\n\n const { history } = context;\n\n const location = normalizeToLocation(\n resolveToLocation(to, context.location),\n context.location\n );\n\n const href = location ? history.createHref(location) : \"\";\n const props = {\n ...rest,\n href,\n navigate() {\n const location = resolveToLocation(to, context.location);\n const isDuplicateNavigation = createPath(context.location) === createPath(normalizeToLocation(location));\n const method = (replace || isDuplicateNavigation) ? history.replace : history.push;\n\n method(location);\n }\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.innerRef = innerRef;\n }\n\n return React.createElement(component, props);\n }}\n </RouterContext.Consumer>\n );\n }\n);\n\nif (__DEV__) {\n const toType = PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.object,\n PropTypes.func\n ]);\n const refType = PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.shape({ current: PropTypes.any })\n ]);\n\n Link.displayName = \"Link\";\n\n Link.propTypes = {\n innerRef: refType,\n onClick: PropTypes.func,\n replace: PropTypes.bool,\n target: PropTypes.string,\n to: toType.isRequired\n };\n}\n\nexport default Link;\n","import React from \"react\";\nimport { __RouterContext as RouterContext, matchPath } from \"react-router\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport Link from \"./Link.js\";\nimport {\n resolveToLocation,\n normalizeToLocation\n} from \"./utils/locationUtils.js\";\n\n// React 15 compat\nconst forwardRefShim = C => C;\nlet { forwardRef } = React;\nif (typeof forwardRef === \"undefined\") {\n forwardRef = forwardRefShim;\n}\n\nfunction joinClassnames(...classnames) {\n return classnames.filter(i => i).join(\" \");\n}\n\n/**\n * A <Link> wrapper that knows if it's \"active\" or not.\n */\nconst NavLink = forwardRef(\n (\n {\n \"aria-current\": ariaCurrent = \"page\",\n activeClassName = \"active\", // TODO: deprecate\n activeStyle, // TODO: deprecate\n className: classNameProp,\n exact,\n isActive: isActiveProp,\n location: locationProp,\n sensitive,\n strict,\n style: styleProp,\n to,\n innerRef, // TODO: deprecate\n ...rest\n },\n forwardedRef\n ) => {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <NavLink> outside a <Router>\");\n\n const currentLocation = locationProp || context.location;\n const toLocation = normalizeToLocation(\n resolveToLocation(to, currentLocation),\n currentLocation\n );\n const { pathname: path } = toLocation;\n // Regex taken from: https://github.com/pillarjs/path-to-regexp/blob/master/index.js#L202\n const escapedPath =\n path && path.replace(/([.+*?=^!:${}()[\\]|/\\\\])/g, \"\\\\$1\");\n\n const match = escapedPath\n ? matchPath(currentLocation.pathname, {\n path: escapedPath,\n exact,\n sensitive,\n strict\n })\n : null;\n const isActive = !!(isActiveProp\n ? isActiveProp(match, currentLocation)\n : match);\n\n let className =\n typeof classNameProp === \"function\"\n ? classNameProp(isActive)\n : classNameProp;\n\n let style =\n typeof styleProp === \"function\" ? styleProp(isActive) : styleProp;\n\n if (isActive) {\n className = joinClassnames(className, activeClassName);\n style = { ...style, ...activeStyle };\n }\n\n const props = {\n \"aria-current\": (isActive && ariaCurrent) || null,\n className,\n style,\n to: toLocation,\n ...rest\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.innerRef = innerRef;\n }\n\n return <Link {...props} />;\n }}\n </RouterContext.Consumer>\n );\n }\n);\n\nif (__DEV__) {\n NavLink.displayName = \"NavLink\";\n\n const ariaCurrentType = PropTypes.oneOf([\n \"page\",\n \"step\",\n \"location\",\n \"date\",\n \"time\",\n \"true\",\n \"false\"\n ]);\n\n NavLink.propTypes = {\n ...Link.propTypes,\n \"aria-current\": ariaCurrentType,\n activeClassName: PropTypes.string,\n activeStyle: PropTypes.object,\n className: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n exact: PropTypes.bool,\n isActive: PropTypes.func,\n location: PropTypes.object,\n sensitive: PropTypes.bool,\n strict: PropTypes.bool,\n style: PropTypes.oneOfType([PropTypes.object, PropTypes.func])\n };\n}\n\nexport default NavLink;\n","import React, { Component } from 'react';\nimport _inheritsLoose from '@babel/runtime/helpers/esm/inheritsLoose';\nimport PropTypes from 'prop-types';\nimport warning from 'tiny-warning';\n\nvar MAX_SIGNED_31_BIT_INT = 1073741823;\nvar commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : {};\n\nfunction getUniqueId() {\n var key = '__global_unique_id__';\n return commonjsGlobal[key] = (commonjsGlobal[key] || 0) + 1;\n}\n\nfunction objectIs(x, y) {\n if (x === y) {\n return x !== 0 || 1 / x === 1 / y;\n } else {\n return x !== x && y !== y;\n }\n}\n\nfunction createEventEmitter(value) {\n var handlers = [];\n return {\n on: function on(handler) {\n handlers.push(handler);\n },\n off: function off(handler) {\n handlers = handlers.filter(function (h) {\n return h !== handler;\n });\n },\n get: function get() {\n return value;\n },\n set: function set(newValue, changedBits) {\n value = newValue;\n handlers.forEach(function (handler) {\n return handler(value, changedBits);\n });\n }\n };\n}\n\nfunction onlyChild(children) {\n return Array.isArray(children) ? children[0] : children;\n}\n\nfunction createReactContext(defaultValue, calculateChangedBits) {\n var _Provider$childContex, _Consumer$contextType;\n\n var contextProp = '__create-react-context-' + getUniqueId() + '__';\n\n var Provider = /*#__PURE__*/function (_Component) {\n _inheritsLoose(Provider, _Component);\n\n function Provider() {\n var _this;\n\n _this = _Component.apply(this, arguments) || this;\n _this.emitter = createEventEmitter(_this.props.value);\n return _this;\n }\n\n var _proto = Provider.prototype;\n\n _proto.getChildContext = function getChildContext() {\n var _ref;\n\n return _ref = {}, _ref[contextProp] = this.emitter, _ref;\n };\n\n _proto.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n if (this.props.value !== nextProps.value) {\n var oldValue = this.props.value;\n var newValue = nextProps.value;\n var changedBits;\n\n if (objectIs(oldValue, newValue)) {\n changedBits = 0;\n } else {\n changedBits = typeof calculateChangedBits === 'function' ? calculateChangedBits(oldValue, newValue) : MAX_SIGNED_31_BIT_INT;\n\n if (process.env.NODE_ENV !== 'production') {\n warning((changedBits & MAX_SIGNED_31_BIT_INT) === changedBits, 'calculateChangedBits: Expected the return value to be a ' + '31-bit integer. Instead received: ' + changedBits);\n }\n\n changedBits |= 0;\n\n if (changedBits !== 0) {\n this.emitter.set(nextProps.value, changedBits);\n }\n }\n }\n };\n\n _proto.render = function render() {\n return this.props.children;\n };\n\n return Provider;\n }(Component);\n\n Provider.childContextTypes = (_Provider$childContex = {}, _Provider$childContex[contextProp] = PropTypes.object.isRequired, _Provider$childContex);\n\n var Consumer = /*#__PURE__*/function (_Component2) {\n _inheritsLoose(Consumer, _Component2);\n\n function Consumer() {\n var _this2;\n\n _this2 = _Component2.apply(this, arguments) || this;\n _this2.state = {\n value: _this2.getValue()\n };\n\n _this2.onUpdate = function (newValue, changedBits) {\n var observedBits = _this2.observedBits | 0;\n\n if ((observedBits & changedBits) !== 0) {\n _this2.setState({\n value: _this2.getValue()\n });\n }\n };\n\n return _this2;\n }\n\n var _proto2 = Consumer.prototype;\n\n _proto2.componentWillReceiveProps = function componentWillReceiveProps(nextProps) {\n var observedBits = nextProps.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT : observedBits;\n };\n\n _proto2.componentDidMount = function componentDidMount() {\n if (this.context[contextProp]) {\n this.context[contextProp].on(this.onUpdate);\n }\n\n var observedBits = this.props.observedBits;\n this.observedBits = observedBits === undefined || observedBits === null ? MAX_SIGNED_31_BIT_INT : observedBits;\n };\n\n _proto2.componentWillUnmount = function componentWillUnmount() {\n if (this.context[contextProp]) {\n this.context[contextProp].off(this.onUpdate);\n }\n };\n\n _proto2.getValue = function getValue() {\n if (this.context[contextProp]) {\n return this.context[contextProp].get();\n } else {\n return defaultValue;\n }\n };\n\n _proto2.render = function render() {\n return onlyChild(this.props.children)(this.state.value);\n };\n\n return Consumer;\n }(Component);\n\n Consumer.contextTypes = (_Consumer$contextType = {}, _Consumer$contextType[contextProp] = PropTypes.object, _Consumer$contextType);\n return {\n Provider: Provider,\n Consumer: Consumer\n };\n}\n\nvar index = React.createContext || createReactContext;\n\nexport default index;\n","// TODO: Replace with React.createContext once we can assume React 16+\nimport createContext from \"mini-create-react-context\";\n\nconst createNamedContext = name => {\n const context = createContext();\n context.displayName = name;\n\n return context;\n};\n\nexport default createNamedContext;\n","import createNamedContext from \"./createNamedContext\";\n\nconst historyContext = /*#__PURE__*/ createNamedContext(\"Router-History\");\nexport default historyContext;\n","import createNamedContext from \"./createNamedContext\";\n\nconst context = /*#__PURE__*/ createNamedContext(\"Router\");\nexport default context;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\nimport HistoryContext from \"./HistoryContext.js\";\nimport RouterContext from \"./RouterContext.js\";\n\n/**\n * The public API for putting history on context.\n */\nclass Router extends React.Component {\n static computeRootMatch(pathname) {\n return { path: \"/\", url: \"/\", params: {}, isExact: pathname === \"/\" };\n }\n\n constructor(props) {\n super(props);\n\n this.state = {\n location: props.history.location\n };\n\n // This is a bit of a hack. We have to start listening for location\n // changes here in the constructor in case there are any <Redirect>s\n // on the initial render. If there are, they will replace/push when\n // they mount and since cDM fires in children before parents, we may\n // get a new location before the <Router> is mounted.\n this._isMounted = false;\n this._pendingLocation = null;\n\n if (!props.staticContext) {\n this.unlisten = props.history.listen(location => {\n this._pendingLocation = location;\n });\n }\n }\n\n componentDidMount() {\n this._isMounted = true;\n\n if (this.unlisten) {\n // Any pre-mount location changes have been captured at\n // this point, so unregister the listener.\n this.unlisten();\n }\n if (!this.props.staticContext) {\n this.unlisten = this.props.history.listen(location => {\n if (this._isMounted) {\n this.setState({ location });\n }\n });\n }\n if (this._pendingLocation) {\n this.setState({ location: this._pendingLocation });\n }\n }\n\n componentWillUnmount() {\n if (this.unlisten) {\n this.unlisten();\n this._isMounted = false;\n this._pendingLocation = null;\n }\n }\n\n render() {\n return (\n <RouterContext.Provider\n value={{\n history: this.props.history,\n location: this.state.location,\n match: Router.computeRootMatch(this.state.location.pathname),\n staticContext: this.props.staticContext\n }}\n >\n <HistoryContext.Provider\n children={this.props.children || null}\n value={this.props.history}\n />\n </RouterContext.Provider>\n );\n }\n}\n\nif (__DEV__) {\n Router.propTypes = {\n children: PropTypes.node,\n history: PropTypes.object.isRequired,\n staticContext: PropTypes.object\n };\n\n Router.prototype.componentDidUpdate = function(prevProps) {\n warning(\n prevProps.history === this.props.history,\n \"You cannot change <Router history>\"\n );\n };\n}\n\nexport default Router;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport { createMemoryHistory as createHistory } from \"history\";\nimport warning from \"tiny-warning\";\n\nimport Router from \"./Router.js\";\n\n/**\n * The public API for a <Router> that stores location in memory.\n */\nclass MemoryRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return <Router history={this.history} children={this.props.children} />;\n }\n}\n\nif (__DEV__) {\n MemoryRouter.propTypes = {\n initialEntries: PropTypes.array,\n initialIndex: PropTypes.number,\n getUserConfirmation: PropTypes.func,\n keyLength: PropTypes.number,\n children: PropTypes.node\n };\n\n MemoryRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<MemoryRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { MemoryRouter as Router }`.\"\n );\n };\n}\n\nexport default MemoryRouter;\n","import React from \"react\";\n\nclass Lifecycle extends React.Component {\n componentDidMount() {\n if (this.props.onMount) this.props.onMount.call(this, this);\n }\n\n componentDidUpdate(prevProps) {\n if (this.props.onUpdate) this.props.onUpdate.call(this, this, prevProps);\n }\n\n componentWillUnmount() {\n if (this.props.onUnmount) this.props.onUnmount.call(this, this);\n }\n\n render() {\n return null;\n }\n}\n\nexport default Lifecycle;\n","import pathToRegexp from \"path-to-regexp\";\n\nconst cache = {};\nconst cacheLimit = 10000;\nlet cacheCount = 0;\n\nfunction compilePath(path) {\n if (cache[path]) return cache[path];\n\n const generator = pathToRegexp.compile(path);\n\n if (cacheCount < cacheLimit) {\n cache[path] = generator;\n cacheCount++;\n }\n\n return generator;\n}\n\n/**\n * Public API for generating a URL pathname from a path and parameters.\n */\nfunction generatePath(path = \"/\", params = {}) {\n return path === \"/\" ? path : compilePath(path)(params, { pretty: true });\n}\n\nexport default generatePath;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport { createLocation, locationsAreEqual } from \"history\";\nimport invariant from \"tiny-invariant\";\n\nimport Lifecycle from \"./Lifecycle.js\";\nimport RouterContext from \"./RouterContext.js\";\nimport generatePath from \"./generatePath.js\";\n\n/**\n * The public API for navigating programmatically with a component.\n */\nfunction Redirect({ computedMatch, to, push = false }) {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <Redirect> outside a <Router>\");\n\n const { history, staticContext } = context;\n\n const method = push ? history.push : history.replace;\n const location = createLocation(\n computedMatch\n ? typeof to === \"string\"\n ? generatePath(to, computedMatch.params)\n : {\n ...to,\n pathname: generatePath(to.pathname, computedMatch.params)\n }\n : to\n );\n\n // When rendering in a static context,\n // set the new location immediately.\n if (staticContext) {\n method(location);\n return null;\n }\n\n return (\n <Lifecycle\n onMount={() => {\n method(location);\n }}\n onUpdate={(self, prevProps) => {\n const prevLocation = createLocation(prevProps.to);\n if (\n !locationsAreEqual(prevLocation, {\n ...location,\n key: prevLocation.key\n })\n ) {\n method(location);\n }\n }}\n to={to}\n />\n );\n }}\n </RouterContext.Consumer>\n );\n}\n\nif (__DEV__) {\n Redirect.propTypes = {\n push: PropTypes.bool,\n from: PropTypes.string,\n to: PropTypes.oneOfType([PropTypes.string, PropTypes.object]).isRequired\n };\n}\n\nexport default Redirect;\n","import pathToRegexp from \"path-to-regexp\";\n\nconst cache = {};\nconst cacheLimit = 10000;\nlet cacheCount = 0;\n\nfunction compilePath(path, options) {\n const cacheKey = `${options.end}${options.strict}${options.sensitive}`;\n const pathCache = cache[cacheKey] || (cache[cacheKey] = {});\n\n if (pathCache[path]) return pathCache[path];\n\n const keys = [];\n const regexp = pathToRegexp(path, keys, options);\n const result = { regexp, keys };\n\n if (cacheCount < cacheLimit) {\n pathCache[path] = result;\n cacheCount++;\n }\n\n return result;\n}\n\n/**\n * Public API for matching a URL pathname to a path.\n */\nfunction matchPath(pathname, options = {}) {\n if (typeof options === \"string\" || Array.isArray(options)) {\n options = { path: options };\n }\n\n const { path, exact = false, strict = false, sensitive = false } = options;\n\n const paths = [].concat(path);\n\n return paths.reduce((matched, path) => {\n if (!path && path !== \"\") return null;\n if (matched) return matched;\n\n const { regexp, keys } = compilePath(path, {\n end: exact,\n strict,\n sensitive\n });\n const match = regexp.exec(pathname);\n\n if (!match) return null;\n\n const [url, ...values] = match;\n const isExact = pathname === url;\n\n if (exact && !isExact) return null;\n\n return {\n path, // the path used to match\n url: path === \"/\" && url === \"\" ? \"/\" : url, // the matched portion of the URL\n isExact, // whether or not we matched exactly\n params: keys.reduce((memo, key, index) => {\n memo[key.name] = values[index];\n return memo;\n }, {})\n };\n }, null);\n}\n\nexport default matchPath;\n","import React from \"react\";\nimport { isValidElementType } from \"react-is\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport RouterContext from \"./RouterContext.js\";\nimport matchPath from \"./matchPath.js\";\n\nfunction isEmptyChildren(children) {\n return React.Children.count(children) === 0;\n}\n\nfunction evalChildrenDev(children, props, path) {\n const value = children(props);\n\n warning(\n value !== undefined,\n \"You returned `undefined` from the `children` function of \" +\n `<Route${path ? ` path=\"${path}\"` : \"\"}>, but you ` +\n \"should have returned a React element or `null`\"\n );\n\n return value || null;\n}\n\n/**\n * The public API for matching a single path and rendering.\n */\nclass Route extends React.Component {\n render() {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <Route> outside a <Router>\");\n\n const location = this.props.location || context.location;\n const match = this.props.computedMatch\n ? this.props.computedMatch // <Switch> already computed the match for us\n : this.props.path\n ? matchPath(location.pathname, this.props)\n : context.match;\n\n const props = { ...context, location, match };\n\n let { children, component, render } = this.props;\n\n // Preact uses an empty array as children by\n // default, so use null if that's the case.\n if (Array.isArray(children) && isEmptyChildren(children)) {\n children = null;\n }\n\n return (\n <RouterContext.Provider value={props}>\n {props.match\n ? children\n ? typeof children === \"function\"\n ? __DEV__\n ? evalChildrenDev(children, props, this.props.path)\n : children(props)\n : children\n : component\n ? React.createElement(component, props)\n : render\n ? render(props)\n : null\n : typeof children === \"function\"\n ? __DEV__\n ? evalChildrenDev(children, props, this.props.path)\n : children(props)\n : null}\n </RouterContext.Provider>\n );\n }}\n </RouterContext.Consumer>\n );\n }\n}\n\nif (__DEV__) {\n Route.propTypes = {\n children: PropTypes.oneOfType([PropTypes.func, PropTypes.node]),\n component: (props, propName) => {\n if (props[propName] && !isValidElementType(props[propName])) {\n return new Error(\n `Invalid prop 'component' supplied to 'Route': the prop is not a valid React component`\n );\n }\n },\n exact: PropTypes.bool,\n location: PropTypes.object,\n path: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.arrayOf(PropTypes.string)\n ]),\n render: PropTypes.func,\n sensitive: PropTypes.bool,\n strict: PropTypes.bool\n };\n\n Route.prototype.componentDidMount = function() {\n warning(\n !(\n this.props.children &&\n !isEmptyChildren(this.props.children) &&\n this.props.component\n ),\n \"You should not use <Route component> and <Route children> in the same route; <Route component> will be ignored\"\n );\n\n warning(\n !(\n this.props.children &&\n !isEmptyChildren(this.props.children) &&\n this.props.render\n ),\n \"You should not use <Route render> and <Route children> in the same route; <Route render> will be ignored\"\n );\n\n warning(\n !(this.props.component && this.props.render),\n \"You should not use <Route component> and <Route render> in the same route; <Route render> will be ignored\"\n );\n };\n\n Route.prototype.componentDidUpdate = function(prevProps) {\n warning(\n !(this.props.location && !prevProps.location),\n '<Route> elements should not change from uncontrolled to controlled (or vice versa). You initially used no \"location\" prop and then provided one on a subsequent render.'\n );\n\n warning(\n !(!this.props.location && prevProps.location),\n '<Route> elements should not change from controlled to uncontrolled (or vice versa). You provided a \"location\" prop initially but omitted it on a subsequent render.'\n );\n };\n}\n\nexport default Route;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport { createLocation, createPath } from \"history\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport Router from \"./Router.js\";\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === \"/\" ? path : \"/\" + path;\n}\n\nfunction addBasename(basename, location) {\n if (!basename) return location;\n\n return {\n ...location,\n pathname: addLeadingSlash(basename) + location.pathname\n };\n}\n\nfunction stripBasename(basename, location) {\n if (!basename) return location;\n\n const base = addLeadingSlash(basename);\n\n if (location.pathname.indexOf(base) !== 0) return location;\n\n return {\n ...location,\n pathname: location.pathname.substr(base.length)\n };\n}\n\nfunction createURL(location) {\n return typeof location === \"string\" ? location : createPath(location);\n}\n\nfunction staticHandler(methodName) {\n return () => {\n invariant(false, \"You cannot %s with <StaticRouter>\", methodName);\n };\n}\n\nfunction noop() {}\n\n/**\n * The public top-level API for a \"static\" <Router>, so-called because it\n * can't actually change the current location. Instead, it just records\n * location changes in a context object. Useful mainly in testing and\n * server-rendering scenarios.\n */\nclass StaticRouter extends React.Component {\n navigateTo(location, action) {\n const { basename = \"\", context = {} } = this.props;\n context.action = action;\n context.location = addBasename(basename, createLocation(location));\n context.url = createURL(context.location);\n }\n\n handlePush = location => this.navigateTo(location, \"PUSH\");\n handleReplace = location => this.navigateTo(location, \"REPLACE\");\n handleListen = () => noop;\n handleBlock = () => noop;\n\n render() {\n const { basename = \"\", context = {}, location = \"/\", ...rest } = this.props;\n\n const history = {\n createHref: path => addLeadingSlash(basename + createURL(path)),\n action: \"POP\",\n location: stripBasename(basename, createLocation(location)),\n push: this.handlePush,\n replace: this.handleReplace,\n go: staticHandler(\"go\"),\n goBack: staticHandler(\"goBack\"),\n goForward: staticHandler(\"goForward\"),\n listen: this.handleListen,\n block: this.handleBlock\n };\n\n return <Router {...rest} history={history} staticContext={context} />;\n }\n}\n\nif (__DEV__) {\n StaticRouter.propTypes = {\n basename: PropTypes.string,\n context: PropTypes.object,\n location: PropTypes.oneOfType([PropTypes.string, PropTypes.object])\n };\n\n StaticRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \"<StaticRouter> ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { StaticRouter as Router }`.\"\n );\n };\n}\n\nexport default StaticRouter;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport RouterContext from \"./RouterContext.js\";\nimport matchPath from \"./matchPath.js\";\n\n/**\n * The public API for rendering the first <Route> that matches.\n */\nclass Switch extends React.Component {\n render() {\n return (\n <RouterContext.Consumer>\n {context => {\n invariant(context, \"You should not use <Switch> outside a <Router>\");\n\n const location = this.props.location || context.location;\n\n let element, match;\n\n // We use React.Children.forEach instead of React.Children.toArray().find()\n // here because toArray adds keys to all child elements and we do not want\n // to trigger an unmount/remount for two <Route>s that render the same\n // component at different URLs.\n React.Children.forEach(this.props.children, child => {\n if (match == null && React.isValidElement(child)) {\n element = child;\n\n const path = child.props.path || child.props.from;\n\n match = path\n ? matchPath(location.pathname, { ...child.props, path })\n : context.match;\n }\n });\n\n return match\n ? React.cloneElement(element, { location, computedMatch: match })\n : null;\n }}\n </RouterContext.Consumer>\n );\n }\n}\n\nif (__DEV__) {\n Switch.propTypes = {\n children: PropTypes.node,\n location: PropTypes.object\n };\n\n Switch.prototype.componentDidUpdate = function(prevProps) {\n warning(\n !(this.props.location && !prevProps.location),\n '<Switch> elements should not change from uncontrolled to controlled (or vice versa). You initially used no \"location\" prop and then provided one on a subsequent render.'\n );\n\n warning(\n !(!this.props.location && prevProps.location),\n '<Switch> elements should not change from controlled to uncontrolled (or vice versa). You provided a \"location\" prop initially but omitted it on a subsequent render.'\n );\n };\n}\n\nexport default Switch;\n","import React from \"react\";\nimport invariant from \"tiny-invariant\";\n\nimport RouterContext from \"./RouterContext.js\";\nimport HistoryContext from \"./HistoryContext.js\";\nimport matchPath from \"./matchPath.js\";\n\nconst useContext = React.useContext;\n\nexport function useHistory() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useHistory()\"\n );\n }\n\n return useContext(HistoryContext);\n}\n\nexport function useLocation() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useLocation()\"\n );\n }\n\n return useContext(RouterContext).location;\n}\n\nexport function useParams() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useParams()\"\n );\n }\n\n const match = useContext(RouterContext).match;\n return match ? match.params : {};\n}\n\nexport function useRouteMatch(path) {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useRouteMatch()\"\n );\n }\n\n const location = useLocation();\n const match = useContext(RouterContext).match;\n return path ? matchPath(location.pathname, path) : match;\n}\n","/** @license React v17.0.2\n * react-jsx-runtime.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';require(\"object-assign\");var f=require(\"react\"),g=60103;exports.Fragment=60107;if(\"function\"===typeof Symbol&&Symbol.for){var h=Symbol.for;g=h(\"react.element\");exports.Fragment=h(\"react.fragment\")}var m=f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,n=Object.prototype.hasOwnProperty,p={key:!0,ref:!0,__self:!0,__source:!0};\nfunction q(c,a,k){var b,d={},e=null,l=null;void 0!==k&&(e=\"\"+k);void 0!==a.key&&(e=\"\"+a.key);void 0!==a.ref&&(l=a.ref);for(b in a)n.call(a,b)&&!p.hasOwnProperty(b)&&(d[b]=a[b]);if(c&&c.defaultProps)for(b in a=c.defaultProps,a)void 0===d[b]&&(d[b]=a[b]);return{$$typeof:g,type:c,key:e,ref:l,props:d,_owner:m.current}}exports.jsx=q;exports.jsxs=q;\n","/** @license React v17.0.2\n * react.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var l=require(\"object-assign\"),n=60103,p=60106;exports.Fragment=60107;exports.StrictMode=60108;exports.Profiler=60114;var q=60109,r=60110,t=60112;exports.Suspense=60113;var u=60115,v=60116;\nif(\"function\"===typeof Symbol&&Symbol.for){var w=Symbol.for;n=w(\"react.element\");p=w(\"react.portal\");exports.Fragment=w(\"react.fragment\");exports.StrictMode=w(\"react.strict_mode\");exports.Profiler=w(\"react.profiler\");q=w(\"react.provider\");r=w(\"react.context\");t=w(\"react.forward_ref\");exports.Suspense=w(\"react.suspense\");u=w(\"react.memo\");v=w(\"react.lazy\")}var x=\"function\"===typeof Symbol&&Symbol.iterator;\nfunction y(a){if(null===a||\"object\"!==typeof a)return null;a=x&&a[x]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}function z(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;c<arguments.length;c++)b+=\"&args[]=\"+encodeURIComponent(arguments[c]);return\"Minified React error #\"+a+\"; visit \"+b+\" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\"}\nvar A={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},B={};function C(a,b,c){this.props=a;this.context=b;this.refs=B;this.updater=c||A}C.prototype.isReactComponent={};C.prototype.setState=function(a,b){if(\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a)throw Error(z(85));this.updater.enqueueSetState(this,a,b,\"setState\")};C.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};\nfunction D(){}D.prototype=C.prototype;function E(a,b,c){this.props=a;this.context=b;this.refs=B;this.updater=c||A}var F=E.prototype=new D;F.constructor=E;l(F,C.prototype);F.isPureReactComponent=!0;var G={current:null},H=Object.prototype.hasOwnProperty,I={key:!0,ref:!0,__self:!0,__source:!0};\nfunction J(a,b,c){var e,d={},k=null,h=null;if(null!=b)for(e in void 0!==b.ref&&(h=b.ref),void 0!==b.key&&(k=\"\"+b.key),b)H.call(b,e)&&!I.hasOwnProperty(e)&&(d[e]=b[e]);var g=arguments.length-2;if(1===g)d.children=c;else if(1<g){for(var f=Array(g),m=0;m<g;m++)f[m]=arguments[m+2];d.children=f}if(a&&a.defaultProps)for(e in g=a.defaultProps,g)void 0===d[e]&&(d[e]=g[e]);return{$$typeof:n,type:a,key:k,ref:h,props:d,_owner:G.current}}\nfunction K(a,b){return{$$typeof:n,type:a.type,key:b,ref:a.ref,props:a.props,_owner:a._owner}}function L(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===n}function escape(a){var b={\"=\":\"=0\",\":\":\"=2\"};return\"$\"+a.replace(/[=:]/g,function(a){return b[a]})}var M=/\\/+/g;function N(a,b){return\"object\"===typeof a&&null!==a&&null!=a.key?escape(\"\"+a.key):b.toString(36)}\nfunction O(a,b,c,e,d){var k=typeof a;if(\"undefined\"===k||\"boolean\"===k)a=null;var h=!1;if(null===a)h=!0;else switch(k){case \"string\":case \"number\":h=!0;break;case \"object\":switch(a.$$typeof){case n:case p:h=!0}}if(h)return h=a,d=d(h),a=\"\"===e?\".\"+N(h,0):e,Array.isArray(d)?(c=\"\",null!=a&&(c=a.replace(M,\"$&/\")+\"/\"),O(d,b,c,\"\",function(a){return a})):null!=d&&(L(d)&&(d=K(d,c+(!d.key||h&&h.key===d.key?\"\":(\"\"+d.key).replace(M,\"$&/\")+\"/\")+a)),b.push(d)),1;h=0;e=\"\"===e?\".\":e+\":\";if(Array.isArray(a))for(var g=\n0;g<a.length;g++){k=a[g];var f=e+N(k,g);h+=O(k,b,c,f,d)}else if(f=y(a),\"function\"===typeof f)for(a=f.call(a),g=0;!(k=a.next()).done;)k=k.value,f=e+N(k,g++),h+=O(k,b,c,f,d);else if(\"object\"===k)throw b=\"\"+a,Error(z(31,\"[object Object]\"===b?\"object with keys {\"+Object.keys(a).join(\", \")+\"}\":b));return h}function P(a,b,c){if(null==a)return a;var e=[],d=0;O(a,e,\"\",\"\",function(a){return b.call(c,a,d++)});return e}\nfunction Q(a){if(-1===a._status){var b=a._result;b=b();a._status=0;a._result=b;b.then(function(b){0===a._status&&(b=b.default,a._status=1,a._result=b)},function(b){0===a._status&&(a._status=2,a._result=b)})}if(1===a._status)return a._result;throw a._result;}var R={current:null};function S(){var a=R.current;if(null===a)throw Error(z(321));return a}var T={ReactCurrentDispatcher:R,ReactCurrentBatchConfig:{transition:0},ReactCurrentOwner:G,IsSomeRendererActing:{current:!1},assign:l};\nexports.Children={map:P,forEach:function(a,b,c){P(a,function(){b.apply(this,arguments)},c)},count:function(a){var b=0;P(a,function(){b++});return b},toArray:function(a){return P(a,function(a){return a})||[]},only:function(a){if(!L(a))throw Error(z(143));return a}};exports.Component=C;exports.PureComponent=E;exports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=T;\nexports.cloneElement=function(a,b,c){if(null===a||void 0===a)throw Error(z(267,a));var e=l({},a.props),d=a.key,k=a.ref,h=a._owner;if(null!=b){void 0!==b.ref&&(k=b.ref,h=G.current);void 0!==b.key&&(d=\"\"+b.key);if(a.type&&a.type.defaultProps)var g=a.type.defaultProps;for(f in b)H.call(b,f)&&!I.hasOwnProperty(f)&&(e[f]=void 0===b[f]&&void 0!==g?g[f]:b[f])}var f=arguments.length-2;if(1===f)e.children=c;else if(1<f){g=Array(f);for(var m=0;m<f;m++)g[m]=arguments[m+2];e.children=g}return{$$typeof:n,type:a.type,\nkey:d,ref:k,props:e,_owner:h}};exports.createContext=function(a,b){void 0===b&&(b=null);a={$$typeof:r,_calculateChangedBits:b,_currentValue:a,_currentValue2:a,_threadCount:0,Provider:null,Consumer:null};a.Provider={$$typeof:q,_context:a};return a.Consumer=a};exports.createElement=J;exports.createFactory=function(a){var b=J.bind(null,a);b.type=a;return b};exports.createRef=function(){return{current:null}};exports.forwardRef=function(a){return{$$typeof:t,render:a}};exports.isValidElement=L;\nexports.lazy=function(a){return{$$typeof:v,_payload:{_status:-1,_result:a},_init:Q}};exports.memo=function(a,b){return{$$typeof:u,type:a,compare:void 0===b?null:b}};exports.useCallback=function(a,b){return S().useCallback(a,b)};exports.useContext=function(a,b){return S().useContext(a,b)};exports.useDebugValue=function(){};exports.useEffect=function(a,b){return S().useEffect(a,b)};exports.useImperativeHandle=function(a,b,c){return S().useImperativeHandle(a,b,c)};\nexports.useLayoutEffect=function(a,b){return S().useLayoutEffect(a,b)};exports.useMemo=function(a,b){return S().useMemo(a,b)};exports.useReducer=function(a,b,c){return S().useReducer(a,b,c)};exports.useRef=function(a){return S().useRef(a)};exports.useState=function(a){return S().useState(a)};exports.version=\"17.0.2\";\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react.production.min.js');\n} else {\n module.exports = require('./cjs/react.development.js');\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-jsx-runtime.production.min.js');\n} else {\n module.exports = require('./cjs/react-jsx-runtime.development.js');\n}\n","/** @license React v0.20.2\n * scheduler.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var f,g,h,k;if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}\nif(\"undefined\"===typeof window||\"function\"!==typeof MessageChannel){var t=null,u=null,w=function(){if(null!==t)try{var a=exports.unstable_now();t(!0,a);t=null}catch(b){throw setTimeout(w,0),b;}};f=function(a){null!==t?setTimeout(f,0,a):(t=a,setTimeout(w,0))};g=function(a,b){u=setTimeout(a,b)};h=function(){clearTimeout(u)};exports.unstable_shouldYield=function(){return!1};k=exports.unstable_forceFrameRate=function(){}}else{var x=window.setTimeout,y=window.clearTimeout;if(\"undefined\"!==typeof console){var z=\nwindow.cancelAnimationFrame;\"function\"!==typeof window.requestAnimationFrame&&console.error(\"This browser doesn't support requestAnimationFrame. Make sure that you load a polyfill in older browsers. https://reactjs.org/link/react-polyfills\");\"function\"!==typeof z&&console.error(\"This browser doesn't support cancelAnimationFrame. Make sure that you load a polyfill in older browsers. https://reactjs.org/link/react-polyfills\")}var A=!1,B=null,C=-1,D=5,E=0;exports.unstable_shouldYield=function(){return exports.unstable_now()>=\nE};k=function(){};exports.unstable_forceFrameRate=function(a){0>a||125<a?console.error(\"forceFrameRate takes a positive int between 0 and 125, forcing frame rates higher than 125 fps is not supported\"):D=0<a?Math.floor(1E3/a):5};var F=new MessageChannel,G=F.port2;F.port1.onmessage=function(){if(null!==B){var a=exports.unstable_now();E=a+D;try{B(!0,a)?G.postMessage(null):(A=!1,B=null)}catch(b){throw G.postMessage(null),b;}}else A=!1};f=function(a){B=a;A||(A=!0,G.postMessage(null))};g=function(a,b){C=\nx(function(){a(exports.unstable_now())},b)};h=function(){y(C);C=-1}}function H(a,b){var c=a.length;a.push(b);a:for(;;){var d=c-1>>>1,e=a[d];if(void 0!==e&&0<I(e,b))a[d]=b,a[c]=e,c=d;else break a}}function J(a){a=a[0];return void 0===a?null:a}\nfunction K(a){var b=a[0];if(void 0!==b){var c=a.pop();if(c!==b){a[0]=c;a:for(var d=0,e=a.length;d<e;){var m=2*(d+1)-1,n=a[m],v=m+1,r=a[v];if(void 0!==n&&0>I(n,c))void 0!==r&&0>I(r,n)?(a[d]=r,a[v]=c,d=v):(a[d]=n,a[m]=c,d=m);else if(void 0!==r&&0>I(r,c))a[d]=r,a[v]=c,d=v;else break a}}return b}return null}function I(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}var L=[],M=[],N=1,O=null,P=3,Q=!1,R=!1,S=!1;\nfunction T(a){for(var b=J(M);null!==b;){if(null===b.callback)K(M);else if(b.startTime<=a)K(M),b.sortIndex=b.expirationTime,H(L,b);else break;b=J(M)}}function U(a){S=!1;T(a);if(!R)if(null!==J(L))R=!0,f(V);else{var b=J(M);null!==b&&g(U,b.startTime-a)}}\nfunction V(a,b){R=!1;S&&(S=!1,h());Q=!0;var c=P;try{T(b);for(O=J(L);null!==O&&(!(O.expirationTime>b)||a&&!exports.unstable_shouldYield());){var d=O.callback;if(\"function\"===typeof d){O.callback=null;P=O.priorityLevel;var e=d(O.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?O.callback=e:O===J(L)&&K(L);T(b)}else K(L);O=J(L)}if(null!==O)var m=!0;else{var n=J(M);null!==n&&g(U,n.startTime-b);m=!1}return m}finally{O=null,P=c,Q=!1}}var W=k;exports.unstable_IdlePriority=5;\nexports.unstable_ImmediatePriority=1;exports.unstable_LowPriority=4;exports.unstable_NormalPriority=3;exports.unstable_Profiling=null;exports.unstable_UserBlockingPriority=2;exports.unstable_cancelCallback=function(a){a.callback=null};exports.unstable_continueExecution=function(){R||Q||(R=!0,f(V))};exports.unstable_getCurrentPriorityLevel=function(){return P};exports.unstable_getFirstCallbackNode=function(){return J(L)};\nexports.unstable_next=function(a){switch(P){case 1:case 2:case 3:var b=3;break;default:b=P}var c=P;P=b;try{return a()}finally{P=c}};exports.unstable_pauseExecution=function(){};exports.unstable_requestPaint=W;exports.unstable_runWithPriority=function(a,b){switch(a){case 1:case 2:case 3:case 4:case 5:break;default:a=3}var c=P;P=a;try{return b()}finally{P=c}};\nexports.unstable_scheduleCallback=function(a,b,c){var d=exports.unstable_now();\"object\"===typeof c&&null!==c?(c=c.delay,c=\"number\"===typeof c&&0<c?d+c:d):c=d;switch(a){case 1:var e=-1;break;case 2:e=250;break;case 5:e=1073741823;break;case 4:e=1E4;break;default:e=5E3}e=c+e;a={id:N++,callback:b,priorityLevel:a,startTime:c,expirationTime:e,sortIndex:-1};c>d?(a.sortIndex=c,H(M,a),null===J(L)&&a===J(M)&&(S?h():S=!0,g(U,c-d))):(a.sortIndex=e,H(L,a),R||Q||(R=!0,f(V)));return a};\nexports.unstable_wrapCallback=function(a){var b=P;return function(){var c=P;P=b;try{return a.apply(this,arguments)}finally{P=c}}};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","var unitlessKeys = {\n animationIterationCount: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\n\nexport default unitlessKeys;\n","var safeIsNaN = Number.isNaN ||\n function ponyfill(value) {\n return typeof value === 'number' && value !== value;\n };\nfunction isEqual(first, second) {\n if (first === second) {\n return true;\n }\n if (safeIsNaN(first) && safeIsNaN(second)) {\n return true;\n }\n return false;\n}\nfunction areInputsEqual(newInputs, lastInputs) {\n if (newInputs.length !== lastInputs.length) {\n return false;\n }\n for (var i = 0; i < newInputs.length; i++) {\n if (!isEqual(newInputs[i], lastInputs[i])) {\n return false;\n }\n }\n return true;\n}\n\nfunction memoizeOne(resultFn, isEqual) {\n if (isEqual === void 0) { isEqual = areInputsEqual; }\n var lastThis;\n var lastArgs = [];\n var lastResult;\n var calledOnce = false;\n function memoized() {\n var newArgs = [];\n for (var _i = 0; _i < arguments.length; _i++) {\n newArgs[_i] = arguments[_i];\n }\n if (calledOnce && lastThis === this && isEqual(newArgs, lastArgs)) {\n return lastResult;\n }\n lastResult = resultFn.apply(this, newArgs);\n calledOnce = true;\n lastThis = this;\n lastArgs = newArgs;\n return lastResult;\n }\n return memoized;\n}\n\nexport default memoizeOne;\n","import memoize from '@emotion/memoize';\n\nvar reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|download|draggable|encType|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|inert|itemProp|itemScope|itemType|itemID|itemRef|on|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; // https://esbench.com/bench/5bfee68a4cd7e6009ef61d23\n\nvar index = memoize(function (prop) {\n return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111\n /* o */\n && prop.charCodeAt(1) === 110\n /* n */\n && prop.charCodeAt(2) < 91;\n}\n/* Z+1 */\n);\n\nexport default index;\n","function memoize(fn) {\n var cache = {};\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport default memoize;\n","/**\r\n * Returns the object type of the given payload\r\n *\r\n * @param {*} payload\r\n * @returns {string}\r\n */\r\nfunction getType(payload) {\r\n return Object.prototype.toString.call(payload).slice(8, -1);\r\n}\r\n/**\r\n * Returns whether the payload is undefined\r\n *\r\n * @param {*} payload\r\n * @returns {payload is undefined}\r\n */\r\nfunction isUndefined(payload) {\r\n return getType(payload) === 'Undefined';\r\n}\r\n/**\r\n * Returns whether the payload is null\r\n *\r\n * @param {*} payload\r\n * @returns {payload is null}\r\n */\r\nfunction isNull(payload) {\r\n return getType(payload) === 'Null';\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is PlainObject}\r\n */\r\nfunction isPlainObject(payload) {\r\n if (getType(payload) !== 'Object')\r\n return false;\r\n return payload.constructor === Object && Object.getPrototypeOf(payload) === Object.prototype;\r\n}\r\n/**\r\n * Returns whether the payload is a plain JavaScript object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is PlainObject}\r\n */\r\nfunction isObject(payload) {\r\n return isPlainObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a an empty object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is { [K in any]: never }}\r\n */\r\nfunction isEmptyObject(payload) {\r\n return isPlainObject(payload) && Object.keys(payload).length === 0;\r\n}\r\n/**\r\n * Returns whether the payload is a an empty object (excluding special classes or objects with other prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is PlainObject}\r\n */\r\nfunction isFullObject(payload) {\r\n return isPlainObject(payload) && Object.keys(payload).length > 0;\r\n}\r\n/**\r\n * Returns whether the payload is an any kind of object (including special classes or objects with different prototypes)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is PlainObject}\r\n */\r\nfunction isAnyObject(payload) {\r\n return getType(payload) === 'Object';\r\n}\r\n/**\r\n * Returns whether the payload is an object like a type passed in < >\r\n *\r\n * Usage: isObjectLike<{id: any}>(payload) // will make sure it's an object and has an `id` prop.\r\n *\r\n * @template T this must be passed in < >\r\n * @param {*} payload\r\n * @returns {payload is T}\r\n */\r\nfunction isObjectLike(payload) {\r\n return isAnyObject(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a function (regular or async)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is AnyFunction}\r\n */\r\nfunction isFunction(payload) {\r\n return typeof payload === 'function';\r\n}\r\n/**\r\n * Returns whether the payload is an array\r\n *\r\n * @param {any} payload\r\n * @returns {payload is any[]}\r\n */\r\nfunction isArray(payload) {\r\n return getType(payload) === 'Array';\r\n}\r\n/**\r\n * Returns whether the payload is a an array with at least 1 item\r\n *\r\n * @param {*} payload\r\n * @returns {payload is any[]}\r\n */\r\nfunction isFullArray(payload) {\r\n return isArray(payload) && payload.length > 0;\r\n}\r\n/**\r\n * Returns whether the payload is a an empty array\r\n *\r\n * @param {*} payload\r\n * @returns {payload is []}\r\n */\r\nfunction isEmptyArray(payload) {\r\n return isArray(payload) && payload.length === 0;\r\n}\r\n/**\r\n * Returns whether the payload is a string\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isString(payload) {\r\n return getType(payload) === 'String';\r\n}\r\n/**\r\n * Returns whether the payload is a string, BUT returns false for ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isFullString(payload) {\r\n return isString(payload) && payload !== '';\r\n}\r\n/**\r\n * Returns whether the payload is ''\r\n *\r\n * @param {*} payload\r\n * @returns {payload is string}\r\n */\r\nfunction isEmptyString(payload) {\r\n return payload === '';\r\n}\r\n/**\r\n * Returns whether the payload is a number (but not NaN)\r\n *\r\n * This will return `false` for `NaN`!!\r\n *\r\n * @param {*} payload\r\n * @returns {payload is number}\r\n */\r\nfunction isNumber(payload) {\r\n return getType(payload) === 'Number' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a boolean\r\n *\r\n * @param {*} payload\r\n * @returns {payload is boolean}\r\n */\r\nfunction isBoolean(payload) {\r\n return getType(payload) === 'Boolean';\r\n}\r\n/**\r\n * Returns whether the payload is a regular expression (RegExp)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is RegExp}\r\n */\r\nfunction isRegExp(payload) {\r\n return getType(payload) === 'RegExp';\r\n}\r\n/**\r\n * Returns whether the payload is a Map\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Map<any, any>}\r\n */\r\nfunction isMap(payload) {\r\n return getType(payload) === 'Map';\r\n}\r\n/**\r\n * Returns whether the payload is a WeakMap\r\n *\r\n * @param {*} payload\r\n * @returns {payload is WeakMap<any, any>}\r\n */\r\nfunction isWeakMap(payload) {\r\n return getType(payload) === 'WeakMap';\r\n}\r\n/**\r\n * Returns whether the payload is a Set\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Set<any>}\r\n */\r\nfunction isSet(payload) {\r\n return getType(payload) === 'Set';\r\n}\r\n/**\r\n * Returns whether the payload is a WeakSet\r\n *\r\n * @param {*} payload\r\n * @returns {payload is WeakSet<any>}\r\n */\r\nfunction isWeakSet(payload) {\r\n return getType(payload) === 'WeakSet';\r\n}\r\n/**\r\n * Returns whether the payload is a Symbol\r\n *\r\n * @param {*} payload\r\n * @returns {payload is symbol}\r\n */\r\nfunction isSymbol(payload) {\r\n return getType(payload) === 'Symbol';\r\n}\r\n/**\r\n * Returns whether the payload is a Date, and that the date is valid\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Date}\r\n */\r\nfunction isDate(payload) {\r\n return getType(payload) === 'Date' && !isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a Blob\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Blob}\r\n */\r\nfunction isBlob(payload) {\r\n return getType(payload) === 'Blob';\r\n}\r\n/**\r\n * Returns whether the payload is a File\r\n *\r\n * @param {*} payload\r\n * @returns {payload is File}\r\n */\r\nfunction isFile(payload) {\r\n return getType(payload) === 'File';\r\n}\r\n/**\r\n * Returns whether the payload is a Promise\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Promise<any>}\r\n */\r\nfunction isPromise(payload) {\r\n return getType(payload) === 'Promise';\r\n}\r\n/**\r\n * Returns whether the payload is an Error\r\n *\r\n * @param {*} payload\r\n * @returns {payload is Error}\r\n */\r\nfunction isError(payload) {\r\n return getType(payload) === 'Error';\r\n}\r\n/**\r\n * Returns whether the payload is literally the value `NaN` (it's `NaN` and also a `number`)\r\n *\r\n * @param {*} payload\r\n * @returns {payload is typeof NaN}\r\n */\r\nfunction isNaNValue(payload) {\r\n return getType(payload) === 'Number' && isNaN(payload);\r\n}\r\n/**\r\n * Returns whether the payload is a primitive type (eg. Boolean | Null | Undefined | Number | String | Symbol)\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is boolean | null | undefined | number | string | symbol)}\r\n */\r\nfunction isPrimitive(payload) {\r\n return (isBoolean(payload) ||\r\n isNull(payload) ||\r\n isUndefined(payload) ||\r\n isNumber(payload) ||\r\n isString(payload) ||\r\n isSymbol(payload));\r\n}\r\n/**\r\n * Returns true whether the payload is null or undefined\r\n *\r\n * @param {*} payload\r\n * @returns {(payload is null | undefined)}\r\n */\r\nvar isNullOrUndefined = isOneOf(isNull, isUndefined);\r\nfunction isOneOf(a, b, c, d, e) {\r\n return function (value) {\r\n return a(value) || b(value) || (!!c && c(value)) || (!!d && d(value)) || (!!e && e(value));\r\n };\r\n}\r\n/**\r\n * Does a generic check to check that the given payload is of a given type.\r\n * In cases like Number, it will return true for NaN as NaN is a Number (thanks javascript!);\r\n * It will, however, differentiate between object and null\r\n *\r\n * @template T\r\n * @param {*} payload\r\n * @param {T} type\r\n * @throws {TypeError} Will throw type error if type is an invalid type\r\n * @returns {payload is T}\r\n */\r\nfunction isType(payload, type) {\r\n if (!(type instanceof Function)) {\r\n throw new TypeError('Type must be a function');\r\n }\r\n if (!Object.prototype.hasOwnProperty.call(type, 'prototype')) {\r\n throw new TypeError('Type is not a class');\r\n }\r\n // Classes usually have names (as functions usually have names)\r\n var name = type.name;\r\n return getType(payload) === name || Boolean(payload && payload.constructor === type);\r\n}\n\nexport { getType, isAnyObject, isArray, isBlob, isBoolean, isDate, isEmptyArray, isEmptyObject, isEmptyString, isError, isFile, isFullArray, isFullObject, isFullString, isFunction, isMap, isNaNValue, isNull, isNullOrUndefined, isNumber, isObject, isObjectLike, isOneOf, isPlainObject, isPrimitive, isPromise, isRegExp, isSet, isString, isSymbol, isType, isUndefined, isWeakMap, isWeakSet };\n","import { isPlainObject, isArray, isSymbol } from 'is-what';\n\n/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n\r\nfunction __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\n\nfunction assignProp(carry, key, newVal, originalObject) {\r\n var propType = originalObject.propertyIsEnumerable(key)\r\n ? 'enumerable'\r\n : 'nonenumerable';\r\n if (propType === 'enumerable')\r\n carry[key] = newVal;\r\n if (propType === 'nonenumerable') {\r\n Object.defineProperty(carry, key, {\r\n value: newVal,\r\n enumerable: false,\r\n writable: true,\r\n configurable: true\r\n });\r\n }\r\n}\r\nfunction mergeRecursively(origin, newComer, extensions) {\r\n // work directly on newComer if its not an object\r\n if (!isPlainObject(newComer)) {\r\n // extend merge rules\r\n if (extensions && isArray(extensions)) {\r\n extensions.forEach(function (extend) {\r\n newComer = extend(origin, newComer);\r\n });\r\n }\r\n return newComer;\r\n }\r\n // define newObject to merge all values upon\r\n var newObject = {};\r\n if (isPlainObject(origin)) {\r\n var props_1 = Object.getOwnPropertyNames(origin);\r\n var symbols_1 = Object.getOwnPropertySymbols(origin);\r\n newObject = __spreadArrays(props_1, symbols_1).reduce(function (carry, key) {\r\n // @ts-ignore\r\n var targetVal = origin[key];\r\n if ((!isSymbol(key) && !Object.getOwnPropertyNames(newComer).includes(key)) ||\r\n (isSymbol(key) && !Object.getOwnPropertySymbols(newComer).includes(key))) {\r\n assignProp(carry, key, targetVal, origin);\r\n }\r\n return carry;\r\n }, {});\r\n }\r\n var props = Object.getOwnPropertyNames(newComer);\r\n var symbols = Object.getOwnPropertySymbols(newComer);\r\n var result = __spreadArrays(props, symbols).reduce(function (carry, key) {\r\n // re-define the origin and newComer as targetVal and newVal\r\n var newVal = newComer[key];\r\n var targetVal = (isPlainObject(origin))\r\n // @ts-ignore\r\n ? origin[key]\r\n : undefined;\r\n // extend merge rules\r\n if (extensions && isArray(extensions)) {\r\n extensions.forEach(function (extend) {\r\n newVal = extend(targetVal, newVal);\r\n });\r\n }\r\n // When newVal is an object do the merge recursively\r\n if (targetVal !== undefined && isPlainObject(newVal)) {\r\n newVal = mergeRecursively(targetVal, newVal, extensions);\r\n }\r\n assignProp(carry, key, newVal, newComer);\r\n return carry;\r\n }, newObject);\r\n return result;\r\n}\r\n/**\r\n * Merge anything recursively.\r\n * Objects get merged, special objects (classes etc.) are re-assigned \"as is\".\r\n * Basic types overwrite objects or other basic types.\r\n *\r\n * @param {(IConfig | any)} origin\r\n * @param {...any[]} newComers\r\n * @returns the result\r\n */\r\nfunction merge(origin) {\r\n var newComers = [];\r\n for (var _i = 1; _i < arguments.length; _i++) {\r\n newComers[_i - 1] = arguments[_i];\r\n }\r\n var extensions = null;\r\n var base = origin;\r\n if (isPlainObject(origin) && origin.extensions && Object.keys(origin).length === 1) {\r\n base = {};\r\n extensions = origin.extensions;\r\n }\r\n return newComers.reduce(function (result, newComer) {\r\n return mergeRecursively(result, newComer, extensions);\r\n }, base);\r\n}\n\nfunction concatArrays(originVal, newVal) {\r\n if (isArray(originVal) && isArray(newVal)) {\r\n // concat logic\r\n return originVal.concat(newVal);\r\n }\r\n return newVal; // always return newVal as fallback!!\r\n}\n\nexport default merge;\nexport { concatArrays, merge };\n","// @flow\n/* eslint-disable flowtype/object-type-delimiter */\n/* eslint-disable react/prop-types */\n\nimport React, { type Element } from 'react';\nimport { IS_BROWSER, DISABLE_SPEEDY, SC_ATTR, SC_VERSION_ATTR } from '../constants';\nimport StyledError from '../utils/error';\nimport { type ExtractedComp } from '../utils/extractCompsFromCSS';\nimport { splitByRules } from '../utils/stringifyRules';\nimport getNonce from '../utils/nonce';\n\nimport {\n type Names,\n addNameForId,\n resetIdNames,\n hasNameForId,\n stringifyNames,\n cloneNames,\n} from '../utils/styleNames';\n\nimport { sheetForTag, safeInsertRule, deleteRules } from '../utils/insertRuleHelpers';\n\ndeclare var __VERSION__: string;\n\nexport interface Tag<T> {\n // $FlowFixMe: Doesn't seem to accept any combination w/ HTMLStyleElement for some reason\n styleTag: HTMLStyleElement | null;\n /* lists all ids of the tag */\n getIds(): string[];\n /* checks whether `name` is already injected for `id` */\n hasNameForId(id: string, name: string): boolean;\n /* inserts a marker to ensure the id's correct position in the sheet */\n insertMarker(id: string): T;\n /* inserts rules according to the ids markers */\n insertRules(id: string, cssRules: string[], name: ?string): void;\n /* removes all rules belonging to the id, keeping the marker around */\n removeRules(id: string): void;\n css(): string;\n toHTML(additionalAttrs: ?string): string;\n toElement(): Element<*>;\n clone(): Tag<T>;\n /* used in server side rendering to indicate that the rules in the tag have been flushed to HTML */\n sealed: boolean;\n}\n\n/* this marker separates component styles and is important for rehydration */\nconst makeTextMarker = id => `\\n/* sc-component-id: ${id} */\\n`;\n\n/* add up all numbers in array up until and including the index */\nconst addUpUntilIndex = (sizes: number[], index: number): number => {\n let totalUpToIndex = 0;\n for (let i = 0; i <= index; i += 1) {\n totalUpToIndex += sizes[i];\n }\n\n return totalUpToIndex;\n};\n\n/* create a new style tag after lastEl */\nconst makeStyleTag = (target: ?HTMLElement, tagEl: ?Node, insertBefore: ?boolean) => {\n let targetDocument = document;\n if(target) targetDocument = target.ownerDocument;\n else if(tagEl) targetDocument = tagEl.ownerDocument;\n\n const el = targetDocument.createElement('style');\n el.setAttribute(SC_ATTR, '');\n el.setAttribute(SC_VERSION_ATTR, __VERSION__);\n\n const nonce = getNonce();\n if (nonce) {\n el.setAttribute('nonce', nonce);\n }\n\n /* Work around insertRule quirk in EdgeHTML */\n el.appendChild(targetDocument.createTextNode(''));\n\n if (target && !tagEl) {\n /* Append to target when no previous element was passed */\n target.appendChild(el);\n } else {\n if (!tagEl || !target || !tagEl.parentNode) {\n throw new StyledError(6);\n }\n\n /* Insert new style tag after the previous one */\n tagEl.parentNode.insertBefore(el, insertBefore ? tagEl : tagEl.nextSibling);\n }\n\n return el;\n};\n\n/* takes a css factory function and outputs an html styled tag factory */\nconst wrapAsHtmlTag = (css: () => string, names: Names) => (additionalAttrs: ?string): string => {\n const nonce = getNonce();\n const attrs = [\n nonce && `nonce=\"${nonce}\"`,\n `${SC_ATTR}=\"${stringifyNames(names)}\"`,\n `${SC_VERSION_ATTR}=\"${__VERSION__}\"`,\n additionalAttrs,\n ];\n\n const htmlAttr = attrs.filter(Boolean).join(' ');\n return `<style ${htmlAttr}>${css()}</style>`;\n};\n\n/* takes a css factory function and outputs an element factory */\nconst wrapAsElement = (css: () => string, names: Names) => () => {\n const props = {\n [SC_ATTR]: stringifyNames(names),\n [SC_VERSION_ATTR]: __VERSION__,\n };\n\n const nonce = getNonce();\n if (nonce) {\n // $FlowFixMe\n props.nonce = nonce;\n }\n\n // eslint-disable-next-line react/no-danger\n return <style {...props} dangerouslySetInnerHTML={{ __html: css() }} />;\n};\n\nconst getIdsFromMarkersFactory = (markers: Object) => (): string[] => Object.keys(markers);\n\n/* speedy tags utilise insertRule */\nconst makeSpeedyTag = (el: HTMLStyleElement, getImportRuleTag: ?() => Tag<any>): Tag<number> => {\n const names: Names = (Object.create(null): Object);\n const markers = Object.create(null);\n const sizes: number[] = [];\n\n const extractImport = getImportRuleTag !== undefined;\n /* indicates whether getImportRuleTag was called */\n let usedImportRuleTag = false;\n\n const insertMarker = id => {\n const prev = markers[id];\n if (prev !== undefined) {\n return prev;\n }\n\n markers[id] = sizes.length;\n sizes.push(0);\n resetIdNames(names, id);\n\n return markers[id];\n };\n\n const insertRules = (id, cssRules, name) => {\n const marker = insertMarker(id);\n const sheet = sheetForTag(el);\n const insertIndex = addUpUntilIndex(sizes, marker);\n\n let injectedRules = 0;\n const importRules = [];\n const cssRulesSize = cssRules.length;\n\n for (let i = 0; i < cssRulesSize; i += 1) {\n const cssRule = cssRules[i];\n let mayHaveImport = extractImport; /* @import rules are reordered to appear first */\n if (mayHaveImport && cssRule.indexOf('@import') !== -1) {\n importRules.push(cssRule);\n } else if (safeInsertRule(sheet, cssRule, insertIndex + injectedRules)) {\n mayHaveImport = false;\n injectedRules += 1;\n }\n }\n\n if (extractImport && importRules.length > 0) {\n usedImportRuleTag = true;\n // $FlowFixMe\n getImportRuleTag().insertRules(`${id}-import`, importRules);\n }\n\n sizes[marker] += injectedRules; /* add up no of injected rules */\n addNameForId(names, id, name);\n };\n\n const removeRules = id => {\n const marker = markers[id];\n if (marker === undefined) return;\n // $FlowFixMe\n if (el.isConnected === false) return;\n\n const size = sizes[marker];\n const sheet = sheetForTag(el);\n const removalIndex = addUpUntilIndex(sizes, marker) - 1;\n deleteRules(sheet, removalIndex, size);\n sizes[marker] = 0;\n resetIdNames(names, id);\n\n if (extractImport && usedImportRuleTag) {\n // $FlowFixMe\n getImportRuleTag().removeRules(`${id}-import`);\n }\n };\n\n const css = () => {\n const { cssRules } = sheetForTag(el);\n let str = '';\n\n // eslint-disable-next-line guard-for-in\n for (const id in markers) {\n str += makeTextMarker(id);\n const marker = markers[id];\n const end = addUpUntilIndex(sizes, marker);\n const size = sizes[marker];\n for (let i = end - size; i < end; i += 1) {\n const rule = cssRules[i];\n if (rule !== undefined) {\n str += rule.cssText;\n }\n }\n }\n\n return str;\n };\n\n return {\n clone() {\n throw new StyledError(5);\n },\n css,\n getIds: getIdsFromMarkersFactory(markers),\n hasNameForId: hasNameForId(names),\n insertMarker,\n insertRules,\n removeRules,\n sealed: false,\n styleTag: el,\n toElement: wrapAsElement(css, names),\n toHTML: wrapAsHtmlTag(css, names),\n };\n};\n\nconst makeTextNode = (targetDocument, id) => targetDocument.createTextNode(makeTextMarker(id));\n\nconst makeBrowserTag = (el: HTMLStyleElement, getImportRuleTag: ?() => Tag<any>): Tag<Text> => {\n const names = (Object.create(null): Object);\n const markers = Object.create(null);\n\n const extractImport = getImportRuleTag !== undefined;\n\n /* indicates whether getImportRuleTag was called */\n let usedImportRuleTag = false;\n\n const insertMarker = id => {\n const prev = markers[id];\n if (prev !== undefined) {\n return prev;\n }\n\n markers[id] = makeTextNode(el.ownerDocument, id);\n el.appendChild(markers[id]);\n names[id] = Object.create(null);\n\n return markers[id];\n };\n\n const insertRules = (id, cssRules, name) => {\n const marker = insertMarker(id);\n const importRules = [];\n const cssRulesSize = cssRules.length;\n\n for (let i = 0; i < cssRulesSize; i += 1) {\n const rule = cssRules[i];\n let mayHaveImport = extractImport;\n if (mayHaveImport && rule.indexOf('@import') !== -1) {\n importRules.push(rule);\n } else {\n mayHaveImport = false;\n const separator = i === cssRulesSize - 1 ? '' : ' ';\n marker.appendData(`${rule}${separator}`);\n }\n }\n\n addNameForId(names, id, name);\n\n if (extractImport && importRules.length > 0) {\n usedImportRuleTag = true;\n // $FlowFixMe\n getImportRuleTag().insertRules(`${id}-import`, importRules);\n }\n };\n\n const removeRules = id => {\n const marker = markers[id];\n if (marker === undefined) return;\n\n /* create new empty text node and replace the current one */\n const newMarker = makeTextNode(el.ownerDocument, id);\n el.replaceChild(newMarker, marker);\n markers[id] = newMarker;\n resetIdNames(names, id);\n\n if (extractImport && usedImportRuleTag) {\n // $FlowFixMe\n getImportRuleTag().removeRules(`${id}-import`);\n }\n };\n\n const css = () => {\n let str = '';\n\n // eslint-disable-next-line guard-for-in\n for (const id in markers) {\n str += markers[id].data;\n }\n\n return str;\n };\n\n return {\n clone() {\n throw new StyledError(5);\n },\n css,\n getIds: getIdsFromMarkersFactory(markers),\n hasNameForId: hasNameForId(names),\n insertMarker,\n insertRules,\n removeRules,\n sealed: false,\n styleTag: el,\n toElement: wrapAsElement(css, names),\n toHTML: wrapAsHtmlTag(css, names),\n };\n};\n\nconst makeServerTag = (namesArg, markersArg): Tag<[string]> => {\n const names = namesArg === undefined ? (Object.create(null): Object) : namesArg;\n const markers = markersArg === undefined ? Object.create(null) : markersArg;\n\n const insertMarker = id => {\n const prev = markers[id];\n if (prev !== undefined) {\n return prev;\n }\n\n return (markers[id] = ['']);\n };\n\n const insertRules = (id, cssRules, name) => {\n const marker = insertMarker(id);\n marker[0] += cssRules.join(' ');\n addNameForId(names, id, name);\n };\n\n const removeRules = id => {\n const marker = markers[id];\n if (marker === undefined) return;\n marker[0] = '';\n resetIdNames(names, id);\n };\n\n const css = () => {\n let str = '';\n // eslint-disable-next-line guard-for-in\n for (const id in markers) {\n const cssForId = markers[id][0];\n if (cssForId) {\n str += makeTextMarker(id) + cssForId;\n }\n }\n return str;\n };\n\n const clone = () => {\n const namesClone = cloneNames(names);\n const markersClone = Object.create(null);\n\n // eslint-disable-next-line guard-for-in\n for (const id in markers) {\n markersClone[id] = [markers[id][0]];\n }\n\n return makeServerTag(namesClone, markersClone);\n };\n\n const tag = {\n clone,\n css,\n getIds: getIdsFromMarkersFactory(markers),\n hasNameForId: hasNameForId(names),\n insertMarker,\n insertRules,\n removeRules,\n sealed: false,\n styleTag: null,\n toElement: wrapAsElement(css, names),\n toHTML: wrapAsHtmlTag(css, names),\n };\n\n return tag;\n};\n\nexport const makeTag = (\n target: ?HTMLElement,\n tagEl: ?HTMLStyleElement,\n forceServer?: boolean,\n insertBefore?: boolean,\n getImportRuleTag?: () => Tag<any>\n): Tag<any> => {\n if (IS_BROWSER && !forceServer) {\n const el = makeStyleTag(target, tagEl, insertBefore);\n\n if (DISABLE_SPEEDY) {\n return makeBrowserTag(el, getImportRuleTag);\n } else {\n return makeSpeedyTag(el, getImportRuleTag);\n }\n }\n\n return makeServerTag();\n};\n\nexport const rehydrate = (\n tag: Tag<any>,\n els: HTMLStyleElement[],\n extracted: ExtractedComp[]\n): void => {\n /* add all extracted components to the new tag */\n for (let i = 0, len = extracted.length; i < len; i += 1) {\n const { componentId, cssFromDOM } = extracted[i];\n const cssRules = splitByRules(cssFromDOM);\n tag.insertRules(componentId, cssRules);\n }\n\n /* remove old HTMLStyleElements, since they have been rehydrated */\n for (let i = 0, len = els.length; i < len; i += 1) {\n const el = els[i];\n if (el.parentNode) {\n el.parentNode.removeChild(el);\n }\n }\n};\n","// @flow\nimport React, { createContext, Component, type Element } from 'react';\nimport memoize from 'memoize-one';\nimport StyledError from '../utils/error';\nimport isFunction from '../utils/isFunction';\n\nexport type Theme = { [key: string]: mixed };\n\ntype Props = {\n children?: Element<any>,\n theme: Theme | ((outerTheme: Theme) => void),\n};\n\nexport const ThemeContext = createContext();\n\nexport const ThemeConsumer = ThemeContext.Consumer;\n\n/**\n * Provide a theme to an entire react component tree via context\n */\nexport default class ThemeProvider extends Component<Props> {\n getContext: (theme: Theme | ((outerTheme: Theme) => void), outerTheme?: Theme) => Theme;\n\n renderInner: Function;\n\n constructor(props: Props) {\n super(props);\n this.getContext = memoize(this.getContext.bind(this));\n this.renderInner = this.renderInner.bind(this);\n }\n\n render() {\n if (!this.props.children) return null;\n\n return <ThemeContext.Consumer>{this.renderInner}</ThemeContext.Consumer>;\n }\n\n renderInner(outerTheme?: Theme) {\n const context = this.getContext(this.props.theme, outerTheme);\n\n return (\n <ThemeContext.Provider value={context}>\n {this.props.children}\n </ThemeContext.Provider>\n );\n }\n\n /**\n * Get the theme from the props, supporting both (outerTheme) => {}\n * as well as object notation\n */\n getTheme(theme: (outerTheme: ?Theme) => void, outerTheme: ?Theme) {\n if (isFunction(theme)) {\n const mergedTheme = theme(outerTheme);\n\n if (\n process.env.NODE_ENV !== 'production' &&\n (mergedTheme === null || Array.isArray(mergedTheme) || typeof mergedTheme !== 'object')\n ) {\n throw new StyledError(7);\n }\n\n return mergedTheme;\n }\n\n if (theme === null || Array.isArray(theme) || typeof theme !== 'object') {\n throw new StyledError(8);\n }\n\n return { ...outerTheme, ...theme };\n }\n\n getContext(theme: (outerTheme: ?Theme) => void, outerTheme?: Theme) {\n return this.getTheme(theme, outerTheme);\n }\n}\n","// @flow\nimport { EMPTY_ARRAY } from '../utils/empties';\nimport flatten from '../utils/flatten';\nimport isStaticRules from '../utils/isStaticRules';\nimport stringifyRules from '../utils/stringifyRules';\nimport StyleSheet from './StyleSheet';\n\nimport type { RuleSet } from '../types';\n\nexport default class GlobalStyle {\n componentId: string;\n\n isStatic: boolean;\n\n rules: RuleSet;\n\n constructor(rules: RuleSet, componentId: string) {\n this.rules = rules;\n this.componentId = componentId;\n this.isStatic = isStaticRules(rules, EMPTY_ARRAY);\n\n if (!StyleSheet.master.hasId(componentId)) {\n StyleSheet.master.deferredInject(componentId, []);\n }\n }\n\n createStyles(executionContext: Object, styleSheet: StyleSheet) {\n const flatCSS = flatten(this.rules, executionContext, styleSheet);\n const css = stringifyRules(flatCSS, '');\n\n styleSheet.inject(this.componentId, css);\n }\n\n removeStyles(styleSheet: StyleSheet) {\n const { componentId } = this;\n if (styleSheet.hasId(componentId)) {\n styleSheet.remove(componentId);\n }\n }\n\n // TODO: overwrite in-place instead of remove+create?\n renderStyles(executionContext: Object, styleSheet: StyleSheet) {\n this.removeStyles(styleSheet);\n this.createStyles(executionContext, styleSheet);\n }\n}\n","(function (factory) {\n\ttypeof exports === 'object' && typeof module !== 'undefined' ? (module['exports'] = factory()) :\n\t\ttypeof define === 'function' && define['amd'] ? define(factory()) :\n\t\t\t(window['stylisRuleSheet'] = factory())\n}(function () {\n\n\t'use strict'\n\n\treturn function (insertRule) {\n\t\tvar delimiter = '/*|*/'\n\t\tvar needle = delimiter+'}'\n\n\t\tfunction toSheet (block) {\n\t\t\tif (block)\n\t\t\t\ttry {\n\t\t\t\t\tinsertRule(block + '}')\n\t\t\t\t} catch (e) {}\n\t\t}\n\n\t\treturn function ruleSheet (context, content, selectors, parents, line, column, length, ns, depth, at) {\n\t\t\tswitch (context) {\n\t\t\t\t// property\n\t\t\t\tcase 1:\n\t\t\t\t\t// @import\n\t\t\t\t\tif (depth === 0 && content.charCodeAt(0) === 64)\n\t\t\t\t\t\treturn insertRule(content+';'), ''\n\t\t\t\t\tbreak\n\t\t\t\t// selector\n\t\t\t\tcase 2:\n\t\t\t\t\tif (ns === 0)\n\t\t\t\t\t\treturn content + delimiter\n\t\t\t\t\tbreak\n\t\t\t\t// at-rule\n\t\t\t\tcase 3:\n\t\t\t\t\tswitch (ns) {\n\t\t\t\t\t\t// @font-face, @page\n\t\t\t\t\t\tcase 102:\n\t\t\t\t\t\tcase 112:\n\t\t\t\t\t\t\treturn insertRule(selectors[0]+content), ''\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\treturn content + (at === 0 ? delimiter : '')\n\t\t\t\t\t}\n\t\t\t\tcase -2:\n\t\t\t\t\tcontent.split(needle).forEach(toSheet)\n\t\t\t}\n\t\t}\n\t}\n}))\n","/*\n * __ ___\n * _____/ /___ __/ (_)____\n * / ___/ __/ / / / / / ___/\n * (__ ) /_/ /_/ / / (__ )\n * /____/\\__/\\__, /_/_/____/\n * /____/\n *\n * light - weight css preprocessor @licence MIT\n */\n(function (factory) {/* eslint-disable */\n\ttypeof exports === 'object' && typeof module !== 'undefined' ? (module['exports'] = factory(null)) :\n\t\ttypeof define === 'function' && define['amd'] ? define(factory(null)) :\n\t\t\t(window['stylis'] = factory(null))\n}(/** @param {*=} options */function factory (options) {/* eslint-disable */\n\n\t'use strict'\n\n\t/**\n\t * Notes\n\t *\n\t * The ['<method name>'] pattern is used to support closure compiler\n\t * the jsdoc signatures are also used to the same effect\n\t *\n\t * ----\n\t *\n\t * int + int + int === n4 [faster]\n\t *\n\t * vs\n\t *\n\t * int === n1 && int === n2 && int === n3\n\t *\n\t * ----\n\t *\n\t * switch (int) { case ints...} [faster]\n\t *\n\t * vs\n\t *\n\t * if (int == 1 && int === 2 ...)\n\t *\n\t * ----\n\t *\n\t * The (first*n1 + second*n2 + third*n3) format used in the property parser\n\t * is a simple way to hash the sequence of characters\n\t * taking into account the index they occur in\n\t * since any number of 3 character sequences could produce duplicates.\n\t *\n\t * On the other hand sequences that are directly tied to the index of the character\n\t * resolve a far more accurate measure, it's also faster\n\t * to evaluate one condition in a switch statement\n\t * than three in an if statement regardless of the added math.\n\t *\n\t * This allows the vendor prefixer to be both small and fast.\n\t */\n\n\tvar nullptn = /^\\0+/g /* matches leading null characters */\n\tvar formatptn = /[\\0\\r\\f]/g /* matches new line, null and formfeed characters */\n\tvar colonptn = /: */g /* splits animation rules */\n\tvar cursorptn = /zoo|gra/ /* assert cursor varient */\n\tvar transformptn = /([,: ])(transform)/g /* vendor prefix transform, older webkit */\n\tvar animationptn = /,+\\s*(?![^(]*[)])/g /* splits multiple shorthand notation animations */\n\tvar propertiesptn = / +\\s*(?![^(]*[)])/g /* animation properties */\n\tvar elementptn = / *[\\0] */g /* selector elements */\n\tvar selectorptn = /,\\r+?/g /* splits selectors */\n\tvar andptn = /([\\t\\r\\n ])*\\f?&/g /* match & */\n\tvar escapeptn = /:global\\(((?:[^\\(\\)\\[\\]]*|\\[.*\\]|\\([^\\(\\)]*\\))*)\\)/g /* matches :global(.*) */\n\tvar invalidptn = /\\W+/g /* removes invalid characters from keyframes */\n\tvar keyframeptn = /@(k\\w+)\\s*(\\S*)\\s*/ /* matches @keyframes $1 */\n\tvar plcholdrptn = /::(place)/g /* match ::placeholder varient */\n\tvar readonlyptn = /:(read-only)/g /* match :read-only varient */\n\tvar beforeptn = /\\s+(?=[{\\];=:>])/g /* matches \\s before ] ; = : */\n\tvar afterptn = /([[}=:>])\\s+/g /* matches \\s after characters [ } = : */\n\tvar tailptn = /(\\{[^{]+?);(?=\\})/g /* matches tail semi-colons ;} */\n\tvar whiteptn = /\\s{2,}/g /* matches repeating whitespace */\n\tvar pseudoptn = /([^\\(])(:+) */g /* pseudo element */\n\tvar writingptn = /[svh]\\w+-[tblr]{2}/ /* match writing mode property values */\n\tvar gradientptn = /([\\w-]+t\\()/g /* match *gradient property */\n\tvar supportsptn = /\\(\\s*(.*)\\s*\\)/g /* match supports (groups) */\n\tvar propertyptn = /([\\s\\S]*?);/g /* match properties leading semicolon */\n\tvar selfptn = /-self|flex-/g /* match flex- and -self in align-self: flex-*; */\n\tvar pseudofmt = /[^]*?(:[rp][el]a[\\w-]+)[^]*/ /* extrats :readonly or :placholder from selector */\n\tvar trimptn = /[ \\t]+$/ /* match tail whitspace */\n\tvar dimensionptn = /stretch|:\\s*\\w+\\-(?:conte|avail)/ /* match max/min/fit-content, fill-available */\n\tvar imgsrcptn = /([^-])(image-set\\()/\n\n\t/* vendors */\n\tvar webkit = '-webkit-'\n\tvar moz = '-moz-'\n\tvar ms = '-ms-'\n\n\t/* character codes */\n\tvar SEMICOLON = 59 /* ; */\n\tvar CLOSEBRACES = 125 /* } */\n\tvar OPENBRACES = 123 /* { */\n\tvar OPENPARENTHESES = 40 /* ( */\n\tvar CLOSEPARENTHESES = 41 /* ) */\n\tvar OPENBRACKET = 91 /* [ */\n\tvar CLOSEBRACKET = 93 /* ] */\n\tvar NEWLINE = 10 /* \\n */\n\tvar CARRIAGE = 13 /* \\r */\n\tvar TAB = 9 /* \\t */\n\tvar AT = 64 /* @ */\n\tvar SPACE = 32 /* */\n\tvar AND = 38 /* & */\n\tvar DASH = 45 /* - */\n\tvar UNDERSCORE = 95 /* _ */\n\tvar STAR = 42 /* * */\n\tvar COMMA = 44 /* , */\n\tvar COLON = 58 /* : */\n\tvar SINGLEQUOTE = 39 /* ' */\n\tvar DOUBLEQUOTE = 34 /* \" */\n\tvar FOWARDSLASH = 47 /* / */\n\tvar GREATERTHAN = 62 /* > */\n\tvar PLUS = 43 /* + */\n\tvar TILDE = 126 /* ~ */\n\tvar NULL = 0 /* \\0 */\n\tvar FORMFEED = 12 /* \\f */\n\tvar VERTICALTAB = 11 /* \\v */\n\n\t/* special identifiers */\n\tvar KEYFRAME = 107 /* k */\n\tvar MEDIA = 109 /* m */\n\tvar SUPPORTS = 115 /* s */\n\tvar PLACEHOLDER = 112 /* p */\n\tvar READONLY = 111 /* o */\n\tvar IMPORT = 105 /* <at>i */\n\tvar CHARSET = 99 /* <at>c */\n\tvar DOCUMENT = 100 /* <at>d */\n\tvar PAGE = 112 /* <at>p */\n\n\tvar column = 1 /* current column */\n\tvar line = 1 /* current line numebr */\n\tvar pattern = 0 /* :pattern */\n\n\tvar cascade = 1 /* #id h1 h2 vs h1#id h2#id */\n\tvar prefix = 1 /* vendor prefix */\n\tvar escape = 1 /* escape :global() pattern */\n\tvar compress = 0 /* compress output */\n\tvar semicolon = 0 /* no/semicolon option */\n\tvar preserve = 0 /* preserve empty selectors */\n\n\t/* empty reference */\n\tvar array = []\n\n\t/* plugins */\n\tvar plugins = []\n\tvar plugged = 0\n\tvar should = null\n\n\t/* plugin context */\n\tvar POSTS = -2\n\tvar PREPS = -1\n\tvar UNKWN = 0\n\tvar PROPS = 1\n\tvar BLCKS = 2\n\tvar ATRUL = 3\n\n\t/* plugin newline context */\n\tvar unkwn = 0\n\n\t/* keyframe animation */\n\tvar keyed = 1\n\tvar key = ''\n\n\t/* selector namespace */\n\tvar nscopealt = ''\n\tvar nscope = ''\n\n\t/**\n\t * Compile\n\t *\n\t * @param {Array<string>} parent\n\t * @param {Array<string>} current\n\t * @param {string} body\n\t * @param {number} id\n\t * @param {number} depth\n\t * @return {string}\n\t */\n\tfunction compile (parent, current, body, id, depth) {\n\t\tvar bracket = 0 /* brackets [] */\n\t\tvar comment = 0 /* comments /* // or /* */\n\t\tvar parentheses = 0 /* functions () */\n\t\tvar quote = 0 /* quotes '', \"\" */\n\n\t\tvar first = 0 /* first character code */\n\t\tvar second = 0 /* second character code */\n\t\tvar code = 0 /* current character code */\n\t\tvar tail = 0 /* previous character code */\n\t\tvar trail = 0 /* character before previous code */\n\t\tvar peak = 0 /* previous non-whitespace code */\n\n\t\tvar counter = 0 /* count sequence termination */\n\t\tvar context = 0 /* track current context */\n\t\tvar atrule = 0 /* track @at-rule context */\n\t\tvar pseudo = 0 /* track pseudo token index */\n\t\tvar caret = 0 /* current character index */\n\t\tvar format = 0 /* control character formating context */\n\t\tvar insert = 0 /* auto semicolon insertion */\n\t\tvar invert = 0 /* inverted selector pattern */\n\t\tvar length = 0 /* generic length address */\n\t\tvar eof = body.length /* end of file(length) */\n\t\tvar eol = eof - 1 /* end of file(characters) */\n\n\t\tvar char = '' /* current character */\n\t\tvar chars = '' /* current buffer of characters */\n\t\tvar child = '' /* next buffer of characters */\n\t\tvar out = '' /* compiled body */\n\t\tvar children = '' /* compiled children */\n\t\tvar flat = '' /* compiled leafs */\n\t\tvar selector /* generic selector address */\n\t\tvar result /* generic address */\n\n\t\t// ...build body\n\t\twhile (caret < eof) {\n\t\t\tcode = body.charCodeAt(caret)\n\n\t\t\t// eof varient\n\t\t\tif (caret === eol) {\n\t\t\t\t// last character + noop context, add synthetic padding for noop context to terminate\n\t\t\t\tif (comment + quote + parentheses + bracket !== 0) {\n\t\t\t\t\tif (comment !== 0) {\n\t\t\t\t\t\tcode = comment === FOWARDSLASH ? NEWLINE : FOWARDSLASH\n\t\t\t\t\t}\n\n\t\t\t\t\tquote = parentheses = bracket = 0\n\t\t\t\t\teof++\n\t\t\t\t\teol++\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tif (comment + quote + parentheses + bracket === 0) {\n\t\t\t\t// eof varient\n\t\t\t\tif (caret === eol) {\n\t\t\t\t\tif (format > 0) {\n\t\t\t\t\t\tchars = chars.replace(formatptn, '')\n\t\t\t\t\t}\n\n\t\t\t\t\tif (chars.trim().length > 0) {\n\t\t\t\t\t\tswitch (code) {\n\t\t\t\t\t\t\tcase SPACE:\n\t\t\t\t\t\t\tcase TAB:\n\t\t\t\t\t\t\tcase SEMICOLON:\n\t\t\t\t\t\t\tcase CARRIAGE:\n\t\t\t\t\t\t\tcase NEWLINE: {\n\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\tchars += body.charAt(caret)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tcode = SEMICOLON\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// auto semicolon insertion\n\t\t\t\tif (insert === 1) {\n\t\t\t\t\tswitch (code) {\n\t\t\t\t\t\t// false flags\n\t\t\t\t\t\tcase OPENBRACES:\n\t\t\t\t\t\tcase CLOSEBRACES:\n\t\t\t\t\t\tcase SEMICOLON:\n\t\t\t\t\t\tcase DOUBLEQUOTE:\n\t\t\t\t\t\tcase SINGLEQUOTE:\n\t\t\t\t\t\tcase OPENPARENTHESES:\n\t\t\t\t\t\tcase CLOSEPARENTHESES:\n\t\t\t\t\t\tcase COMMA: {\n\t\t\t\t\t\t\tinsert = 0\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// ignore\n\t\t\t\t\t\tcase TAB:\n\t\t\t\t\t\tcase CARRIAGE:\n\t\t\t\t\t\tcase NEWLINE:\n\t\t\t\t\t\tcase SPACE: {\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// valid\n\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\tinsert = 0\n\t\t\t\t\t\t\tlength = caret\n\t\t\t\t\t\t\tfirst = code\n\t\t\t\t\t\t\tcaret--\n\t\t\t\t\t\t\tcode = SEMICOLON\n\n\t\t\t\t\t\t\twhile (length < eof) {\n\t\t\t\t\t\t\t\tswitch (body.charCodeAt(length++)) {\n\t\t\t\t\t\t\t\t\tcase NEWLINE:\n\t\t\t\t\t\t\t\t\tcase CARRIAGE:\n\t\t\t\t\t\t\t\t\tcase SEMICOLON: {\n\t\t\t\t\t\t\t\t\t\t++caret\n\t\t\t\t\t\t\t\t\t\tcode = first\n\t\t\t\t\t\t\t\t\t\tlength = eof\n\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tcase COLON: {\n\t\t\t\t\t\t\t\t\t\tif (format > 0) {\n\t\t\t\t\t\t\t\t\t\t\t++caret\n\t\t\t\t\t\t\t\t\t\t\tcode = first\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tcase OPENBRACES: {\n\t\t\t\t\t\t\t\t\t\tlength = eof\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\t// token varient\n\t\t\t\tswitch (code) {\n\t\t\t\t\tcase OPENBRACES: {\n\t\t\t\t\t\tchars = chars.trim()\n\t\t\t\t\t\tfirst = chars.charCodeAt(0)\n\t\t\t\t\t\tcounter = 1\n\t\t\t\t\t\tlength = ++caret\n\n\t\t\t\t\t\twhile (caret < eof) {\n\t\t\t\t\t\t\tswitch (code = body.charCodeAt(caret)) {\n\t\t\t\t\t\t\t\tcase OPENBRACES: {\n\t\t\t\t\t\t\t\t\tcounter++\n\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tcase CLOSEBRACES: {\n\t\t\t\t\t\t\t\t\tcounter--\n\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tcase FOWARDSLASH: {\n\t\t\t\t\t\t\t\t\tswitch (second = body.charCodeAt(caret + 1)) {\n\t\t\t\t\t\t\t\t\t\t// /*, //\n\t\t\t\t\t\t\t\t\t\tcase STAR:\n\t\t\t\t\t\t\t\t\t\tcase FOWARDSLASH: {\n\t\t\t\t\t\t\t\t\t\t\tcaret = delimited(second, caret, eol, body)\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t// given \"[\" === 91 & \"]\" === 93 hence forth 91 + 1 + 1 === 93\n\t\t\t\t\t\t\t\tcase OPENBRACKET: {\n\t\t\t\t\t\t\t\t\tcode++\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t// given \"(\" === 40 & \")\" === 41 hence forth 40 + 1 === 41\n\t\t\t\t\t\t\t\tcase OPENPARENTHESES: {\n\t\t\t\t\t\t\t\t\tcode++\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t// quote tail delimiter is identical to the head delimiter hence noop,\n\t\t\t\t\t\t\t\t// fallthrough clauses have been shifted to the correct tail delimiter\n\t\t\t\t\t\t\t\tcase DOUBLEQUOTE:\n\t\t\t\t\t\t\t\tcase SINGLEQUOTE: {\n\t\t\t\t\t\t\t\t\twhile (caret++ < eol) {\n\t\t\t\t\t\t\t\t\t\tif (body.charCodeAt(caret) === code) {\n\t\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (counter === 0) {\n\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tcaret++\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tchild = body.substring(length, caret)\n\n\t\t\t\t\t\tif (first === NULL) {\n\t\t\t\t\t\t\tfirst = (chars = chars.replace(nullptn, '').trim()).charCodeAt(0)\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tswitch (first) {\n\t\t\t\t\t\t\t// @at-rule\n\t\t\t\t\t\t\tcase AT: {\n\t\t\t\t\t\t\t\tif (format > 0) {\n\t\t\t\t\t\t\t\t\tchars = chars.replace(formatptn, '')\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tsecond = chars.charCodeAt(1)\n\n\t\t\t\t\t\t\t\tswitch (second) {\n\t\t\t\t\t\t\t\t\tcase DOCUMENT:\n\t\t\t\t\t\t\t\t\tcase MEDIA:\n\t\t\t\t\t\t\t\t\tcase SUPPORTS:\n\t\t\t\t\t\t\t\t\tcase DASH: {\n\t\t\t\t\t\t\t\t\t\tselector = current\n\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\t\t\tselector = array\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tchild = compile(current, selector, child, second, depth+1)\n\t\t\t\t\t\t\t\tlength = child.length\n\n\t\t\t\t\t\t\t\t// preserve empty @at-rule\n\t\t\t\t\t\t\t\tif (preserve > 0 && length === 0) {\n\t\t\t\t\t\t\t\t\tlength = chars.length\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t// execute plugins, @at-rule context\n\t\t\t\t\t\t\t\tif (plugged > 0) {\n\t\t\t\t\t\t\t\t\tselector = select(array, chars, invert)\n\t\t\t\t\t\t\t\t\tresult = proxy(ATRUL, child, selector, current, line, column, length, second, depth, id)\n\t\t\t\t\t\t\t\t\tchars = selector.join('')\n\n\t\t\t\t\t\t\t\t\tif (result !== void 0) {\n\t\t\t\t\t\t\t\t\t\tif ((length = (child = result.trim()).length) === 0) {\n\t\t\t\t\t\t\t\t\t\t\tsecond = 0\n\t\t\t\t\t\t\t\t\t\t\tchild = ''\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tif (length > 0) {\n\t\t\t\t\t\t\t\t\tswitch (second) {\n\t\t\t\t\t\t\t\t\t\tcase SUPPORTS: {\n\t\t\t\t\t\t\t\t\t\t\tchars = chars.replace(supportsptn, supports)\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\tcase DOCUMENT:\n\t\t\t\t\t\t\t\t\t\tcase MEDIA:\n\t\t\t\t\t\t\t\t\t\tcase DASH: {\n\t\t\t\t\t\t\t\t\t\t\tchild = chars + '{' + child + '}'\n\t\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\tcase KEYFRAME: {\n\t\t\t\t\t\t\t\t\t\t\tchars = chars.replace(keyframeptn, '$1 $2' + (keyed > 0 ? key : ''))\n\t\t\t\t\t\t\t\t\t\t\tchild = chars + '{' + child + '}'\n\n\t\t\t\t\t\t\t\t\t\t\tif (prefix === 1 || (prefix === 2 && vendor('@'+child, 3))) {\n\t\t\t\t\t\t\t\t\t\t\t\tchild = '@' + webkit + child + '@' + child\n\t\t\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\t\t\tchild = '@' + child\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\t\t\t\tchild = chars + child\n\n\t\t\t\t\t\t\t\t\t\t\tif (id === PAGE) {\n\t\t\t\t\t\t\t\t\t\t\t\tchild = (out += child, '')\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tchild = ''\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t// selector\n\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\tchild = compile(current, select(current, chars, invert), child, id, depth+1)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\tchildren += child\n\n\t\t\t\t\t\t// reset\n\t\t\t\t\t\tcontext = 0\n\t\t\t\t\t\tinsert = 0\n\t\t\t\t\t\tpseudo = 0\n\t\t\t\t\t\tformat = 0\n\t\t\t\t\t\tinvert = 0\n\t\t\t\t\t\tatrule = 0\n\t\t\t\t\t\tchars = ''\n\t\t\t\t\t\tchild = ''\n\t\t\t\t\t\tcode = body.charCodeAt(++caret)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t\tcase CLOSEBRACES:\n\t\t\t\t\tcase SEMICOLON: {\n\t\t\t\t\t\tchars = (format > 0 ? chars.replace(formatptn, '') : chars).trim()\n\n\t\t\t\t\t\tif ((length = chars.length) > 1) {\n\t\t\t\t\t\t\t// monkey-patch missing colon\n\t\t\t\t\t\t\tif (pseudo === 0) {\n\t\t\t\t\t\t\t\tfirst = chars.charCodeAt(0)\n\n\t\t\t\t\t\t\t\t// first character is a letter or dash, buffer has a space character\n\t\t\t\t\t\t\t\tif ((first === DASH || first > 96 && first < 123)) {\n\t\t\t\t\t\t\t\t\tlength = (chars = chars.replace(' ', ':')).length\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t// execute plugins, property context\n\t\t\t\t\t\t\tif (plugged > 0) {\n\t\t\t\t\t\t\t\tif ((result = proxy(PROPS, chars, current, parent, line, column, out.length, id, depth, id)) !== void 0) {\n\t\t\t\t\t\t\t\t\tif ((length = (chars = result.trim()).length) === 0) {\n\t\t\t\t\t\t\t\t\t\tchars = '\\0\\0'\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tfirst = chars.charCodeAt(0)\n\t\t\t\t\t\t\tsecond = chars.charCodeAt(1)\n\n\t\t\t\t\t\t\tswitch (first) {\n\t\t\t\t\t\t\t\tcase NULL: {\n\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tcase AT: {\n\t\t\t\t\t\t\t\t\tif (second === IMPORT || second === CHARSET) {\n\t\t\t\t\t\t\t\t\t\tflat += chars + body.charAt(caret)\n\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\t\tif (chars.charCodeAt(length-1) === COLON) {\n\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\tout += property(chars, first, second, chars.charCodeAt(2))\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// reset\n\t\t\t\t\t\tcontext = 0\n\t\t\t\t\t\tinsert = 0\n\t\t\t\t\t\tpseudo = 0\n\t\t\t\t\t\tformat = 0\n\t\t\t\t\t\tinvert = 0\n\t\t\t\t\t\tchars = ''\n\t\t\t\t\t\tcode = body.charCodeAt(++caret)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// parse characters\n\t\t\tswitch (code) {\n\t\t\t\tcase CARRIAGE:\n\t\t\t\tcase NEWLINE: {\n\t\t\t\t\t// auto insert semicolon\n\t\t\t\t\tif (comment + quote + parentheses + bracket + semicolon === 0) {\n\t\t\t\t\t\t// valid non-whitespace characters that\n\t\t\t\t\t\t// may precede a newline\n\t\t\t\t\t\tswitch (peak) {\n\t\t\t\t\t\t\tcase CLOSEPARENTHESES:\n\t\t\t\t\t\t\tcase SINGLEQUOTE:\n\t\t\t\t\t\t\tcase DOUBLEQUOTE:\n\t\t\t\t\t\t\tcase AT:\n\t\t\t\t\t\t\tcase TILDE:\n\t\t\t\t\t\t\tcase GREATERTHAN:\n\t\t\t\t\t\t\tcase STAR:\n\t\t\t\t\t\t\tcase PLUS:\n\t\t\t\t\t\t\tcase FOWARDSLASH:\n\t\t\t\t\t\t\tcase DASH:\n\t\t\t\t\t\t\tcase COLON:\n\t\t\t\t\t\t\tcase COMMA:\n\t\t\t\t\t\t\tcase SEMICOLON:\n\t\t\t\t\t\t\tcase OPENBRACES:\n\t\t\t\t\t\t\tcase CLOSEBRACES: {\n\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\t// current buffer has a colon\n\t\t\t\t\t\t\t\tif (pseudo > 0) {\n\t\t\t\t\t\t\t\t\tinsert = 1\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// terminate line comment\n\t\t\t\t\tif (comment === FOWARDSLASH) {\n\t\t\t\t\t\tcomment = 0\n\t\t\t\t\t} else if (cascade + context === 0 && id !== KEYFRAME && chars.length > 0) {\n\t\t\t\t\t\tformat = 1\n\t\t\t\t\t\tchars += '\\0'\n\t\t\t\t\t}\n\n\t\t\t\t\t// execute plugins, newline context\n\t\t\t\t\tif (plugged * unkwn > 0) {\n\t\t\t\t\t\tproxy(UNKWN, chars, current, parent, line, column, out.length, id, depth, id)\n\t\t\t\t\t}\n\n\t\t\t\t\t// next line, reset column position\n\t\t\t\t\tcolumn = 1\n\t\t\t\t\tline++\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t\tcase SEMICOLON:\n\t\t\t\tcase CLOSEBRACES: {\n\t\t\t\t\tif (comment + quote + parentheses + bracket === 0) {\n\t\t\t\t\t\tcolumn++\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tdefault: {\n\t\t\t\t\t// increment column position\n\t\t\t\t\tcolumn++\n\n\t\t\t\t\t// current character\n\t\t\t\t\tchar = body.charAt(caret)\n\n\t\t\t\t\t// remove comments, escape functions, strings, attributes and prepare selectors\n\t\t\t\t\tswitch (code) {\n\t\t\t\t\t\tcase TAB:\n\t\t\t\t\t\tcase SPACE: {\n\t\t\t\t\t\t\tif (quote + bracket + comment === 0) {\n\t\t\t\t\t\t\t\tswitch (tail) {\n\t\t\t\t\t\t\t\t\tcase COMMA:\n\t\t\t\t\t\t\t\t\tcase COLON:\n\t\t\t\t\t\t\t\t\tcase TAB:\n\t\t\t\t\t\t\t\t\tcase SPACE: {\n\t\t\t\t\t\t\t\t\t\tchar = ''\n\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\t\t\tif (code !== SPACE) {\n\t\t\t\t\t\t\t\t\t\t\tchar = ' '\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// escape breaking control characters\n\t\t\t\t\t\tcase NULL: {\n\t\t\t\t\t\t\tchar = '\\\\0'\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcase FORMFEED: {\n\t\t\t\t\t\t\tchar = '\\\\f'\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcase VERTICALTAB: {\n\t\t\t\t\t\t\tchar = '\\\\v'\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// &\n\t\t\t\t\t\tcase AND: {\n\t\t\t\t\t\t\t// inverted selector pattern i.e html &\n\t\t\t\t\t\t\tif (quote + comment + bracket === 0 && cascade > 0) {\n\t\t\t\t\t\t\t\tinvert = 1\n\t\t\t\t\t\t\t\tformat = 1\n\t\t\t\t\t\t\t\tchar = '\\f' + char\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// ::p<l>aceholder, l\n\t\t\t\t\t\t// :read-on<l>y, l\n\t\t\t\t\t\tcase 108: {\n\t\t\t\t\t\t\tif (quote + comment + bracket + pattern === 0 && pseudo > 0) {\n\t\t\t\t\t\t\t\tswitch (caret - pseudo) {\n\t\t\t\t\t\t\t\t\t// ::placeholder\n\t\t\t\t\t\t\t\t\tcase 2: {\n\t\t\t\t\t\t\t\t\t\tif (tail === PLACEHOLDER && body.charCodeAt(caret-3) === COLON) {\n\t\t\t\t\t\t\t\t\t\t\tpattern = tail\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t// :read-only\n\t\t\t\t\t\t\t\t\tcase 8: {\n\t\t\t\t\t\t\t\t\t\tif (trail === READONLY) {\n\t\t\t\t\t\t\t\t\t\t\tpattern = trail\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// :<pattern>\n\t\t\t\t\t\tcase COLON: {\n\t\t\t\t\t\t\tif (quote + comment + bracket === 0) {\n\t\t\t\t\t\t\t\tpseudo = caret\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// selectors\n\t\t\t\t\t\tcase COMMA: {\n\t\t\t\t\t\t\tif (comment + parentheses + quote + bracket === 0) {\n\t\t\t\t\t\t\t\tformat = 1\n\t\t\t\t\t\t\t\tchar += '\\r'\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// quotes\n\t\t\t\t\t\tcase DOUBLEQUOTE:\n\t\t\t\t\t\tcase SINGLEQUOTE: {\n\t\t\t\t\t\t\tif (comment === 0) {\n\t\t\t\t\t\t\t\tquote = quote === code ? 0 : (quote === 0 ? code : quote)\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// attributes\n\t\t\t\t\t\tcase OPENBRACKET: {\n\t\t\t\t\t\t\tif (quote + comment + parentheses === 0) {\n\t\t\t\t\t\t\t\tbracket++\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcase CLOSEBRACKET: {\n\t\t\t\t\t\t\tif (quote + comment + parentheses === 0) {\n\t\t\t\t\t\t\t\tbracket--\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// functions\n\t\t\t\t\t\tcase CLOSEPARENTHESES: {\n\t\t\t\t\t\t\tif (quote + comment + bracket === 0) {\n\t\t\t\t\t\t\t\tparentheses--\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcase OPENPARENTHESES: {\n\t\t\t\t\t\t\tif (quote + comment + bracket === 0) {\n\t\t\t\t\t\t\t\tif (context === 0) {\n\t\t\t\t\t\t\t\t\tswitch (tail*2 + trail*3) {\n\t\t\t\t\t\t\t\t\t\t// :matches\n\t\t\t\t\t\t\t\t\t\tcase 533: {\n\t\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t// :global, :not, :nth-child etc...\n\t\t\t\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\t\t\t\tcounter = 0\n\t\t\t\t\t\t\t\t\t\t\tcontext = 1\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\tparentheses++\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\tcase AT: {\n\t\t\t\t\t\t\tif (comment + parentheses + quote + bracket + pseudo + atrule === 0) {\n\t\t\t\t\t\t\t\tatrule = 1\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// block/line comments\n\t\t\t\t\t\tcase STAR:\n\t\t\t\t\t\tcase FOWARDSLASH: {\n\t\t\t\t\t\t\tif (quote + bracket + parentheses > 0) {\n\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tswitch (comment) {\n\t\t\t\t\t\t\t\t// initialize line/block comment context\n\t\t\t\t\t\t\t\tcase 0: {\n\t\t\t\t\t\t\t\t\tswitch (code*2 + body.charCodeAt(caret+1)*3) {\n\t\t\t\t\t\t\t\t\t\t// //\n\t\t\t\t\t\t\t\t\t\tcase 235: {\n\t\t\t\t\t\t\t\t\t\t\tcomment = FOWARDSLASH\n\t\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t// /*\n\t\t\t\t\t\t\t\t\t\tcase 220: {\n\t\t\t\t\t\t\t\t\t\t\tlength = caret\n\t\t\t\t\t\t\t\t\t\t\tcomment = STAR\n\t\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t// end block comment context\n\t\t\t\t\t\t\t\tcase STAR: {\n\t\t\t\t\t\t\t\t\tif (code === FOWARDSLASH && tail === STAR && length + 2 !== caret) {\n\t\t\t\t\t\t\t\t\t\t// /*<!> ... */, !\n\t\t\t\t\t\t\t\t\t\tif (body.charCodeAt(length+2) === 33) {\n\t\t\t\t\t\t\t\t\t\t\tout += body.substring(length, caret+1)\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\tchar = ''\n\t\t\t\t\t\t\t\t\t\tcomment = 0\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// ignore comment blocks\n\t\t\t\t\tif (comment === 0) {\n\t\t\t\t\t\t// aggressive isolation mode, divide each individual selector\n\t\t\t\t\t\t// including selectors in :not function but excluding selectors in :global function\n\t\t\t\t\t\tif (cascade + quote + bracket + atrule === 0 && id !== KEYFRAME && code !== SEMICOLON) {\n\t\t\t\t\t\t\tswitch (code) {\n\t\t\t\t\t\t\t\tcase COMMA:\n\t\t\t\t\t\t\t\tcase TILDE:\n\t\t\t\t\t\t\t\tcase GREATERTHAN:\n\t\t\t\t\t\t\t\tcase PLUS:\n\t\t\t\t\t\t\t\tcase CLOSEPARENTHESES:\n\t\t\t\t\t\t\t\tcase OPENPARENTHESES: {\n\t\t\t\t\t\t\t\t\tif (context === 0) {\n\t\t\t\t\t\t\t\t\t\t// outside of an isolated context i.e nth-child(<...>)\n\t\t\t\t\t\t\t\t\t\tswitch (tail) {\n\t\t\t\t\t\t\t\t\t\t\tcase TAB:\n\t\t\t\t\t\t\t\t\t\t\tcase SPACE:\n\t\t\t\t\t\t\t\t\t\t\tcase NEWLINE:\n\t\t\t\t\t\t\t\t\t\t\tcase CARRIAGE: {\n\t\t\t\t\t\t\t\t\t\t\t\tchar = char + '\\0'\n\t\t\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\t\t\t\t\tchar = '\\0' + char + (code === COMMA ? '' : '\\0')\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\tformat = 1\n\t\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\t\t// within an isolated context, sleep untill it's terminated\n\t\t\t\t\t\t\t\t\t\tswitch (code) {\n\t\t\t\t\t\t\t\t\t\t\tcase OPENPARENTHESES: {\n\t\t\t\t\t\t\t\t\t\t\t\t// :globa<l>(\n\t\t\t\t\t\t\t\t\t\t\t\tif (pseudo + 7 === caret && tail === 108) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tpseudo = 0\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\tcontext = ++counter\n\t\t\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\tcase CLOSEPARENTHESES: {\n\t\t\t\t\t\t\t\t\t\t\t\tif ((context = --counter) === 0) {\n\t\t\t\t\t\t\t\t\t\t\t\t\tformat = 1\n\t\t\t\t\t\t\t\t\t\t\t\t\tchar += '\\0'\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tcase TAB:\n\t\t\t\t\t\t\t\tcase SPACE: {\n\t\t\t\t\t\t\t\t\tswitch (tail) {\n\t\t\t\t\t\t\t\t\t\tcase NULL:\n\t\t\t\t\t\t\t\t\t\tcase OPENBRACES:\n\t\t\t\t\t\t\t\t\t\tcase CLOSEBRACES:\n\t\t\t\t\t\t\t\t\t\tcase SEMICOLON:\n\t\t\t\t\t\t\t\t\t\tcase COMMA:\n\t\t\t\t\t\t\t\t\t\tcase FORMFEED:\n\t\t\t\t\t\t\t\t\t\tcase TAB:\n\t\t\t\t\t\t\t\t\t\tcase SPACE:\n\t\t\t\t\t\t\t\t\t\tcase NEWLINE:\n\t\t\t\t\t\t\t\t\t\tcase CARRIAGE: {\n\t\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\t\t\t\t// ignore in isolated contexts\n\t\t\t\t\t\t\t\t\t\t\tif (context === 0) {\n\t\t\t\t\t\t\t\t\t\t\t\tformat = 1\n\t\t\t\t\t\t\t\t\t\t\t\tchar += '\\0'\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// concat buffer of characters\n\t\t\t\t\t\tchars += char\n\n\t\t\t\t\t\t// previous non-whitespace character code\n\t\t\t\t\t\tif (code !== SPACE && code !== TAB) {\n\t\t\t\t\t\t\tpeak = code\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// tail character codes\n\t\t\ttrail = tail\n\t\t\ttail = code\n\n\t\t\t// visit every character\n\t\t\tcaret++\n\t\t}\n\n\t\tlength = out.length\n\n\t\t// preserve empty selector\n \t\tif (preserve > 0) {\n \t\t\tif (length === 0 && children.length === 0 && (current[0].length === 0) === false) {\n \t\t\t\tif (id !== MEDIA || (current.length === 1 && (cascade > 0 ? nscopealt : nscope) === current[0])) {\n\t\t\t\t\tlength = current.join(',').length + 2\n \t\t\t\t}\n \t\t\t}\n\t\t}\n\n\t\tif (length > 0) {\n\t\t\t// cascade isolation mode?\n\t\t\tselector = cascade === 0 && id !== KEYFRAME ? isolate(current) : current\n\n\t\t\t// execute plugins, block context\n\t\t\tif (plugged > 0) {\n\t\t\t\tresult = proxy(BLCKS, out, selector, parent, line, column, length, id, depth, id)\n\n\t\t\t\tif (result !== void 0 && (out = result).length === 0) {\n\t\t\t\t\treturn flat + out + children\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tout = selector.join(',') + '{' + out + '}'\n\n\t\t\tif (prefix*pattern !== 0) {\n\t\t\t\tif (prefix === 2 && !vendor(out, 2))\n\t\t\t\t\tpattern = 0\n\n\t\t\t\tswitch (pattern) {\n\t\t\t\t\t// ::read-only\n\t\t\t\t\tcase READONLY: {\n\t\t\t\t\t\tout = out.replace(readonlyptn, ':'+moz+'$1')+out\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t\t// ::placeholder\n\t\t\t\t\tcase PLACEHOLDER: {\n\t\t\t\t\t\tout = (\n\t\t\t\t\t\t\tout.replace(plcholdrptn, '::' + webkit + 'input-$1') +\n\t\t\t\t\t\t\tout.replace(plcholdrptn, '::' + moz + '$1') +\n\t\t\t\t\t\t\tout.replace(plcholdrptn, ':' + ms + 'input-$1') + out\n\t\t\t\t\t\t)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tpattern = 0\n\t\t\t}\n\t\t}\n\n\t\treturn flat + out + children\n\t}\n\n\t/**\n\t * Select\n\t *\n\t * @param {Array<string>} parent\n\t * @param {string} current\n\t * @param {number} invert\n\t * @return {Array<string>}\n\t */\n\tfunction select (parent, current, invert) {\n\t\tvar selectors = current.trim().split(selectorptn)\n\t\tvar out = selectors\n\n\t\tvar length = selectors.length\n\t\tvar l = parent.length\n\n\t\tswitch (l) {\n\t\t\t// 0-1 parent selectors\n\t\t\tcase 0:\n\t\t\tcase 1: {\n\t\t\t\tfor (var i = 0, selector = l === 0 ? '' : parent[0] + ' '; i < length; ++i) {\n\t\t\t\t\tout[i] = scope(selector, out[i], invert, l).trim()\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\t}\n\t\t\t// >2 parent selectors, nested\n\t\t\tdefault: {\n\t\t\t\tfor (var i = 0, j = 0, out = []; i < length; ++i) {\n\t\t\t\t\tfor (var k = 0; k < l; ++k) {\n\t\t\t\t\t\tout[j++] = scope(parent[k] + ' ', selectors[i], invert, l).trim()\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn out\n\t}\n\n\t/**\n\t * Scope\n\t *\n\t * @param {string} parent\n\t * @param {string} current\n\t * @param {number} invert\n\t * @param {number} level\n\t * @return {string}\n\t */\n\tfunction scope (parent, current, invert, level) {\n\t\tvar selector = current\n\t\tvar code = selector.charCodeAt(0)\n\n\t\t// trim leading whitespace\n\t\tif (code < 33) {\n\t\t\tcode = (selector = selector.trim()).charCodeAt(0)\n\t\t}\n\n\t\tswitch (code) {\n\t\t\t// &\n\t\t\tcase AND: {\n\t\t\t\tswitch (cascade + level) {\n\t\t\t\t\tcase 0:\n\t\t\t\t\tcase 1: {\n\t\t\t\t\t\tif (parent.trim().length === 0) {\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tdefault: {\n\t\t\t\t\t\treturn selector.replace(andptn, '$1'+parent.trim())\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\t}\n\t\t\t// :\n\t\t\tcase COLON: {\n\t\t\t\tswitch (selector.charCodeAt(1)) {\n\t\t\t\t\t// g in :global\n\t\t\t\t\tcase 103: {\n\t\t\t\t\t\tif (escape > 0 && cascade > 0) {\n\t\t\t\t\t\t\treturn selector.replace(escapeptn, '$1').replace(andptn, '$1'+nscope)\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t\tdefault: {\n\t\t\t\t\t\t// :hover\n\t\t\t\t\t\treturn parent.trim() + selector.replace(andptn, '$1'+parent.trim())\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tdefault: {\n\t\t\t\t// html &\n\t\t\t\tif (invert*cascade > 0 && selector.indexOf('\\f') > 0) {\n\t\t\t\t\treturn selector.replace(andptn, (parent.charCodeAt(0) === COLON ? '' : '$1')+parent.trim())\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn parent + selector\n\t}\n\n\t/**\n\t * Property\n\t *\n\t * @param {string} input\n\t * @param {number} first\n\t * @param {number} second\n\t * @param {number} third\n\t * @return {string}\n\t */\n\tfunction property (input, first, second, third) {\n\t\tvar index = 0\n\t\tvar out = input + ';'\n\t\tvar hash = (first*2) + (second*3) + (third*4)\n\t\tvar cache\n\n\t\t// animation: a, n, i characters\n\t\tif (hash === 944) {\n\t\t\treturn animation(out)\n\t\t} else if (prefix === 0 || (prefix === 2 && !vendor(out, 1))) {\n\t\t\treturn out\n\t\t}\n\n\t\t// vendor prefix\n\t\tswitch (hash) {\n\t\t\t// text-decoration/text-size-adjust/text-shadow/text-align/text-transform: t, e, x\n\t\t\tcase 1015: {\n\t\t\t\t// text-shadow/text-align/text-transform, a\n\t\t\t\treturn out.charCodeAt(10) === 97 ? webkit + out + out : out\n\t\t\t}\n\t\t\t// filter/fill f, i, l\n\t\t\tcase 951: {\n\t\t\t\t// filter, t\n\t\t\t\treturn out.charCodeAt(3) === 116 ? webkit + out + out : out\n\t\t\t}\n\t\t\t// color/column, c, o, l\n\t\t\tcase 963: {\n\t\t\t\t// column, n\n\t\t\t\treturn out.charCodeAt(5) === 110 ? webkit + out + out : out\n\t\t\t}\n\t\t\t// box-decoration-break, b, o, x\n\t\t\tcase 1009: {\n\t\t\t\tif (out.charCodeAt(4) !== 100) {\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t}\n\t\t\t// mask, m, a, s\n\t\t\t// clip-path, c, l, i\n\t\t\tcase 969:\n\t\t\tcase 942: {\n\t\t\t\treturn webkit + out + out\n\t\t\t}\n\t\t\t// appearance: a, p, p\n\t\t\tcase 978: {\n\t\t\t\treturn webkit + out + moz + out + out\n\t\t\t}\n\t\t\t// hyphens: h, y, p\n\t\t\t// user-select: u, s, e\n\t\t\tcase 1019:\n\t\t\tcase 983: {\n\t\t\t\treturn webkit + out + moz + out + ms + out + out\n\t\t\t}\n\t\t\t// background/backface-visibility, b, a, c\n\t\t\tcase 883: {\n\t\t\t\t// backface-visibility, -\n\t\t\t\tif (out.charCodeAt(8) === DASH) {\n\t\t\t\t\treturn webkit + out + out\n\t\t\t\t}\n\n\t\t\t\t// image-set(...)\n\t\t\t\tif (out.indexOf('image-set(', 11) > 0) {\n\t\t\t\t\treturn out.replace(imgsrcptn, '$1'+webkit+'$2') + out\n\t\t\t\t}\n\n\t\t\t\treturn out\n\t\t\t}\n\t\t\t// flex: f, l, e\n\t\t\tcase 932: {\n\t\t\t\tif (out.charCodeAt(4) === DASH) {\n\t\t\t\t\tswitch (out.charCodeAt(5)) {\n\t\t\t\t\t\t// flex-grow, g\n\t\t\t\t\t\tcase 103: {\n\t\t\t\t\t\t\treturn webkit + 'box-' + out.replace('-grow', '') + webkit + out + ms + out.replace('grow', 'positive') + out\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// flex-shrink, s\n\t\t\t\t\t\tcase 115: {\n\t\t\t\t\t\t\treturn webkit + out + ms + out.replace('shrink', 'negative') + out\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// flex-basis, b\n\t\t\t\t\t\tcase 98: {\n\t\t\t\t\t\t\treturn webkit + out + ms + out.replace('basis', 'preferred-size') + out\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn webkit + out + ms + out + out\n\t\t\t}\n\t\t\t// order: o, r, d\n\t\t\tcase 964: {\n\t\t\t\treturn webkit + out + ms + 'flex' + '-' + out + out\n\t\t\t}\n\t\t\t// justify-items/justify-content, j, u, s\n\t\t\tcase 1023: {\n\t\t\t\t// justify-content, c\n\t\t\t\tif (out.charCodeAt(8) !== 99) {\n\t\t\t\t\tbreak\n\t\t\t\t}\n\n\t\t\t\tcache = out.substring(out.indexOf(':', 15)).replace('flex-', '').replace('space-between', 'justify')\n\t\t\t\treturn webkit + 'box-pack' + cache + webkit + out + ms + 'flex-pack' + cache + out\n\t\t\t}\n\t\t\t// cursor, c, u, r\n\t\t\tcase 1005: {\n\t\t\t\treturn cursorptn.test(out) ? out.replace(colonptn, ':' + webkit) + out.replace(colonptn, ':' + moz) + out : out\n\t\t\t}\n\t\t\t// writing-mode, w, r, i\n\t\t\tcase 1000: {\n\t\t\t\tcache = out.substring(13).trim()\n\t\t\t\tindex = cache.indexOf('-') + 1\n\n\t\t\t\tswitch (cache.charCodeAt(0)+cache.charCodeAt(index)) {\n\t\t\t\t\t// vertical-lr\n\t\t\t\t\tcase 226: {\n\t\t\t\t\t\tcache = out.replace(writingptn, 'tb')\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t\t// vertical-rl\n\t\t\t\t\tcase 232: {\n\t\t\t\t\t\tcache = out.replace(writingptn, 'tb-rl')\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t\t// horizontal-tb\n\t\t\t\t\tcase 220: {\n\t\t\t\t\t\tcache = out.replace(writingptn, 'lr')\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t\tdefault: {\n\t\t\t\t\t\treturn out\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn webkit + out + ms + cache + out\n\t\t\t}\n\t\t\t// position: sticky\n\t\t\tcase 1017: {\n\t\t\t\tif (out.indexOf('sticky', 9) === -1) {\n\t\t\t\t\treturn out\n\t\t\t\t}\n\t\t\t}\n\t\t\t// display(flex/inline-flex/inline-box): d, i, s\n\t\t\tcase 975: {\n\t\t\t\tindex = (out = input).length - 10\n\t\t\t\tcache = (out.charCodeAt(index) === 33 ? out.substring(0, index) : out).substring(input.indexOf(':', 7) + 1).trim()\n\n\t\t\t\tswitch (hash = cache.charCodeAt(0) + (cache.charCodeAt(7)|0)) {\n\t\t\t\t\t// inline-\n\t\t\t\t\tcase 203: {\n\t\t\t\t\t\t// inline-box\n\t\t\t\t\t\tif (cache.charCodeAt(8) < 111) {\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t// inline-box/sticky\n\t\t\t\t\tcase 115: {\n\t\t\t\t\t\tout = out.replace(cache, webkit+cache)+';'+out\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t\t// inline-flex\n\t\t\t\t\t// flex\n\t\t\t\t\tcase 207:\n\t\t\t\t\tcase 102: {\n\t\t\t\t\t\tout = (\n\t\t\t\t\t\t\tout.replace(cache, webkit+(hash > 102 ? 'inline-' : '')+'box')+';'+\n\t\t\t\t\t\t\tout.replace(cache, webkit+cache)+';'+\n\t\t\t\t\t\t\tout.replace(cache, ms+cache+'box')+';'+\n\t\t\t\t\t\t\tout\n\t\t\t\t\t\t)\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\treturn out + ';'\n\t\t\t}\n\t\t\t// align-items, align-center, align-self: a, l, i, -\n\t\t\tcase 938: {\n\t\t\t\tif (out.charCodeAt(5) === DASH) {\n\t\t\t\t\tswitch (out.charCodeAt(6)) {\n\t\t\t\t\t\t// align-items, i\n\t\t\t\t\t\tcase 105: {\n\t\t\t\t\t\t\tcache = out.replace('-items', '')\n\t\t\t\t\t\t\treturn webkit + out + webkit + 'box-' + cache + ms + 'flex-' + cache + out\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// align-self, s\n\t\t\t\t\t\tcase 115: {\n\t\t\t\t\t\t\treturn webkit + out + ms + 'flex-item-' + out.replace(selfptn, '') + out\n\t\t\t\t\t\t}\n\t\t\t\t\t\t// align-content\n\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\treturn webkit + out + ms + 'flex-line-pack' + out.replace('align-content', '').replace(selfptn, '') + out\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\t}\n\t\t\t// min/max\n\t\t\tcase 973:\n\t\t\tcase 989: {\n\t\t\t\t// min-/max- height/width/block-size/inline-size\n\t\t\t\tif (out.charCodeAt(3) !== DASH || out.charCodeAt(4) === 122) {\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t}\n\t\t\t// height/width: min-content / width: max-content\n\t\t\tcase 931:\n\t\t\tcase 953: {\n\t\t\t\tif (dimensionptn.test(input) === true) {\n\t\t\t\t\t// stretch\n\t\t\t\t\tif ((cache = input.substring(input.indexOf(':') + 1)).charCodeAt(0) === 115)\n\t\t\t\t\t\treturn property(input.replace('stretch', 'fill-available'), first, second, third).replace(':fill-available', ':stretch')\n\t\t\t\t\telse\n\t\t\t\t\t\treturn out.replace(cache, webkit + cache) + out.replace(cache, moz + cache.replace('fill-', '')) + out\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\t}\n\t\t\t// transform, transition: t, r, a\n\t\t\tcase 962: {\n\t\t\t\tout = webkit + out + (out.charCodeAt(5) === 102 ? ms + out : '') + out\n\n\t\t\t\t// transitions\n\t\t\t\tif (second + third === 211 && out.charCodeAt(13) === 105 && out.indexOf('transform', 10) > 0) {\n\t\t\t\t\treturn out.substring(0, out.indexOf(';', 27) + 1).replace(transformptn, '$1' + webkit + '$2') + out\n\t\t\t\t}\n\n\t\t\t\tbreak\n\t\t\t}\n\t\t}\n\n\t\treturn out\n\t}\n\n\t/**\n\t * Vendor\n\t *\n\t * @param {string} content\n\t * @param {number} context\n\t * @return {boolean}\n\t */\n\tfunction vendor (content, context) {\n\t\tvar index = content.indexOf(context === 1 ? ':' : '{')\n\t\tvar key = content.substring(0, context !== 3 ? index : 10)\n\t\tvar value = content.substring(index + 1, content.length - 1)\n\n\t\treturn should(context !== 2 ? key : key.replace(pseudofmt, '$1'), value, context)\n\t}\n\n\t/**\n\t * Supports\n\t *\n\t * @param {string} match\n\t * @param {string} group\n\t * @return {string}\n\t */\n\tfunction supports (match, group) {\n\t\tvar out = property(group, group.charCodeAt(0), group.charCodeAt(1), group.charCodeAt(2))\n\n\t\treturn out !== group+';' ? out.replace(propertyptn, ' or ($1)').substring(4) : '('+group+')'\n\t}\n\n\t/**\n\t * Animation\n\t *\n\t * @param {string} input\n\t * @return {string}\n\t */\n\tfunction animation (input) {\n\t\tvar length = input.length\n\t\tvar index = input.indexOf(':', 9) + 1\n\t\tvar declare = input.substring(0, index).trim()\n\t\tvar out = input.substring(index, length-1).trim()\n\n\t\tswitch (input.charCodeAt(9)*keyed) {\n\t\t\tcase 0: {\n\t\t\t\tbreak\n\t\t\t}\n\t\t\t// animation-*, -\n\t\t\tcase DASH: {\n\t\t\t\t// animation-name, n\n\t\t\t\tif (input.charCodeAt(10) !== 110) {\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t}\n\t\t\t// animation/animation-name\n\t\t\tdefault: {\n\t\t\t\t// split in case of multiple animations\n\t\t\t\tvar list = out.split((out = '', animationptn))\n\n\t\t\t\tfor (var i = 0, index = 0, length = list.length; i < length; index = 0, ++i) {\n\t\t\t\t\tvar value = list[i]\n\t\t\t\t\tvar items = value.split(propertiesptn)\n\n\t\t\t\t\twhile (value = items[index]) {\n\t\t\t\t\t\tvar peak = value.charCodeAt(0)\n\n\t\t\t\t\t\tif (keyed === 1 && (\n\t\t\t\t\t\t\t// letters\n\t\t\t\t\t\t\t(peak > AT && peak < 90) || (peak > 96 && peak < 123) || peak === UNDERSCORE ||\n\t\t\t\t\t\t\t// dash but not in sequence i.e --\n\t\t\t\t\t\t\t(peak === DASH && value.charCodeAt(1) !== DASH)\n\t\t\t\t\t\t)) {\n\t\t\t\t\t\t\t// not a number/function\n\t\t\t\t\t\t\tswitch (isNaN(parseFloat(value)) + (value.indexOf('(') !== -1)) {\n\t\t\t\t\t\t\t\tcase 1: {\n\t\t\t\t\t\t\t\t\tswitch (value) {\n\t\t\t\t\t\t\t\t\t\t// not a valid reserved keyword\n\t\t\t\t\t\t\t\t\t\tcase 'infinite': case 'alternate': case 'backwards': case 'running':\n\t\t\t\t\t\t\t\t\t\tcase 'normal': case 'forwards': case 'both': case 'none': case 'linear':\n\t\t\t\t\t\t\t\t\t\tcase 'ease': case 'ease-in': case 'ease-out': case 'ease-in-out':\n\t\t\t\t\t\t\t\t\t\tcase 'paused': case 'reverse': case 'alternate-reverse': case 'inherit':\n\t\t\t\t\t\t\t\t\t\tcase 'initial': case 'unset': case 'step-start': case 'step-end': {\n\t\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\t\t\t\tvalue += key\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\titems[index++] = value\n\t\t\t\t\t}\n\n\t\t\t\t\tout += (i === 0 ? '' : ',') + items.join(' ')\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tout = declare + out + ';'\n\n\t\tif (prefix === 1 || (prefix === 2 && vendor(out, 1)))\n\t\t\treturn webkit + out + out\n\n\t\treturn out\n\t}\n\n\t/**\n\t * Isolate\n\t *\n\t * @param {Array<string>} current\n\t */\n\tfunction isolate (current) {\n\t\tfor (var i = 0, length = current.length, selector = Array(length), padding, element; i < length; ++i) {\n\t\t\t// split individual elements in a selector i.e h1 h2 === [h1, h2]\n\t\t\tvar elements = current[i].split(elementptn)\n\t\t\tvar out = ''\n\n\t\t\tfor (var j = 0, size = 0, tail = 0, code = 0, l = elements.length; j < l; ++j) {\n\t\t\t\t// empty element\n\t\t\t\tif ((size = (element = elements[j]).length) === 0 && l > 1) {\n\t\t\t\t\tcontinue\n\t\t\t\t}\n\n\t\t\t\ttail = out.charCodeAt(out.length-1)\n\t\t\t\tcode = element.charCodeAt(0)\n\t\t\t\tpadding = ''\n\n\t\t\t\tif (j !== 0) {\n\t\t\t\t\t// determine if we need padding\n\t\t\t\t\tswitch (tail) {\n\t\t\t\t\t\tcase STAR:\n\t\t\t\t\t\tcase TILDE:\n\t\t\t\t\t\tcase GREATERTHAN:\n\t\t\t\t\t\tcase PLUS:\n\t\t\t\t\t\tcase SPACE:\n\t\t\t\t\t\tcase OPENPARENTHESES: {\n\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t}\n\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\tpadding = ' '\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tswitch (code) {\n\t\t\t\t\tcase AND: {\n\t\t\t\t\t\telement = padding + nscopealt\n\t\t\t\t\t}\n\t\t\t\t\tcase TILDE:\n\t\t\t\t\tcase GREATERTHAN:\n\t\t\t\t\tcase PLUS:\n\t\t\t\t\tcase SPACE:\n\t\t\t\t\tcase CLOSEPARENTHESES:\n\t\t\t\t\tcase OPENPARENTHESES: {\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t\tcase OPENBRACKET: {\n\t\t\t\t\t\telement = padding + element + nscopealt\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t\tcase COLON: {\n\t\t\t\t\t\tswitch (element.charCodeAt(1)*2 + element.charCodeAt(2)*3) {\n\t\t\t\t\t\t\t// :global\n\t\t\t\t\t\t\tcase 530: {\n\t\t\t\t\t\t\t\tif (escape > 0) {\n\t\t\t\t\t\t\t\t\telement = padding + element.substring(8, size - 1)\n\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t// :hover, :nth-child(), ...\n\t\t\t\t\t\t\tdefault: {\n\t\t\t\t\t\t\t\tif (j < 1 || elements[j-1].length < 1) {\n\t\t\t\t\t\t\t\t\telement = padding + nscopealt + element\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak\n\t\t\t\t\t}\n\t\t\t\t\tcase COMMA: {\n\t\t\t\t\t\tpadding = ''\n\t\t\t\t\t}\n\t\t\t\t\tdefault: {\n\t\t\t\t\t\tif (size > 1 && element.indexOf(':') > 0) {\n\t\t\t\t\t\t\telement = padding + element.replace(pseudoptn, '$1' + nscopealt + '$2')\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\telement = padding + element + nscopealt\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tout += element\n\t\t\t}\n\n\t\t\tselector[i] = out.replace(formatptn, '').trim()\n\t\t}\n\n\t\treturn selector\n\t}\n\n\t/**\n\t * Proxy\n\t *\n\t * @param {number} context\n\t * @param {string} content\n\t * @param {Array<string>} selectors\n\t * @param {Array<string>} parents\n\t * @param {number} line\n\t * @param {number} column\n\t * @param {number} length\n\t * @param {number} id\n\t * @param {number} depth\n\t * @param {number} at\n\t * @return {(string|void|*)}\n\t */\n\tfunction proxy (context, content, selectors, parents, line, column, length, id, depth, at) {\n\t\tfor (var i = 0, out = content, next; i < plugged; ++i) {\n\t\t\tswitch (next = plugins[i].call(stylis, context, out, selectors, parents, line, column, length, id, depth, at)) {\n\t\t\t\tcase void 0:\n\t\t\t\tcase false:\n\t\t\t\tcase true:\n\t\t\t\tcase null: {\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t\tdefault: {\n\t\t\t\t\tout = next\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\tif (out !== content) {\n\t\t return out\n\t\t}\n\t}\n\n\t/**\n\t * @param {number} code\n\t * @param {number} index\n\t * @param {number} length\n\t * @param {string} body\n\t * @return {number}\n\t */\n\tfunction delimited (code, index, length, body) {\n\t\tfor (var i = index + 1; i < length; ++i) {\n\t\t\tswitch (body.charCodeAt(i)) {\n\t\t\t\t// /*\n\t\t\t\tcase FOWARDSLASH: {\n\t\t\t\t\tif (code === STAR) {\n\t\t\t\t\t\tif (body.charCodeAt(i - 1) === STAR && index + 2 !== i) {\n\t\t\t\t\t\t\treturn i + 1\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t\t// //\n\t\t\t\tcase NEWLINE: {\n\t\t\t\t\tif (code === FOWARDSLASH) {\n\t\t\t\t\t\treturn i + 1\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn i\n\t}\n\n\t/**\n\t * @param {number} type\n\t * @param {number} index\n\t * @param {number} length\n\t * @param {number} find\n\t * @param {string} body\n\t * @return {number}\n\t */\n\tfunction match (type, index, length, body) {\n\t\tfor (var i = index + 1; i < length; ++i) {\n\t\t\tswitch (body.charCodeAt(i)) {\n\t\t\t\tcase type: {\n\t\t\t\t\treturn i\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn i\n\t}\n\n\t/**\n\t * Minify\n\t *\n\t * @param {(string|*)} output\n\t * @return {string}\n\t */\n\tfunction minify (output) {\n\t\treturn output\n\t\t\t.replace(formatptn, '')\n\t\t\t.replace(beforeptn, '')\n\t\t\t.replace(afterptn, '$1')\n\t\t\t.replace(tailptn, '$1')\n\t\t\t.replace(whiteptn, ' ')\n\t}\n\n\t/**\n\t * Use\n\t *\n\t * @param {(Array<function(...?)>|function(...?)|number|void)?} plugin\n\t */\n\tfunction use (plugin) {\n\t\tswitch (plugin) {\n\t\t\tcase void 0:\n\t\t\tcase null: {\n\t\t\t\tplugged = plugins.length = 0\n\t\t\t\tbreak\n\t\t\t}\n\t\t\tdefault: {\n\t\t\t\tif (typeof plugin === 'function') {\n\t\t\t\t\tplugins[plugged++] = plugin\n\t\t\t\t}\telse if (typeof plugin === 'object') {\n\t\t\t\t\tfor (var i = 0, length = plugin.length; i < length; ++i) {\n\t\t\t\t\t\tuse(plugin[i])\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tunkwn = !!plugin|0\n\t\t\t\t}\n\t\t\t}\n \t\t}\n\n \t\treturn use\n\t}\n\n\t/**\n\t * Set\n\t *\n\t * @param {*} options\n\t */\n\tfunction set (options) {\n\t\tfor (var name in options) {\n\t\t\tvar value = options[name]\n\t\t\tswitch (name) {\n\t\t\t\tcase 'keyframe': keyed = value|0; break\n\t\t\t\tcase 'global': escape = value|0; break\n\t\t\t\tcase 'cascade': cascade = value|0; break\n\t\t\t\tcase 'compress': compress = value|0; break\n\t\t\t\tcase 'semicolon': semicolon = value|0; break\n\t\t\t\tcase 'preserve': preserve = value|0; break\n\t\t\t\tcase 'prefix':\n\t\t\t\t\tshould = null\n\n\t\t\t\t\tif (!value) {\n\t\t\t\t\t\tprefix = 0\n\t\t\t\t\t} else if (typeof value !== 'function') {\n\t\t\t\t\t\tprefix = 1\n\t\t\t\t\t} else {\n\t\t\t\t\t\tprefix = 2\n\t\t\t\t\t\tshould = value\n\t\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn set\n\t}\n\n\t/**\n\t * Stylis\n\t *\n\t * @param {string} selector\n\t * @param {string} input\n\t * @return {*}\n\t */\n\tfunction stylis (selector, input) {\n\t\tif (this !== void 0 && this.constructor === stylis) {\n\t\t\treturn factory(selector)\n\t\t}\n\n\t\t// setup\n\t\tvar ns = selector\n\t\tvar code = ns.charCodeAt(0)\n\n\t\t// trim leading whitespace\n\t\tif (code < 33) {\n\t\t\tcode = (ns = ns.trim()).charCodeAt(0)\n\t\t}\n\n\t\t// keyframe/animation namespace\n\t\tif (keyed > 0) {\n\t\t\tkey = ns.replace(invalidptn, code === OPENBRACKET ? '' : '-')\n\t\t}\n\n\t\t// reset, used to assert if a plugin is moneky-patching the return value\n\t\tcode = 1\n\n\t\t// cascade/isolate\n\t\tif (cascade === 1) {\n\t\t\tnscope = ns\n\t\t} else {\n\t\t\tnscopealt = ns\n\t\t}\n\n\t\tvar selectors = [nscope]\n\t\tvar result\n\n\t\t// execute plugins, pre-process context\n\t\tif (plugged > 0) {\n\t\t\tresult = proxy(PREPS, input, selectors, selectors, line, column, 0, 0, 0, 0)\n\n\t\t\tif (result !== void 0 && typeof result === 'string') {\n\t\t\t\tinput = result\n\t\t\t}\n\t\t}\n\n\t\t// build\n\t\tvar output = compile(array, selectors, input, 0, 0)\n\n\t\t// execute plugins, post-process context\n\t\tif (plugged > 0) {\n\t\t\tresult = proxy(POSTS, output, selectors, selectors, line, column, output.length, 0, 0, 0)\n\n\t\t\t// bypass minification\n\t\t\tif (result !== void 0 && typeof(output = result) !== 'string') {\n\t\t\t\tcode = 0\n\t\t\t}\n\t\t}\n\n\t\t// reset\n\t\tkey = ''\n\t\tnscope = ''\n\t\tnscopealt = ''\n\t\tpattern = 0\n\t\tline = 1\n\t\tcolumn = 1\n\n\t\treturn compress*code === 0 ? output : minify(output)\n\t}\n\n\tstylis['use'] = use\n\tstylis['set'] = set\n\n\tif (options !== void 0) {\n\t\tset(options)\n\t}\n\n\treturn stylis\n}));\n","var isProduction = process.env.NODE_ENV === 'production';\nvar prefix = 'Invariant failed';\nfunction invariant(condition, message) {\n if (condition) {\n return;\n }\n if (isProduction) {\n throw new Error(prefix);\n }\n var provided = typeof message === 'function' ? message() : message;\n var value = provided ? prefix + \": \" + provided : prefix;\n throw new Error(value);\n}\n\nexport { invariant as default };\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","export default function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}","export default function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nexport default function _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}","export default function _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n return _extends.apply(this, arguments);\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n setPrototypeOf(subClass, superClass);\n}","export default function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n return _setPrototypeOf(o, p);\n}","export default function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}","import arrayLikeToArray from \"./arrayLikeToArray.js\";\nexport default function _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}","/**\n * The current status of a query’s execution in our system.\n */\nexport enum NetworkStatus {\n /**\n * The query has never been run before and the query is now currently running. A query will still\n * have this network status even if a partial data result was returned from the cache, but a\n * query was dispatched anyway.\n */\n loading = 1,\n\n /**\n * If `setVariables` was called and a query was fired because of that then the network status\n * will be `setVariables` until the result of that query comes back.\n */\n setVariables = 2,\n\n /**\n * Indicates that `fetchMore` was called on this query and that the query created is currently in\n * flight.\n */\n fetchMore = 3,\n\n /**\n * Similar to the `setVariables` network status. It means that `refetch` was called on a query\n * and the refetch request is currently in flight.\n */\n refetch = 4,\n\n /**\n * Indicates that a polling query is currently in flight. So for example if you are polling a\n * query every 10 seconds then the network status will switch to `poll` every 10 seconds whenever\n * a poll request has been sent but not resolved.\n */\n poll = 6,\n\n /**\n * No request is in flight for this query, and no errors happened. Everything is OK.\n */\n ready = 7,\n\n /**\n * No request is in flight for this query, but one or more errors were detected.\n */\n error = 8,\n}\n\n/**\n * Returns true if there is currently a network request in flight according to a given network\n * status.\n */\nexport function isNetworkRequestInFlight(\n networkStatus?: NetworkStatus,\n): boolean {\n return networkStatus ? networkStatus < 7 : false;\n}\n","import '../utilities/globals';\n\nimport { GraphQLError } from 'graphql';\n\nimport { isNonEmptyArray } from '../utilities';\nimport { ServerParseError } from '../link/http';\nimport { ServerError } from '../link/utils';\n\nexport function isApolloError(err: Error): err is ApolloError {\n return err.hasOwnProperty('graphQLErrors');\n}\n\n// Sets the error message on this error according to the\n// the GraphQL and network errors that are present.\n// If the error message has already been set through the\n// constructor or otherwise, this function is a nop.\nconst generateErrorMessage = (err: ApolloError) => {\n let message = '';\n // If we have GraphQL errors present, add that to the error message.\n if (isNonEmptyArray(err.graphQLErrors) || isNonEmptyArray(err.clientErrors)) {\n const errors = ((err.graphQLErrors || []) as readonly Error[])\n .concat(err.clientErrors || []);\n errors.forEach((error: Error) => {\n const errorMessage = error\n ? error.message\n : 'Error message not found.';\n message += `${errorMessage}\\n`;\n });\n }\n\n if (err.networkError) {\n message += `${err.networkError.message}\\n`;\n }\n\n // strip newline from the end of the message\n message = message.replace(/\\n$/, '');\n return message;\n};\n\nexport type GraphQLErrors = ReadonlyArray<GraphQLError>;\n\nexport type NetworkError = Error | ServerParseError | ServerError | null;\n\nexport class ApolloError extends Error {\n public message: string;\n public graphQLErrors: GraphQLErrors;\n public clientErrors: ReadonlyArray<Error>;\n public networkError: Error | ServerParseError | ServerError | null;\n\n // An object that can be used to provide some additional information\n // about an error, e.g. specifying the type of error this is. Used\n // internally within Apollo Client.\n public extraInfo: any;\n\n // Constructs an instance of ApolloError given a GraphQLError\n // or a network error. Note that one of these has to be a valid\n // value or the constructed error will be meaningless.\n constructor({\n graphQLErrors,\n clientErrors,\n networkError,\n errorMessage,\n extraInfo,\n }: {\n graphQLErrors?: ReadonlyArray<GraphQLError>;\n clientErrors?: ReadonlyArray<Error>;\n networkError?: Error | ServerParseError | ServerError | null;\n errorMessage?: string;\n extraInfo?: any;\n }) {\n super(errorMessage);\n this.graphQLErrors = graphQLErrors || [];\n this.clientErrors = clientErrors || [];\n this.networkError = networkError || null;\n this.message = errorMessage || generateErrorMessage(this);\n this.extraInfo = extraInfo;\n\n // We're not using `Object.setPrototypeOf` here as it isn't fully\n // supported on Android (see issue #3236).\n (this as any).__proto__ = ApolloError.prototype;\n }\n}\n","import * as React from 'react';\nimport { ApolloClient } from '../../core';\nimport { canUseSymbol } from '../../utilities';\nimport type { RenderPromises } from '../ssr';\n\nexport interface ApolloContextValue {\n client?: ApolloClient<object>;\n renderPromises?: RenderPromises;\n}\n\n// To make sure Apollo Client doesn't create more than one React context\n// (which can lead to problems like having an Apollo Client instance added\n// in one context, then attempting to retrieve it from another different\n// context), a single Apollo context is created and tracked in global state.\nconst contextKey = canUseSymbol\n ? Symbol.for('__APOLLO_CONTEXT__')\n : '__APOLLO_CONTEXT__';\n\nexport function getApolloContext(): React.Context<ApolloContextValue> {\n let context = (React.createContext as any)[contextKey] as React.Context<ApolloContextValue>;\n if (!context) {\n Object.defineProperty(React.createContext, contextKey, {\n value: context = React.createContext<ApolloContextValue>({}),\n enumerable: false,\n writable: false,\n configurable: true,\n });\n context.displayName = 'ApolloContext';\n }\n return context;\n}\n\nexport { getApolloContext as resetApolloContext }\n","export function isNonEmptyArray<T>(value?: ArrayLike<T>): value is Array<T> {\n return Array.isArray(value) && value.length > 0;\n}\n","import { maybe } from \"../globals\";\n\nexport const canUseWeakMap =\n typeof WeakMap === 'function' &&\n maybe(() => navigator.product) !== 'ReactNative';\n\nexport const canUseWeakSet = typeof WeakSet === 'function';\n\nexport const canUseSymbol =\n typeof Symbol === 'function' &&\n typeof Symbol.for === 'function';\n\nexport const canUseDOM =\n typeof maybe(() => window.document.createElement) === \"function\";\n\nconst usingJSDOM: boolean =\n // Following advice found in this comment from @domenic (maintainer of jsdom):\n // https://github.com/jsdom/jsdom/issues/1537#issuecomment-229405327\n //\n // Since we control the version of Jest and jsdom used when running Apollo\n // Client tests, and that version is recent enought to include \" jsdom/x.y.z\"\n // at the end of the user agent string, I believe this case is all we need to\n // check. Testing for \"Node.js\" was recommended for backwards compatibility\n // with older version of jsdom, but we don't have that problem.\n maybe(() => navigator.userAgent.indexOf(\"jsdom\") >= 0) || false;\n\n// Our tests should all continue to pass if we remove this !usingJSDOM\n// condition, thereby allowing useLayoutEffect when using jsdom. Unfortunately,\n// if we allow useLayoutEffect, then useSyncExternalStore generates many\n// warnings about useLayoutEffect doing nothing on the server. While these\n// warnings are harmless, this !usingJSDOM condition seems to be the best way to\n// prevent them (i.e. skipping useLayoutEffect when using jsdom).\nexport const canUseLayoutEffect = canUseDOM && !usingJSDOM;\n","import { TupleToIntersection } from './mergeDeep';\n\n/**\n * Merges the provided objects shallowly and removes\n * all properties with an `undefined` value\n */\nexport function compact<TArgs extends any[]>(\n ...objects: TArgs\n): TupleToIntersection<TArgs> {\n const result = Object.create(null);\n\n objects.forEach(obj => {\n if (!obj) return;\n Object.keys(obj).forEach(key => {\n const value = (obj as any)[key];\n if (value !== void 0) {\n result[key] = value;\n }\n });\n });\n\n return result;\n}\n","import '../globals'; // For __DEV__\nimport { isNonNullObject } from './objects';\n\nfunction deepFreeze(value: any) {\n const workSet = new Set([value]);\n workSet.forEach(obj => {\n if (isNonNullObject(obj) && shallowFreeze(obj) === obj) {\n Object.getOwnPropertyNames(obj).forEach(name => {\n if (isNonNullObject(obj[name])) workSet.add(obj[name]);\n });\n }\n });\n return value;\n}\n\nfunction shallowFreeze<T extends object>(obj: T): T | null {\n if (__DEV__ && !Object.isFrozen(obj)) {\n try {\n Object.freeze(obj);\n } catch (e) {\n // Some types like Uint8Array and Node.js's Buffer cannot be frozen, but\n // they all throw a TypeError when you try, so we re-throw any exceptions\n // that are not TypeErrors, since that would be unexpected.\n if (e instanceof TypeError) return null;\n throw e;\n }\n }\n return obj;\n}\n\nexport function maybeDeepFreeze<T>(obj: T): T {\n if (__DEV__) {\n deepFreeze(obj);\n }\n return obj;\n}\n","import type {\n QueryOptions,\n WatchQueryOptions,\n MutationOptions,\n} from \"../../core\";\n\nimport { compact } from \"./compact\";\n\ntype OptionsUnion<TData, TVariables, TContext> =\n | WatchQueryOptions<TVariables, TData>\n | QueryOptions<TVariables, TData>\n | MutationOptions<TData, TVariables, TContext>;\n\nexport function mergeOptions<\n TOptions extends OptionsUnion<any, any, any>\n>(\n defaults: TOptions | Partial<TOptions> | undefined,\n options: TOptions | Partial<TOptions>,\n): TOptions {\n return compact(defaults, options, options.variables && {\n variables: {\n ...(defaults && defaults.variables),\n ...options.variables,\n },\n });\n}\n","export function isNonNullObject(obj: any): obj is Record<string | number, any> {\n return obj !== null && typeof obj === 'object';\n}\n","const genericMessage = \"Invariant Violation\";\nconst {\n setPrototypeOf = function (obj: any, proto: any) {\n obj.__proto__ = proto;\n return obj;\n },\n} = Object as any;\n\nexport class InvariantError extends Error {\n framesToPop = 1;\n name = genericMessage;\n constructor(message: string | number = genericMessage) {\n super(\n typeof message === \"number\"\n ? `${genericMessage}: ${message} (see https://github.com/apollographql/invariant-packages)`\n : message\n );\n setPrototypeOf(this, InvariantError.prototype);\n }\n}\n\nexport function invariant(\n condition: any,\n message?: string | number,\n): asserts condition {\n if (!condition) {\n throw new InvariantError(message);\n }\n}\n\nconst verbosityLevels = [\"debug\", \"log\", \"warn\", \"error\", \"silent\"] as const;\nexport type VerbosityLevel = (typeof verbosityLevels)[number];\nexport type ConsoleMethodName = Exclude<VerbosityLevel, \"silent\">;\nlet verbosityLevel = verbosityLevels.indexOf(\"log\");\n\nfunction wrapConsoleMethod<M extends ConsoleMethodName>(name: M) {\n return function () {\n if (verbosityLevels.indexOf(name) >= verbosityLevel) {\n // Default to console.log if this host environment happens not to provide\n // all the console.* methods we need.\n const method = console[name] || console.log;\n return method.apply(console, arguments as any);\n }\n } as (typeof console)[M];\n}\n\nexport namespace invariant {\n export const debug = wrapConsoleMethod(\"debug\");\n export const log = wrapConsoleMethod(\"log\");\n export const warn = wrapConsoleMethod(\"warn\");\n export const error = wrapConsoleMethod(\"error\");\n}\n\nexport function setVerbosity(level: VerbosityLevel): VerbosityLevel {\n const old = verbosityLevels[verbosityLevel];\n verbosityLevel = Math.max(0, verbosityLevels.indexOf(level));\n return old;\n}\n\nexport default invariant;\n","export function maybe<T>(thunk: () => T): T | undefined {\n try { return thunk() } catch {}\n}\n","import { maybe } from \"./maybe\";\n\ndeclare global {\n // Despite our attempts to reuse the React Native __DEV__ constant instead of\n // inventing something new and Apollo-specific, declaring a useful type for\n // __DEV__ unfortunately conflicts (TS2451) with the global declaration in\n // @types/react-native/index.d.ts.\n //\n // To hide that harmless conflict, we @ts-ignore this line, which should\n // continue to provide a type for __DEV__ elsewhere in the Apollo Client\n // codebase, even when @types/react-native is not in use.\n //\n // However, because TypeScript drops @ts-ignore comments when generating .d.ts\n // files (https://github.com/microsoft/TypeScript/issues/38628), we also\n // sanitize the dist/utilities/globals/global.d.ts file to avoid declaring\n // __DEV__ globally altogether when @apollo/client is installed in the\n // node_modules directory of an application.\n //\n // @ts-ignore\n const __DEV__: boolean | undefined;\n}\n\nexport default (\n maybe(() => globalThis) ||\n maybe(() => window) ||\n maybe(() => self) ||\n maybe(() => global) ||\n // We don't expect the Function constructor ever to be invoked at runtime, as\n // long as at least one of globalThis, window, self, or global is defined, so\n // we are under no obligation to make it easy for static analysis tools to\n // detect syntactic usage of the Function constructor. If you think you can\n // improve your static analysis to detect this obfuscation, think again. This\n // is an arms race you cannot win, at least not in JavaScript.\n maybe(function() { return maybe.constructor(\"return this\")() })\n) as typeof globalThis & {\n __DEV__: typeof __DEV__;\n};\n","import global from \"./global\";\nimport { maybe } from \"./maybe\";\n\n// To keep string-based find/replace minifiers from messing with __DEV__ inside\n// string literals or properties like global.__DEV__, we construct the \"__DEV__\"\n// string in a roundabout way that won't be altered by find/replace strategies.\nconst __ = \"__\";\nconst GLOBAL_KEY = [__, __].join(\"DEV\");\n\nfunction getDEV() {\n try {\n return Boolean(__DEV__);\n } catch {\n Object.defineProperty(global, GLOBAL_KEY, {\n // In a buildless browser environment, maybe(() => process.env.NODE_ENV)\n // evaluates as undefined, so __DEV__ becomes true by default, but can be\n // initialized to false instead by a script/module that runs earlier.\n value: maybe(() => process.env.NODE_ENV) !== \"production\",\n enumerable: false,\n configurable: true,\n writable: true,\n });\n // Using computed property access rather than global.__DEV__ here prevents\n // string-based find/replace strategies from munging this to global.false:\n return (global as any)[GLOBAL_KEY];\n }\n}\n\nexport default getDEV();\n","function maybe(thunk) {\n try { return thunk() } catch (_) {}\n}\n\nvar safeGlobal = (\n maybe(function() { return globalThis }) ||\n maybe(function() { return window }) ||\n maybe(function() { return self }) ||\n maybe(function() { return global }) ||\n // We don't expect the Function constructor ever to be invoked at runtime, as\n // long as at least one of globalThis, window, self, or global is defined, so\n // we are under no obligation to make it easy for static analysis tools to\n // detect syntactic usage of the Function constructor. If you think you can\n // improve your static analysis to detect this obfuscation, think again. This\n // is an arms race you cannot win, at least not in JavaScript.\n maybe(function() { return maybe.constructor(\"return this\")() })\n);\n\nvar needToRemove = false;\n\nexport function install() {\n if (safeGlobal &&\n !maybe(function() { return process.env.NODE_ENV }) &&\n !maybe(function() { return process })) {\n Object.defineProperty(safeGlobal, \"process\", {\n value: {\n env: {\n // This default needs to be \"production\" instead of \"development\", to\n // avoid the problem https://github.com/graphql/graphql-js/pull/2894\n // will eventually solve, once merged and released.\n NODE_ENV: \"production\",\n },\n },\n // Let anyone else change global.process as they see fit, but hide it from\n // Object.keys(global) enumeration.\n configurable: true,\n enumerable: false,\n writable: true,\n });\n needToRemove = true;\n }\n}\n\n// Call install() at least once, when this module is imported.\ninstall();\n\nexport function remove() {\n if (needToRemove) {\n delete safeGlobal.process;\n needToRemove = false;\n }\n}\n","// 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","// The ordering of these imports is important, because it ensures the temporary\n// process.env.NODE_ENV polyfill is defined globally (if necessary) before we\n// import { Source } from 'graphql'. The instanceOf function that we really care\n// about (the one that uses process.env.NODE_ENV) is not exported from the\n// top-level graphql package, but graphql/language/source uses instanceOf, and\n// has relatively few dependencies, so importing it here should not increase\n// bundle sizes as much as other options.\nimport { remove } from 'ts-invariant/process';\nimport { Source } from 'graphql';\n\nexport function removeTemporaryGlobals() {\n // Using Source here here just to make sure it won't be tree-shaken away.\n return typeof Source === \"function\" ? remove() : remove();\n}\n","import { invariant, InvariantError } from \"ts-invariant\";\n\n// Just in case the graphql package switches from process.env.NODE_ENV to\n// __DEV__, make sure __DEV__ is polyfilled before importing graphql.\nimport DEV from \"./DEV\";\nexport { DEV }\nexport function checkDEV() {\n invariant(\"boolean\" === typeof DEV, DEV);\n}\n\n// Import graphql/jsutils/instanceOf safely, working around its unchecked usage\n// of process.env.NODE_ENV and https://github.com/graphql/graphql-js/pull/2894.\nimport { removeTemporaryGlobals } from \"./fix-graphql\";\n\n// Synchronously undo the global process.env.NODE_ENV polyfill that we created\n// temporarily while importing the offending graphql/jsutils/instanceOf module.\nremoveTemporaryGlobals();\n\nexport { maybe } from \"./maybe\";\nexport { default as global } from \"./global\";\nexport { invariant, InvariantError }\n\n// Ensure __DEV__ was properly initialized, and prevent tree-shaking bundlers\n// from mistakenly pruning the ./DEV module (see issue #8674).\ncheckDEV();\n","function _typeof(obj) { \"@babel/helpers - typeof\"; if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n/* eslint-disable flowtype/no-weak-types */\nimport nodejsCustomInspectSymbol from \"./nodejsCustomInspectSymbol.mjs\";\nvar MAX_ARRAY_LENGTH = 10;\nvar MAX_RECURSIVE_DEPTH = 2;\n/**\n * Used to print values in error messages.\n */\n\nexport default function inspect(value) {\n return formatValue(value, []);\n}\n\nfunction formatValue(value, seenValues) {\n switch (_typeof(value)) {\n case 'string':\n return JSON.stringify(value);\n\n case 'function':\n return value.name ? \"[function \".concat(value.name, \"]\") : '[function]';\n\n case 'object':\n if (value === null) {\n return 'null';\n }\n\n return formatObjectValue(value, seenValues);\n\n default:\n return String(value);\n }\n}\n\nfunction formatObjectValue(value, previouslySeenValues) {\n if (previouslySeenValues.indexOf(value) !== -1) {\n return '[Circular]';\n }\n\n var seenValues = [].concat(previouslySeenValues, [value]);\n var customInspectFn = getCustomFn(value);\n\n if (customInspectFn !== undefined) {\n var customValue = customInspectFn.call(value); // check for infinite recursion\n\n if (customValue !== value) {\n return typeof customValue === 'string' ? customValue : formatValue(customValue, seenValues);\n }\n } else if (Array.isArray(value)) {\n return formatArray(value, seenValues);\n }\n\n return formatObject(value, seenValues);\n}\n\nfunction formatObject(object, seenValues) {\n var keys = Object.keys(object);\n\n if (keys.length === 0) {\n return '{}';\n }\n\n if (seenValues.length > MAX_RECURSIVE_DEPTH) {\n return '[' + getObjectTag(object) + ']';\n }\n\n var properties = keys.map(function (key) {\n var value = formatValue(object[key], seenValues);\n return key + ': ' + value;\n });\n return '{ ' + properties.join(', ') + ' }';\n}\n\nfunction formatArray(array, seenValues) {\n if (array.length === 0) {\n return '[]';\n }\n\n if (seenValues.length > MAX_RECURSIVE_DEPTH) {\n return '[Array]';\n }\n\n var len = Math.min(MAX_ARRAY_LENGTH, array.length);\n var remaining = array.length - len;\n var items = [];\n\n for (var i = 0; i < len; ++i) {\n items.push(formatValue(array[i], seenValues));\n }\n\n if (remaining === 1) {\n items.push('... 1 more item');\n } else if (remaining > 1) {\n items.push(\"... \".concat(remaining, \" more items\"));\n }\n\n return '[' + items.join(', ') + ']';\n}\n\nfunction getCustomFn(object) {\n var customInspectFn = object[String(nodejsCustomInspectSymbol)];\n\n if (typeof customInspectFn === 'function') {\n return customInspectFn;\n }\n\n if (typeof object.inspect === 'function') {\n return object.inspect;\n }\n}\n\nfunction getObjectTag(object) {\n var tag = Object.prototype.toString.call(object).replace(/^\\[object /, '').replace(/]$/, '');\n\n if (tag === 'Object' && typeof object.constructor === 'function') {\n var name = object.constructor.name;\n\n if (typeof name === 'string' && name !== '') {\n return name;\n }\n }\n\n return tag;\n}\n","// istanbul ignore next (See: 'https://github.com/graphql/graphql-js/issues/2317')\nvar nodejsCustomInspectSymbol = typeof Symbol === 'function' && typeof Symbol.for === 'function' ? Symbol.for('nodejs.util.inspect.custom') : undefined;\nexport default nodejsCustomInspectSymbol;\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__);\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n\t__webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach((key) => (def[key] = () => (value[key])));\n\t}\n\tdef['default'] = () => (value);\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"static/js/\" + chunkId + \".\" + {\"67\":\"a7170863\",\"111\":\"a655442c\",\"320\":\"0c46507c\",\"457\":\"f992cf5b\",\"506\":\"15888891\",\"571\":\"701047a2\",\"635\":\"d66b800c\",\"868\":\"4c42b742\"}[chunkId] + \".chunk.js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = (chunkId) => {\n\t// return url for filenames based on template\n\treturn undefined;\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","var inProgress = {};\nvar dataWebpackPrefix = \"nicholas-lazzerini-website:\";\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\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\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};","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.nmd = (module) => {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","__webpack_require__.p = \"/\";","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t179: 0\n};\n\n__webpack_require__.f.j = (chunkId, promises) => {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise((resolve, reject) => (installedChunkData = installedChunks[chunkId] = [resolve, reject]));\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = (event) => {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t} else installedChunks[chunkId] = 0;\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = (parentChunkLoadingFunction, data) => {\n\tvar [chunkIds, moreModules, runtime] = data;\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some((id) => (installedChunks[id] !== 0))) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunknicholas_lazzerini_website\"] = self[\"webpackChunknicholas_lazzerini_website\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","__webpack_require__.nc = undefined;","import { invariant } from '../../utilities/globals';\n\nimport * as React from 'react';\n\nimport { ApolloClient } from '../../core';\nimport { getApolloContext } from './ApolloContext';\n\nexport interface ApolloProviderProps<TCache> {\n client: ApolloClient<TCache>;\n children: React.ReactNode | React.ReactNode[] | null;\n}\n\nexport const ApolloProvider: React.FC<ApolloProviderProps<any>> = ({\n client,\n children\n}) => {\n const ApolloContext = getApolloContext();\n return (\n <ApolloContext.Consumer>\n {(context: any = {}) => {\n if (client && context.client !== client) {\n context = Object.assign({}, context, { client });\n }\n\n invariant(\n context.client,\n 'ApolloProvider was not passed a client instance. Make ' +\n 'sure you pass in your client via the \"client\" prop.'\n );\n\n return (\n <ApolloContext.Provider value={context}>\n {children}\n </ApolloContext.Provider>\n );\n }}\n </ApolloContext.Consumer>\n );\n};\n","import invariant from \"./invariant.mjs\";\nimport nodejsCustomInspectSymbol from \"./nodejsCustomInspectSymbol.mjs\";\n/**\n * The `defineInspect()` function defines `inspect()` prototype method as alias of `toJSON`\n */\n\nexport default function defineInspect(classObject) {\n var fn = classObject.prototype.toJSON;\n typeof fn === 'function' || invariant(0);\n classObject.prototype.inspect = fn; // istanbul ignore else (See: 'https://github.com/graphql/graphql-js/issues/2317')\n\n if (nodejsCustomInspectSymbol) {\n classObject.prototype[nodejsCustomInspectSymbol] = fn;\n }\n}\n","export default function invariant(condition, message) {\n var booleanCondition = Boolean(condition); // istanbul ignore else (See transformation done in './resources/inlineInvariant.js')\n\n if (!booleanCondition) {\n throw new Error(message != null ? message : 'Unexpected invariant triggered.');\n }\n}\n","import defineInspect from \"../jsutils/defineInspect.mjs\";\n\n/**\n * Contains a range of UTF-8 character offsets and token references that\n * identify the region of the source from which the AST derived.\n */\nexport var Location = /*#__PURE__*/function () {\n /**\n * The character offset at which this Node begins.\n */\n\n /**\n * The character offset at which this Node ends.\n */\n\n /**\n * The Token at which this Node begins.\n */\n\n /**\n * The Token at which this Node ends.\n */\n\n /**\n * The Source document the AST represents.\n */\n function Location(startToken, endToken, source) {\n this.start = startToken.start;\n this.end = endToken.end;\n this.startToken = startToken;\n this.endToken = endToken;\n this.source = source;\n }\n\n var _proto = Location.prototype;\n\n _proto.toJSON = function toJSON() {\n return {\n start: this.start,\n end: this.end\n };\n };\n\n return Location;\n}(); // Print a simplified form when appearing in `inspect` and `util.inspect`.\n\ndefineInspect(Location);\n/**\n * Represents a range of characters represented by a lexical token\n * within a Source.\n */\n\nexport var Token = /*#__PURE__*/function () {\n /**\n * The kind of Token.\n */\n\n /**\n * The character offset at which this Node begins.\n */\n\n /**\n * The character offset at which this Node ends.\n */\n\n /**\n * The 1-indexed line number on which this Token appears.\n */\n\n /**\n * The 1-indexed column number at which this Token begins.\n */\n\n /**\n * For non-punctuation tokens, represents the interpreted value of the token.\n */\n\n /**\n * Tokens exist as nodes in a double-linked-list amongst all tokens\n * including ignored tokens. <SOF> is always the first node and <EOF>\n * the last.\n */\n function Token(kind, start, end, line, column, prev, value) {\n this.kind = kind;\n this.start = start;\n this.end = end;\n this.line = line;\n this.column = column;\n this.value = value;\n this.prev = prev;\n this.next = null;\n }\n\n var _proto2 = Token.prototype;\n\n _proto2.toJSON = function toJSON() {\n return {\n kind: this.kind,\n value: this.value,\n line: this.line,\n column: this.column\n };\n };\n\n return Token;\n}(); // Print a simplified form when appearing in `inspect` and `util.inspect`.\n\ndefineInspect(Token);\n/**\n * @internal\n */\n\nexport function isNode(maybeNode) {\n return maybeNode != null && typeof maybeNode.kind === 'string';\n}\n/**\n * The list of all possible AST node types.\n */\n","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","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 { invariant, InvariantError } from '../globals';\n\nimport {\n DocumentNode,\n FragmentDefinitionNode,\n InlineFragmentNode,\n SelectionNode,\n} from 'graphql';\n\n// TODO(brian): A hack until this issue is resolved (https://github.com/graphql/graphql-js/issues/3356)\ntype Kind = any;\ntype OperationTypeNode = any;\n/**\n * Returns a query document which adds a single query operation that only\n * spreads the target fragment inside of it.\n *\n * So for example a document of:\n *\n * ```graphql\n * fragment foo on Foo { a b c }\n * ```\n *\n * Turns into:\n *\n * ```graphql\n * { ...foo }\n *\n * fragment foo on Foo { a b c }\n * ```\n *\n * The target fragment will either be the only fragment in the document, or a\n * fragment specified by the provided `fragmentName`. If there is more than one\n * fragment, but a `fragmentName` was not defined then an error will be thrown.\n */\nexport function getFragmentQueryDocument(\n document: DocumentNode,\n fragmentName?: string,\n): DocumentNode {\n let actualFragmentName = fragmentName;\n\n // Build an array of all our fragment definitions that will be used for\n // validations. We also do some validations on the other definitions in the\n // document while building this list.\n const fragments: Array<FragmentDefinitionNode> = [];\n document.definitions.forEach(definition => {\n // Throw an error if we encounter an operation definition because we will\n // define our own operation definition later on.\n if (definition.kind === 'OperationDefinition') {\n throw new InvariantError(\n `Found a ${definition.operation} operation${\n definition.name ? ` named '${definition.name.value}'` : ''\n }. ` +\n 'No operations are allowed when using a fragment as a query. Only fragments are allowed.',\n );\n }\n // Add our definition to the fragments array if it is a fragment\n // definition.\n if (definition.kind === 'FragmentDefinition') {\n fragments.push(definition);\n }\n });\n\n // If the user did not give us a fragment name then let us try to get a\n // name from a single fragment in the definition.\n if (typeof actualFragmentName === 'undefined') {\n invariant(\n fragments.length === 1,\n `Found ${\n fragments.length\n } fragments. \\`fragmentName\\` must be provided when there is not exactly 1 fragment.`,\n );\n actualFragmentName = fragments[0].name.value;\n }\n\n // Generate a query document with an operation that simply spreads the\n // fragment inside of it.\n const query: DocumentNode = {\n ...document,\n definitions: [\n {\n kind: 'OperationDefinition' as Kind,\n // OperationTypeNode is an enum\n operation: 'query' as OperationTypeNode,\n selectionSet: {\n kind: 'SelectionSet' as Kind,\n selections: [\n {\n kind: 'FragmentSpread' as Kind,\n name: {\n kind: 'Name' as Kind,\n value: actualFragmentName,\n },\n },\n ],\n },\n },\n ...document.definitions,\n ],\n };\n\n return query;\n}\n\n/**\n * This is an interface that describes a map from fragment names to fragment definitions.\n */\nexport interface FragmentMap {\n [fragmentName: string]: FragmentDefinitionNode;\n}\n\n// Utility function that takes a list of fragment definitions and makes a hash out of them\n// that maps the name of the fragment to the fragment definition.\nexport function createFragmentMap(\n fragments: FragmentDefinitionNode[] = [],\n): FragmentMap {\n const symTable: FragmentMap = {};\n fragments.forEach(fragment => {\n symTable[fragment.name.value] = fragment;\n });\n return symTable;\n}\n\nexport function getFragmentFromSelection(\n selection: SelectionNode,\n fragmentMap?: FragmentMap,\n): InlineFragmentNode | FragmentDefinitionNode | null {\n switch (selection.kind) {\n case 'InlineFragment':\n return selection;\n case 'FragmentSpread': {\n const fragment = fragmentMap && fragmentMap[selection.name.value];\n invariant(fragment, `No fragment named ${selection.name.value}.`);\n return fragment!;\n }\n default:\n return null;\n }\n}\n","import { InvariantError } from '../globals';\n\nimport {\n DirectiveNode,\n FieldNode,\n IntValueNode,\n FloatValueNode,\n StringValueNode,\n BooleanValueNode,\n ObjectValueNode,\n ListValueNode,\n EnumValueNode,\n NullValueNode,\n VariableNode,\n InlineFragmentNode,\n ValueNode,\n SelectionNode,\n NameNode,\n SelectionSetNode,\n DocumentNode,\n} from 'graphql';\n\nimport { isNonNullObject } from '../common/objects';\nimport { FragmentMap, getFragmentFromSelection } from './fragments';\n\nexport interface Reference {\n readonly __ref: string;\n}\n\nexport function makeReference(id: string): Reference {\n return { __ref: String(id) };\n}\n\nexport function isReference(obj: any): obj is Reference {\n return Boolean(obj && typeof obj === 'object' && typeof obj.__ref === 'string');\n}\n\nexport type StoreValue =\n | number\n | string\n | string[]\n | Reference\n | Reference[]\n | null\n | undefined\n | void\n | Object;\n\nexport interface StoreObject {\n __typename?: string;\n [storeFieldName: string]: StoreValue;\n}\n\nexport function isDocumentNode(value: any): value is DocumentNode {\n return (\n isNonNullObject(value) &&\n (value as DocumentNode).kind === \"Document\" &&\n Array.isArray((value as DocumentNode).definitions)\n );\n}\n\nfunction isStringValue(value: ValueNode): value is StringValueNode {\n return value.kind === 'StringValue';\n}\n\nfunction isBooleanValue(value: ValueNode): value is BooleanValueNode {\n return value.kind === 'BooleanValue';\n}\n\nfunction isIntValue(value: ValueNode): value is IntValueNode {\n return value.kind === 'IntValue';\n}\n\nfunction isFloatValue(value: ValueNode): value is FloatValueNode {\n return value.kind === 'FloatValue';\n}\n\nfunction isVariable(value: ValueNode): value is VariableNode {\n return value.kind === 'Variable';\n}\n\nfunction isObjectValue(value: ValueNode): value is ObjectValueNode {\n return value.kind === 'ObjectValue';\n}\n\nfunction isListValue(value: ValueNode): value is ListValueNode {\n return value.kind === 'ListValue';\n}\n\nfunction isEnumValue(value: ValueNode): value is EnumValueNode {\n return value.kind === 'EnumValue';\n}\n\nfunction isNullValue(value: ValueNode): value is NullValueNode {\n return value.kind === 'NullValue';\n}\n\nexport function valueToObjectRepresentation(\n argObj: any,\n name: NameNode,\n value: ValueNode,\n variables?: Object,\n) {\n if (isIntValue(value) || isFloatValue(value)) {\n argObj[name.value] = Number(value.value);\n } else if (isBooleanValue(value) || isStringValue(value)) {\n argObj[name.value] = value.value;\n } else if (isObjectValue(value)) {\n const nestedArgObj = {};\n value.fields.map(obj =>\n valueToObjectRepresentation(nestedArgObj, obj.name, obj.value, variables),\n );\n argObj[name.value] = nestedArgObj;\n } else if (isVariable(value)) {\n const variableValue = (variables || ({} as any))[value.name.value];\n argObj[name.value] = variableValue;\n } else if (isListValue(value)) {\n argObj[name.value] = value.values.map(listValue => {\n const nestedArgArrayObj = {};\n valueToObjectRepresentation(\n nestedArgArrayObj,\n name,\n listValue,\n variables,\n );\n return (nestedArgArrayObj as any)[name.value];\n });\n } else if (isEnumValue(value)) {\n argObj[name.value] = (value as EnumValueNode).value;\n } else if (isNullValue(value)) {\n argObj[name.value] = null;\n } else {\n throw new InvariantError(\n `The inline argument \"${name.value}\" of kind \"${(value as any).kind}\"` +\n 'is not supported. Use variables instead of inline arguments to ' +\n 'overcome this limitation.',\n );\n }\n}\n\nexport function storeKeyNameFromField(\n field: FieldNode,\n variables?: Object,\n): string {\n let directivesObj: any = null;\n if (field.directives) {\n directivesObj = {};\n field.directives.forEach(directive => {\n directivesObj[directive.name.value] = {};\n\n if (directive.arguments) {\n directive.arguments.forEach(({ name, value }) =>\n valueToObjectRepresentation(\n directivesObj[directive.name.value],\n name,\n value,\n variables,\n ),\n );\n }\n });\n }\n\n let argObj: any = null;\n if (field.arguments && field.arguments.length) {\n argObj = {};\n field.arguments.forEach(({ name, value }) =>\n valueToObjectRepresentation(argObj, name, value, variables),\n );\n }\n\n return getStoreKeyName(field.name.value, argObj, directivesObj);\n}\n\nexport type Directives = {\n [directiveName: string]: {\n [argName: string]: any;\n };\n};\n\nconst KNOWN_DIRECTIVES: string[] = [\n 'connection',\n 'include',\n 'skip',\n 'client',\n 'rest',\n 'export',\n];\n\nexport const getStoreKeyName = Object.assign(function (\n fieldName: string,\n args?: Record<string, any> | null,\n directives?: Directives,\n): string {\n if (\n args &&\n directives &&\n directives['connection'] &&\n directives['connection']['key']\n ) {\n if (\n directives['connection']['filter'] &&\n (directives['connection']['filter'] as string[]).length > 0\n ) {\n const filterKeys = directives['connection']['filter']\n ? (directives['connection']['filter'] as string[])\n : [];\n filterKeys.sort();\n\n const filteredArgs = {} as { [key: string]: any };\n filterKeys.forEach(key => {\n filteredArgs[key] = args[key];\n });\n\n return `${directives['connection']['key']}(${stringify(\n filteredArgs,\n )})`;\n } else {\n return directives['connection']['key'];\n }\n }\n\n let completeFieldName: string = fieldName;\n\n if (args) {\n // We can't use `JSON.stringify` here since it's non-deterministic,\n // and can lead to different store key names being created even though\n // the `args` object used during creation has the same properties/values.\n const stringifiedArgs: string = stringify(args);\n completeFieldName += `(${stringifiedArgs})`;\n }\n\n if (directives) {\n Object.keys(directives).forEach(key => {\n if (KNOWN_DIRECTIVES.indexOf(key) !== -1) return;\n if (directives[key] && Object.keys(directives[key]).length) {\n completeFieldName += `@${key}(${stringify(directives[key])})`;\n } else {\n completeFieldName += `@${key}`;\n }\n });\n }\n\n return completeFieldName;\n}, {\n setStringify(s: typeof stringify) {\n const previous = stringify;\n stringify = s;\n return previous;\n },\n});\n\n// Default stable JSON.stringify implementation. Can be updated/replaced with\n// something better by calling getStoreKeyName.setStringify.\nlet stringify = function defaultStringify(value: any): string {\n return JSON.stringify(value, stringifyReplacer);\n};\n\nfunction stringifyReplacer(_key: string, value: any): any {\n if (isNonNullObject(value) && !Array.isArray(value)) {\n value = Object.keys(value).sort().reduce((copy, key) => {\n copy[key] = value[key];\n return copy;\n }, {} as Record<string, any>);\n }\n return value;\n}\n\nexport function argumentsObjectFromField(\n field: FieldNode | DirectiveNode,\n variables?: Record<string, any>,\n): Object | null {\n if (field.arguments && field.arguments.length) {\n const argObj: Object = {};\n field.arguments.forEach(({ name, value }) =>\n valueToObjectRepresentation(argObj, name, value, variables),\n );\n return argObj;\n }\n return null;\n}\n\nexport function resultKeyNameFromField(field: FieldNode): string {\n return field.alias ? field.alias.value : field.name.value;\n}\n\nexport function getTypenameFromResult(\n result: Record<string, any>,\n selectionSet: SelectionSetNode,\n fragmentMap?: FragmentMap,\n): string | undefined {\n if (typeof result.__typename === 'string') {\n return result.__typename;\n }\n\n for (const selection of selectionSet.selections) {\n if (isField(selection)) {\n if (selection.name.value === '__typename') {\n return result[resultKeyNameFromField(selection)];\n }\n } else {\n const typename = getTypenameFromResult(\n result,\n getFragmentFromSelection(selection, fragmentMap)!.selectionSet,\n fragmentMap,\n );\n if (typeof typename === 'string') {\n return typename;\n }\n }\n }\n}\n\nexport function isField(selection: SelectionNode): selection is FieldNode {\n return selection.kind === 'Field';\n}\n\nexport function isInlineFragment(\n selection: SelectionNode,\n): selection is InlineFragmentNode {\n return selection.kind === 'InlineFragment';\n}\n\nexport type VariableValue = (node: VariableNode) => any;\n","import { invariant, InvariantError } from '../globals';\n\nimport {\n DocumentNode,\n OperationDefinitionNode,\n FragmentDefinitionNode,\n ValueNode,\n} from 'graphql';\n\nimport { valueToObjectRepresentation } from './storeUtils';\n\n// Checks the document for errors and throws an exception if there is an error.\nexport function checkDocument(doc: DocumentNode) {\n invariant(\n doc && doc.kind === 'Document',\n `Expecting a parsed GraphQL document. Perhaps you need to wrap the query \\\nstring in a \"gql\" tag? http://docs.apollostack.com/apollo-client/core.html#gql`,\n );\n\n const operations = doc.definitions\n .filter(d => d.kind !== 'FragmentDefinition')\n .map(definition => {\n if (definition.kind !== 'OperationDefinition') {\n throw new InvariantError(\n `Schema type definitions not allowed in queries. Found: \"${\n definition.kind\n }\"`,\n );\n }\n return definition;\n });\n\n invariant(\n operations.length <= 1,\n `Ambiguous GraphQL document: contains ${operations.length} operations`,\n );\n\n return doc;\n}\n\nexport function getOperationDefinition(\n doc: DocumentNode,\n): OperationDefinitionNode | undefined {\n checkDocument(doc);\n return doc.definitions.filter(\n definition => definition.kind === 'OperationDefinition',\n )[0] as OperationDefinitionNode;\n}\n\nexport function getOperationName(doc: DocumentNode): string | null {\n return (\n doc.definitions\n .filter(\n definition =>\n definition.kind === 'OperationDefinition' && definition.name,\n )\n .map((x: OperationDefinitionNode) => x!.name!.value)[0] || null\n );\n}\n\n// Returns the FragmentDefinitions from a particular document as an array\nexport function getFragmentDefinitions(\n doc: DocumentNode,\n): FragmentDefinitionNode[] {\n return doc.definitions.filter(\n definition => definition.kind === 'FragmentDefinition',\n ) as FragmentDefinitionNode[];\n}\n\nexport function getQueryDefinition(doc: DocumentNode): OperationDefinitionNode {\n const queryDef = getOperationDefinition(doc) as OperationDefinitionNode;\n\n invariant(\n queryDef && queryDef.operation === 'query',\n 'Must contain a query definition.',\n );\n\n return queryDef;\n}\n\nexport function getFragmentDefinition(\n doc: DocumentNode,\n): FragmentDefinitionNode {\n invariant(\n doc.kind === 'Document',\n `Expecting a parsed GraphQL document. Perhaps you need to wrap the query \\\nstring in a \"gql\" tag? http://docs.apollostack.com/apollo-client/core.html#gql`,\n );\n\n invariant(\n doc.definitions.length <= 1,\n 'Fragment must have exactly one definition.',\n );\n\n const fragmentDef = doc.definitions[0] as FragmentDefinitionNode;\n\n invariant(\n fragmentDef.kind === 'FragmentDefinition',\n 'Must be a fragment definition.',\n );\n\n return fragmentDef as FragmentDefinitionNode;\n}\n\n/**\n * Returns the first operation definition found in this document.\n * If no operation definition is found, the first fragment definition will be returned.\n * If no definitions are found, an error will be thrown.\n */\nexport function getMainDefinition(\n queryDoc: DocumentNode,\n): OperationDefinitionNode | FragmentDefinitionNode {\n checkDocument(queryDoc);\n\n let fragmentDefinition;\n\n for (let definition of queryDoc.definitions) {\n if (definition.kind === 'OperationDefinition') {\n const operation = (definition as OperationDefinitionNode).operation;\n if (\n operation === 'query' ||\n operation === 'mutation' ||\n operation === 'subscription'\n ) {\n return definition as OperationDefinitionNode;\n }\n }\n if (definition.kind === 'FragmentDefinition' && !fragmentDefinition) {\n // we do this because we want to allow multiple fragment definitions\n // to precede an operation definition.\n fragmentDefinition = definition as FragmentDefinitionNode;\n }\n }\n\n if (fragmentDefinition) {\n return fragmentDefinition;\n }\n\n throw new InvariantError(\n 'Expected a parsed GraphQL query with a query, mutation, subscription, or a fragment.',\n );\n}\n\nexport function getDefaultValues(\n definition: OperationDefinitionNode | undefined,\n): Record<string, any> {\n const defaultValues = Object.create(null);\n const defs = definition && definition.variableDefinitions;\n if (defs && defs.length) {\n defs.forEach(def => {\n if (def.defaultValue) {\n valueToObjectRepresentation(\n defaultValues,\n def.variable.name,\n def.defaultValue as ValueNode,\n );\n }\n });\n }\n return defaultValues;\n}\n","import { InvariantError, invariant } from '../../utilities/globals';\n\nimport { Observable, Observer } from '../../utilities';\nimport {\n NextLink,\n Operation,\n RequestHandler,\n FetchResult,\n GraphQLRequest\n} from './types';\nimport {\n validateOperation,\n createOperation,\n transformOperation,\n} from '../utils';\n\nfunction passthrough(op: Operation, forward: NextLink) {\n return (forward ? forward(op) : Observable.of()) as Observable<FetchResult>;\n}\n\nfunction toLink(handler: RequestHandler | ApolloLink) {\n return typeof handler === 'function' ? new ApolloLink(handler) : handler;\n}\n\nfunction isTerminating(link: ApolloLink): boolean {\n return link.request.length <= 1;\n}\n\nclass LinkError extends Error {\n public link?: ApolloLink;\n constructor(message?: string, link?: ApolloLink) {\n super(message);\n this.link = link;\n }\n}\n\nexport class ApolloLink {\n public static empty(): ApolloLink {\n return new ApolloLink(() => Observable.of());\n }\n\n public static from(links: (ApolloLink | RequestHandler)[]): ApolloLink {\n if (links.length === 0) return ApolloLink.empty();\n return links.map(toLink).reduce((x, y) => x.concat(y)) as ApolloLink;\n }\n\n public static split(\n test: (op: Operation) => boolean,\n left: ApolloLink | RequestHandler,\n right?: ApolloLink | RequestHandler,\n ): ApolloLink {\n const leftLink = toLink(left);\n const rightLink = toLink(right || new ApolloLink(passthrough));\n\n if (isTerminating(leftLink) && isTerminating(rightLink)) {\n return new ApolloLink(operation => {\n return test(operation)\n ? leftLink.request(operation) || Observable.of()\n : rightLink.request(operation) || Observable.of();\n });\n } else {\n return new ApolloLink((operation, forward) => {\n return test(operation)\n ? leftLink.request(operation, forward) || Observable.of()\n : rightLink.request(operation, forward) || Observable.of();\n });\n }\n }\n\n public static execute(\n link: ApolloLink,\n operation: GraphQLRequest,\n ): Observable<FetchResult> {\n return (\n link.request(\n createOperation(\n operation.context,\n transformOperation(validateOperation(operation)),\n ),\n ) || Observable.of()\n );\n }\n\n public static concat(\n first: ApolloLink | RequestHandler,\n second: ApolloLink | RequestHandler,\n ) {\n const firstLink = toLink(first);\n if (isTerminating(firstLink)) {\n invariant.warn(\n new LinkError(\n `You are calling concat on a terminating link, which will have no effect`,\n firstLink,\n ),\n );\n return firstLink;\n }\n const nextLink = toLink(second);\n\n if (isTerminating(nextLink)) {\n return new ApolloLink(\n operation =>\n firstLink.request(\n operation,\n op => nextLink.request(op) || Observable.of(),\n ) || Observable.of(),\n );\n } else {\n return new ApolloLink((operation, forward) => {\n return (\n firstLink.request(operation, op => {\n return nextLink.request(op, forward) || Observable.of();\n }) || Observable.of()\n );\n });\n }\n }\n\n constructor(request?: RequestHandler) {\n if (request) this.request = request;\n }\n\n public split(\n test: (op: Operation) => boolean,\n left: ApolloLink | RequestHandler,\n right?: ApolloLink | RequestHandler,\n ): ApolloLink {\n return this.concat(\n ApolloLink.split(test, left, right || new ApolloLink(passthrough))\n );\n }\n\n public concat(next: ApolloLink | RequestHandler): ApolloLink {\n return ApolloLink.concat(this, next);\n }\n\n public request(\n operation: Operation,\n forward?: NextLink,\n ): Observable<FetchResult> | null {\n throw new InvariantError('request is not implemented');\n }\n\n protected onError(\n error: any,\n observer?: Observer<FetchResult>,\n ): false | void {\n if (observer && observer.error) {\n observer.error(error);\n // Returning false indicates that observer.error does not need to be\n // called again, since it was already called (on the previous line).\n // Calling observer.error again would not cause any real problems,\n // since only the first call matters, but custom onError functions\n // might have other reasons for wanting to prevent the default\n // behavior by returning false.\n return false;\n }\n // Throw errors will be passed to observer.error.\n throw error;\n }\n\n public setOnError(fn: ApolloLink[\"onError\"]): this {\n this.onError = fn;\n return this;\n }\n}\n","import { GraphQLRequest, Operation } from '../core';\n\nexport function createOperation(\n starting: any,\n operation: GraphQLRequest,\n): Operation {\n let context = { ...starting };\n const setContext = (next: any) => {\n if (typeof next === 'function') {\n context = { ...context, ...next(context) };\n } else {\n context = { ...context, ...next };\n }\n };\n const getContext = () => ({ ...context });\n\n Object.defineProperty(operation, 'setContext', {\n enumerable: false,\n value: setContext,\n });\n\n Object.defineProperty(operation, 'getContext', {\n enumerable: false,\n value: getContext,\n });\n\n return operation as Operation;\n}\n","import { GraphQLRequest, Operation } from '../core';\nimport { getOperationName } from '../../utilities';\n\nexport function transformOperation(operation: GraphQLRequest): GraphQLRequest {\n const transformedOperation: GraphQLRequest = {\n variables: operation.variables || {},\n extensions: operation.extensions || {},\n operationName: operation.operationName,\n query: operation.query,\n };\n\n // Best guess at an operation name\n if (!transformedOperation.operationName) {\n transformedOperation.operationName =\n typeof transformedOperation.query !== 'string'\n ? getOperationName(transformedOperation.query) || undefined\n : '';\n }\n\n return transformedOperation as Operation;\n}\n","import { InvariantError } from '../../utilities/globals'\nimport { GraphQLRequest } from '../core';\n\nexport function validateOperation(operation: GraphQLRequest): GraphQLRequest {\n const OPERATION_FIELDS = [\n 'query',\n 'operationName',\n 'variables',\n 'extensions',\n 'context',\n ];\n for (let key of Object.keys(operation)) {\n if (OPERATION_FIELDS.indexOf(key) < 0) {\n throw new InvariantError(`illegal argument: ${key}`);\n }\n }\n\n return operation;\n}\n","import { InvariantError } from '../../utilities/globals';\n\nexport type ClientParseError = InvariantError & {\n parseError: Error;\n};\n\nexport const serializeFetchParameter = (p: any, label: string) => {\n let serialized;\n try {\n serialized = JSON.stringify(p);\n } catch (e) {\n const parseError = new InvariantError(\n `Network request failed. ${label} is not serializable: ${e.message}`,\n ) as ClientParseError;\n parseError.parseError = e;\n throw parseError;\n }\n return serialized;\n};\n","export type ServerError = Error & {\n response: Response;\n result: Record<string, any>;\n statusCode: number;\n};\n\nexport const throwServerError = (\n response: Response,\n result: any,\n message: string\n) => {\n const error = new Error(message) as ServerError;\n error.name = 'ServerError';\n error.response = response;\n error.statusCode = response.status;\n error.result = result;\n throw error;\n};\n","import { Operation } from '../core';\nimport { throwServerError } from '../utils';\n\nconst { hasOwnProperty } = Object.prototype;\n\nexport type ServerParseError = Error & {\n response: Response;\n statusCode: number;\n bodyText: string;\n};\n\nexport function parseAndCheckHttpResponse(\n operations: Operation | Operation[],\n) {\n return (response: Response) => response\n .text()\n .then(bodyText => {\n try {\n return JSON.parse(bodyText);\n } catch (err) {\n const parseError = err as ServerParseError;\n parseError.name = 'ServerParseError';\n parseError.response = response;\n parseError.statusCode = response.status;\n parseError.bodyText = bodyText;\n throw parseError;\n }\n })\n .then((result: any) => {\n if (response.status >= 300) {\n // Network error\n throwServerError(\n response,\n result,\n `Response not successful: Received status code ${response.status}`,\n );\n }\n\n if (\n !Array.isArray(result) &&\n !hasOwnProperty.call(result, 'data') &&\n !hasOwnProperty.call(result, 'errors')\n ) {\n // Data error\n throwServerError(\n response,\n result,\n `Server response was missing for query '${\n Array.isArray(operations)\n ? operations.map(op => op.operationName)\n : operations.operationName\n }'.`,\n );\n }\n return result;\n });\n}\n","import { 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","/**\n * Produces the value of a block string from its parsed raw value, similar to\n * CoffeeScript's block string, Python's docstring trim or Ruby's strip_heredoc.\n *\n * This implements the GraphQL spec's BlockStringValue() static algorithm.\n *\n * @internal\n */\nexport function dedentBlockStringValue(rawString) {\n // Expand a block string's raw value into independent lines.\n var lines = rawString.split(/\\r\\n|[\\n\\r]/g); // Remove common indentation from all lines but first.\n\n var commonIndent = getBlockStringIndentation(rawString);\n\n if (commonIndent !== 0) {\n for (var i = 1; i < lines.length; i++) {\n lines[i] = lines[i].slice(commonIndent);\n }\n } // Remove leading and trailing blank lines.\n\n\n var startLine = 0;\n\n while (startLine < lines.length && isBlank(lines[startLine])) {\n ++startLine;\n }\n\n var endLine = lines.length;\n\n while (endLine > startLine && isBlank(lines[endLine - 1])) {\n --endLine;\n } // Return a string of the lines joined with U+000A.\n\n\n return lines.slice(startLine, endLine).join('\\n');\n}\n\nfunction isBlank(str) {\n for (var i = 0; i < str.length; ++i) {\n if (str[i] !== ' ' && str[i] !== '\\t') {\n return false;\n }\n }\n\n return true;\n}\n/**\n * @internal\n */\n\n\nexport function getBlockStringIndentation(value) {\n var _commonIndent;\n\n var isFirstLine = true;\n var isEmptyLine = true;\n var indent = 0;\n var commonIndent = null;\n\n for (var i = 0; i < value.length; ++i) {\n switch (value.charCodeAt(i)) {\n case 13:\n // \\r\n if (value.charCodeAt(i + 1) === 10) {\n ++i; // skip \\r\\n as one symbol\n }\n\n // falls through\n\n case 10:\n // \\n\n isFirstLine = false;\n isEmptyLine = true;\n indent = 0;\n break;\n\n case 9: // \\t\n\n case 32:\n // <space>\n ++indent;\n break;\n\n default:\n if (isEmptyLine && !isFirstLine && (commonIndent === null || indent < commonIndent)) {\n commonIndent = indent;\n }\n\n isEmptyLine = false;\n }\n }\n\n return (_commonIndent = commonIndent) !== null && _commonIndent !== void 0 ? _commonIndent : 0;\n}\n/**\n * Print a block string in the indented block form by adding a leading and\n * trailing blank line. However, if a block string starts with whitespace and is\n * a single-line, adding a leading blank line would strip that whitespace.\n *\n * @internal\n */\n\nexport function printBlockString(value) {\n var indentation = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n var preferMultipleLines = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n var isSingleLine = value.indexOf('\\n') === -1;\n var hasLeadingSpace = value[0] === ' ' || value[0] === '\\t';\n var hasTrailingQuote = value[value.length - 1] === '\"';\n var hasTrailingSlash = value[value.length - 1] === '\\\\';\n var printAsMultipleLines = !isSingleLine || hasTrailingQuote || hasTrailingSlash || preferMultipleLines;\n var result = ''; // Format a multi-line block quote to account for leading space.\n\n if (printAsMultipleLines && !(isSingleLine && hasLeadingSpace)) {\n result += '\\n' + indentation;\n }\n\n result += indentation ? value.replace(/\\n/g, '\\n' + indentation) : value;\n\n if (printAsMultipleLines) {\n result += '\\n';\n }\n\n return '\"\"\"' + result.replace(/\"\"\"/g, '\\\\\"\"\"') + '\"\"\"';\n}\n","import { ASTNode, print } from 'graphql';\n\nimport { Operation } from '../core';\n\nexport interface Printer {\n (node: ASTNode, originalPrint: typeof print): string\n};\n\nexport interface UriFunction {\n (operation: Operation): string;\n}\n\nexport interface Body {\n query?: string;\n operationName?: string;\n variables?: Record<string, any>;\n extensions?: Record<string, any>;\n}\n\nexport interface HttpOptions {\n /**\n * The URI to use when fetching operations.\n *\n * Defaults to '/graphql'.\n */\n uri?: string | UriFunction;\n\n /**\n * Passes the extensions field to your graphql server.\n *\n * Defaults to false.\n */\n includeExtensions?: boolean;\n\n /**\n * A `fetch`-compatible API to use when making requests.\n */\n fetch?: WindowOrWorkerGlobalScope['fetch'];\n\n /**\n * An object representing values to be sent as headers on the request.\n */\n headers?: any;\n\n /**\n * The credentials policy you want to use for the fetch call.\n */\n credentials?: string;\n\n /**\n * Any overrides of the fetch options argument to pass to the fetch call.\n */\n fetchOptions?: any;\n\n /**\n * If set to true, use the HTTP GET method for query operations. Mutations\n * will still use the method specified in fetchOptions.method (which defaults\n * to POST).\n */\n useGETForQueries?: boolean;\n\n /**\n * If set to true, the default behavior of stripping unused variables\n * from the request will be disabled.\n *\n * Unused variables are likely to trigger server-side validation errors,\n * per https://spec.graphql.org/draft/#sec-All-Variables-Used, but this\n * includeUnusedVariables option can be useful if your server deviates\n * from the GraphQL specification by not strictly enforcing that rule.\n */\n includeUnusedVariables?: boolean;\n /**\n * A function to substitute for the default query print function. Can be\n * used to apply changes to the results of the print function.\n */\n print?: Printer;\n}\n\nexport interface HttpQueryOptions {\n includeQuery?: boolean;\n includeExtensions?: boolean;\n}\n\nexport interface HttpConfig {\n http?: HttpQueryOptions;\n options?: any;\n headers?: any;\n credentials?: any;\n}\n\nconst defaultHttpOptions: HttpQueryOptions = {\n includeQuery: true,\n includeExtensions: false,\n};\n\nconst defaultHeaders = {\n // headers are case insensitive (https://stackoverflow.com/a/5259004)\n accept: '*/*',\n // The content-type header describes the type of the body of the request, and\n // so it typically only is sent with requests that actually have bodies. One\n // could imagine that Apollo Client would remove this header when constructing\n // a GET request (which has no body), but we historically have not done that.\n // This means that browsers will preflight all Apollo Client requests (even\n // GET requests). Apollo Server's CSRF prevention feature (introduced in\n // AS3.7) takes advantage of this fact and does not block requests with this\n // header. If you want to drop this header from GET requests, then you should\n // probably replace it with a `apollo-require-preflight` header, or servers\n // with CSRF prevention enabled might block your GET request. See\n // https://www.apollographql.com/docs/apollo-server/security/cors/#preventing-cross-site-request-forgery-csrf\n // for more details.\n 'content-type': 'application/json',\n};\n\nconst defaultOptions = {\n method: 'POST',\n};\n\nexport const fallbackHttpConfig = {\n http: defaultHttpOptions,\n headers: defaultHeaders,\n options: defaultOptions,\n};\n\nexport const defaultPrinter: Printer = (ast, printer) => printer(ast);\n\nexport function selectHttpOptionsAndBody(\n operation: Operation,\n fallbackConfig: HttpConfig,\n ...configs: Array<HttpConfig>\n) {\n configs.unshift(fallbackConfig);\n return selectHttpOptionsAndBodyInternal(\n operation,\n defaultPrinter,\n ...configs,\n );\n}\n\nexport function selectHttpOptionsAndBodyInternal(\n operation: Operation,\n printer: Printer,\n ...configs: HttpConfig[]\n) {\n let options = {} as HttpConfig & Record<string, any>;\n let http = {} as HttpQueryOptions;\n\n configs.forEach(config => {\n options = {\n ...options,\n ...config.options,\n headers: {\n ...options.headers,\n ...headersToLowerCase(config.headers),\n },\n };\n\n if (config.credentials) {\n options.credentials = config.credentials;\n }\n\n http = {\n ...http,\n ...config.http,\n };\n });\n\n //The body depends on the http options\n const { operationName, extensions, variables, query } = operation;\n const body: Body = { operationName, variables };\n\n if (http.includeExtensions) (body as any).extensions = extensions;\n\n // not sending the query (i.e persisted queries)\n if (http.includeQuery) (body as any).query = printer(query, print);\n\n return {\n options,\n body,\n };\n};\n\nfunction headersToLowerCase(\n headers: Record<string, string> | undefined\n): typeof headers {\n if (headers) {\n const normalized = Object.create(null);\n Object.keys(Object(headers)).forEach(name => {\n normalized[name.toLowerCase()] = headers[name];\n });\n return normalized;\n }\n return headers;\n}\n","import { Observable } from '../../utilities';\n\nexport function fromError<T>(errorValue: any): Observable<T> {\n return new Observable<T>(observer => {\n observer.error(errorValue);\n });\n}\n","import '../../utilities/globals';\n\nimport { visit, DefinitionNode, VariableDefinitionNode } from 'graphql';\n\nimport { ApolloLink } from '../core';\nimport { Observable } from '../../utilities';\nimport { serializeFetchParameter } from './serializeFetchParameter';\nimport { selectURI } from './selectURI';\nimport { parseAndCheckHttpResponse } from './parseAndCheckHttpResponse';\nimport { checkFetcher } from './checkFetcher';\nimport {\n selectHttpOptionsAndBodyInternal,\n defaultPrinter,\n fallbackHttpConfig,\n HttpOptions\n} from './selectHttpOptionsAndBody';\nimport { createSignalIfSupported } from './createSignalIfSupported';\nimport { rewriteURIForGET } from './rewriteURIForGET';\nimport { fromError } from '../utils';\nimport { maybe } from '../../utilities';\n\nconst backupFetch = maybe(() => fetch);\n\nexport const createHttpLink = (linkOptions: HttpOptions = {}) => {\n let {\n uri = '/graphql',\n // use default global fetch if nothing passed in\n fetch: preferredFetch,\n print = defaultPrinter,\n includeExtensions,\n useGETForQueries,\n includeUnusedVariables = false,\n ...requestOptions\n } = linkOptions;\n\n if (__DEV__) {\n // Make sure at least one of preferredFetch, window.fetch, or backupFetch is\n // defined, so requests won't fail at runtime.\n checkFetcher(preferredFetch || backupFetch);\n }\n\n const linkConfig = {\n http: { includeExtensions },\n options: requestOptions.fetchOptions,\n credentials: requestOptions.credentials,\n headers: requestOptions.headers,\n };\n\n return new ApolloLink(operation => {\n let chosenURI = selectURI(operation, uri);\n\n const context = operation.getContext();\n\n // `apollographql-client-*` headers are automatically set if a\n // `clientAwareness` object is found in the context. These headers are\n // set first, followed by the rest of the headers pulled from\n // `context.headers`. If desired, `apollographql-client-*` headers set by\n // the `clientAwareness` object can be overridden by\n // `apollographql-client-*` headers set in `context.headers`.\n const clientAwarenessHeaders: {\n 'apollographql-client-name'?: string;\n 'apollographql-client-version'?: string;\n } = {};\n\n if (context.clientAwareness) {\n const { name, version } = context.clientAwareness;\n if (name) {\n clientAwarenessHeaders['apollographql-client-name'] = name;\n }\n if (version) {\n clientAwarenessHeaders['apollographql-client-version'] = version;\n }\n }\n\n const contextHeaders = { ...clientAwarenessHeaders, ...context.headers };\n\n const contextConfig = {\n http: context.http,\n options: context.fetchOptions,\n credentials: context.credentials,\n headers: contextHeaders,\n };\n\n //uses fallback, link, and then context to build options\n const { options, body } = selectHttpOptionsAndBodyInternal(\n operation,\n print,\n fallbackHttpConfig,\n linkConfig,\n contextConfig,\n );\n\n if (body.variables && !includeUnusedVariables) {\n const unusedNames = new Set(Object.keys(body.variables));\n visit(operation.query, {\n Variable(node, _key, parent) {\n // A variable type definition at the top level of a query is not\n // enough to silence server-side errors about the variable being\n // unused, so variable definitions do not count as usage.\n // https://spec.graphql.org/draft/#sec-All-Variables-Used\n if (parent && (parent as VariableDefinitionNode).kind !== 'VariableDefinition') {\n unusedNames.delete(node.name.value);\n }\n },\n });\n if (unusedNames.size) {\n // Make a shallow copy of body.variables (with keys in the same\n // order) and then delete unused variables from the copy.\n body.variables = { ...body.variables };\n unusedNames.forEach(name => {\n delete body.variables![name];\n });\n }\n }\n\n let controller: any;\n if (!(options as any).signal) {\n const { controller: _controller, signal } = createSignalIfSupported();\n controller = _controller;\n if (controller) (options as any).signal = signal;\n }\n\n // If requested, set method to GET if there are no mutations.\n const definitionIsMutation = (d: DefinitionNode) => {\n return d.kind === 'OperationDefinition' && d.operation === 'mutation';\n };\n if (\n useGETForQueries &&\n !operation.query.definitions.some(definitionIsMutation)\n ) {\n options.method = 'GET';\n }\n\n if (options.method === 'GET') {\n const { newURI, parseError } = rewriteURIForGET(chosenURI, body);\n if (parseError) {\n return fromError(parseError);\n }\n chosenURI = newURI;\n } else {\n try {\n (options as any).body = serializeFetchParameter(body, 'Payload');\n } catch (parseError) {\n return fromError(parseError);\n }\n }\n\n return new Observable(observer => {\n // Prefer linkOptions.fetch (preferredFetch) if provided, and otherwise\n // fall back to the *current* global window.fetch function (see issue\n // #7832), or (if all else fails) the backupFetch function we saved when\n // this module was first evaluated. This last option protects against the\n // removal of window.fetch, which is unlikely but not impossible.\n const currentFetch = preferredFetch || maybe(() => fetch) || backupFetch;\n\n currentFetch!(chosenURI, options)\n .then(response => {\n operation.setContext({ response });\n return response;\n })\n .then(parseAndCheckHttpResponse(operation))\n .then(result => {\n // we have data and can send it to back up the link chain\n observer.next(result);\n observer.complete();\n return result;\n })\n .catch(err => {\n // fetch was cancelled so it's already been cleaned up in the unsubscribe\n if (err.name === 'AbortError') return;\n // if it is a network error, BUT there is graphql result info\n // fire the next observer before calling error\n // this gives apollo-client (and react-apollo) the `graphqlErrors` and `networErrors`\n // to pass to UI\n // this should only happen if we *also* have data as part of the response key per\n // the spec\n if (err.result && err.result.errors && err.result.data) {\n // if we don't call next, the UI can only show networkError because AC didn't\n // get any graphqlErrors\n // this is graphql execution result info (i.e errors and possibly data)\n // this is because there is no formal spec how errors should translate to\n // http status codes. So an auth error (401) could have both data\n // from a public field, errors from a private field, and a status of 401\n // {\n // user { // this will have errors\n // firstName\n // }\n // products { // this is public so will have data\n // cost\n // }\n // }\n //\n // the result of above *could* look like this:\n // {\n // data: { products: [{ cost: \"$10\" }] },\n // errors: [{\n // message: 'your session has timed out',\n // path: []\n // }]\n // }\n // status code of above would be a 401\n // in the UI you want to show data where you can, errors as data where you can\n // and use correct http status codes\n observer.next(err.result);\n }\n observer.error(err);\n });\n\n return () => {\n // XXX support canceling this request\n // https://developers.google.com/web/updates/2017/09/abortable-fetch\n if (controller) controller.abort();\n };\n });\n });\n};\n","import { InvariantError } from '../../utilities/globals';\n\nexport const checkFetcher = (fetcher: WindowOrWorkerGlobalScope['fetch'] | undefined) => {\n if (!fetcher && typeof fetch === 'undefined') {\n throw new InvariantError(`\n\"fetch\" has not been found globally and no fetcher has been \\\nconfigured. To fix this, install a fetch package (like \\\nhttps://www.npmjs.com/package/cross-fetch), instantiate the \\\nfetcher, and pass it into your HttpLink constructor. For example:\n\nimport fetch from 'cross-fetch';\nimport { ApolloClient, HttpLink } from '@apollo/client';\nconst client = new ApolloClient({\n link: new HttpLink({ uri: '/graphql', fetch })\n});\n `);\n }\n};\n","import { Operation } from '../core';\n\nexport const selectURI = (\n operation: Operation,\n fallbackURI?: string | ((operation: Operation) => string),\n) => {\n const context = operation.getContext();\n const contextURI = context.uri;\n\n if (contextURI) {\n return contextURI;\n } else if (typeof fallbackURI === 'function') {\n return fallbackURI(operation);\n } else {\n return (fallbackURI as string) || '/graphql';\n }\n};\n","export const createSignalIfSupported = () => {\n if (typeof AbortController === 'undefined')\n return { controller: false, signal: false };\n\n const controller = new AbortController();\n const signal = controller.signal;\n return { controller, signal };\n};\n","import { serializeFetchParameter } from './serializeFetchParameter';\nimport { Body } from './selectHttpOptionsAndBody';\n\n// For GET operations, returns the given URI rewritten with parameters, or a\n// parse error.\nexport function rewriteURIForGET(chosenURI: string, body: Body) {\n // Implement the standard HTTP GET serialization, plus 'extensions'. Note\n // the extra level of JSON serialization!\n const queryParams: string[] = [];\n const addQueryParam = (key: string, value: string) => {\n queryParams.push(`${key}=${encodeURIComponent(value)}`);\n };\n\n if ('query' in body) {\n addQueryParam('query', body.query!);\n }\n if (body.operationName) {\n addQueryParam('operationName', body.operationName);\n }\n if (body.variables) {\n let serializedVariables;\n try {\n serializedVariables = serializeFetchParameter(\n body.variables,\n 'Variables map',\n );\n } catch (parseError) {\n return { parseError };\n }\n addQueryParam('variables', serializedVariables);\n }\n if (body.extensions) {\n let serializedExtensions;\n try {\n serializedExtensions = serializeFetchParameter(\n body.extensions,\n 'Extensions map',\n );\n } catch (parseError) {\n return { parseError };\n }\n addQueryParam('extensions', serializedExtensions);\n }\n\n // Reconstruct the URI with added query params.\n // XXX This assumes that the URI is well-formed and that it doesn't\n // already contain any of these query params. We could instead use the\n // URL API and take a polyfill (whatwg-url@6) for older browsers that\n // don't support URLSearchParams. Note that some browsers (and\n // versions of whatwg-url) support URL but not URLSearchParams!\n let fragment = '',\n preFragment = chosenURI;\n const fragmentStart = chosenURI.indexOf('#');\n if (fragmentStart !== -1) {\n fragment = chosenURI.substr(fragmentStart);\n preFragment = chosenURI.substr(0, fragmentStart);\n }\n const queryParamsPrefix = preFragment.indexOf('?') === -1 ? '?' : '&';\n const newURI =\n preFragment + queryParamsPrefix + queryParams.join('&') + fragment;\n return { newURI };\n}\n","import { ApolloLink } from './ApolloLink';\n\nexport const execute = ApolloLink.execute;\n","import { ApolloLink, RequestHandler } from '../core';\nimport { HttpOptions } from './selectHttpOptionsAndBody';\nimport { createHttpLink } from './createHttpLink';\n\nexport class HttpLink extends ApolloLink {\n public requester: RequestHandler;\n constructor(public options: HttpOptions = {}) {\n super(createHttpLink(options).request);\n }\n}\n","// 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\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\n// Useful for processing arguments objects as well as arrays.\nconst { forEach, slice } = Array.prototype;\n\nexport class Trie<Data> {\n // Since a `WeakMap` cannot hold primitive values as keys, we need a\n // backup `Map` instance to hold primitive keys. Both `this._weakMap`\n // and `this._strongMap` are lazily initialized.\n private weak?: WeakMap<any, Trie<Data>>;\n private strong?: Map<any, Trie<Data>>;\n private data?: Data;\n\n constructor(\n private weakness = true,\n private makeData: (array: any[]) => Data = defaultMakeData,\n ) {}\n\n public lookup<T extends any[]>(...array: T): Data {\n return this.lookupArray(array);\n }\n\n public lookupArray<T extends IArguments | any[]>(array: T): Data {\n let node: Trie<Data> = this;\n forEach.call(array, key => node = node.getChildTrie(key));\n return node.data || (node.data = this.makeData(slice.call(array)));\n }\n\n private getChildTrie(key: any) {\n const map = this.weakness && isObjRef(key)\n ? this.weak || (this.weak = new WeakMap<any, Trie<Data>>())\n : this.strong || (this.strong = new Map<any, Trie<Data>>());\n let child = map.get(key);\n if (!child) map.set(key, child = new Trie<Data>(this.weakness, this.makeData));\n return child;\n }\n}\n\nfunction isObjRef(value: any) {\n switch (typeof value) {\n case \"object\":\n if (value === null) break;\n // Fall through to return true...\n case \"function\":\n return true;\n }\n return false;\n}\n","import { invariant } from '../globals';\n\n// Provides the methods that allow QueryManager to handle the `skip` and\n// `include` directives within GraphQL.\nimport {\n SelectionNode,\n VariableNode,\n BooleanValueNode,\n DirectiveNode,\n DocumentNode,\n ArgumentNode,\n ValueNode,\n ASTNode,\n visit,\n} from 'graphql';\n\nexport type DirectiveInfo = {\n [fieldName: string]: { [argName: string]: any };\n};\n\nexport function shouldInclude(\n { directives }: SelectionNode,\n variables?: Record<string, any>,\n): boolean {\n if (!directives || !directives.length) {\n return true;\n }\n return getInclusionDirectives(\n directives\n ).every(({ directive, ifArgument }) => {\n let evaledValue: boolean = false;\n if (ifArgument.value.kind === 'Variable') {\n evaledValue = variables && variables[(ifArgument.value as VariableNode).name.value];\n invariant(\n evaledValue !== void 0,\n `Invalid variable referenced in @${directive.name.value} directive.`,\n );\n } else {\n evaledValue = (ifArgument.value as BooleanValueNode).value;\n }\n return directive.name.value === 'skip' ? !evaledValue : evaledValue;\n });\n}\n\nexport function getDirectiveNames(root: ASTNode) {\n const names: string[] = [];\n\n visit(root, {\n Directive(node: DirectiveNode) {\n names.push(node.name.value);\n },\n });\n\n return names;\n}\n\nexport function hasDirectives(names: string[], root: ASTNode) {\n return getDirectiveNames(root).some(\n (name: string) => names.indexOf(name) > -1,\n );\n}\n\nexport function hasClientExports(document: DocumentNode) {\n return (\n document &&\n hasDirectives(['client'], document) &&\n hasDirectives(['export'], document)\n );\n}\n\nexport type InclusionDirectives = Array<{\n directive: DirectiveNode;\n ifArgument: ArgumentNode;\n}>;\n\nfunction isInclusionDirective({ name: { value } }: DirectiveNode): boolean {\n return value === 'skip' || value === 'include';\n}\n\nexport function getInclusionDirectives(\n directives: ReadonlyArray<DirectiveNode>,\n): InclusionDirectives {\n const result: InclusionDirectives = [];\n\n if (directives && directives.length) {\n directives.forEach(directive => {\n if (!isInclusionDirective(directive)) return;\n\n const directiveArguments = directive.arguments;\n const directiveName = directive.name.value;\n\n invariant(\n directiveArguments && directiveArguments.length === 1,\n `Incorrect number of arguments for the @${directiveName} directive.`,\n );\n\n const ifArgument = directiveArguments![0];\n invariant(\n ifArgument.name && ifArgument.name.value === 'if',\n `Invalid argument for the @${directiveName} directive.`,\n );\n\n const ifValue: ValueNode = ifArgument.value;\n\n // means it has to be a variable value if this is a valid @skip or @include directive\n invariant(\n ifValue &&\n (ifValue.kind === 'Variable' || ifValue.kind === 'BooleanValue'),\n `Argument for the @${directiveName} directive must be a variable or a boolean value.`,\n );\n\n result.push({ directive, ifArgument });\n });\n }\n\n return result;\n}\n\n","import { isNonNullObject } from \"./objects\";\n\nconst { hasOwnProperty } = Object.prototype;\n\n// These mergeDeep and mergeDeepArray utilities merge any number of objects\n// together, sharing as much memory as possible with the source objects, while\n// remaining careful to avoid modifying any source objects.\n\n// Logically, the return type of mergeDeep should be the intersection of\n// all the argument types. The binary call signature is by far the most\n// common, but we support 0- through 5-ary as well. After that, the\n// resulting type is just the inferred array element type. Note to nerds:\n// there is a more clever way of doing this that converts the tuple type\n// first to a union type (easy enough: T[number]) and then converts the\n// union to an intersection type using distributive conditional type\n// inference, but that approach has several fatal flaws (boolean becomes\n// true & false, and the inferred type ends up as unknown in many cases),\n// in addition to being nearly impossible to explain/understand.\nexport type TupleToIntersection<T extends any[]> =\n T extends [infer A] ? A :\n T extends [infer A, infer B] ? A & B :\n T extends [infer A, infer B, infer C] ? A & B & C :\n T extends [infer A, infer B, infer C, infer D] ? A & B & C & D :\n T extends [infer A, infer B, infer C, infer D, infer E] ? A & B & C & D & E :\n T extends (infer U)[] ? U : any;\n\nexport function mergeDeep<T extends any[]>(\n ...sources: T\n): TupleToIntersection<T> {\n return mergeDeepArray(sources);\n}\n\n// In almost any situation where you could succeed in getting the\n// TypeScript compiler to infer a tuple type for the sources array, you\n// could just use mergeDeep instead of mergeDeepArray, so instead of\n// trying to convert T[] to an intersection type we just infer the array\n// element type, which works perfectly when the sources array has a\n// consistent element type.\nexport function mergeDeepArray<T>(sources: T[]): T {\n let target = sources[0] || ({} as T);\n const count = sources.length;\n if (count > 1) {\n const merger = new DeepMerger();\n for (let i = 1; i < count; ++i) {\n target = merger.merge(target, sources[i]);\n }\n }\n return target;\n}\n\nexport type ReconcilerFunction<TContextArgs extends any[]> = (\n this: DeepMerger<TContextArgs>,\n target: Record<string | number, any>,\n source: Record<string | number, any>,\n property: string | number,\n ...context: TContextArgs\n) => any;\n\nconst defaultReconciler: ReconcilerFunction<any[]> =\n function (target, source, property) {\n return this.merge(target[property], source[property]);\n };\n\nexport class DeepMerger<TContextArgs extends any[]> {\n constructor(\n private reconciler: ReconcilerFunction<TContextArgs> = defaultReconciler,\n ) {}\n\n public merge(target: any, source: any, ...context: TContextArgs): any {\n if (isNonNullObject(source) && isNonNullObject(target)) {\n Object.keys(source).forEach(sourceKey => {\n if (hasOwnProperty.call(target, sourceKey)) {\n const targetValue = target[sourceKey];\n if (source[sourceKey] !== targetValue) {\n const result = this.reconciler(target, source, sourceKey, ...context);\n // A well-implemented reconciler may return targetValue to indicate\n // the merge changed nothing about the structure of the target.\n if (result !== targetValue) {\n target = this.shallowCopyForMerge(target);\n target[sourceKey] = result;\n }\n }\n } else {\n // If there is no collision, the target can safely share memory with\n // the source, and the recursion can terminate here.\n target = this.shallowCopyForMerge(target);\n target[sourceKey] = source[sourceKey];\n }\n });\n\n return target;\n }\n\n // If source (or target) is not an object, let source replace target.\n return source;\n }\n\n public isObject = isNonNullObject;\n\n private pastCopies = new Set<any>();\n\n public shallowCopyForMerge<T>(value: T): T {\n if (isNonNullObject(value)) {\n if (!this.pastCopies.has(value)) {\n if (Array.isArray(value)) {\n value = (value as any).slice(0);\n } else {\n value = {\n __proto__: Object.getPrototypeOf(value),\n ...value,\n };\n }\n this.pastCopies.add(value);\n }\n }\n return value;\n }\n}\n","import { SelectionSetNode } from 'graphql';\n\nimport {\n NormalizedCache,\n InMemoryCacheConfig,\n} from './types';\n\nimport { KeyFieldsContext } from './policies';\n\nimport {\n Reference,\n isReference,\n StoreValue,\n StoreObject,\n isField,\n DeepMerger,\n resultKeyNameFromField,\n shouldInclude,\n isNonNullObject,\n compact,\n} from '../../utilities';\n\nexport const {\n hasOwnProperty: hasOwn,\n} = Object.prototype;\n\nexport function defaultDataIdFromObject(\n { __typename, id, _id }: Readonly<StoreObject>,\n context?: KeyFieldsContext,\n): string | undefined {\n if (typeof __typename === \"string\") {\n if (context) {\n context.keyObject =\n id !== void 0 ? { id } :\n _id !== void 0 ? { _id } :\n void 0;\n }\n // If there is no object.id, fall back to object._id.\n if (id === void 0) id = _id;\n if (id !== void 0) {\n return `${__typename}:${(\n typeof id === \"number\" ||\n typeof id === \"string\"\n ) ? id : JSON.stringify(id)}`;\n }\n }\n}\n\nconst defaultConfig = {\n dataIdFromObject: defaultDataIdFromObject,\n addTypename: true,\n resultCaching: true,\n // Thanks to the shouldCanonizeResults helper, this should be the only line\n // you have to change to reenable canonization by default in the future.\n canonizeResults: false,\n};\n\nexport function normalizeConfig(config: InMemoryCacheConfig) {\n return compact(defaultConfig, config);\n}\n\nexport function shouldCanonizeResults(\n config: Pick<InMemoryCacheConfig, \"canonizeResults\">,\n): boolean {\n const value = config.canonizeResults;\n return value === void 0 ? defaultConfig.canonizeResults : value;\n}\n\nexport function getTypenameFromStoreObject(\n store: NormalizedCache,\n objectOrReference: StoreObject | Reference,\n): string | undefined {\n return isReference(objectOrReference)\n ? store.get(objectOrReference.__ref, \"__typename\") as string\n : objectOrReference && objectOrReference.__typename;\n}\n\nexport const TypeOrFieldNameRegExp = /^[_a-z][_0-9a-z]*/i;\n\nexport function fieldNameFromStoreName(storeFieldName: string): string {\n const match = storeFieldName.match(TypeOrFieldNameRegExp);\n return match ? match[0] : storeFieldName;\n}\n\nexport function selectionSetMatchesResult(\n selectionSet: SelectionSetNode,\n result: Record<string, any>,\n variables?: Record<string, any>,\n): boolean {\n if (isNonNullObject(result)) {\n return isArray(result)\n ? result.every(item => selectionSetMatchesResult(selectionSet, item, variables))\n : selectionSet.selections.every(field => {\n if (isField(field) && shouldInclude(field, variables)) {\n const key = resultKeyNameFromField(field);\n return hasOwn.call(result, key) &&\n (!field.selectionSet ||\n selectionSetMatchesResult(field.selectionSet, result[key], variables));\n }\n // If the selection has been skipped with @skip(true) or\n // @include(false), it should not count against the matching. If\n // the selection is not a field, it must be a fragment (inline or\n // named). We will determine if selectionSetMatchesResult for that\n // fragment when we get to it, so for now we return true.\n return true;\n });\n }\n return false;\n}\n\nexport function storeValueIsStoreObject(\n value: StoreValue,\n): value is StoreObject {\n return isNonNullObject(value) &&\n !isReference(value) &&\n !isArray(value);\n}\n\nexport function makeProcessedFieldsMerger() {\n return new DeepMerger;\n}\n\nexport const isArray = (a: any): a is any[] | readonly any[] => Array.isArray(a)\n","import \"../../utilities/globals\";\n\nimport { Trie } from \"@wry/trie\";\nimport {\n canUseWeakMap,\n canUseWeakSet,\n isNonNullObject as isObjectOrArray,\n} from \"../../utilities\";\nimport { isArray } from \"./helpers\";\n\nfunction shallowCopy<T>(value: T): T {\n if (isObjectOrArray(value)) {\n return isArray(value)\n ? value.slice(0) as any as T\n : { __proto__: Object.getPrototypeOf(value), ...value };\n }\n return value;\n}\n\n// When programmers talk about the \"canonical form\" of an object, they\n// usually have the following meaning in mind, which I've copied from\n// https://en.wiktionary.org/wiki/canonical_form:\n//\n// 1. A standard or normal presentation of a mathematical entity [or\n// object]. A canonical form is an element of a set of representatives\n// of equivalence classes of forms such that there is a function or\n// procedure which projects every element of each equivalence class\n// onto that one element, the canonical form of that equivalence\n// class. The canonical form is expected to be simpler than the rest of\n// the forms in some way.\n//\n// That's a long-winded way of saying any two objects that have the same\n// canonical form may be considered equivalent, even if they are !==,\n// which usually means the objects are structurally equivalent (deeply\n// equal), but don't necessarily use the same memory.\n//\n// Like a literary or musical canon, this ObjectCanon class represents a\n// collection of unique canonical items (JavaScript objects), with the\n// important property that canon.admit(a) === canon.admit(b) if a and b\n// are deeply equal to each other. In terms of the definition above, the\n// canon.admit method is the \"function or procedure which projects every\"\n// object \"onto that one element, the canonical form.\"\n//\n// In the worst case, the canonicalization process may involve looking at\n// every property in the provided object tree, so it takes the same order\n// of time as deep equality checking. Fortunately, already-canonicalized\n// objects are returned immediately from canon.admit, so the presence of\n// canonical subtrees tends to speed up canonicalization.\n//\n// Since consumers of canonical objects can check for deep equality in\n// constant time, canonicalizing cache results can massively improve the\n// performance of application code that skips re-rendering unchanged\n// results, such as \"pure\" UI components in a framework like React.\n//\n// Of course, since canonical objects may be shared widely between\n// unrelated consumers, it's important to think of them as immutable, even\n// though they are not actually frozen with Object.freeze in production,\n// due to the extra performance overhead that comes with frozen objects.\n//\n// Custom scalar objects whose internal class name is neither Array nor\n// Object can be included safely in the admitted tree, but they will not\n// be replaced with a canonical version (to put it another way, they are\n// assumed to be canonical already).\n//\n// If we ignore custom objects, no detection of cycles or repeated object\n// references is currently required by the StoreReader class, since\n// GraphQL result objects are JSON-serializable trees (and thus contain\n// neither cycles nor repeated subtrees), so we can avoid the complexity\n// of keeping track of objects we've already seen during the recursion of\n// the admit method.\n//\n// In the future, we may consider adding additional cases to the switch\n// statement to handle other common object types, such as \"[object Date]\"\n// objects, as needed.\nexport class ObjectCanon {\n // Set of all canonical objects this ObjectCanon has admitted, allowing\n // canon.admit to return previously-canonicalized objects immediately.\n private known = new (canUseWeakSet ? WeakSet : Set)<object>();\n\n // Efficient storage/lookup structure for canonical objects.\n private pool = new Trie<{\n array?: any[];\n object?: Record<string, any>;\n keys?: SortedKeysInfo;\n }>(canUseWeakMap);\n\n public isKnown(value: any): boolean {\n return isObjectOrArray(value) && this.known.has(value);\n }\n\n // Make the ObjectCanon assume this value has already been\n // canonicalized.\n private passes = new WeakMap<object, object>();\n public pass<T>(value: T): T;\n public pass(value: any) {\n if (isObjectOrArray(value)) {\n const copy = shallowCopy(value);\n this.passes.set(copy, value);\n return copy;\n }\n return value;\n }\n\n // Returns the canonical version of value.\n public admit<T>(value: T): T;\n public admit(value: any) {\n if (isObjectOrArray(value)) {\n const original = this.passes.get(value);\n if (original) return original;\n\n const proto = Object.getPrototypeOf(value);\n switch (proto) {\n case Array.prototype: {\n if (this.known.has(value)) return value;\n const array: any[] = (value as any[]).map(this.admit, this);\n // Arrays are looked up in the Trie using their recursively\n // canonicalized elements, and the known version of the array is\n // preserved as node.array.\n const node = this.pool.lookupArray(array);\n if (!node.array) {\n this.known.add(node.array = array);\n // Since canonical arrays may be shared widely between\n // unrelated consumers, it's important to regard them as\n // immutable, even if they are not frozen in production.\n if (__DEV__) {\n Object.freeze(array);\n }\n }\n return node.array;\n }\n\n case null:\n case Object.prototype: {\n if (this.known.has(value)) return value;\n const proto = Object.getPrototypeOf(value);\n const array = [proto];\n const keys = this.sortedKeys(value);\n array.push(keys.json);\n const firstValueIndex = array.length;\n keys.sorted.forEach(key => {\n array.push(this.admit((value as any)[key]));\n });\n // Objects are looked up in the Trie by their prototype (which\n // is *not* recursively canonicalized), followed by a JSON\n // representation of their (sorted) keys, followed by the\n // sequence of recursively canonicalized values corresponding to\n // those keys. To keep the final results unambiguous with other\n // sequences (such as arrays that just happen to contain [proto,\n // keys.json, value1, value2, ...]), the known version of the\n // object is stored as node.object.\n const node = this.pool.lookupArray(array);\n if (!node.object) {\n const obj = node.object = Object.create(proto);\n this.known.add(obj);\n keys.sorted.forEach((key, i) => {\n obj[key] = array[firstValueIndex + i];\n });\n // Since canonical objects may be shared widely between\n // unrelated consumers, it's important to regard them as\n // immutable, even if they are not frozen in production.\n if (__DEV__) {\n Object.freeze(obj);\n }\n }\n return node.object;\n }\n }\n }\n return value;\n }\n\n // It's worthwhile to cache the sorting of arrays of strings, since the\n // same initial unsorted arrays tend to be encountered many times.\n // Fortunately, we can reuse the Trie machinery to look up the sorted\n // arrays in linear time (which is faster than sorting large arrays).\n private sortedKeys(obj: object) {\n const keys = Object.keys(obj);\n const node = this.pool.lookupArray(keys);\n if (!node.keys) {\n keys.sort();\n const json = JSON.stringify(keys);\n if (!(node.keys = this.keysByJSON.get(json))) {\n this.keysByJSON.set(json, node.keys = { sorted: keys, json });\n }\n }\n return node.keys;\n }\n // Arrays that contain the same elements in a different order can share\n // the same SortedKeysInfo object, to save memory.\n private keysByJSON = new Map<string, SortedKeysInfo>();\n\n // This has to come last because it depends on keysByJSON.\n public readonly empty = this.admit({});\n}\n\ntype SortedKeysInfo = {\n sorted: string[];\n json: string;\n};\n\n// Since the keys of canonical objects are always created in lexicographically\n// sorted order, we can use the ObjectCanon to implement a fast and stable\n// version of JSON.stringify, which automatically sorts object keys.\nexport const canonicalStringify = Object.assign(function (value: any): string {\n if (isObjectOrArray(value)) {\n if (stringifyCanon === void 0) {\n resetCanonicalStringify();\n }\n const canonical = stringifyCanon.admit(value);\n let json = stringifyCache.get(canonical);\n if (json === void 0) {\n stringifyCache.set(\n canonical,\n json = JSON.stringify(canonical),\n );\n }\n return json;\n }\n return JSON.stringify(value);\n}, {\n reset: resetCanonicalStringify,\n});\n\n// Can be reset by calling canonicalStringify.reset().\nlet stringifyCanon: ObjectCanon;\nlet stringifyCache: WeakMap<object, string>;\n\nfunction resetCanonicalStringify() {\n stringifyCanon = new ObjectCanon;\n stringifyCache = new (canUseWeakMap ? WeakMap : Map)();\n}\n","import { Observable, Observer } from \"./Observable\";\n\n// Like Observable.prototype.map, except that the mapping function can\n// optionally return a Promise (or be async).\nexport function asyncMap<V, R>(\n observable: Observable<V>,\n mapFn: (value: V) => R | PromiseLike<R>,\n catchFn?: (error: any) => R | PromiseLike<R>,\n): Observable<R> {\n return new Observable<R>(observer => {\n const { next, error, complete } = observer;\n let activeCallbackCount = 0;\n let completed = false;\n let promiseQueue = {\n // Normally we would initialize promiseQueue to Promise.resolve(), but\n // in this case, for backwards compatibility, we need to be careful to\n // invoke the first callback synchronously.\n then(callback: () => any) {\n return new Promise(resolve => resolve(callback()));\n },\n } as Promise<void>;\n\n function makeCallback(\n examiner: typeof mapFn | typeof catchFn,\n delegate: typeof next | typeof error,\n ): (arg: any) => void {\n if (examiner) {\n return arg => {\n ++activeCallbackCount;\n const both = () => examiner(arg);\n promiseQueue = promiseQueue.then(both, both).then(\n result => {\n --activeCallbackCount;\n next && next.call(observer, result);\n if (completed) {\n handler.complete!();\n }\n },\n error => {\n --activeCallbackCount;\n throw error;\n },\n ).catch(caught => {\n error && error.call(observer, caught);\n });\n };\n } else {\n return arg => delegate && delegate.call(observer, arg);\n }\n }\n\n const handler: Observer<V> = {\n next: makeCallback(mapFn, next),\n error: makeCallback(catchFn, error),\n complete() {\n completed = true;\n if (!activeCallbackCount) {\n complete && complete.call(observer);\n }\n },\n };\n\n const sub = observable.subscribe(handler);\n return () => sub.unsubscribe();\n });\n}\n","import { ExecutionResult } from 'graphql';\n\nexport function graphQLResultHasError(result: ExecutionResult<unknown>): boolean {\n return (result.errors && result.errors.length > 0) || false;\n}\n","export function filterInPlace<T>(\n array: T[],\n test: (elem: T) => boolean,\n context?: any,\n): T[] {\n let target = 0;\n array.forEach(function (elem, i) {\n if (test.call(this, elem, i, array)) {\n array[target++] = elem;\n }\n }, context);\n array.length = target;\n return array;\n}\n","import { invariant } from '../globals';\n\nimport {\n DocumentNode,\n SelectionNode,\n SelectionSetNode,\n OperationDefinitionNode,\n FieldNode,\n DirectiveNode,\n FragmentDefinitionNode,\n ArgumentNode,\n FragmentSpreadNode,\n VariableDefinitionNode,\n VariableNode,\n visit,\n ASTNode,\n} from 'graphql';\n\n// TODO(brian): A hack until this issue is resolved (https://github.com/graphql/graphql-js/issues/3356)\ntype Kind = any;\n\nimport {\n checkDocument,\n getOperationDefinition,\n getFragmentDefinition,\n getFragmentDefinitions,\n getMainDefinition,\n} from './getFromAST';\nimport { filterInPlace } from '../common/filterInPlace';\nimport { isField, isInlineFragment } from './storeUtils';\nimport {\n createFragmentMap,\n FragmentMap,\n} from './fragments';\n\nexport type RemoveNodeConfig<N> = {\n name?: string;\n test?: (node: N) => boolean;\n remove?: boolean;\n};\n\nexport type GetNodeConfig<N> = {\n name?: string;\n test?: (node: N) => boolean;\n};\n\nexport type RemoveDirectiveConfig = RemoveNodeConfig<DirectiveNode>;\nexport type GetDirectiveConfig = GetNodeConfig<DirectiveNode>;\nexport type RemoveArgumentsConfig = RemoveNodeConfig<ArgumentNode>;\nexport type GetFragmentSpreadConfig = GetNodeConfig<FragmentSpreadNode>;\nexport type RemoveFragmentSpreadConfig = RemoveNodeConfig<FragmentSpreadNode>;\nexport type RemoveFragmentDefinitionConfig = RemoveNodeConfig<\n FragmentDefinitionNode\n>;\nexport type RemoveVariableDefinitionConfig = RemoveNodeConfig<\n VariableDefinitionNode\n>;\n\nconst TYPENAME_FIELD: FieldNode = {\n kind: 'Field' as Kind,\n name: {\n kind: 'Name' as Kind,\n value: '__typename',\n },\n};\n\nfunction isEmpty(\n op: OperationDefinitionNode | FragmentDefinitionNode,\n fragments: FragmentMap,\n): boolean {\n return op.selectionSet.selections.every(\n selection =>\n selection.kind === 'FragmentSpread' &&\n isEmpty(fragments[selection.name.value], fragments),\n );\n}\n\nfunction nullIfDocIsEmpty(doc: DocumentNode) {\n return isEmpty(\n getOperationDefinition(doc) || getFragmentDefinition(doc),\n createFragmentMap(getFragmentDefinitions(doc)),\n )\n ? null\n : doc;\n}\n\nfunction getDirectiveMatcher(\n directives: (RemoveDirectiveConfig | GetDirectiveConfig)[],\n) {\n return function directiveMatcher(directive: DirectiveNode) {\n return directives.some(\n dir =>\n (dir.name && dir.name === directive.name.value) ||\n (dir.test && dir.test(directive)),\n );\n };\n}\n\nexport function removeDirectivesFromDocument(\n directives: RemoveDirectiveConfig[],\n doc: DocumentNode,\n): DocumentNode | null {\n const variablesInUse: Record<string, boolean> = Object.create(null);\n let variablesToRemove: RemoveArgumentsConfig[] = [];\n\n const fragmentSpreadsInUse: Record<string, boolean> = Object.create(null);\n let fragmentSpreadsToRemove: RemoveFragmentSpreadConfig[] = [];\n\n let modifiedDoc = nullIfDocIsEmpty(\n visit(doc, {\n Variable: {\n enter(node, _key, parent) {\n // Store each variable that's referenced as part of an argument\n // (excluding operation definition variables), so we know which\n // variables are being used. If we later want to remove a variable\n // we'll first check to see if it's being used, before continuing with\n // the removal.\n if (\n (parent as VariableDefinitionNode).kind !== 'VariableDefinition'\n ) {\n variablesInUse[node.name.value] = true;\n }\n },\n },\n\n Field: {\n enter(node) {\n if (directives && node.directives) {\n // If `remove` is set to true for a directive, and a directive match\n // is found for a field, remove the field as well.\n const shouldRemoveField = directives.some(\n directive => directive.remove,\n );\n\n if (\n shouldRemoveField &&\n node.directives &&\n node.directives.some(getDirectiveMatcher(directives))\n ) {\n if (node.arguments) {\n // Store field argument variables so they can be removed\n // from the operation definition.\n node.arguments.forEach(arg => {\n if (arg.value.kind === 'Variable') {\n variablesToRemove.push({\n name: (arg.value as VariableNode).name.value,\n });\n }\n });\n }\n\n if (node.selectionSet) {\n // Store fragment spread names so they can be removed from the\n // document.\n getAllFragmentSpreadsFromSelectionSet(node.selectionSet).forEach(\n frag => {\n fragmentSpreadsToRemove.push({\n name: frag.name.value,\n });\n },\n );\n }\n\n // Remove the field.\n return null;\n }\n }\n },\n },\n\n FragmentSpread: {\n enter(node) {\n // Keep track of referenced fragment spreads. This is used to\n // determine if top level fragment definitions should be removed.\n fragmentSpreadsInUse[node.name.value] = true;\n },\n },\n\n Directive: {\n enter(node) {\n // If a matching directive is found, remove it.\n if (getDirectiveMatcher(directives)(node)) {\n return null;\n }\n },\n },\n }),\n );\n\n // If we've removed fields with arguments, make sure the associated\n // variables are also removed from the rest of the document, as long as they\n // aren't being used elsewhere.\n if (\n modifiedDoc &&\n filterInPlace(variablesToRemove, v => !!v.name && !variablesInUse[v.name]).length\n ) {\n modifiedDoc = removeArgumentsFromDocument(variablesToRemove, modifiedDoc);\n }\n\n // If we've removed selection sets with fragment spreads, make sure the\n // associated fragment definitions are also removed from the rest of the\n // document, as long as they aren't being used elsewhere.\n if (\n modifiedDoc &&\n filterInPlace(fragmentSpreadsToRemove, fs => !!fs.name && !fragmentSpreadsInUse[fs.name])\n .length\n ) {\n modifiedDoc = removeFragmentSpreadFromDocument(\n fragmentSpreadsToRemove,\n modifiedDoc,\n );\n }\n\n return modifiedDoc;\n}\n\nexport const addTypenameToDocument = Object.assign(function <\n TNode extends ASTNode\n>(\n doc: TNode\n): TNode {\n return visit(doc, {\n SelectionSet: {\n enter(node, _key, parent) {\n // Don't add __typename to OperationDefinitions.\n if (\n parent &&\n (parent as OperationDefinitionNode).kind === 'OperationDefinition'\n ) {\n return;\n }\n\n // No changes if no selections.\n const { selections } = node;\n if (!selections) {\n return;\n }\n\n // If selections already have a __typename, or are part of an\n // introspection query, do nothing.\n const skip = selections.some(selection => {\n return (\n isField(selection) &&\n (selection.name.value === '__typename' ||\n selection.name.value.lastIndexOf('__', 0) === 0)\n );\n });\n if (skip) {\n return;\n }\n\n // If this SelectionSet is @export-ed as an input variable, it should\n // not have a __typename field (see issue #4691).\n const field = parent as FieldNode;\n if (\n isField(field) &&\n field.directives &&\n field.directives.some(d => d.name.value === 'export')\n ) {\n return;\n }\n\n // Create and return a new SelectionSet with a __typename Field.\n return {\n ...node,\n selections: [...selections, TYPENAME_FIELD],\n };\n },\n },\n });\n}, {\n added(field: FieldNode): boolean {\n return field === TYPENAME_FIELD;\n },\n});\n\nconst connectionRemoveConfig = {\n test: (directive: DirectiveNode) => {\n const willRemove = directive.name.value === 'connection';\n if (willRemove) {\n if (\n !directive.arguments ||\n !directive.arguments.some(arg => arg.name.value === 'key')\n ) {\n invariant.warn(\n 'Removing an @connection directive even though it does not have a key. ' +\n 'You may want to use the key parameter to specify a store key.',\n );\n }\n }\n\n return willRemove;\n },\n};\n\nexport function removeConnectionDirectiveFromDocument(doc: DocumentNode) {\n return removeDirectivesFromDocument(\n [connectionRemoveConfig],\n checkDocument(doc),\n );\n}\n\nfunction hasDirectivesInSelectionSet(\n directives: GetDirectiveConfig[],\n selectionSet: SelectionSetNode | undefined,\n nestedCheck = true,\n): boolean {\n return (\n !!selectionSet &&\n selectionSet.selections &&\n selectionSet.selections.some(selection =>\n hasDirectivesInSelection(directives, selection, nestedCheck),\n )\n );\n}\n\nfunction hasDirectivesInSelection(\n directives: GetDirectiveConfig[],\n selection: SelectionNode,\n nestedCheck = true,\n): boolean {\n if (!isField(selection)) {\n return true;\n }\n\n if (!selection.directives) {\n return false;\n }\n\n return (\n selection.directives.some(getDirectiveMatcher(directives)) ||\n (nestedCheck &&\n hasDirectivesInSelectionSet(\n directives,\n selection.selectionSet,\n nestedCheck,\n ))\n );\n}\n\nfunction getArgumentMatcher(config: RemoveArgumentsConfig[]) {\n return function argumentMatcher(argument: ArgumentNode) {\n return config.some(\n (aConfig: RemoveArgumentsConfig) =>\n argument.value &&\n argument.value.kind === 'Variable' &&\n argument.value.name &&\n (aConfig.name === argument.value.name.value ||\n (aConfig.test && aConfig.test(argument))),\n );\n };\n}\n\nexport function removeArgumentsFromDocument(\n config: RemoveArgumentsConfig[],\n doc: DocumentNode,\n): DocumentNode | null {\n const argMatcher = getArgumentMatcher(config);\n\n return nullIfDocIsEmpty(\n visit(doc, {\n OperationDefinition: {\n enter(node) {\n return {\n ...node,\n // Remove matching top level variables definitions.\n variableDefinitions: node.variableDefinitions ? node.variableDefinitions.filter(\n varDef =>\n !config.some(arg => arg.name === varDef.variable.name.value),\n ) : [],\n };\n },\n },\n\n Field: {\n enter(node) {\n // If `remove` is set to true for an argument, and an argument match\n // is found for a field, remove the field as well.\n const shouldRemoveField = config.some(argConfig => argConfig.remove);\n\n if (shouldRemoveField) {\n let argMatchCount = 0;\n if (node.arguments) {\n node.arguments.forEach(arg => {\n if (argMatcher(arg)) {\n argMatchCount += 1;\n }\n });\n }\n\n if (argMatchCount === 1) {\n return null;\n }\n }\n },\n },\n\n Argument: {\n enter(node) {\n // Remove all matching arguments.\n if (argMatcher(node)) {\n return null;\n }\n },\n },\n }),\n );\n}\n\nexport function removeFragmentSpreadFromDocument(\n config: RemoveFragmentSpreadConfig[],\n doc: DocumentNode,\n): DocumentNode | null {\n function enter(\n node: FragmentSpreadNode | FragmentDefinitionNode,\n ): null | void {\n if (config.some(def => def.name === node.name.value)) {\n return null;\n }\n }\n\n return nullIfDocIsEmpty(\n visit(doc, {\n FragmentSpread: { enter },\n FragmentDefinition: { enter },\n }),\n );\n}\n\nfunction getAllFragmentSpreadsFromSelectionSet(\n selectionSet: SelectionSetNode,\n): FragmentSpreadNode[] {\n const allFragments: FragmentSpreadNode[] = [];\n\n selectionSet.selections.forEach(selection => {\n if (\n (isField(selection) || isInlineFragment(selection)) &&\n selection.selectionSet\n ) {\n getAllFragmentSpreadsFromSelectionSet(selection.selectionSet).forEach(\n frag => allFragments.push(frag),\n );\n } else if (selection.kind === 'FragmentSpread') {\n allFragments.push(selection);\n }\n });\n\n return allFragments;\n}\n\n// If the incoming document is a query, return it as is. Otherwise, build a\n// new document containing a query operation based on the selection set\n// of the previous main operation.\nexport function buildQueryFromSelectionSet(\n document: DocumentNode,\n): DocumentNode {\n const definition = getMainDefinition(document);\n const definitionOperation = (<OperationDefinitionNode>definition).operation;\n\n if (definitionOperation === 'query') {\n // Already a query, so return the existing document.\n return document;\n }\n\n // Build a new query using the selection set of the main operation.\n const modifiedDoc = visit(document, {\n OperationDefinition: {\n enter(node) {\n return {\n ...node,\n operation: 'query',\n };\n },\n },\n });\n return modifiedDoc;\n}\n\n// Remove fields / selection sets that include an @client directive.\nexport function removeClientSetsFromDocument(\n document: DocumentNode,\n): DocumentNode | null {\n checkDocument(document);\n\n let modifiedDoc = removeDirectivesFromDocument(\n [\n {\n test: (directive: DirectiveNode) => directive.name.value === 'client',\n remove: true,\n },\n ],\n document,\n );\n\n // After a fragment definition has had its @client related document\n // sets removed, if the only field it has left is a __typename field,\n // remove the entire fragment operation to prevent it from being fired\n // on the server.\n if (modifiedDoc) {\n modifiedDoc = visit(modifiedDoc, {\n FragmentDefinition: {\n enter(node) {\n if (node.selectionSet) {\n const isTypenameOnly = node.selectionSet.selections.every(\n selection =>\n isField(selection) && selection.name.value === '__typename',\n );\n if (isTypenameOnly) {\n return null;\n }\n }\n },\n },\n });\n }\n\n return modifiedDoc;\n}\n","const prefixCounts = new Map<string, number>();\n\n// These IDs won't be globally unique, but they will be unique within this\n// process, thanks to the counter, and unguessable thanks to the random suffix.\nexport function makeUniqueId(prefix: string) {\n const count = prefixCounts.get(prefix) || 1;\n prefixCounts.set(prefix, count + 1);\n return `${prefix}:${count}:${Math.random().toString(36).slice(2)}`;\n}\n","import { Observer } from \"./Observable\";\n\nexport function iterateObserversSafely<E, A>(\n observers: Set<Observer<E>>,\n method: keyof Observer<E>,\n argument?: A,\n) {\n // In case observers is modified during iteration, we need to commit to the\n // original elements, which also provides an opportunity to filter them down\n // to just the observers with the given method.\n const observersWithMethod: Observer<E>[] = [];\n observers.forEach(obs => obs[method] && observersWithMethod.push(obs));\n observersWithMethod.forEach(obs => (obs as any)[method](argument));\n}\n","import { Observable } from \"./Observable\";\nimport { canUseSymbol } from \"../common/canUse\";\n\n// Generic implementations of Observable.prototype methods like map and\n// filter need to know how to create a new Observable from an Observable\n// subclass (like Concast or ObservableQuery). Those methods assume\n// (perhaps unwisely?) that they can call the subtype's constructor with a\n// Subscriber function, even though the subclass constructor might expect\n// different parameters. Defining this static Symbol.species property on\n// the subclass is a hint to generic Observable code to use the default\n// constructor instead of trying to do `new Subclass(observer => ...)`.\nexport function fixObservableSubclass<\n S extends new (...args: any[]) => Observable<any>,\n>(subclass: S): S {\n function set(key: symbol | string) {\n // Object.defineProperty is necessary because the Symbol.species\n // property is a getter by default in modern JS environments, so we\n // can't assign to it with a normal assignment expression.\n Object.defineProperty(subclass, key, { value: Observable });\n }\n if (canUseSymbol && Symbol.species) {\n set(Symbol.species);\n }\n // The \"@@species\" string is used as a fake Symbol.species value in some\n // polyfill systems (including the SymbolSpecies variable used by\n // zen-observable), so we should set it as well, to be safe.\n set(\"@@species\");\n return subclass;\n}\n","import { Observable, Observer, ObservableSubscription, Subscriber } from \"./Observable\";\nimport { iterateObserversSafely } from \"./iteration\";\nimport { fixObservableSubclass } from \"./subclassing\";\n\ntype MaybeAsync<T> = T | PromiseLike<T>;\n\nfunction isPromiseLike<T>(value: MaybeAsync<T>): value is PromiseLike<T> {\n return value && typeof (value as any).then === \"function\";\n}\n\n// Any individual Source<T> can be an Observable<T> or a promise for one.\ntype Source<T> = MaybeAsync<Observable<T>>;\n\nexport type ConcastSourcesIterable<T> = Iterable<Source<T>>;\nexport type ConcastSourcesArray<T> = Array<Source<T>>;\n\n// A Concast<T> observable concatenates the given sources into a single\n// non-overlapping sequence of Ts, automatically unwrapping any promises,\n// and broadcasts the T elements of that sequence to any number of\n// subscribers, all without creating a bunch of intermediary Observable\n// wrapper objects.\n//\n// Even though any number of observers can subscribe to the Concast, each\n// source observable is guaranteed to receive at most one subscribe call,\n// and the results are multicast to all observers.\n//\n// In addition to broadcasting every next/error message to this.observers,\n// the Concast stores the most recent message using this.latest, so any\n// new observers can immediately receive the latest message, even if it\n// was originally delivered in the past. This behavior means we can assume\n// every active observer in this.observers has received the same most\n// recent message.\n//\n// With the exception of this.latest replay, a Concast is a \"hot\"\n// observable in the sense that it does not replay past results from the\n// beginning of time for each new observer.\n//\n// Could we have used some existing RxJS class instead? Concast<T> is\n// similar to a BehaviorSubject<T>, because it is multicast and redelivers\n// the latest next/error message to new subscribers. Unlike Subject<T>,\n// Concast<T> does not expose an Observer<T> interface (this.handlers is\n// intentionally private), since Concast<T> gets its inputs from the\n// concatenated sources. If we ever switch to RxJS, there may be some\n// value in reusing their code, but for now we use zen-observable, which\n// does not contain any Subject implementations.\nexport class Concast<T> extends Observable<T> {\n // Active observers receiving broadcast messages. Thanks to this.latest,\n // we can assume all observers in this Set have received the same most\n // recent message, though possibly at different times in the past.\n private observers = new Set<Observer<T>>();\n\n // This property starts off undefined to indicate the initial\n // subscription has not yet begun, then points to each source\n // subscription in turn, and finally becomes null after the sources have\n // been exhausted. After that, it stays null.\n private sub?: ObservableSubscription | null;\n\n // Not only can the individual elements of the iterable be promises, but\n // also the iterable itself can be wrapped in a promise.\n constructor(sources: MaybeAsync<ConcastSourcesIterable<T>> | Subscriber<T>) {\n super(observer => {\n this.addObserver(observer);\n return () => this.removeObserver(observer);\n });\n\n // Suppress rejection warnings for this.promise, since it's perfectly\n // acceptable to pay no attention to this.promise if you're consuming\n // the results through the normal observable API.\n this.promise.catch(_ => {});\n\n // If someone accidentally tries to create a Concast using a subscriber\n // function, recover by creating an Observable from that subscriber and\n // using it as the source.\n if (typeof sources === \"function\") {\n sources = [new Observable(sources)];\n }\n\n if (isPromiseLike(sources)) {\n sources.then(\n iterable => this.start(iterable),\n this.handlers.error,\n );\n } else {\n this.start(sources);\n }\n }\n\n // A consumable array of source observables, incrementally consumed\n // each time this.handlers.complete is called.\n private sources: Source<T>[];\n\n private start(sources: ConcastSourcesIterable<T>) {\n if (this.sub !== void 0) return;\n\n // In practice, sources is most often simply an Array of observables.\n // TODO Consider using sources[Symbol.iterator]() to take advantage\n // of the laziness of non-Array iterables.\n this.sources = Array.from(sources);\n\n // Calling this.handlers.complete() kicks off consumption of the first\n // source observable. It's tempting to do this step lazily in\n // addObserver, but this.promise can be accessed without calling\n // addObserver, so consumption needs to begin eagerly.\n this.handlers.complete();\n }\n\n private deliverLastMessage(observer: Observer<T>) {\n if (this.latest) {\n const nextOrError = this.latest[0];\n const method = observer[nextOrError];\n if (method) {\n method.call(observer, this.latest[1]);\n }\n // If the subscription is already closed, and the last message was\n // a 'next' message, simulate delivery of the final 'complete'\n // message again.\n if (this.sub === null &&\n nextOrError === \"next\" &&\n observer.complete) {\n observer.complete();\n }\n }\n }\n\n // Note: cleanup observers do not count towards this total.\n private addCount = 0;\n\n public addObserver(observer: Observer<T>) {\n if (!this.observers.has(observer)) {\n // Immediately deliver the most recent message, so we can always\n // be sure all observers have the latest information.\n this.deliverLastMessage(observer);\n this.observers.add(observer);\n ++this.addCount;\n }\n }\n\n public removeObserver(\n observer: Observer<T>,\n quietly?: boolean,\n ) {\n if (this.observers.delete(observer) &&\n --this.addCount < 1 &&\n !quietly) {\n // In case there are still any cleanup observers in this.observers, and no\n // error or completion has been broadcast yet, make sure those observers\n // have a chance to run and then remove themselves from this.observers.\n this.handlers.complete();\n }\n }\n\n // Any Concast object can be trivially converted to a Promise, without\n // having to create a new wrapper Observable. This promise provides an\n // easy way to observe the final state of the Concast.\n private resolve: (result?: T | PromiseLike<T>) => void;\n private reject: (reason: any) => void;\n public readonly promise = new Promise<T>((resolve, reject) => {\n this.resolve = resolve;\n this.reject = reject;\n });\n\n // Name and argument of the most recently invoked observer method, used\n // to deliver latest results immediately to new observers.\n private latest?: [\"next\" | \"error\", any];\n\n // Bound handler functions that can be reused for every internal\n // subscription.\n private handlers = {\n next: (result: T) => {\n if (this.sub !== null) {\n this.latest = [\"next\", result];\n iterateObserversSafely(this.observers, \"next\", result);\n }\n },\n\n error: (error: any) => {\n const { sub } = this;\n if (sub !== null) {\n // Delay unsubscribing from the underlying subscription slightly,\n // so that immediately subscribing another observer can keep the\n // subscription active.\n if (sub) setTimeout(() => sub.unsubscribe());\n this.sub = null;\n this.latest = [\"error\", error];\n this.reject(error);\n iterateObserversSafely(this.observers, \"error\", error);\n }\n },\n\n complete: () => {\n const { sub } = this;\n if (sub !== null) {\n const value = this.sources.shift();\n if (!value) {\n if (sub) setTimeout(() => sub.unsubscribe());\n this.sub = null;\n if (this.latest &&\n this.latest[0] === \"next\") {\n this.resolve(this.latest[1]);\n } else {\n this.resolve();\n }\n // We do not store this.latest = [\"complete\"], because doing so\n // discards useful information about the previous next (or\n // error) message. Instead, if new observers subscribe after\n // this Concast has completed, they will receive the final\n // 'next' message (unless there was an error) immediately\n // followed by a 'complete' message (see addObserver).\n iterateObserversSafely(this.observers, \"complete\");\n } else if (isPromiseLike(value)) {\n value.then(obs => this.sub = obs.subscribe(this.handlers));\n } else {\n this.sub = value.subscribe(this.handlers);\n }\n }\n },\n };\n\n public cleanup(callback: () => any) {\n let called = false;\n const once = () => {\n if (!called) {\n called = true;\n // Removing a cleanup observer should not unsubscribe from the\n // underlying Observable, so the only removeObserver behavior we\n // need here is to delete observer from this.observers.\n this.observers.delete(observer);\n callback();\n }\n }\n const observer = {\n next: once,\n error: once,\n complete: once,\n };\n const count = this.addCount;\n this.addObserver(observer);\n // Normally addObserver increments this.addCount, but we can \"hide\"\n // cleanup observers by restoring this.addCount to its previous value\n // after adding any cleanup observer.\n this.addCount = count;\n }\n\n // A public way to abort observation and broadcast.\n public cancel = (reason: any) => {\n this.reject(reason);\n this.sources = [];\n this.handlers.complete();\n }\n}\n\n// Necessary because the Concast constructor has a different signature\n// than the Observable constructor.\nfixObservableSubclass(Concast);\n","const { toString } = Object.prototype;\n\n/**\n * Deeply clones a value to create a new instance.\n */\nexport function cloneDeep<T>(value: T): T {\n return cloneDeepHelper(value);\n}\n\nfunction cloneDeepHelper<T>(val: T, seen?: Map<any, any>): T {\n switch (toString.call(val)) {\n case \"[object Array]\": {\n seen = seen || new Map;\n if (seen.has(val)) return seen.get(val);\n const copy: T & any[] = (val as any).slice(0);\n seen.set(val, copy);\n copy.forEach(function (child, i) {\n copy[i] = cloneDeepHelper(child, seen);\n });\n return copy;\n }\n\n case \"[object Object]\": {\n seen = seen || new Map;\n if (seen.has(val)) return seen.get(val);\n // High fidelity polyfills of Object.create and Object.getPrototypeOf are\n // possible in all JS environments, so we will assume they exist/work.\n const copy = Object.create(Object.getPrototypeOf(val));\n seen.set(val, copy);\n Object.keys(val).forEach(key => {\n copy[key] = cloneDeepHelper((val as any)[key], seen);\n });\n return copy;\n }\n\n default:\n return val;\n }\n}\n","import { invariant } from '../utilities/globals';\nimport { DocumentNode } from 'graphql';\nimport { equal } from '@wry/equality';\n\nimport { NetworkStatus, isNetworkRequestInFlight } from './networkStatus';\nimport {\n Concast,\n cloneDeep,\n compact,\n getOperationDefinition,\n Observable,\n Observer,\n ObservableSubscription,\n iterateObserversSafely,\n isNonEmptyArray,\n fixObservableSubclass,\n getQueryDefinition,\n} from '../utilities';\nimport { ApolloError } from '../errors';\nimport { QueryManager } from './QueryManager';\nimport {\n ApolloQueryResult,\n OperationVariables,\n TypedDocumentNode,\n} from './types';\nimport {\n WatchQueryOptions,\n FetchMoreQueryOptions,\n SubscribeToMoreOptions,\n NextFetchPolicyContext,\n} from './watchQueryOptions';\nimport { QueryInfo } from './QueryInfo';\nimport { MissingFieldError } from '../cache';\nimport { MissingTree } from '../cache/core/types/common';\n\nconst {\n assign,\n hasOwnProperty,\n} = Object;\n\nexport interface FetchMoreOptions<\n TData = any,\n TVariables = OperationVariables\n> {\n updateQuery?: (\n previousQueryResult: TData,\n options: {\n fetchMoreResult?: TData;\n variables?: TVariables;\n },\n ) => TData;\n}\n\nexport interface UpdateQueryOptions<TVariables> {\n variables?: TVariables;\n}\n\ninterface Last<TData, TVariables> {\n result: ApolloQueryResult<TData>;\n variables?: TVariables;\n error?: ApolloError;\n}\n\nexport class ObservableQuery<\n TData = any,\n TVariables = OperationVariables\n> extends Observable<ApolloQueryResult<TData>> {\n public readonly options: WatchQueryOptions<TVariables, TData>;\n public readonly queryId: string;\n public readonly queryName?: string;\n\n public get query(): TypedDocumentNode<TData, TVariables> {\n // This transform is heavily cached, so it should not be expensive to\n // transform the same this.options.query document repeatedly.\n return this.queryManager.transform(this.options.query).document;\n }\n\n // Computed shorthand for this.options.variables, preserved for\n // backwards compatibility.\n public get variables(): TVariables | undefined {\n return this.options.variables;\n }\n\n private isTornDown: boolean;\n private queryManager: QueryManager<any>;\n private observers = new Set<Observer<ApolloQueryResult<TData>>>();\n private subscriptions = new Set<ObservableSubscription>();\n\n private last?: Last<TData, TVariables>;\n\n private queryInfo: QueryInfo;\n\n // When this.concast is defined, this.observer is the Observer currently\n // subscribed to that Concast.\n private concast?: Concast<ApolloQueryResult<TData>>;\n private observer?: Observer<ApolloQueryResult<TData>>;\n\n private pollingInfo?: {\n interval: number;\n timeout: ReturnType<typeof setTimeout>;\n };\n\n constructor({\n queryManager,\n queryInfo,\n options,\n }: {\n queryManager: QueryManager<any>;\n queryInfo: QueryInfo;\n options: WatchQueryOptions<TVariables, TData>;\n }) {\n super((observer: Observer<ApolloQueryResult<TData>>) => {\n // Zen Observable has its own error function, so in order to log correctly\n // we need to provide a custom error callback.\n try {\n var subObserver = (observer as any)._subscription._observer;\n if (subObserver && !subObserver.error) {\n subObserver.error = defaultSubscriptionObserverErrorCallback;\n }\n } catch {}\n\n const first = !this.observers.size;\n this.observers.add(observer);\n\n // Deliver most recent error or result.\n const last = this.last;\n if (last && last.error) {\n observer.error && observer.error(last.error);\n } else if (last && last.result) {\n observer.next && observer.next(last.result);\n }\n\n // Initiate observation of this query if it hasn't been reported to\n // the QueryManager yet.\n if (first) {\n // Blindly catching here prevents unhandled promise rejections,\n // and is safe because the ObservableQuery handles this error with\n // this.observer.error, so we're not just swallowing the error by\n // ignoring it here.\n this.reobserve().catch(() => {});\n }\n\n return () => {\n if (this.observers.delete(observer) && !this.observers.size) {\n this.tearDownQuery();\n }\n };\n });\n\n // related classes\n this.queryInfo = queryInfo;\n this.queryManager = queryManager;\n\n // active state\n this.isTornDown = false;\n\n const {\n watchQuery: {\n fetchPolicy: defaultFetchPolicy = \"cache-first\",\n } = {},\n } = queryManager.defaultOptions;\n\n const {\n fetchPolicy = defaultFetchPolicy,\n initialFetchPolicy = (\n // Make sure we don't store \"standby\" as the initialFetchPolicy.\n fetchPolicy === \"standby\" ? defaultFetchPolicy : fetchPolicy\n ),\n } = options;\n\n this.options = {\n ...options,\n\n // Remember the initial options.fetchPolicy so we can revert back to this\n // policy when variables change. This information can also be specified\n // (or overridden) by providing options.initialFetchPolicy explicitly.\n initialFetchPolicy,\n\n // This ensures this.options.fetchPolicy always has a string value, in\n // case options.fetchPolicy was not provided.\n fetchPolicy,\n };\n\n this.queryId = queryInfo.queryId || queryManager.generateQueryId();\n\n const opDef = getOperationDefinition(this.query);\n this.queryName = opDef && opDef.name && opDef.name.value;\n }\n\n public result(): Promise<ApolloQueryResult<TData>> {\n return new Promise((resolve, reject) => {\n // TODO: this code doesn’t actually make sense insofar as the observer\n // will never exist in this.observers due how zen-observable wraps observables.\n // https://github.com/zenparsing/zen-observable/blob/master/src/Observable.js#L169\n const observer: Observer<ApolloQueryResult<TData>> = {\n next: (result: ApolloQueryResult<TData>) => {\n resolve(result);\n\n // Stop the query within the QueryManager if we can before\n // this function returns.\n //\n // We do this in order to prevent observers piling up within\n // the QueryManager. Notice that we only fully unsubscribe\n // from the subscription in a setTimeout(..., 0) call. This call can\n // actually be handled by the browser at a much later time. If queries\n // are fired in the meantime, observers that should have been removed\n // from the QueryManager will continue to fire, causing an unnecessary\n // performance hit.\n this.observers.delete(observer);\n if (!this.observers.size) {\n this.queryManager.removeQuery(this.queryId);\n }\n\n setTimeout(() => {\n subscription.unsubscribe();\n }, 0);\n },\n error: reject,\n };\n const subscription = this.subscribe(observer);\n });\n }\n\n public getCurrentResult(saveAsLastResult = true): ApolloQueryResult<TData> {\n // Use the last result as long as the variables match this.variables.\n const lastResult = this.getLastResult(true);\n\n const networkStatus =\n this.queryInfo.networkStatus ||\n (lastResult && lastResult.networkStatus) ||\n NetworkStatus.ready;\n\n const result = {\n ...lastResult,\n loading: isNetworkRequestInFlight(networkStatus),\n networkStatus,\n } as ApolloQueryResult<TData>;\n\n const { fetchPolicy = \"cache-first\" } = this.options;\n if (\n // These fetch policies should never deliver data from the cache, unless\n // redelivering a previously delivered result.\n fetchPolicy === 'network-only' ||\n fetchPolicy === 'no-cache' ||\n fetchPolicy === 'standby' ||\n // If this.options.query has @client(always: true) fields, we cannot\n // trust diff.result, since it was read from the cache without running\n // local resolvers (and it's too late to run resolvers now, since we must\n // return a result synchronously).\n this.queryManager.transform(this.options.query).hasForcedResolvers\n ) {\n // Fall through.\n } else {\n const diff = this.queryInfo.getDiff();\n\n if (diff.complete || this.options.returnPartialData) {\n result.data = diff.result;\n }\n\n if (equal(result.data, {})) {\n result.data = void 0 as any;\n }\n\n if (diff.complete) {\n // Similar to setting result.partial to false, but taking advantage of the\n // falsiness of missing fields.\n delete result.partial;\n\n // If the diff is complete, and we're using a FetchPolicy that\n // terminates after a complete cache read, we can assume the next result\n // we receive will have NetworkStatus.ready and !loading.\n if (\n diff.complete &&\n result.networkStatus === NetworkStatus.loading &&\n (fetchPolicy === 'cache-first' ||\n fetchPolicy === 'cache-only')\n ) {\n result.networkStatus = NetworkStatus.ready;\n result.loading = false;\n }\n } else {\n result.partial = true;\n }\n\n if (\n __DEV__ &&\n !diff.complete &&\n !this.options.partialRefetch &&\n !result.loading &&\n !result.data &&\n !result.error\n ) {\n logMissingFieldErrors(diff.missing);\n }\n }\n\n if (saveAsLastResult) {\n this.updateLastResult(result);\n }\n\n return result;\n }\n\n // Compares newResult to the snapshot we took of this.lastResult when it was\n // first received.\n public isDifferentFromLastResult(newResult: ApolloQueryResult<TData>) {\n return !this.last || !equal(this.last.result, newResult);\n }\n\n private getLast<K extends keyof Last<TData, TVariables>>(\n key: K,\n variablesMustMatch?: boolean,\n ) {\n const last = this.last;\n if (\n last &&\n last[key] &&\n (!variablesMustMatch || equal(last.variables, this.variables))\n ) {\n return last[key];\n }\n }\n\n public getLastResult(variablesMustMatch?: boolean): ApolloQueryResult<TData> | undefined {\n return this.getLast(\"result\", variablesMustMatch);\n }\n\n public getLastError(variablesMustMatch?: boolean): ApolloError | undefined {\n return this.getLast(\"error\", variablesMustMatch);\n }\n\n public resetLastResults(): void {\n delete this.last;\n this.isTornDown = false;\n }\n\n public resetQueryStoreErrors() {\n this.queryManager.resetErrors(this.queryId);\n }\n\n /**\n * Update the variables of this observable query, and fetch the new results.\n * This method should be preferred over `setVariables` in most use cases.\n *\n * @param variables: The new set of variables. If there are missing variables,\n * the previous values of those variables will be used.\n */\n public refetch(variables?: Partial<TVariables>): Promise<ApolloQueryResult<TData>> {\n const reobserveOptions: Partial<WatchQueryOptions<TVariables, TData>> = {\n // Always disable polling for refetches.\n pollInterval: 0,\n };\n\n // Unless the provided fetchPolicy always consults the network\n // (no-cache, network-only, or cache-and-network), override it with\n // network-only to force the refetch for this fetchQuery call.\n const { fetchPolicy } = this.options;\n if (fetchPolicy === 'cache-and-network') {\n reobserveOptions.fetchPolicy = fetchPolicy;\n } else if (fetchPolicy === 'no-cache') {\n reobserveOptions.fetchPolicy = 'no-cache';\n } else {\n reobserveOptions.fetchPolicy = 'network-only';\n }\n\n if (__DEV__ && variables && hasOwnProperty.call(variables, \"variables\")) {\n const queryDef = getQueryDefinition(this.query);\n const vars = queryDef.variableDefinitions;\n if (!vars || !vars.some(v => v.variable.name.value === \"variables\")) {\n invariant.warn(`Called refetch(${\n JSON.stringify(variables)\n }) for query ${\n queryDef.name?.value || JSON.stringify(queryDef)\n }, which does not declare a $variables variable.\nDid you mean to call refetch(variables) instead of refetch({ variables })?`);\n }\n }\n\n if (variables && !equal(this.options.variables, variables)) {\n // Update the existing options with new variables\n reobserveOptions.variables = this.options.variables = {\n ...this.options.variables,\n ...variables,\n } as TVariables;\n }\n\n this.queryInfo.resetLastWrite();\n return this.reobserve(reobserveOptions, NetworkStatus.refetch);\n }\n\n public fetchMore<\n TFetchData = TData,\n TFetchVars = TVariables,\n >(fetchMoreOptions: FetchMoreQueryOptions<TFetchVars, TFetchData> & {\n updateQuery?: (\n previousQueryResult: TData,\n options: {\n fetchMoreResult: TFetchData;\n variables: TFetchVars;\n },\n ) => TData;\n }): Promise<ApolloQueryResult<TFetchData>> {\n const combinedOptions = {\n ...(fetchMoreOptions.query ? fetchMoreOptions : {\n ...this.options,\n query: this.query,\n ...fetchMoreOptions,\n variables: {\n ...this.options.variables,\n ...fetchMoreOptions.variables,\n },\n }),\n // The fetchMore request goes immediately to the network and does\n // not automatically write its result to the cache (hence no-cache\n // instead of network-only), because we allow the caller of\n // fetchMore to provide an updateQuery callback that determines how\n // the data gets written to the cache.\n fetchPolicy: \"no-cache\",\n } as WatchQueryOptions<TFetchVars, TFetchData>;\n\n const qid = this.queryManager.generateQueryId();\n\n // Simulate a loading result for the original query with\n // result.networkStatus === NetworkStatus.fetchMore.\n const { queryInfo } = this;\n const originalNetworkStatus = queryInfo.networkStatus;\n queryInfo.networkStatus = NetworkStatus.fetchMore;\n if (combinedOptions.notifyOnNetworkStatusChange) {\n this.observe();\n }\n\n const updatedQuerySet = new Set<DocumentNode>();\n\n return this.queryManager.fetchQuery(\n qid,\n combinedOptions,\n NetworkStatus.fetchMore,\n ).then(fetchMoreResult => {\n this.queryManager.removeQuery(qid);\n\n if (queryInfo.networkStatus === NetworkStatus.fetchMore) {\n queryInfo.networkStatus = originalNetworkStatus;\n }\n\n // Performing this cache update inside a cache.batch transaction ensures\n // any affected cache.watch watchers are notified at most once about any\n // updates. Most watchers will be using the QueryInfo class, which\n // responds to notifications by calling reobserveCacheFirst to deliver\n // fetchMore cache results back to this ObservableQuery.\n this.queryManager.cache.batch({\n update: cache => {\n const { updateQuery } = fetchMoreOptions;\n if (updateQuery) {\n cache.updateQuery({\n query: this.query,\n variables: this.variables,\n returnPartialData: true,\n optimistic: false,\n }, previous => updateQuery(previous!, {\n fetchMoreResult: fetchMoreResult.data,\n variables: combinedOptions.variables as TFetchVars,\n }));\n\n } else {\n // If we're using a field policy instead of updateQuery, the only\n // thing we need to do is write the new data to the cache using\n // combinedOptions.variables (instead of this.variables, which is\n // what this.updateQuery uses, because it works by abusing the\n // original field value, keyed by the original variables).\n cache.writeQuery({\n query: combinedOptions.query,\n variables: combinedOptions.variables,\n data: fetchMoreResult.data,\n });\n }\n },\n\n onWatchUpdated: watch => {\n // Record the DocumentNode associated with any watched query whose\n // data were updated by the cache writes above.\n updatedQuerySet.add(watch.query);\n },\n });\n\n return fetchMoreResult as ApolloQueryResult<TFetchData>;\n\n }).finally(() => {\n // In case the cache writes above did not generate a broadcast\n // notification (which would have been intercepted by onWatchUpdated),\n // likely because the written data were the same as what was already in\n // the cache, we still want fetchMore to deliver its final loading:false\n // result with the unchanged data.\n if (!updatedQuerySet.has(this.query)) {\n reobserveCacheFirst(this);\n }\n });\n }\n\n // XXX the subscription variables are separate from the query variables.\n // if you want to update subscription variables, right now you have to do that separately,\n // and you can only do it by stopping the subscription and then subscribing again with new variables.\n public subscribeToMore<\n TSubscriptionData = TData,\n TSubscriptionVariables = TVariables\n >(\n options: SubscribeToMoreOptions<\n TData,\n TSubscriptionVariables,\n TSubscriptionData\n >,\n ) {\n const subscription = this.queryManager\n .startGraphQLSubscription({\n query: options.document,\n variables: options.variables,\n context: options.context,\n })\n .subscribe({\n next: (subscriptionData: { data: TSubscriptionData }) => {\n const { updateQuery } = options;\n if (updateQuery) {\n this.updateQuery<TSubscriptionVariables>(\n (previous, { variables }) =>\n updateQuery(previous, {\n subscriptionData,\n variables,\n }),\n );\n }\n },\n error: (err: any) => {\n if (options.onError) {\n options.onError(err);\n return;\n }\n invariant.error('Unhandled GraphQL subscription error', err);\n },\n });\n\n this.subscriptions.add(subscription);\n\n return () => {\n if (this.subscriptions.delete(subscription)) {\n subscription.unsubscribe();\n }\n };\n }\n\n public setOptions(\n newOptions: Partial<WatchQueryOptions<TVariables, TData>>,\n ): Promise<ApolloQueryResult<TData>> {\n return this.reobserve(newOptions);\n }\n\n /**\n * This is for *internal* use only. Most users should instead use `refetch`\n * in order to be properly notified of results even when they come from cache.\n *\n * Update the variables of this observable query, and fetch the new results\n * if they've changed. If you want to force new results, use `refetch`.\n *\n * Note: the `next` callback will *not* fire if the variables have not changed\n * or if the result is coming from cache.\n *\n * Note: the promise will return the old results immediately if the variables\n * have not changed.\n *\n * Note: the promise will return null immediately if the query is not active\n * (there are no subscribers).\n *\n * @private\n *\n * @param variables: The new set of variables. If there are missing variables,\n * the previous values of those variables will be used.\n */\n public setVariables(\n variables: TVariables,\n ): Promise<ApolloQueryResult<TData> | void> {\n if (equal(this.variables, variables)) {\n // If we have no observers, then we don't actually want to make a network\n // request. As soon as someone observes the query, the request will kick\n // off. For now, we just store any changes. (See #1077)\n return this.observers.size\n ? this.result()\n : Promise.resolve();\n }\n\n this.options.variables = variables;\n\n // See comment above\n if (!this.observers.size) {\n return Promise.resolve();\n }\n\n return this.reobserve({\n // Reset options.fetchPolicy to its original value.\n fetchPolicy: this.options.initialFetchPolicy,\n variables,\n }, NetworkStatus.setVariables);\n }\n\n public updateQuery<TVars = TVariables>(\n mapFn: (\n previousQueryResult: TData,\n options: Pick<WatchQueryOptions<TVars, TData>, \"variables\">,\n ) => TData,\n ): void {\n const { queryManager } = this;\n const { result } = queryManager.cache.diff<TData>({\n query: this.options.query,\n variables: this.variables,\n returnPartialData: true,\n optimistic: false,\n });\n\n const newResult = mapFn(result!, {\n variables: (this as any).variables,\n });\n\n if (newResult) {\n queryManager.cache.writeQuery({\n query: this.options.query,\n data: newResult,\n variables: this.variables,\n });\n\n queryManager.broadcastQueries();\n }\n }\n\n public startPolling(pollInterval: number) {\n this.options.pollInterval = pollInterval;\n this.updatePolling();\n }\n\n public stopPolling() {\n this.options.pollInterval = 0;\n this.updatePolling();\n }\n\n // Update options.fetchPolicy according to options.nextFetchPolicy.\n private applyNextFetchPolicy(\n reason: NextFetchPolicyContext<TData, TVariables>[\"reason\"],\n // It's possible to use this method to apply options.nextFetchPolicy to\n // options.fetchPolicy even if options !== this.options, though that happens\n // most often when the options are temporary, used for only one request and\n // then thrown away, so nextFetchPolicy may not end up mattering.\n options: WatchQueryOptions<TVariables, TData>,\n ) {\n if (options.nextFetchPolicy) {\n const {\n fetchPolicy = \"cache-first\",\n initialFetchPolicy = fetchPolicy,\n } = options;\n\n if (fetchPolicy === \"standby\") {\n // Do nothing, leaving options.fetchPolicy unchanged.\n } else if (typeof options.nextFetchPolicy === \"function\") {\n // When someone chooses \"cache-and-network\" or \"network-only\" as their\n // initial FetchPolicy, they often do not want future cache updates to\n // trigger unconditional network requests, which is what repeatedly\n // applying the \"cache-and-network\" or \"network-only\" policies would\n // seem to imply. Instead, when the cache reports an update after the\n // initial network request, it may be desirable for subsequent network\n // requests to be triggered only if the cache result is incomplete. To\n // that end, the options.nextFetchPolicy option provides an easy way to\n // update options.fetchPolicy after the initial network request, without\n // having to call observableQuery.setOptions.\n options.fetchPolicy = options.nextFetchPolicy(fetchPolicy, {\n reason,\n options,\n observable: this,\n initialFetchPolicy,\n });\n } else if (reason === \"variables-changed\") {\n options.fetchPolicy = initialFetchPolicy;\n } else {\n options.fetchPolicy = options.nextFetchPolicy;\n }\n }\n\n return options.fetchPolicy;\n }\n\n private fetch(\n options: WatchQueryOptions<TVariables, TData>,\n newNetworkStatus?: NetworkStatus,\n ): Concast<ApolloQueryResult<TData>> {\n // TODO Make sure we update the networkStatus (and infer fetchVariables)\n // before actually committing to the fetch.\n this.queryManager.setObservableQuery(this);\n return this.queryManager.fetchQueryObservable(\n this.queryId,\n options,\n newNetworkStatus,\n );\n }\n\n // Turns polling on or off based on this.options.pollInterval.\n private updatePolling() {\n // Avoid polling in SSR mode\n if (this.queryManager.ssrMode) {\n return;\n }\n\n const {\n pollingInfo,\n options: {\n pollInterval,\n },\n } = this;\n\n if (!pollInterval) {\n if (pollingInfo) {\n clearTimeout(pollingInfo.timeout);\n delete this.pollingInfo;\n }\n return;\n }\n\n if (pollingInfo &&\n pollingInfo.interval === pollInterval) {\n return;\n }\n\n invariant(\n pollInterval,\n 'Attempted to start a polling query without a polling interval.',\n );\n\n const info = pollingInfo || (this.pollingInfo = {} as any);\n info.interval = pollInterval;\n\n const maybeFetch = () => {\n if (this.pollingInfo) {\n if (!isNetworkRequestInFlight(this.queryInfo.networkStatus)) {\n this.reobserve({\n fetchPolicy: \"network-only\",\n }, NetworkStatus.poll).then(poll, poll);\n } else {\n poll();\n }\n };\n };\n\n const poll = () => {\n const info = this.pollingInfo;\n if (info) {\n clearTimeout(info.timeout);\n info.timeout = setTimeout(maybeFetch, info.interval);\n }\n };\n\n poll();\n }\n\n private updateLastResult(\n newResult: ApolloQueryResult<TData>,\n variables = this.variables,\n ) {\n this.last = {\n ...this.last,\n result: this.queryManager.assumeImmutableResults\n ? newResult\n : cloneDeep(newResult),\n variables,\n };\n if (!isNonEmptyArray(newResult.errors)) {\n delete this.last.error;\n }\n return this.last;\n }\n\n public reobserve(\n newOptions?: Partial<WatchQueryOptions<TVariables, TData>>,\n newNetworkStatus?: NetworkStatus,\n ): Promise<ApolloQueryResult<TData>> {\n this.isTornDown = false;\n\n const useDisposableConcast =\n // Refetching uses a disposable Concast to allow refetches using different\n // options/variables, without permanently altering the options of the\n // original ObservableQuery.\n newNetworkStatus === NetworkStatus.refetch ||\n // The fetchMore method does not actually call the reobserve method, but,\n // if it did, it would definitely use a disposable Concast.\n newNetworkStatus === NetworkStatus.fetchMore ||\n // Polling uses a disposable Concast so the polling options (which force\n // fetchPolicy to be \"network-only\") won't override the original options.\n newNetworkStatus === NetworkStatus.poll;\n\n // Save the old variables, since Object.assign may modify them below.\n const oldVariables = this.options.variables;\n const oldFetchPolicy = this.options.fetchPolicy;\n\n const mergedOptions = compact(this.options, newOptions || {});\n const options = useDisposableConcast\n // Disposable Concast fetches receive a shallow copy of this.options\n // (merged with newOptions), leaving this.options unmodified.\n ? mergedOptions\n : assign(this.options, mergedOptions);\n\n if (!useDisposableConcast) {\n // We can skip calling updatePolling if we're not changing this.options.\n this.updatePolling();\n\n // Reset options.fetchPolicy to its original value when variables change,\n // unless a new fetchPolicy was provided by newOptions.\n if (\n newOptions &&\n newOptions.variables &&\n !equal(newOptions.variables, oldVariables) &&\n // Don't mess with the fetchPolicy if it's currently \"standby\".\n options.fetchPolicy !== \"standby\" &&\n // If we're changing the fetchPolicy anyway, don't try to change it here\n // using applyNextFetchPolicy. The explicit options.fetchPolicy wins.\n options.fetchPolicy === oldFetchPolicy\n ) {\n this.applyNextFetchPolicy(\"variables-changed\", options);\n if (newNetworkStatus === void 0) {\n newNetworkStatus = NetworkStatus.setVariables;\n }\n }\n }\n\n const variables = options.variables && { ...options.variables };\n const concast = this.fetch(options, newNetworkStatus);\n const observer: Observer<ApolloQueryResult<TData>> = {\n next: result => {\n this.reportResult(result, variables);\n },\n error: error => {\n this.reportError(error, variables);\n },\n };\n\n if (!useDisposableConcast) {\n // We use the {add,remove}Observer methods directly to avoid wrapping\n // observer with an unnecessary SubscriptionObserver object, in part so\n // that we can remove it here without triggering any unsubscriptions,\n // because we just want to ignore the old observable, not prematurely shut\n // it down, since other consumers may be awaiting this.concast.promise.\n if (this.concast && this.observer) {\n this.concast.removeObserver(this.observer);\n }\n\n this.concast = concast;\n this.observer = observer;\n }\n\n concast.addObserver(observer);\n\n return concast.promise;\n }\n\n // (Re)deliver the current result to this.observers without applying fetch\n // policies or making network requests.\n private observe() {\n this.reportResult(\n // Passing false is important so that this.getCurrentResult doesn't\n // save the fetchMore result as this.lastResult, causing it to be\n // ignored due to the this.isDifferentFromLastResult check in\n // this.reportResult.\n this.getCurrentResult(false),\n this.variables,\n );\n }\n\n private reportResult(\n result: ApolloQueryResult<TData>,\n variables: TVariables | undefined,\n ) {\n const lastError = this.getLastError();\n if (lastError || this.isDifferentFromLastResult(result)) {\n if (lastError || !result.partial || this.options.returnPartialData) {\n this.updateLastResult(result, variables);\n }\n\n iterateObserversSafely(this.observers, 'next', result);\n }\n }\n\n private reportError(\n error: ApolloError,\n variables: TVariables | undefined,\n ) {\n // Since we don't get the current result on errors, only the error, we\n // must mirror the updates that occur in QueryStore.markQueryError here\n const errorResult = {\n ...this.getLastResult(),\n error,\n errors: error.graphQLErrors,\n networkStatus: NetworkStatus.error,\n loading: false,\n } as ApolloQueryResult<TData>;\n\n this.updateLastResult(errorResult, variables);\n\n iterateObserversSafely(this.observers, 'error', this.last!.error = error);\n }\n\n public hasObservers() {\n return this.observers.size > 0;\n }\n\n private tearDownQuery() {\n if (this.isTornDown) return;\n if (this.concast && this.observer) {\n this.concast.removeObserver(this.observer);\n delete this.concast;\n delete this.observer;\n }\n\n this.stopPolling();\n // stop all active GraphQL subscriptions\n this.subscriptions.forEach(sub => sub.unsubscribe());\n this.subscriptions.clear();\n this.queryManager.stopQuery(this.queryId);\n this.observers.clear();\n this.isTornDown = true;\n }\n}\n\n// Necessary because the ObservableQuery constructor has a different\n// signature than the Observable constructor.\nfixObservableSubclass(ObservableQuery);\n\n// Reobserve with fetchPolicy effectively set to \"cache-first\", triggering\n// delivery of any new data from the cache, possibly falling back to the network\n// if any cache data are missing. This allows _complete_ cache results to be\n// delivered without also kicking off unnecessary network requests when\n// this.options.fetchPolicy is \"cache-and-network\" or \"network-only\". When\n// this.options.fetchPolicy is any other policy (\"cache-first\", \"cache-only\",\n// \"standby\", or \"no-cache\"), we call this.reobserve() as usual.\nexport function reobserveCacheFirst<TData, TVars>(\n obsQuery: ObservableQuery<TData, TVars>,\n) {\n const { fetchPolicy, nextFetchPolicy } = obsQuery.options;\n\n if (\n fetchPolicy === \"cache-and-network\" ||\n fetchPolicy === \"network-only\"\n ) {\n return obsQuery.reobserve({\n fetchPolicy: \"cache-first\",\n // Use a temporary nextFetchPolicy function that replaces itself with the\n // previous nextFetchPolicy value and returns the original fetchPolicy.\n nextFetchPolicy(this: WatchQueryOptions<TVars, TData>) {\n // Replace this nextFetchPolicy function in the options object with the\n // original this.options.nextFetchPolicy value.\n this.nextFetchPolicy = nextFetchPolicy;\n // If the original nextFetchPolicy value was a function, give it a\n // chance to decide what happens here.\n if (typeof nextFetchPolicy === \"function\") {\n return nextFetchPolicy.apply(this, arguments);\n }\n // Otherwise go back to the original this.options.fetchPolicy.\n return fetchPolicy!;\n },\n });\n }\n\n return obsQuery.reobserve();\n}\n\nfunction defaultSubscriptionObserverErrorCallback(error: ApolloError) {\n invariant.error('Unhandled error', error.message, error.stack);\n}\n\nexport function logMissingFieldErrors(\n missing: MissingFieldError[] | MissingTree | undefined,\n) {\n if (__DEV__ && missing) {\n invariant.debug(`Missing cache result fields: ${\n JSON.stringify(missing)\n }`, missing);\n }\n}\n","type Context = {\n parent: Context | null;\n slots: { [slotId: string]: any };\n}\n\n// This currentContext variable will only be used if the makeSlotClass\n// function is called, which happens only if this is the first copy of the\n// @wry/context package to be imported.\nlet currentContext: Context | null = null;\n\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: any = {};\n\nlet idCounter = 1;\n\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<TValue> {\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 public readonly id = [\n \"slot\",\n idCounter++,\n Date.now(),\n Math.random().toString(36).slice(2),\n ].join(\":\");\n\n public hasValue() {\n for (let context = currentContext; context; context = context.parent) {\n // We use the Slot object iself as a key to its value, which means the\n // value cannot be obtained without a reference to the Slot object.\n if (this.id in context.slots) {\n const value = context.slots[this.id];\n if (value === MISSING_VALUE) break;\n if (context !== currentContext) {\n // Cache the value in currentContext.slots so the next lookup will\n // be faster. This caching is safe because the tree of contexts and\n // the values of the slots are logically immutable.\n currentContext!.slots[this.id] = value;\n }\n return true;\n }\n }\n if (currentContext) {\n // If a value was not found for this Slot, it's never going to be found\n // no matter how many times we look it up, so we might as well cache\n // the absence of the value, too.\n currentContext.slots[this.id] = MISSING_VALUE;\n }\n return false;\n }\n\n public getValue(): TValue | undefined {\n if (this.hasValue()) {\n return currentContext!.slots[this.id] as TValue;\n }\n }\n\n public withValue<TResult, TArgs extends any[], TThis = any>(\n value: TValue,\n callback: (this: TThis, ...args: TArgs) => TResult,\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?: TArgs,\n thisArg?: TThis,\n ): TResult {\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 } finally {\n currentContext = parent;\n }\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<TArgs extends any[], TResult, TThis = any>(\n callback: (this: TThis, ...args: TArgs) => TResult,\n ) {\n const context = currentContext;\n return function (this: TThis) {\n const saved = currentContext;\n try {\n currentContext = context;\n return callback.apply(this, arguments as any);\n } finally {\n currentContext = saved;\n }\n } as typeof callback;\n }\n\n // Immediately run a callback function without any captured context.\n static noContext<TResult, TArgs extends any[], TThis = any>(\n callback: (this: TThis, ...args: TArgs) => TResult,\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?: TArgs,\n thisArg?: TThis,\n ) {\n if (currentContext) {\n const saved = currentContext;\n try {\n currentContext = null;\n // Function.prototype.apply allows the arguments array argument to be\n // omitted or undefined, so args! is fine here.\n return callback.apply(thisArg!, args!);\n } finally {\n currentContext = saved;\n }\n } else {\n return callback.apply(thisArg!, args!);\n }\n }\n};\n\n// We store a single global implementation of the Slot class as a permanent\n// non-enumerable symbol property of the Array constructor. This obfuscation\n// does nothing to prevent access to the Slot class, but at least it ensures\n// the implementation (i.e. currentContext) cannot be tampered with, and all\n// copies of the @wry/context package (hopefully just one) will share the\n// same Slot implementation. Since the first copy of the @wry/context package\n// to be imported wins, this technique imposes a very high cost for any\n// future breaking changes to the Slot class.\nconst globalKey = \"@wry/context:Slot\";\nconst host = Array as any;\n\nexport const Slot: ReturnType<typeof makeSlotClass> = host[globalKey] || function () {\n const Slot = makeSlotClass();\n try {\n Object.defineProperty(host, globalKey, {\n value: host[globalKey] = Slot,\n enumerable: false,\n writable: false,\n configurable: false,\n });\n } finally {\n return Slot;\n }\n}();\n","import { Slot } from \"./slot\";\nexport { Slot }\nexport const { bind, noContext } = Slot;\n\n// Relying on the @types/node declaration of global.setTimeout can make\n// things tricky for dowstream projects (see PR #7).\ndeclare function setTimeout(\n callback: (...args: any[]) => any,\n ms?: number,\n ...args: any[]\n): any;\n\n// Like global.setTimeout, except the callback runs with captured context.\nexport { setTimeoutWithContext as setTimeout };\nfunction setTimeoutWithContext(callback: () => any, delay: number) {\n return setTimeout(bind(callback), delay);\n}\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<\n TArgs extends any[],\n TYield = any,\n TReturn = any,\n TNext = any,\n>(\n genFn: (...args: TArgs) => Generator<TYield, TReturn, TNext>\n) {\n return function (this: any) {\n const gen = genFn.apply(this, arguments as any);\n\n type Method = (\n this: Generator<TYield, TReturn, TNext>,\n arg: any,\n ) => IteratorResult<TYield, TReturn>;\n\n const boundNext: Method = bind(gen.next);\n const boundThrow: Method = bind(gen.throw!);\n\n return new Promise((resolve, reject) => {\n function invoke(method: Method, argument: any) {\n try {\n var result: any = method.call(gen, argument);\n } catch (error) {\n return reject(error);\n }\n const next = result.done ? resolve : invokeNext;\n if (isPromiseLike(result.value)) {\n result.value.then(next, result.done ? reject : invokeThrow);\n } else {\n next(result.value);\n }\n }\n const invokeNext = (value?: any) => invoke(boundNext, value);\n const invokeThrow = (error: any) => invoke(boundThrow, error);\n invokeNext();\n });\n } as (...args: TArgs) => Promise<any>;\n}\n\nfunction isPromiseLike(value: any): value is PromiseLike<any> {\n return value && typeof value.then === \"function\";\n}\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: Function[] = [];\nexport function wrapYieldingFiberMethods<F extends Function>(Fiber: F): F {\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: any, method: string) => {\n const fn = obj[method];\n obj[method] = function () {\n return noContext(fn, arguments as any, 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","interface Node<K, V> {\n key: K;\n value: V;\n newer: Node<K, V> | null;\n older: Node<K, V> | null;\n}\n\nfunction defaultDispose() {}\n\nexport class Cache<K = any, V = any> {\n private map = new Map<K, Node<K, V>>();\n private newest: Node<K, V> | null = null;\n private oldest: Node<K, V> | null = null;\n\n constructor(\n private max = Infinity,\n public dispose: (value: V, key: K) => void = defaultDispose,\n ) {}\n\n public has(key: K): boolean {\n return this.map.has(key);\n }\n\n public get(key: K): V | undefined {\n const node = this.getNode(key);\n return node && node.value;\n }\n\n private getNode(key: K): Node<K, V> | undefined {\n const node = this.map.get(key);\n\n if (node && node !== this.newest) {\n const { older, newer } = node;\n\n if (newer) {\n newer.older = older;\n }\n\n if (older) {\n older.newer = newer;\n }\n\n node.older = this.newest;\n node.older!.newer = node;\n\n node.newer = null;\n this.newest = node;\n\n if (node === this.oldest) {\n this.oldest = newer;\n }\n }\n\n return node;\n }\n\n public set(key: K, value: V): V {\n let node = this.getNode(key);\n if (node) {\n return node.value = value;\n }\n\n node = {\n key,\n value,\n newer: null,\n older: this.newest\n };\n\n if (this.newest) {\n this.newest.newer = node;\n }\n\n this.newest = node;\n this.oldest = this.oldest || node;\n\n this.map.set(key, node);\n\n return node.value;\n }\n\n public clean() {\n while (this.oldest && this.map.size > this.max) {\n this.delete(this.oldest.key);\n }\n }\n\n public delete(key: K): boolean {\n const node = this.map.get(key);\n if (node) {\n if (node === this.newest) {\n this.newest = node.older;\n }\n\n if (node === this.oldest) {\n this.oldest = node.newer;\n }\n\n if (node.newer) {\n node.newer.older = node.older;\n }\n\n if (node.older) {\n node.older.newer = node.newer;\n }\n\n this.map.delete(key);\n this.dispose(node.value, key);\n\n return true;\n }\n\n return false;\n }\n}\n","import { AnyEntry } from \"./entry\";\nimport { Slot } from \"@wry/context\";\n\nexport const parentEntrySlot = new Slot<AnyEntry>();\n\nexport {\n bind as bindContext,\n noContext,\n setTimeout,\n asyncFromGen,\n} from \"@wry/context\";\n","export const {\n hasOwnProperty,\n} = Object.prototype;\n\nexport const {\n // This Array.from polyfill is restricted to working with Set<any> for now,\n // but we can improve the polyfill and add other input types, as needed. Note\n // that this fallback implementation will only be used if the host environment\n // does not support a native Array.from function. In most modern JS runtimes,\n // the toArray function exported here will be === Array.from.\n from: toArray = (collection: Set<any>) => {\n const array: any[] = [];\n collection.forEach(item => array.push(item));\n return array;\n },\n} = Array;\n\nexport type Unsubscribable = {\n unsubscribe?: void | (() => any);\n}\n\nexport function maybeUnsubscribe(entryOrDep: Unsubscribable) {\n const { unsubscribe } = entryOrDep;\n if (typeof unsubscribe === \"function\") {\n entryOrDep.unsubscribe = void 0;\n unsubscribe();\n }\n}\n","import { parentEntrySlot } from \"./context\";\nimport { OptimisticWrapOptions } from \"./index\";\nimport { Dep } from \"./dep\";\nimport { maybeUnsubscribe, toArray, Unsubscribable } from \"./helpers\";\n\nconst emptySetPool: Set<any>[] = [];\nconst POOL_TARGET_SIZE = 100;\n\n// Since this package might be used browsers, we should avoid using the\n// Node built-in assert module.\nfunction assert(condition: any, optionalMessage?: string) {\n if (! condition) {\n throw new Error(optionalMessage || \"assertion failure\");\n }\n}\n\n// Since exceptions are cached just like normal values, we need an efficient\n// way of representing unknown, ordinary, and exceptional values.\ntype Value<T> =\n | [] // unknown\n | [T] // known value\n | [void, any]; // known exception\n\nfunction valueIs(a: Value<any>, b: Value<any>) {\n const len = a.length;\n return (\n // Unknown values are not equal to each other.\n len > 0 &&\n // Both values must be ordinary (or both exceptional) to be equal.\n len === b.length &&\n // The underlying value or exception must be the same.\n a[len - 1] === b[len - 1]\n );\n}\n\nfunction valueGet<T>(value: Value<T>): T {\n switch (value.length) {\n case 0: throw new Error(\"unknown value\");\n case 1: return value[0];\n case 2: throw value[1];\n }\n}\n\nfunction valueCopy<T>(value: Value<T>): Value<T> {\n return value.slice(0) as Value<T>;\n}\n\nexport type AnyEntry = Entry<any, any>;\n\nexport class Entry<TArgs extends any[], TValue> {\n public static count = 0;\n\n public subscribe: OptimisticWrapOptions<TArgs>[\"subscribe\"];\n public unsubscribe: Unsubscribable[\"unsubscribe\"];\n\n public readonly parents = new Set<AnyEntry>();\n public readonly childValues = new Map<AnyEntry, Value<any>>();\n\n // When this Entry has children that are dirty, this property becomes\n // a Set containing other Entry objects, borrowed from emptySetPool.\n // When the set becomes empty, it gets recycled back to emptySetPool.\n public dirtyChildren: Set<AnyEntry> | null = null;\n\n public dirty = true;\n public recomputing = false;\n public readonly value: Value<TValue> = [];\n\n constructor(\n public readonly fn: (...args: TArgs) => TValue,\n ) {\n ++Entry.count;\n }\n\n public peek(): TValue | undefined {\n if (this.value.length === 1 && !mightBeDirty(this)) {\n rememberParent(this);\n return this.value[0];\n }\n }\n\n // This is the most important method of the Entry API, because it\n // determines whether the cached this.value can be returned immediately,\n // or must be recomputed. The overall performance of the caching system\n // depends on the truth of the following observations: (1) this.dirty is\n // usually false, (2) this.dirtyChildren is usually null/empty, and thus\n // (3) valueGet(this.value) is usually returned without recomputation.\n public recompute(args: TArgs): TValue {\n assert(! this.recomputing, \"already recomputing\");\n rememberParent(this);\n return mightBeDirty(this)\n ? reallyRecompute(this, args)\n : valueGet(this.value);\n }\n\n public setDirty() {\n if (this.dirty) return;\n this.dirty = true;\n this.value.length = 0;\n reportDirty(this);\n // We can go ahead and unsubscribe here, since any further dirty\n // notifications we receive will be redundant, and unsubscribing may\n // free up some resources, e.g. file watchers.\n maybeUnsubscribe(this);\n }\n\n public dispose() {\n this.setDirty();\n\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\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\n public 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\n private deps: Set<Dep<any>> | null = null;\n\n public dependOn(dep: Dep<any>) {\n dep.add(this);\n if (! this.deps) {\n this.deps = emptySetPool.pop() || new Set<Set<AnyEntry>>();\n }\n this.deps.add(dep);\n }\n\n public forgetDeps() {\n if (this.deps) {\n toArray(this.deps).forEach(dep => dep.delete(this));\n this.deps.clear();\n emptySetPool.push(this.deps);\n this.deps = null;\n }\n }\n}\n\nfunction rememberParent(child: AnyEntry) {\n const parent = parentEntrySlot.getValue();\n if (parent) {\n child.parents.add(parent);\n\n if (! parent.childValues.has(child)) {\n parent.childValues.set(child, []);\n }\n\n if (mightBeDirty(child)) {\n reportDirtyChild(parent, child);\n } else {\n reportCleanChild(parent, child);\n }\n\n return parent;\n }\n}\n\nfunction reallyRecompute(entry: AnyEntry, args: any[]) {\n forgetChildren(entry);\n\n // Set entry as the parent entry while calling recomputeNewValue(entry).\n parentEntrySlot.withValue(entry, recomputeNewValue, [entry, args]);\n\n if (maybeSubscribe(entry, args)) {\n // If we successfully recomputed entry.value and did not fail to\n // (re)subscribe, then this Entry is no longer explicitly dirty.\n setClean(entry);\n }\n\n return valueGet(entry.value);\n}\n\nfunction recomputeNewValue(entry: AnyEntry, args: any[]) {\n entry.recomputing = true;\n // Set entry.value as unknown.\n entry.value.length = 0;\n try {\n // If entry.fn succeeds, entry.value will become a normal Value.\n entry.value[0] = entry.fn.apply(null, args);\n } catch (e) {\n // If entry.fn throws, entry.value will become exceptional.\n entry.value[1] = e;\n }\n // Either way, this line is always reached.\n entry.recomputing = false;\n}\n\nfunction mightBeDirty(entry: AnyEntry) {\n return entry.dirty || !!(entry.dirtyChildren && entry.dirtyChildren.size);\n}\n\nfunction setClean(entry: AnyEntry) {\n entry.dirty = false;\n\n if (mightBeDirty(entry)) {\n // This Entry may still have dirty children, in which case we can't\n // let our parents know we're clean just yet.\n return;\n }\n\n reportClean(entry);\n}\n\nfunction reportDirty(child: AnyEntry) {\n eachParent(child, reportDirtyChild);\n}\n\nfunction reportClean(child: AnyEntry) {\n eachParent(child, reportCleanChild);\n}\n\nfunction eachParent(\n child: AnyEntry,\n callback: (parent: AnyEntry, child: AnyEntry) => any,\n) {\n const parentCount = child.parents.size;\n if (parentCount) {\n const parents = toArray(child.parents);\n for (let i = 0; i < parentCount; ++i) {\n callback(parents[i], child);\n }\n }\n}\n\n// Let a parent Entry know that one of its children may be dirty.\nfunction reportDirtyChild(parent: AnyEntry, child: AnyEntry) {\n // Must have called rememberParent(child) before calling\n // reportDirtyChild(parent, child).\n assert(parent.childValues.has(child));\n assert(mightBeDirty(child));\n const parentWasClean = !mightBeDirty(parent);\n\n if (! parent.dirtyChildren) {\n parent.dirtyChildren = emptySetPool.pop() || new Set;\n\n } else if (parent.dirtyChildren.has(child)) {\n // If we already know this child is dirty, then we must have already\n // informed our own parents that we are dirty, so we can terminate\n // the recursion early.\n return;\n }\n\n parent.dirtyChildren.add(child);\n\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\n// Let a parent Entry know that one of its children is no longer dirty.\nfunction reportCleanChild(parent: AnyEntry, child: AnyEntry) {\n // Must have called rememberChild(child) before calling\n // reportCleanChild(parent, child).\n assert(parent.childValues.has(child));\n assert(! mightBeDirty(child));\n\n const childValue = parent.childValues.get(child)!;\n if (childValue.length === 0) {\n parent.childValues.set(child, valueCopy(child.value));\n } else if (! valueIs(childValue, child.value)) {\n parent.setDirty();\n }\n\n removeDirtyChild(parent, child);\n\n if (mightBeDirty(parent)) {\n return;\n }\n\n reportClean(parent);\n}\n\nfunction removeDirtyChild(parent: AnyEntry, child: AnyEntry) {\n const dc = parent.dirtyChildren;\n if (dc) {\n dc.delete(child);\n if (dc.size === 0) {\n if (emptySetPool.length < POOL_TARGET_SIZE) {\n emptySetPool.push(dc);\n }\n parent.dirtyChildren = null;\n }\n }\n}\n\n// Removes all children from this entry and returns an array of the\n// removed children.\nfunction forgetChildren(parent: AnyEntry) {\n if (parent.childValues.size > 0) {\n parent.childValues.forEach((_value, child) => {\n forgetChild(parent, child);\n });\n }\n\n // Remove this parent Entry from any sets to which it was added by the\n // addToSet method.\n parent.forgetDeps();\n\n // After we forget all our children, this.dirtyChildren must be empty\n // and therefore must have been reset to null.\n assert(parent.dirtyChildren === null);\n}\n\nfunction forgetChild(parent: AnyEntry, child: AnyEntry) {\n child.parents.delete(parent);\n parent.childValues.delete(child);\n removeDirtyChild(parent, child);\n}\n\nfunction maybeSubscribe(entry: AnyEntry, args: any[]) {\n if (typeof entry.subscribe === \"function\") {\n try {\n maybeUnsubscribe(entry); // Prevent double subscriptions.\n entry.unsubscribe = entry.subscribe.apply(null, args);\n } catch (e) {\n // If this Entry has a subscribe function and it threw an exception\n // (or an unsubscribe function it previously returned now throws),\n // return false to indicate that we were not able to subscribe (or\n // unsubscribe), and this Entry should remain dirty.\n entry.setDirty();\n return false;\n }\n }\n\n // Returning true indicates either that there was no entry.subscribe\n // function or that it succeeded.\n return true;\n}\n","import { AnyEntry } from \"./entry\";\nimport { OptimisticWrapOptions } from \"./index\";\nimport { parentEntrySlot } from \"./context\";\nimport { hasOwnProperty, Unsubscribable, maybeUnsubscribe, toArray } from \"./helpers\";\n\ntype EntryMethodName = keyof typeof EntryMethods;\nconst EntryMethods = {\n setDirty: true, // Mark parent Entry as needing to be recomputed (default)\n dispose: true, // Detach parent Entry from parents and children, but leave in LRU cache\n forget: true, // Fully remove parent Entry from LRU cache and computation graph\n};\n\nexport type OptimisticDependencyFunction<TKey> =\n ((key: TKey) => void) & {\n dirty: (key: TKey, entryMethodName?: EntryMethodName) => void;\n };\n\nexport type Dep<TKey> = Set<AnyEntry> & {\n subscribe: OptimisticWrapOptions<[TKey]>[\"subscribe\"];\n} & Unsubscribable;\n\nexport function dep<TKey>(options?: {\n subscribe: Dep<TKey>[\"subscribe\"];\n}) {\n const depsByKey = new Map<TKey, Dep<TKey>>();\n const subscribe = options && options.subscribe;\n\n function depend(key: TKey) {\n const parent = parentEntrySlot.getValue();\n if (parent) {\n let dep = depsByKey.get(key);\n if (!dep) {\n depsByKey.set(key, dep = new Set as Dep<TKey>);\n }\n parent.dependOn(dep);\n if (typeof subscribe === \"function\") {\n maybeUnsubscribe(dep);\n dep.unsubscribe = subscribe(key);\n }\n }\n }\n\n depend.dirty = function dirty(\n key: TKey,\n entryMethodName?: EntryMethodName,\n ) {\n const dep = depsByKey.get(key);\n if (dep) {\n const m: EntryMethodName = (\n entryMethodName &&\n hasOwnProperty.call(EntryMethods, entryMethodName)\n ) ? entryMethodName : \"setDirty\";\n // We have to use toArray(dep).forEach instead of dep.forEach, because\n // modifying a Set while iterating over it can cause elements in the Set\n // to be removed from the Set before they've been iterated over.\n toArray(dep).forEach(entry => entry[m]());\n depsByKey.delete(key);\n maybeUnsubscribe(dep);\n }\n };\n\n return depend as OptimisticDependencyFunction<TKey>;\n}\n","import { Trie } from \"@wry/trie\";\n\nimport { Cache } from \"./cache\";\nimport { Entry, AnyEntry } from \"./entry\";\nimport { parentEntrySlot } from \"./context\";\n\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 {\n bindContext,\n noContext,\n setTimeout,\n asyncFromGen,\n} from \"./context\";\n\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, OptimisticDependencyFunction } from \"./dep\";\n\nfunction makeDefaultMakeCacheKeyFunction<\n TKeyArgs extends any[],\n TCacheKey = any,\n>(): (...args: TKeyArgs) => TCacheKey {\n const keyTrie = new Trie<TCacheKey>(typeof WeakMap === \"function\");\n return function () {\n return keyTrie.lookupArray(arguments);\n };\n}\n\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.\nexport const defaultMakeCacheKey = makeDefaultMakeCacheKeyFunction();\n\n// If you're paranoid about memory leaks, or you want to avoid using WeakMap\n// under the hood, but you still need the behavior of defaultMakeCacheKey,\n// import this constructor to create your own tries.\nexport { Trie as KeyTrie }\n\nexport type OptimisticWrapperFunction<\n TArgs extends any[],\n TResult,\n TKeyArgs extends any[] = TArgs,\n TCacheKey = any,\n> = ((...args: TArgs) => TResult) & {\n // Get the current number of Entry objects in the LRU cache.\n readonly size: number;\n\n // \"Dirty\" any cached Entry stored for the given arguments, marking that Entry\n // and its ancestors as potentially needing to be recomputed. The .dirty(...)\n // method of an optimistic function takes the same parameter types as the\n // original function by default, unless a keyArgs function is configured, and\n // then it matters that .dirty takes TKeyArgs instead of TArgs.\n dirty: (...args: TKeyArgs) => void;\n // A version of .dirty that accepts a key returned by .getKey.\n dirtyKey: (key: TCacheKey) => void;\n\n // Examine the current value without recomputing it.\n peek: (...args: TKeyArgs) => TResult | undefined;\n // A version of .peek that accepts a key returned by .getKey.\n peekKey: (key: TCacheKey) => TResult | undefined;\n\n // Completely remove the entry from the cache, dirtying any parent entries.\n forget: (...args: TKeyArgs) => boolean;\n // A version of .forget that accepts a key returned by .getKey.\n forgetKey: (key: TCacheKey) => boolean;\n\n // In order to use the -Key version of the above functions, you need a key\n // rather than the arguments used to compute the key. These two functions take\n // TArgs or TKeyArgs and return the corresponding TCacheKey. If no keyArgs\n // function has been configured, TArgs will be the same as TKeyArgs, and thus\n // getKey and makeCacheKey will be synonymous.\n getKey: (...args: TArgs) => TCacheKey;\n\n // This property is equivalent to the makeCacheKey function provided in the\n // OptimisticWrapOptions, or (if no options.makeCacheKey function is provided)\n // a default implementation of makeCacheKey.\n makeCacheKey: (...args: TKeyArgs) => TCacheKey;\n};\n\nexport type OptimisticWrapOptions<\n TArgs extends any[],\n TKeyArgs extends any[] = TArgs,\n TCacheKey = any,\n> = {\n // The maximum number of cache entries that should be retained before the\n // cache begins evicting the oldest ones.\n max?: number;\n // Transform the raw arguments to some other type of array, which will then\n // be passed to makeCacheKey.\n keyArgs?: (...args: TArgs) => TKeyArgs;\n // The makeCacheKey function takes the same arguments that were passed to\n // the wrapper function and returns a single value that can be used as a key\n // in a Map to identify the cached result.\n makeCacheKey?: (...args: TKeyArgs) => TCacheKey;\n // If provided, the subscribe function should either return an unsubscribe\n // function or return nothing.\n subscribe?: (...args: TArgs) => void | (() => any);\n};\n\nconst caches = new Set<Cache<any, AnyEntry>>();\n\nexport function wrap<\n TArgs extends any[],\n TResult,\n TKeyArgs extends any[] = TArgs,\n TCacheKey = any,\n>(\n originalFunction: (...args: TArgs) => TResult,\n options: OptimisticWrapOptions<TArgs, TKeyArgs> = Object.create(null),\n) {\n const cache = new Cache<TCacheKey, Entry<TArgs, TResult>>(\n options.max || Math.pow(2, 16),\n entry => entry.dispose(),\n );\n\n const keyArgs = options.keyArgs;\n const makeCacheKey = options.makeCacheKey ||\n makeDefaultMakeCacheKeyFunction<TKeyArgs, TCacheKey>();\n\n const optimistic = function (): TResult {\n const key = makeCacheKey.apply(\n null,\n keyArgs ? keyArgs.apply(null, arguments as any) : arguments as any\n );\n\n if (key === void 0) {\n return originalFunction.apply(null, arguments as any);\n }\n\n let entry = cache.get(key)!;\n if (!entry) {\n cache.set(key, entry = new Entry(originalFunction));\n entry.subscribe = options.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\n const value = entry.recompute(\n Array.prototype.slice.call(arguments) as TArgs,\n );\n\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\n caches.add(cache);\n\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\n return value;\n } as OptimisticWrapperFunction<TArgs, TResult, TKeyArgs, TCacheKey>;\n\n Object.defineProperty(optimistic, \"size\", {\n get() {\n return cache[\"map\"].size;\n },\n configurable: false,\n enumerable: false,\n });\n\n function dirtyKey(key: TCacheKey) {\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 as any));\n };\n\n function peekKey(key: TCacheKey) {\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 as any));\n };\n\n function forgetKey(key: TCacheKey) {\n return cache.delete(key);\n }\n optimistic.forgetKey = forgetKey;\n optimistic.forget = function forget() {\n return forgetKey(makeCacheKey.apply(null, arguments as any));\n };\n\n optimistic.makeCacheKey = makeCacheKey;\n optimistic.getKey = keyArgs ? function getKey() {\n return makeCacheKey.apply(null, keyArgs.apply(null, arguments as any));\n } : makeCacheKey as (...args: any[]) => TCacheKey;\n\n return Object.freeze(optimistic);\n}\n","import { dep, OptimisticDependencyFunction } from \"optimism\";\nimport { Slot } from \"@wry/context\";\nimport { InMemoryCache } from \"./inMemoryCache\";\nimport { ApolloCache } from '../../core';\n\nexport interface ReactiveVar<T> {\n (newValue?: T): T;\n onNextChange(listener: ReactiveListener<T>): () => void;\n attachCache(cache: ApolloCache<any>): this;\n forgetCache(cache: ApolloCache<any>): boolean;\n}\n\nexport type ReactiveListener<T> = (value: T) => any;\n\n// Contextual Slot that acquires its value when custom read functions are\n// called in Policies#readField.\nexport const cacheSlot = new Slot<ApolloCache<any>>();\n\nconst cacheInfoMap = new WeakMap<ApolloCache<any>, {\n vars: Set<ReactiveVar<any>>;\n dep: OptimisticDependencyFunction<ReactiveVar<any>>;\n}>();\n\nfunction getCacheInfo(cache: ApolloCache<any>) {\n let info = cacheInfoMap.get(cache)!;\n if (!info) {\n cacheInfoMap.set(cache, info = {\n vars: new Set,\n dep: dep(),\n });\n }\n return info;\n}\n\nexport function forgetCache(cache: ApolloCache<any>) {\n getCacheInfo(cache).vars.forEach(rv => rv.forgetCache(cache));\n}\n\n// Calling forgetCache(cache) serves to silence broadcasts and allows the\n// cache to be garbage collected. However, the varsByCache WeakMap\n// preserves the set of reactive variables that were previously associated\n// with this cache, which makes it possible to \"recall\" the cache at a\n// later time, by reattaching it to those variables. If the cache has been\n// garbage collected in the meantime, because it is no longer reachable,\n// you won't be able to call recallCache(cache), and the cache will\n// automatically disappear from the varsByCache WeakMap.\nexport function recallCache(cache: ApolloCache<any>) {\n getCacheInfo(cache).vars.forEach(rv => rv.attachCache(cache));\n}\n\nexport function makeVar<T>(value: T): ReactiveVar<T> {\n const caches = new Set<ApolloCache<any>>();\n const listeners = new Set<ReactiveListener<T>>();\n\n const rv: ReactiveVar<T> = function (newValue) {\n if (arguments.length > 0) {\n if (value !== newValue) {\n value = newValue!;\n caches.forEach(cache => {\n // Invalidate any fields with custom read functions that\n // consumed this variable, so query results involving those\n // fields will be recomputed the next time we read them.\n getCacheInfo(cache).dep.dirty(rv);\n // Broadcast changes to any caches that have previously read\n // from this variable.\n broadcast(cache);\n });\n // Finally, notify any listeners added via rv.onNextChange.\n const oldListeners = Array.from(listeners);\n listeners.clear();\n oldListeners.forEach(listener => listener(value));\n }\n } else {\n // When reading from the variable, obtain the current cache from\n // context via cacheSlot. This isn't entirely foolproof, but it's\n // the same system that powers varDep.\n const cache = cacheSlot.getValue();\n if (cache) {\n attach(cache);\n getCacheInfo(cache).dep(rv);\n }\n }\n\n return value;\n };\n\n rv.onNextChange = listener => {\n listeners.add(listener);\n return () => {\n listeners.delete(listener);\n };\n };\n\n const attach = rv.attachCache = cache => {\n caches.add(cache);\n getCacheInfo(cache).vars.add(rv);\n return rv;\n };\n\n rv.forgetCache = cache => caches.delete(cache);\n\n return rv;\n}\n\ntype Broadcastable = ApolloCache<any> & {\n // This method is protected in InMemoryCache, which we are ignoring, but\n // we still want some semblance of type safety when we call it.\n broadcastWatches?: InMemoryCache[\"broadcastWatches\"];\n};\n\nfunction broadcast(cache: Broadcastable) {\n if (cache.broadcastWatches) {\n cache.broadcastWatches();\n }\n}\n","import { invariant } from '../utilities/globals';\n\nimport {\n DocumentNode,\n OperationDefinitionNode,\n SelectionSetNode,\n SelectionNode,\n InlineFragmentNode,\n FragmentDefinitionNode,\n FieldNode,\n ASTNode,\n visit,\n BREAK,\n} from 'graphql';\n\nimport { ApolloCache } from '../cache';\nimport {\n FragmentMap,\n StoreObject,\n argumentsObjectFromField,\n buildQueryFromSelectionSet,\n createFragmentMap,\n getFragmentDefinitions,\n getMainDefinition,\n hasDirectives,\n isField,\n isInlineFragment,\n mergeDeep,\n mergeDeepArray,\n removeClientSetsFromDocument,\n resultKeyNameFromField,\n shouldInclude,\n} from '../utilities';\nimport { ApolloClient } from './ApolloClient';\nimport { Resolvers, OperationVariables } from './types';\nimport { FetchResult } from '../link/core';\nimport { cacheSlot } from '../cache';\n\nexport type Resolver = (\n rootValue?: any,\n args?: any,\n context?: any,\n info?: {\n field: FieldNode;\n fragmentMap: FragmentMap;\n },\n) => any;\n\nexport type VariableMap = { [name: string]: any };\n\nexport type FragmentMatcher = (\n rootValue: any,\n typeCondition: string,\n context: any,\n) => boolean;\n\nexport type ExecContext = {\n fragmentMap: FragmentMap;\n context: any;\n variables: VariableMap;\n fragmentMatcher: FragmentMatcher;\n defaultOperationType: string;\n exportedVariables: Record<string, any>;\n onlyRunForcedResolvers: boolean;\n};\n\nexport type LocalStateOptions<TCacheShape> = {\n cache: ApolloCache<TCacheShape>;\n client?: ApolloClient<TCacheShape>;\n resolvers?: Resolvers | Resolvers[];\n fragmentMatcher?: FragmentMatcher;\n};\n\nexport class LocalState<TCacheShape> {\n private cache: ApolloCache<TCacheShape>;\n private client: ApolloClient<TCacheShape>;\n private resolvers?: Resolvers;\n private fragmentMatcher: FragmentMatcher;\n\n constructor({\n cache,\n client,\n resolvers,\n fragmentMatcher,\n }: LocalStateOptions<TCacheShape>) {\n this.cache = cache;\n\n if (client) {\n this.client = client;\n }\n\n if (resolvers) {\n this.addResolvers(resolvers);\n }\n\n if (fragmentMatcher) {\n this.setFragmentMatcher(fragmentMatcher);\n }\n }\n\n public addResolvers(resolvers: Resolvers | Resolvers[]) {\n this.resolvers = this.resolvers || {};\n if (Array.isArray(resolvers)) {\n resolvers.forEach(resolverGroup => {\n this.resolvers = mergeDeep(this.resolvers, resolverGroup);\n });\n } else {\n this.resolvers = mergeDeep(this.resolvers, resolvers);\n }\n }\n\n public setResolvers(resolvers: Resolvers | Resolvers[]) {\n this.resolvers = {};\n this.addResolvers(resolvers);\n }\n\n public getResolvers() {\n return this.resolvers || {};\n }\n\n // Run local client resolvers against the incoming query and remote data.\n // Locally resolved field values are merged with the incoming remote data,\n // and returned. Note that locally resolved fields will overwrite\n // remote data using the same field name.\n public async runResolvers<TData>({\n document,\n remoteResult,\n context,\n variables,\n onlyRunForcedResolvers = false,\n }: {\n document: DocumentNode | null;\n remoteResult: FetchResult<TData>;\n context?: Record<string, any>;\n variables?: Record<string, any>;\n onlyRunForcedResolvers?: boolean;\n }): Promise<FetchResult<TData>> {\n if (document) {\n return this.resolveDocument(\n document,\n remoteResult.data,\n context,\n variables,\n this.fragmentMatcher,\n onlyRunForcedResolvers,\n ).then(localResult => ({\n ...remoteResult,\n data: localResult.result,\n }));\n }\n\n return remoteResult;\n }\n\n public setFragmentMatcher(fragmentMatcher: FragmentMatcher) {\n this.fragmentMatcher = fragmentMatcher;\n }\n\n public getFragmentMatcher(): FragmentMatcher {\n return this.fragmentMatcher;\n }\n\n // Client queries contain everything in the incoming document (if a @client\n // directive is found).\n public clientQuery(document: DocumentNode) {\n if (hasDirectives(['client'], document)) {\n if (this.resolvers) {\n return document;\n }\n }\n return null;\n }\n\n // Server queries are stripped of all @client based selection sets.\n public serverQuery(document: DocumentNode) {\n return removeClientSetsFromDocument(document);\n }\n\n public prepareContext(context?: Record<string, any>) {\n const { cache } = this;\n return {\n ...context,\n cache,\n // Getting an entry's cache key is useful for local state resolvers.\n getCacheKey(obj: StoreObject) {\n return cache.identify(obj);\n },\n };\n }\n\n // To support `@client @export(as: \"someVar\")` syntax, we'll first resolve\n // @client @export fields locally, then pass the resolved values back to be\n // used alongside the original operation variables.\n public async addExportedVariables(\n document: DocumentNode,\n variables: OperationVariables = {},\n context = {},\n ) {\n if (document) {\n return this.resolveDocument(\n document,\n this.buildRootValueFromCache(document, variables) || {},\n this.prepareContext(context),\n variables,\n ).then(data => ({\n ...variables,\n ...data.exportedVariables,\n }));\n }\n\n return {\n ...variables,\n };\n }\n\n public shouldForceResolvers(document: ASTNode) {\n let forceResolvers = false;\n visit(document, {\n Directive: {\n enter(node) {\n if (node.name.value === 'client' && node.arguments) {\n forceResolvers = node.arguments.some(\n arg =>\n arg.name.value === 'always' &&\n arg.value.kind === 'BooleanValue' &&\n arg.value.value === true,\n );\n if (forceResolvers) {\n return BREAK;\n }\n }\n },\n },\n });\n return forceResolvers;\n }\n\n // Query the cache and return matching data.\n private buildRootValueFromCache(\n document: DocumentNode,\n variables?: Record<string, any>,\n ) {\n return this.cache.diff({\n query: buildQueryFromSelectionSet(document),\n variables,\n returnPartialData: true,\n optimistic: false,\n }).result;\n }\n\n private async resolveDocument<TData>(\n document: DocumentNode,\n rootValue: TData,\n context: any = {},\n variables: VariableMap = {},\n fragmentMatcher: FragmentMatcher = () => true,\n onlyRunForcedResolvers: boolean = false,\n ) {\n const mainDefinition = getMainDefinition(document);\n const fragments = getFragmentDefinitions(document);\n const fragmentMap = createFragmentMap(fragments);\n\n const definitionOperation = (mainDefinition as OperationDefinitionNode)\n .operation;\n\n const defaultOperationType = definitionOperation\n ? definitionOperation.charAt(0).toUpperCase() +\n definitionOperation.slice(1)\n : 'Query';\n\n const { cache, client } = this;\n const execContext: ExecContext = {\n fragmentMap,\n context: {\n ...context,\n cache,\n client,\n },\n variables,\n fragmentMatcher,\n defaultOperationType,\n exportedVariables: {},\n onlyRunForcedResolvers,\n };\n\n return this.resolveSelectionSet(\n mainDefinition.selectionSet,\n rootValue,\n execContext,\n ).then(result => ({\n result,\n exportedVariables: execContext.exportedVariables,\n }));\n }\n\n private async resolveSelectionSet<TData>(\n selectionSet: SelectionSetNode,\n rootValue: TData,\n execContext: ExecContext,\n ) {\n const { fragmentMap, context, variables } = execContext;\n const resultsToMerge: TData[] = [rootValue];\n\n const execute = async (selection: SelectionNode): Promise<void> => {\n if (!shouldInclude(selection, variables)) {\n // Skip this entirely.\n return;\n }\n\n if (isField(selection)) {\n return this.resolveField(selection, rootValue, execContext).then(\n fieldResult => {\n if (typeof fieldResult !== 'undefined') {\n resultsToMerge.push({\n [resultKeyNameFromField(selection)]: fieldResult,\n } as TData);\n }\n },\n );\n }\n\n let fragment: InlineFragmentNode | FragmentDefinitionNode;\n\n if (isInlineFragment(selection)) {\n fragment = selection;\n } else {\n // This is a named fragment.\n fragment = fragmentMap[selection.name.value];\n invariant(fragment, `No fragment named ${selection.name.value}`);\n }\n\n if (fragment && fragment.typeCondition) {\n const typeCondition = fragment.typeCondition.name.value;\n if (execContext.fragmentMatcher(rootValue, typeCondition, context)) {\n return this.resolveSelectionSet(\n fragment.selectionSet,\n rootValue,\n execContext,\n ).then(fragmentResult => {\n resultsToMerge.push(fragmentResult);\n });\n }\n }\n };\n\n return Promise.all(selectionSet.selections.map(execute)).then(function() {\n return mergeDeepArray(resultsToMerge);\n });\n }\n\n private async resolveField(\n field: FieldNode,\n rootValue: any,\n execContext: ExecContext,\n ): Promise<any> {\n const { variables } = execContext;\n const fieldName = field.name.value;\n const aliasedFieldName = resultKeyNameFromField(field);\n const aliasUsed = fieldName !== aliasedFieldName;\n const defaultResult = rootValue[aliasedFieldName] || rootValue[fieldName];\n let resultPromise = Promise.resolve(defaultResult);\n\n // Usually all local resolvers are run when passing through here, but\n // if we've specifically identified that we only want to run forced\n // resolvers (that is, resolvers for fields marked with\n // `@client(always: true)`), then we'll skip running non-forced resolvers.\n if (\n !execContext.onlyRunForcedResolvers ||\n this.shouldForceResolvers(field)\n ) {\n const resolverType =\n rootValue.__typename || execContext.defaultOperationType;\n const resolverMap = this.resolvers && this.resolvers[resolverType];\n if (resolverMap) {\n const resolve = resolverMap[aliasUsed ? fieldName : aliasedFieldName];\n if (resolve) {\n resultPromise = Promise.resolve(\n // In case the resolve function accesses reactive variables,\n // set cacheSlot to the current cache instance.\n cacheSlot.withValue(this.cache, resolve, [\n rootValue,\n argumentsObjectFromField(field, variables),\n execContext.context,\n { field, fragmentMap: execContext.fragmentMap },\n ])\n );\n }\n }\n }\n\n return resultPromise.then((result = defaultResult) => {\n // If an @export directive is associated with the current field, store\n // the `as` export variable name and current result for later use.\n if (field.directives) {\n field.directives.forEach(directive => {\n if (directive.name.value === 'export' && directive.arguments) {\n directive.arguments.forEach(arg => {\n if (arg.name.value === 'as' && arg.value.kind === 'StringValue') {\n execContext.exportedVariables[arg.value.value] = result;\n }\n });\n }\n });\n }\n\n // Handle all scalar types here.\n if (!field.selectionSet) {\n return result;\n }\n\n // From here down, the field has a selection set, which means it's trying\n // to query a GraphQLObjectType.\n if (result == null) {\n // Basically any field in a GraphQL response can be null, or missing\n return result;\n }\n\n if (Array.isArray(result)) {\n return this.resolveSubSelectedArray(field, result, execContext);\n }\n\n // Returned value is an object, and the query has a sub-selection. Recurse.\n if (field.selectionSet) {\n return this.resolveSelectionSet(\n field.selectionSet,\n result,\n execContext,\n );\n }\n });\n }\n\n private resolveSubSelectedArray(\n field: FieldNode,\n result: any[],\n execContext: ExecContext,\n ): any {\n return Promise.all(\n result.map(item => {\n if (item === null) {\n return null;\n }\n\n // This is a nested array, recurse.\n if (Array.isArray(item)) {\n return this.resolveSubSelectedArray(field, item, execContext);\n }\n\n // This is an object, run the selection set on it.\n if (field.selectionSet) {\n return this.resolveSelectionSet(field.selectionSet, item, execContext);\n }\n }),\n );\n }\n}\n","import { DocumentNode, GraphQLError } from 'graphql';\nimport { equal } from \"@wry/equality\";\n\nimport { Cache, ApolloCache } from '../cache';\nimport { WatchQueryOptions, ErrorPolicy } from './watchQueryOptions';\nimport { ObservableQuery, reobserveCacheFirst } from './ObservableQuery';\nimport { QueryListener } from './types';\nimport { FetchResult } from '../link/core';\nimport {\n ObservableSubscription,\n isNonEmptyArray,\n graphQLResultHasError,\n canUseWeakMap,\n} from '../utilities';\nimport {\n NetworkStatus,\n isNetworkRequestInFlight,\n} from './networkStatus';\nimport { ApolloError } from '../errors';\nimport { QueryManager } from './QueryManager';\n\nexport type QueryStoreValue = Pick<QueryInfo,\n | \"variables\"\n | \"networkStatus\"\n | \"networkError\"\n | \"graphQLErrors\"\n >;\n\nexport const enum CacheWriteBehavior {\n FORBID,\n OVERWRITE,\n MERGE,\n};\n\nconst destructiveMethodCounts = new (\n canUseWeakMap ? WeakMap : Map\n)<ApolloCache<any>, number>();\n\nfunction wrapDestructiveCacheMethod(\n cache: ApolloCache<any>,\n methodName: keyof ApolloCache<any>,\n) {\n const original = cache[methodName];\n if (typeof original === \"function\") {\n cache[methodName] = function () {\n destructiveMethodCounts.set(\n cache,\n // The %1e15 allows the count to wrap around to 0 safely every\n // quadrillion evictions, so there's no risk of overflow. To be\n // clear, this is more of a pedantic principle than something\n // that matters in any conceivable practical scenario.\n (destructiveMethodCounts.get(cache)! + 1) % 1e15,\n );\n return original.apply(this, arguments);\n };\n }\n}\n\nfunction cancelNotifyTimeout(info: QueryInfo) {\n if (info[\"notifyTimeout\"]) {\n clearTimeout(info[\"notifyTimeout\"]);\n info[\"notifyTimeout\"] = void 0;\n }\n}\n\n// A QueryInfo object represents a single query managed by the\n// QueryManager, which tracks all QueryInfo objects by queryId in its\n// this.queries Map. QueryInfo objects store the latest results and errors\n// for the given query, and are responsible for reporting those results to\n// the corresponding ObservableQuery, via the QueryInfo.notify method.\n// Results are reported asynchronously whenever setDiff marks the\n// QueryInfo object as dirty, though a call to the QueryManager's\n// broadcastQueries method may trigger the notification before it happens\n// automatically. This class used to be a simple interface type without\n// any field privacy or meaningful methods, which is why it still has so\n// many public fields. The effort to lock down and simplify the QueryInfo\n// interface is ongoing, and further improvements are welcome.\nexport class QueryInfo {\n listeners = new Set<QueryListener>();\n document: DocumentNode | null = null;\n lastRequestId = 1;\n subscriptions = new Set<ObservableSubscription>();\n variables?: Record<string, any>;\n networkStatus?: NetworkStatus;\n networkError?: Error | null;\n graphQLErrors?: ReadonlyArray<GraphQLError>;\n stopped = false;\n\n private cache: ApolloCache<any>;\n\n constructor(\n queryManager: QueryManager<any>,\n public readonly queryId = queryManager.generateQueryId(),\n ) {\n const cache = this.cache = queryManager.cache;\n\n // Track how often cache.evict is called, since we want eviction to\n // override the feud-stopping logic in the markResult method, by\n // causing shouldWrite to return true. Wrapping the cache.evict method\n // is a bit of a hack, but it saves us from having to make eviction\n // counting an official part of the ApolloCache API.\n if (!destructiveMethodCounts.has(cache)) {\n destructiveMethodCounts.set(cache, 0);\n wrapDestructiveCacheMethod(cache, \"evict\");\n wrapDestructiveCacheMethod(cache, \"modify\");\n wrapDestructiveCacheMethod(cache, \"reset\");\n }\n }\n\n public init(query: {\n document: DocumentNode;\n variables: Record<string, any> | undefined,\n // The initial networkStatus for this fetch, most often\n // NetworkStatus.loading, but also possibly fetchMore, poll, refetch,\n // or setVariables.\n networkStatus?: NetworkStatus,\n observableQuery?: ObservableQuery<any>;\n lastRequestId?: number;\n }): this {\n let networkStatus = query.networkStatus || NetworkStatus.loading;\n if (this.variables &&\n this.networkStatus !== NetworkStatus.loading &&\n !equal(this.variables, query.variables)) {\n networkStatus = NetworkStatus.setVariables;\n }\n\n if (!equal(query.variables, this.variables)) {\n this.lastDiff = void 0;\n }\n\n Object.assign(this, {\n document: query.document,\n variables: query.variables,\n networkError: null,\n graphQLErrors: this.graphQLErrors || [],\n networkStatus,\n });\n\n if (query.observableQuery) {\n this.setObservableQuery(query.observableQuery);\n }\n\n if (query.lastRequestId) {\n this.lastRequestId = query.lastRequestId;\n }\n\n return this;\n }\n\n private dirty: boolean = false;\n\n private notifyTimeout?: ReturnType<typeof setTimeout>;\n\n reset() {\n cancelNotifyTimeout(this);\n this.lastDiff = void 0;\n this.dirty = false;\n }\n\n getDiff(variables = this.variables): Cache.DiffResult<any> {\n const options = this.getDiffOptions(variables);\n\n if (this.lastDiff && equal(options, this.lastDiff.options)) {\n return this.lastDiff.diff;\n }\n\n this.updateWatch(this.variables = variables);\n\n const oq = this.observableQuery;\n if (oq && oq.options.fetchPolicy === \"no-cache\") {\n return { complete: false };\n }\n\n const diff = this.cache.diff(options);\n this.updateLastDiff(diff, options);\n return diff;\n }\n\n private lastDiff?: {\n diff: Cache.DiffResult<any>,\n options: Cache.DiffOptions,\n };\n\n private updateLastDiff(\n diff: Cache.DiffResult<any> | null,\n options?: Cache.DiffOptions,\n ) {\n this.lastDiff = diff ? {\n diff,\n options: options || this.getDiffOptions(),\n } : void 0;\n }\n\n private getDiffOptions(variables = this.variables): Cache.DiffOptions {\n return {\n query: this.document!,\n variables,\n returnPartialData: true,\n optimistic: true,\n canonizeResults: this.observableQuery?.options.canonizeResults,\n };\n }\n\n setDiff(diff: Cache.DiffResult<any> | null) {\n const oldDiff = this.lastDiff && this.lastDiff.diff;\n this.updateLastDiff(diff);\n if (!this.dirty &&\n !equal(oldDiff && oldDiff.result,\n diff && diff.result)) {\n this.dirty = true;\n if (!this.notifyTimeout) {\n this.notifyTimeout = setTimeout(() => this.notify(), 0);\n }\n }\n }\n\n public readonly observableQuery: ObservableQuery<any> | null = null;\n private oqListener?: QueryListener;\n\n setObservableQuery(oq: ObservableQuery<any> | null) {\n if (oq === this.observableQuery) return;\n\n if (this.oqListener) {\n this.listeners.delete(this.oqListener);\n }\n\n (this as any).observableQuery = oq;\n\n if (oq) {\n oq[\"queryInfo\"] = this;\n this.listeners.add(this.oqListener = () => {\n const diff = this.getDiff();\n if (diff.fromOptimisticTransaction) {\n // If this diff came from an optimistic transaction, deliver the\n // current cache data to the ObservableQuery, but don't perform a\n // reobservation, since oq.reobserveCacheFirst might make a network\n // request, and we never want to trigger network requests in the\n // middle of optimistic updates.\n oq[\"observe\"]();\n } else {\n // Otherwise, make the ObservableQuery \"reobserve\" the latest data\n // using a temporary fetch policy of \"cache-first\", so complete cache\n // results have a chance to be delivered without triggering additional\n // network requests, even when options.fetchPolicy is \"network-only\"\n // or \"cache-and-network\". All other fetch policies are preserved by\n // this method, and are handled by calling oq.reobserve(). If this\n // reobservation is spurious, isDifferentFromLastResult still has a\n // chance to catch it before delivery to ObservableQuery subscribers.\n reobserveCacheFirst(oq);\n }\n });\n } else {\n delete this.oqListener;\n }\n }\n\n notify() {\n cancelNotifyTimeout(this);\n\n if (this.shouldNotify()) {\n this.listeners.forEach(listener => listener(this));\n }\n\n this.dirty = false;\n }\n\n private shouldNotify() {\n if (!this.dirty || !this.listeners.size) {\n return false;\n }\n\n if (isNetworkRequestInFlight(this.networkStatus) &&\n this.observableQuery) {\n const { fetchPolicy } = this.observableQuery.options;\n if (fetchPolicy !== \"cache-only\" &&\n fetchPolicy !== \"cache-and-network\") {\n return false;\n }\n }\n\n return true;\n }\n\n public stop() {\n if (!this.stopped) {\n this.stopped = true;\n\n // Cancel the pending notify timeout\n this.reset();\n\n this.cancel();\n // Revert back to the no-op version of cancel inherited from\n // QueryInfo.prototype.\n this.cancel = QueryInfo.prototype.cancel;\n\n this.subscriptions.forEach(sub => sub.unsubscribe());\n\n const oq = this.observableQuery;\n if (oq) oq.stopPolling();\n }\n }\n\n // This method is a no-op by default, until/unless overridden by the\n // updateWatch method.\n private cancel() {}\n\n private lastWatch?: Cache.WatchOptions;\n\n private updateWatch(variables = this.variables) {\n const oq = this.observableQuery;\n if (oq && oq.options.fetchPolicy === \"no-cache\") {\n return;\n }\n\n const watchOptions: Cache.WatchOptions = {\n // Although this.getDiffOptions returns Cache.DiffOptions instead of\n // Cache.WatchOptions, all the overlapping options should be the same, so\n // we can reuse getDiffOptions here, for consistency.\n ...this.getDiffOptions(variables),\n watcher: this,\n callback: diff => this.setDiff(diff),\n };\n\n if (!this.lastWatch ||\n !equal(watchOptions, this.lastWatch)) {\n this.cancel();\n this.cancel = this.cache.watch(this.lastWatch = watchOptions);\n }\n }\n\n private lastWrite?: {\n result: FetchResult<any>;\n variables: WatchQueryOptions[\"variables\"];\n dmCount: number | undefined;\n };\n\n public resetLastWrite() {\n this.lastWrite = void 0;\n }\n\n private shouldWrite(\n result: FetchResult<any>,\n variables: WatchQueryOptions[\"variables\"],\n ) {\n const { lastWrite } = this;\n return !(\n lastWrite &&\n // If cache.evict has been called since the last time we wrote this\n // data into the cache, there's a chance writing this result into\n // the cache will repair what was evicted.\n lastWrite.dmCount === destructiveMethodCounts.get(this.cache) &&\n equal(variables, lastWrite.variables) &&\n equal(result.data, lastWrite.result.data)\n );\n }\n\n public markResult<T>(\n result: FetchResult<T>,\n options: Pick<WatchQueryOptions,\n | \"variables\"\n | \"fetchPolicy\"\n | \"errorPolicy\">,\n cacheWriteBehavior: CacheWriteBehavior,\n ) {\n this.graphQLErrors = isNonEmptyArray(result.errors) ? result.errors : [];\n\n // Cancel the pending notify timeout (if it exists) to prevent extraneous network\n // requests. To allow future notify timeouts, diff and dirty are reset as well.\n this.reset();\n\n if (options.fetchPolicy === 'no-cache') {\n this.updateLastDiff(\n { result: result.data, complete: true },\n this.getDiffOptions(options.variables),\n );\n\n } else if (cacheWriteBehavior !== CacheWriteBehavior.FORBID) {\n if (shouldWriteResult(result, options.errorPolicy)) {\n // Using a transaction here so we have a chance to read the result\n // back from the cache before the watch callback fires as a result\n // of writeQuery, so we can store the new diff quietly and ignore\n // it when we receive it redundantly from the watch callback.\n this.cache.performTransaction(cache => {\n if (this.shouldWrite(result, options.variables)) {\n cache.writeQuery({\n query: this.document!,\n data: result.data as T,\n variables: options.variables,\n overwrite: cacheWriteBehavior === CacheWriteBehavior.OVERWRITE,\n });\n\n this.lastWrite = {\n result,\n variables: options.variables,\n dmCount: destructiveMethodCounts.get(this.cache),\n };\n } else {\n // If result is the same as the last result we received from\n // the network (and the variables match too), avoid writing\n // result into the cache again. The wisdom of skipping this\n // cache write is far from obvious, since any cache write\n // could be the one that puts the cache back into a desired\n // state, fixing corruption or missing data. However, if we\n // always write every network result into the cache, we enable\n // feuds between queries competing to update the same data in\n // incompatible ways, which can lead to an endless cycle of\n // cache broadcasts and useless network requests. As with any\n // feud, eventually one side must step back from the brink,\n // letting the other side(s) have the last word(s). There may\n // be other points where we could break this cycle, such as\n // silencing the broadcast for cache.writeQuery (not a good\n // idea, since it just delays the feud a bit) or somehow\n // avoiding the network request that just happened (also bad,\n // because the server could return useful new data). All\n // options considered, skipping this cache write seems to be\n // the least damaging place to break the cycle, because it\n // reflects the intuition that we recently wrote this exact\n // result into the cache, so the cache *should* already/still\n // contain this data. If some other query has clobbered that\n // data in the meantime, that's too bad, but there will be no\n // winners if every query blindly reverts to its own version\n // of the data. This approach also gives the network a chance\n // to return new data, which will be written into the cache as\n // usual, notifying only those queries that are directly\n // affected by the cache updates, as usual. In the future, an\n // even more sophisticated cache could perhaps prevent or\n // mitigate the clobbering somehow, but that would make this\n // particular cache write even less important, and thus\n // skipping it would be even safer than it is today.\n if (this.lastDiff &&\n this.lastDiff.diff.complete) {\n // Reuse data from the last good (complete) diff that we\n // received, when possible.\n result.data = this.lastDiff.diff.result;\n return;\n }\n // If the previous this.diff was incomplete, fall through to\n // re-reading the latest data with cache.diff, below.\n }\n\n const diffOptions = this.getDiffOptions(options.variables);\n const diff = cache.diff<T>(diffOptions);\n\n // In case the QueryManager stops this QueryInfo before its\n // results are delivered, it's important to avoid restarting the\n // cache watch when markResult is called.\n if (!this.stopped) {\n // Any time we're about to update this.diff, we need to make\n // sure we've started watching the cache.\n this.updateWatch(options.variables);\n }\n\n // If we're allowed to write to the cache, and we can read a\n // complete result from the cache, update result.data to be the\n // result from the cache, rather than the raw network result.\n // Set without setDiff to avoid triggering a notify call, since\n // we have other ways of notifying for this result.\n this.updateLastDiff(diff, diffOptions);\n if (diff.complete) {\n result.data = diff.result;\n }\n });\n } else {\n this.lastWrite = void 0;\n }\n }\n }\n\n public markReady() {\n this.networkError = null;\n return this.networkStatus = NetworkStatus.ready;\n }\n\n public markError(error: ApolloError) {\n this.networkStatus = NetworkStatus.error;\n this.lastWrite = void 0;\n\n this.reset();\n\n if (error.graphQLErrors) {\n this.graphQLErrors = error.graphQLErrors;\n }\n\n if (error.networkError) {\n this.networkError = error.networkError;\n }\n\n return error;\n }\n}\n\nexport function shouldWriteResult<T>(\n result: FetchResult<T>,\n errorPolicy: ErrorPolicy = \"none\",\n) {\n const ignoreErrors =\n errorPolicy === \"ignore\" ||\n errorPolicy === \"all\";\n let writeWithErrors = !graphQLResultHasError(result);\n if (!writeWithErrors && ignoreErrors && result.data) {\n writeWithErrors = true;\n }\n return writeWithErrors;\n}\n","import { invariant, InvariantError } from '../utilities/globals';\n\nimport { DocumentNode } from 'graphql';\n// TODO(brian): A hack until this issue is resolved (https://github.com/graphql/graphql-js/issues/3356)\ntype OperationTypeNode = any;\nimport { equal } from '@wry/equality';\n\nimport { ApolloLink, execute, FetchResult } from '../link/core';\nimport { Cache, ApolloCache, canonicalStringify } from '../cache';\n\nimport {\n getDefaultValues,\n getOperationDefinition,\n getOperationName,\n hasClientExports,\n graphQLResultHasError,\n removeConnectionDirectiveFromDocument,\n canUseWeakMap,\n ObservableSubscription,\n Observable,\n asyncMap,\n isNonEmptyArray,\n Concast,\n ConcastSourcesArray,\n makeUniqueId,\n isDocumentNode,\n isNonNullObject,\n} from '../utilities';\nimport { ApolloError, isApolloError } from '../errors';\nimport {\n QueryOptions,\n WatchQueryOptions,\n SubscriptionOptions,\n MutationOptions,\n ErrorPolicy,\n MutationFetchPolicy,\n} from './watchQueryOptions';\nimport { ObservableQuery, logMissingFieldErrors } from './ObservableQuery';\nimport { NetworkStatus, isNetworkRequestInFlight } from './networkStatus';\nimport {\n ApolloQueryResult,\n OperationVariables,\n MutationUpdaterFunction,\n OnQueryUpdated,\n InternalRefetchQueriesInclude,\n InternalRefetchQueriesOptions,\n InternalRefetchQueriesResult,\n InternalRefetchQueriesMap,\n} from './types';\nimport { LocalState } from './LocalState';\n\nimport {\n QueryInfo,\n QueryStoreValue,\n shouldWriteResult,\n CacheWriteBehavior,\n} from './QueryInfo';\n\nconst { hasOwnProperty } = Object.prototype;\n\ninterface MutationStoreValue {\n mutation: DocumentNode;\n variables: Record<string, any>;\n loading: boolean;\n error: Error | null;\n}\n\ntype UpdateQueries<TData> = MutationOptions<TData, any, any>[\"updateQueries\"];\n\ninterface TransformCacheEntry {\n document: DocumentNode;\n hasClientExports: boolean;\n hasForcedResolvers: boolean;\n clientQuery: DocumentNode | null;\n serverQuery: DocumentNode | null;\n defaultVars: OperationVariables;\n asQuery: DocumentNode;\n}\n\ntype DefaultOptions = import(\"./ApolloClient\").DefaultOptions;\n\nexport class QueryManager<TStore> {\n public cache: ApolloCache<TStore>;\n public link: ApolloLink;\n public defaultOptions: DefaultOptions;\n\n public readonly assumeImmutableResults: boolean;\n public readonly ssrMode: boolean;\n\n private queryDeduplication: boolean;\n private clientAwareness: Record<string, string> = {};\n private localState: LocalState<TStore>;\n\n private onBroadcast?: () => void;\n public mutationStore?: {\n [mutationId: string]: MutationStoreValue;\n };\n\n // All the queries that the QueryManager is currently managing (not\n // including mutations and subscriptions).\n private queries = new Map<string, QueryInfo>();\n\n // Maps from queryId strings to Promise rejection functions for\n // currently active queries and fetches.\n private fetchCancelFns = new Map<string, (error: any) => any>();\n\n constructor({\n cache,\n link,\n defaultOptions,\n queryDeduplication = false,\n onBroadcast,\n ssrMode = false,\n clientAwareness = {},\n localState,\n assumeImmutableResults,\n }: {\n cache: ApolloCache<TStore>;\n link: ApolloLink;\n defaultOptions?: DefaultOptions;\n queryDeduplication?: boolean;\n onBroadcast?: () => void;\n ssrMode?: boolean;\n clientAwareness?: Record<string, string>;\n localState?: LocalState<TStore>;\n assumeImmutableResults?: boolean;\n }) {\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 });\n this.ssrMode = ssrMode;\n this.assumeImmutableResults = !!assumeImmutableResults;\n if ((this.onBroadcast = onBroadcast)) {\n this.mutationStore = Object.create(null);\n }\n }\n\n /**\n * Call this method to terminate any active query processes, making it safe\n * to dispose of this QueryManager instance.\n */\n public stop() {\n this.queries.forEach((_info, queryId) => {\n this.stopQueryNoBroadcast(queryId);\n });\n\n this.cancelPendingFetches(\n new InvariantError('QueryManager stopped while query was in flight'),\n );\n }\n\n private cancelPendingFetches(error: Error) {\n this.fetchCancelFns.forEach(cancel => cancel(error));\n this.fetchCancelFns.clear();\n }\n\n public async mutate<\n TData,\n TVariables,\n TContext,\n TCache extends ApolloCache<any>\n >({\n mutation,\n variables,\n optimisticResponse,\n updateQueries,\n refetchQueries = [],\n awaitRefetchQueries = false,\n update: updateWithProxyFn,\n onQueryUpdated,\n fetchPolicy = this.defaultOptions.mutate?.fetchPolicy || \"network-only\",\n errorPolicy = this.defaultOptions.mutate?.errorPolicy || \"none\",\n keepRootFields,\n context,\n }: MutationOptions<TData, TVariables, TContext>): Promise<FetchResult<TData>> {\n invariant(\n mutation,\n 'mutation option is required. You must specify your GraphQL document in the mutation option.',\n );\n\n invariant(\n fetchPolicy === 'network-only' ||\n fetchPolicy === 'no-cache',\n \"Mutations support only 'network-only' or 'no-cache' fetchPolicy strings. The default `network-only` behavior automatically writes mutation results to the cache. Passing `no-cache` skips the cache write.\"\n );\n\n const mutationId = this.generateMutationId();\n mutation = this.transform(mutation).document;\n\n variables = this.getVariables(mutation, variables) as TVariables;\n\n if (this.transform(mutation).hasClientExports) {\n variables = await this.localState.addExportedVariables(mutation, variables, context) as TVariables;\n }\n\n const mutationStoreValue =\n this.mutationStore &&\n (this.mutationStore[mutationId] = {\n mutation,\n variables,\n loading: true,\n error: null,\n } as MutationStoreValue);\n\n if (optimisticResponse) {\n this.markMutationOptimistic<\n TData,\n TVariables,\n TContext,\n TCache\n >(optimisticResponse, {\n mutationId,\n document: mutation,\n variables,\n fetchPolicy,\n errorPolicy,\n context,\n updateQueries,\n update: updateWithProxyFn,\n keepRootFields,\n });\n }\n\n this.broadcastQueries();\n\n const self = this;\n\n return new Promise((resolve, reject) => {\n return asyncMap(\n self.getObservableFromLink(\n mutation,\n {\n ...context,\n optimisticResponse,\n },\n variables,\n false,\n ),\n\n (result: FetchResult<TData>) => {\n if (graphQLResultHasError(result) && errorPolicy === 'none') {\n throw new ApolloError({\n graphQLErrors: result.errors,\n });\n }\n\n if (mutationStoreValue) {\n mutationStoreValue.loading = false;\n mutationStoreValue.error = null;\n }\n\n const storeResult: typeof result = { ...result };\n\n if (typeof refetchQueries === \"function\") {\n refetchQueries = refetchQueries(storeResult);\n }\n\n if (errorPolicy === 'ignore' &&\n graphQLResultHasError(storeResult)) {\n delete storeResult.errors;\n }\n\n return self.markMutationResult<\n TData,\n TVariables,\n TContext,\n TCache\n >({\n mutationId,\n result: storeResult,\n document: mutation,\n variables,\n fetchPolicy,\n errorPolicy,\n context,\n update: updateWithProxyFn,\n updateQueries,\n awaitRefetchQueries,\n refetchQueries,\n removeOptimistic: optimisticResponse ? mutationId : void 0,\n onQueryUpdated,\n keepRootFields,\n });\n },\n\n ).subscribe({\n next(storeResult) {\n self.broadcastQueries();\n\n // At the moment, a mutation can have only one result, so we can\n // immediately resolve upon receiving the first result. In the future,\n // mutations containing @defer or @stream directives might receive\n // multiple FetchResult payloads from the ApolloLink chain, so we will\n // probably need to collect those results in this next method and call\n // resolve only later, in an observer.complete function.\n resolve(storeResult);\n },\n\n error(err: Error) {\n if (mutationStoreValue) {\n mutationStoreValue.loading = false;\n mutationStoreValue.error = err;\n }\n\n if (optimisticResponse) {\n self.cache.removeOptimistic(mutationId);\n }\n\n self.broadcastQueries();\n\n reject(\n err instanceof ApolloError ? err : new ApolloError({\n networkError: err,\n }),\n );\n },\n });\n });\n }\n\n public markMutationResult<\n TData,\n TVariables,\n TContext,\n TCache extends ApolloCache<any>\n >(\n mutation: {\n mutationId: string;\n result: FetchResult<TData>;\n document: DocumentNode;\n variables?: TVariables;\n fetchPolicy?: MutationFetchPolicy;\n errorPolicy: ErrorPolicy;\n context?: TContext;\n updateQueries: UpdateQueries<TData>;\n update?: MutationUpdaterFunction<TData, TVariables, TContext, TCache>;\n awaitRefetchQueries?: boolean;\n refetchQueries?: InternalRefetchQueriesInclude;\n removeOptimistic?: string;\n onQueryUpdated?: OnQueryUpdated<any>;\n keepRootFields?: boolean;\n },\n cache = this.cache,\n ): Promise<FetchResult<TData>> {\n let { result } = mutation;\n const cacheWrites: Cache.WriteOptions[] = [];\n const skipCache = mutation.fetchPolicy === \"no-cache\";\n\n if (!skipCache && shouldWriteResult(result, mutation.errorPolicy)) {\n cacheWrites.push({\n result: result.data,\n dataId: 'ROOT_MUTATION',\n query: mutation.document,\n variables: mutation.variables,\n });\n\n const { updateQueries } = mutation;\n if (updateQueries) {\n this.queries.forEach(({ observableQuery }, queryId) => {\n const queryName = observableQuery && observableQuery.queryName;\n if (!queryName || !hasOwnProperty.call(updateQueries, queryName)) {\n return;\n }\n const updater = updateQueries[queryName];\n const { document, variables } = this.queries.get(queryId)!;\n\n // Read the current query result from the store.\n const { result: currentQueryResult, complete } = cache.diff<TData>({\n query: document!,\n variables,\n returnPartialData: true,\n optimistic: false,\n });\n\n if (complete && currentQueryResult) {\n // Run our reducer using the current query result and the mutation result.\n const nextQueryResult = updater(currentQueryResult, {\n mutationResult: result,\n queryName: document && getOperationName(document) || void 0,\n queryVariables: variables!,\n });\n\n // Write the modified result back into the store if we got a new result.\n if (nextQueryResult) {\n cacheWrites.push({\n result: nextQueryResult,\n dataId: 'ROOT_QUERY',\n query: document!,\n variables,\n });\n }\n }\n });\n }\n }\n\n if (\n cacheWrites.length > 0 ||\n mutation.refetchQueries ||\n mutation.update ||\n mutation.onQueryUpdated ||\n mutation.removeOptimistic\n ) {\n const results: any[] = [];\n\n this.refetchQueries({\n updateCache: (cache: TCache) => {\n if (!skipCache) {\n cacheWrites.forEach(write => cache.write(write));\n }\n\n // If the mutation has some writes associated with it then we need to\n // apply those writes to the store by running this reducer again with\n // a write action.\n const { update } = mutation;\n if (update) {\n if (!skipCache) {\n // Re-read the ROOT_MUTATION data we just wrote into the cache\n // (the first cache.write call in the cacheWrites.forEach loop\n // above), so field read functions have a chance to run for\n // fields within mutation result objects.\n const diff = cache.diff<TData>({\n id: \"ROOT_MUTATION\",\n // The cache complains if passed a mutation where it expects a\n // query, so we transform mutations and subscriptions to queries\n // (only once, thanks to this.transformCache).\n query: this.transform(mutation.document).asQuery,\n variables: mutation.variables,\n optimistic: false,\n returnPartialData: true,\n });\n\n if (diff.complete) {\n result = { ...result, data: diff.result };\n }\n }\n\n update(cache, result, {\n context: mutation.context,\n variables: mutation.variables,\n });\n }\n\n // TODO Do this with cache.evict({ id: 'ROOT_MUTATION' }) but make it\n // shallow to allow rolling back optimistic evictions.\n if (!skipCache && !mutation.keepRootFields) {\n cache.modify({\n id: 'ROOT_MUTATION',\n fields(value, { fieldName, DELETE }) {\n return fieldName === \"__typename\" ? value : DELETE;\n },\n });\n }\n },\n\n include: mutation.refetchQueries,\n\n // Write the final mutation.result to the root layer of the cache.\n optimistic: false,\n\n // Remove the corresponding optimistic layer at the same time as we\n // write the final non-optimistic result.\n removeOptimistic: mutation.removeOptimistic,\n\n // Let the caller of client.mutate optionally determine the refetching\n // behavior for watched queries after the mutation.update function runs.\n // If no onQueryUpdated function was provided for this mutation, pass\n // null instead of undefined to disable the default refetching behavior.\n onQueryUpdated: mutation.onQueryUpdated || null,\n\n }).forEach(result => results.push(result));\n\n if (mutation.awaitRefetchQueries || mutation.onQueryUpdated) {\n // Returning a promise here makes the mutation await that promise, so we\n // include results in that promise's work if awaitRefetchQueries or an\n // onQueryUpdated function was specified.\n return Promise.all(results).then(() => result);\n }\n }\n\n return Promise.resolve(result);\n }\n\n public markMutationOptimistic<TData, TVariables, TContext, TCache extends ApolloCache<any>>(\n optimisticResponse: any,\n mutation: {\n mutationId: string;\n document: DocumentNode;\n variables?: TVariables;\n fetchPolicy?: MutationFetchPolicy;\n errorPolicy: ErrorPolicy;\n context?: TContext;\n updateQueries: UpdateQueries<TData>,\n update?: MutationUpdaterFunction<TData, TVariables, TContext, TCache>;\n keepRootFields?: boolean,\n },\n ) {\n const data = typeof optimisticResponse === \"function\"\n ? optimisticResponse(mutation.variables)\n : optimisticResponse;\n\n return this.cache.recordOptimisticTransaction(cache => {\n try {\n this.markMutationResult<TData, TVariables, TContext, TCache>({\n ...mutation,\n result: { data },\n }, cache);\n } catch (error) {\n invariant.error(error);\n }\n }, mutation.mutationId);\n }\n\n public fetchQuery<TData, TVars>(\n queryId: string,\n options: WatchQueryOptions<TVars, TData>,\n networkStatus?: NetworkStatus,\n ): Promise<ApolloQueryResult<TData>> {\n return this.fetchQueryObservable<TData, TVars>(\n queryId,\n options,\n networkStatus,\n ).promise;\n }\n\n public getQueryStore() {\n const store: Record<string, QueryStoreValue> = Object.create(null);\n this.queries.forEach((info, queryId) => {\n store[queryId] = {\n variables: info.variables,\n networkStatus: info.networkStatus,\n networkError: info.networkError,\n graphQLErrors: info.graphQLErrors,\n };\n });\n return store;\n }\n\n public resetErrors(queryId: string) {\n const queryInfo = this.queries.get(queryId);\n if (queryInfo) {\n queryInfo.networkError = undefined;\n queryInfo.graphQLErrors = [];\n }\n }\n\n private transformCache = new (\n canUseWeakMap ? WeakMap : Map\n )<DocumentNode, TransformCacheEntry>();\n\n public transform(document: DocumentNode) {\n const { transformCache } = this;\n\n if (!transformCache.has(document)) {\n const transformed = this.cache.transformDocument(document);\n const forLink = removeConnectionDirectiveFromDocument(\n this.cache.transformForLink(transformed));\n\n const clientQuery = this.localState.clientQuery(transformed);\n const serverQuery = forLink && this.localState.serverQuery(forLink);\n\n const cacheEntry: TransformCacheEntry = {\n document: transformed,\n // TODO These two calls (hasClientExports and shouldForceResolvers)\n // could probably be merged into a single traversal.\n hasClientExports: hasClientExports(transformed),\n hasForcedResolvers: this.localState.shouldForceResolvers(transformed),\n clientQuery,\n serverQuery,\n defaultVars: getDefaultValues(\n getOperationDefinition(transformed)\n ) as OperationVariables,\n // Transform any mutation or subscription operations to query operations\n // so we can read/write them from/to the cache.\n asQuery: {\n ...transformed,\n definitions: transformed.definitions.map(def => {\n if (def.kind === \"OperationDefinition\" &&\n def.operation !== \"query\") {\n return { ...def, operation: \"query\" as OperationTypeNode };\n }\n return def;\n }),\n }\n };\n\n const add = (doc: DocumentNode | null) => {\n if (doc && !transformCache.has(doc)) {\n transformCache.set(doc, cacheEntry);\n }\n }\n // Add cacheEntry to the transformCache using several different keys,\n // since any one of these documents could end up getting passed to the\n // transform method again in the future.\n add(document);\n add(transformed);\n add(clientQuery);\n add(serverQuery);\n }\n\n return transformCache.get(document)!;\n }\n\n private getVariables<TVariables>(\n document: DocumentNode,\n variables?: TVariables,\n ): OperationVariables {\n return {\n ...this.transform(document).defaultVars,\n ...variables,\n };\n }\n\n public watchQuery<T, TVariables = OperationVariables>(\n options: WatchQueryOptions<TVariables, T>,\n ): ObservableQuery<T, TVariables> {\n // assign variable default values if supplied\n options = {\n ...options,\n variables: this.getVariables(\n options.query,\n options.variables,\n ) as TVariables,\n };\n\n if (typeof options.notifyOnNetworkStatusChange === 'undefined') {\n options.notifyOnNetworkStatusChange = false;\n }\n\n const queryInfo = new QueryInfo(this);\n const observable = new ObservableQuery<T, TVariables>({\n queryManager: this,\n queryInfo,\n options,\n });\n\n this.queries.set(observable.queryId, queryInfo);\n\n queryInfo.init({\n document: observable.query,\n observableQuery: observable,\n variables: observable.variables,\n });\n\n return observable;\n }\n\n public query<TData, TVars = OperationVariables>(\n options: QueryOptions<TVars, TData>,\n queryId = this.generateQueryId(),\n ): Promise<ApolloQueryResult<TData>> {\n invariant(\n options.query,\n 'query option is required. You must specify your GraphQL document ' +\n 'in the query option.',\n );\n\n invariant(\n options.query.kind === 'Document',\n 'You must wrap the query string in a \"gql\" tag.',\n );\n\n invariant(\n !(options as any).returnPartialData,\n 'returnPartialData option only supported on watchQuery.',\n );\n\n invariant(\n !(options as any).pollInterval,\n 'pollInterval option only supported on watchQuery.',\n );\n\n return this.fetchQuery<TData, TVars>(\n queryId,\n options,\n ).finally(() => this.stopQuery(queryId));\n }\n\n private queryIdCounter = 1;\n public generateQueryId() {\n return String(this.queryIdCounter++);\n }\n\n private requestIdCounter = 1;\n public generateRequestId() {\n return this.requestIdCounter++;\n }\n\n private mutationIdCounter = 1;\n public generateMutationId() {\n return String(this.mutationIdCounter++);\n }\n\n public stopQueryInStore(queryId: string) {\n this.stopQueryInStoreNoBroadcast(queryId);\n this.broadcastQueries();\n }\n\n private stopQueryInStoreNoBroadcast(queryId: string) {\n const queryInfo = this.queries.get(queryId);\n if (queryInfo) queryInfo.stop();\n }\n\n public clearStore(options: Cache.ResetOptions = {\n discardWatches: true,\n }): Promise<void> {\n // Before we have sent the reset action to the store, we can no longer\n // rely on the results returned by in-flight requests since these may\n // depend on values that previously existed in the data portion of the\n // store. So, we cancel the promises and observers that we have issued\n // so far and not yet resolved (in the case of queries).\n this.cancelPendingFetches(new InvariantError(\n 'Store reset while query was in flight (not completed in link chain)',\n ));\n\n this.queries.forEach(queryInfo => {\n if (queryInfo.observableQuery) {\n // Set loading to true so listeners don't trigger unless they want\n // results with partial data.\n queryInfo.networkStatus = NetworkStatus.loading;\n } else {\n queryInfo.stop();\n }\n });\n\n if (this.mutationStore) {\n this.mutationStore = Object.create(null);\n }\n\n // begin removing data from the store\n return this.cache.reset(options);\n }\n\n public getObservableQueries(\n include: InternalRefetchQueriesInclude = \"active\",\n ) {\n const queries = new Map<string, ObservableQuery<any>>();\n const queryNamesAndDocs = new Map<string | DocumentNode, boolean>();\n const legacyQueryOptions = new Set<QueryOptions>();\n\n if (Array.isArray(include)) {\n include.forEach(desc => {\n if (typeof desc === \"string\") {\n queryNamesAndDocs.set(desc, false);\n } else if (isDocumentNode(desc)) {\n queryNamesAndDocs.set(this.transform(desc).document, false);\n } else if (isNonNullObject(desc) && desc.query) {\n legacyQueryOptions.add(desc);\n }\n });\n }\n\n this.queries.forEach(({ observableQuery: oq, document }, queryId) => {\n if (oq) {\n if (include === \"all\") {\n queries.set(queryId, oq);\n return;\n }\n\n const {\n queryName,\n options: { fetchPolicy },\n } = oq;\n\n if (\n fetchPolicy === \"standby\" ||\n (include === \"active\" && !oq.hasObservers())\n ) {\n return;\n }\n\n if (\n include === \"active\" ||\n (queryName && queryNamesAndDocs.has(queryName)) ||\n (document && queryNamesAndDocs.has(document))\n ) {\n queries.set(queryId, oq);\n if (queryName) queryNamesAndDocs.set(queryName, true);\n if (document) queryNamesAndDocs.set(document, true);\n }\n }\n });\n\n if (legacyQueryOptions.size) {\n legacyQueryOptions.forEach((options: QueryOptions) => {\n // We will be issuing a fresh network request for this query, so we\n // pre-allocate a new query ID here, using a special prefix to enable\n // cleaning up these temporary queries later, after fetching.\n const queryId = makeUniqueId(\"legacyOneTimeQuery\");\n const queryInfo = this.getQuery(queryId).init({\n document: options.query,\n variables: options.variables,\n });\n const oq = new ObservableQuery({\n queryManager: this,\n queryInfo,\n options: {\n ...options,\n fetchPolicy: \"network-only\",\n },\n });\n invariant(oq.queryId === queryId);\n queryInfo.setObservableQuery(oq);\n queries.set(queryId, oq);\n });\n }\n\n if (__DEV__ && queryNamesAndDocs.size) {\n queryNamesAndDocs.forEach((included, nameOrDoc) => {\n if (!included) {\n invariant.warn(`Unknown query ${\n typeof nameOrDoc === \"string\" ? \"named \" : \"\"\n }${\n JSON.stringify(nameOrDoc, null, 2)\n } requested in refetchQueries options.include array`);\n }\n });\n }\n\n return queries;\n }\n\n public reFetchObservableQueries(\n includeStandby: boolean = false,\n ): Promise<ApolloQueryResult<any>[]> {\n const observableQueryPromises: Promise<ApolloQueryResult<any>>[] = [];\n\n this.getObservableQueries(\n includeStandby ? \"all\" : \"active\"\n ).forEach((observableQuery, queryId) => {\n const { fetchPolicy } = observableQuery.options;\n observableQuery.resetLastResults();\n if (includeStandby ||\n (fetchPolicy !== \"standby\" &&\n fetchPolicy !== \"cache-only\")) {\n observableQueryPromises.push(observableQuery.refetch());\n }\n this.getQuery(queryId).setDiff(null);\n });\n\n this.broadcastQueries();\n\n return Promise.all(observableQueryPromises);\n }\n\n public setObservableQuery(observableQuery: ObservableQuery<any, any>) {\n this.getQuery(observableQuery.queryId).setObservableQuery(observableQuery);\n }\n\n public startGraphQLSubscription<T = any>({\n query,\n fetchPolicy,\n errorPolicy,\n variables,\n context = {},\n }: SubscriptionOptions): Observable<FetchResult<T>> {\n query = this.transform(query).document;\n variables = this.getVariables(query, variables);\n\n const makeObservable = (variables: OperationVariables) =>\n this.getObservableFromLink<T>(\n query,\n context,\n variables,\n ).map(result => {\n if (fetchPolicy !== 'no-cache') {\n // the subscription interface should handle not sending us results we no longer subscribe to.\n // XXX I don't think we ever send in an object with errors, but we might in the future...\n if (shouldWriteResult(result, errorPolicy)) {\n this.cache.write({\n query,\n result: result.data,\n dataId: 'ROOT_SUBSCRIPTION',\n variables: variables,\n });\n }\n\n this.broadcastQueries();\n }\n\n if (graphQLResultHasError(result)) {\n throw new ApolloError({\n graphQLErrors: result.errors,\n });\n }\n\n return result;\n });\n\n if (this.transform(query).hasClientExports) {\n const observablePromise = this.localState.addExportedVariables(\n query,\n variables,\n context,\n ).then(makeObservable);\n\n return new Observable<FetchResult<T>>(observer => {\n let sub: ObservableSubscription | null = null;\n observablePromise.then(\n observable => sub = observable.subscribe(observer),\n observer.error,\n );\n return () => sub && sub.unsubscribe();\n });\n }\n\n return makeObservable(variables);\n }\n\n public stopQuery(queryId: string) {\n this.stopQueryNoBroadcast(queryId);\n this.broadcastQueries();\n }\n\n private stopQueryNoBroadcast(queryId: string) {\n this.stopQueryInStoreNoBroadcast(queryId);\n this.removeQuery(queryId);\n }\n\n public removeQuery(queryId: string) {\n // teardown all links\n // Both `QueryManager.fetchRequest` and `QueryManager.query` create separate promises\n // that each add their reject functions to fetchCancelFns.\n // A query created with `QueryManager.query()` could trigger a `QueryManager.fetchRequest`.\n // The same queryId could have two rejection fns for two promises\n this.fetchCancelFns.delete(queryId);\n if (this.queries.has(queryId)) {\n this.getQuery(queryId).stop();\n this.queries.delete(queryId);\n }\n }\n\n public broadcastQueries() {\n if (this.onBroadcast) this.onBroadcast();\n this.queries.forEach(info => info.notify());\n }\n\n public getLocalState(): LocalState<TStore> {\n return this.localState;\n }\n\n private inFlightLinkObservables = new Map<\n DocumentNode,\n Map<string, Observable<FetchResult>>\n >();\n\n private getObservableFromLink<T = any>(\n query: DocumentNode,\n context: any,\n variables?: OperationVariables,\n deduplication: boolean =\n // Prefer context.queryDeduplication if specified.\n context?.queryDeduplication ??\n this.queryDeduplication,\n ): Observable<FetchResult<T>> {\n let observable: Observable<FetchResult<T>>;\n\n const { serverQuery } = this.transform(query);\n if (serverQuery) {\n const { inFlightLinkObservables, link } = this;\n\n const operation = {\n query: serverQuery,\n variables,\n operationName: getOperationName(serverQuery) || void 0,\n context: this.prepareContext({\n ...context,\n forceFetch: !deduplication\n }),\n };\n\n context = operation.context;\n\n if (deduplication) {\n const byVariables = inFlightLinkObservables.get(serverQuery) || new Map();\n inFlightLinkObservables.set(serverQuery, byVariables);\n\n const varJson = canonicalStringify(variables);\n observable = byVariables.get(varJson);\n\n if (!observable) {\n const concast = new Concast([\n execute(link, operation) as Observable<FetchResult<T>>\n ]);\n\n byVariables.set(varJson, observable = concast);\n\n concast.cleanup(() => {\n if (byVariables.delete(varJson) &&\n byVariables.size < 1) {\n inFlightLinkObservables.delete(serverQuery);\n }\n });\n }\n\n } else {\n observable = new Concast([\n execute(link, operation) as Observable<FetchResult<T>>\n ]);\n }\n } else {\n observable = new Concast([\n Observable.of({ data: {} } as FetchResult<T>)\n ]);\n context = this.prepareContext(context);\n }\n\n const { clientQuery } = this.transform(query);\n if (clientQuery) {\n observable = asyncMap(observable, result => {\n return this.localState.runResolvers({\n document: clientQuery,\n remoteResult: result,\n context,\n variables,\n });\n });\n }\n\n return observable;\n }\n\n private getResultsFromLink<TData, TVars>(\n queryInfo: QueryInfo,\n cacheWriteBehavior: CacheWriteBehavior,\n options: Pick<WatchQueryOptions<TVars, TData>,\n | \"variables\"\n | \"context\"\n | \"fetchPolicy\"\n | \"errorPolicy\">,\n ): Observable<ApolloQueryResult<TData>> {\n const requestId = queryInfo.lastRequestId = this.generateRequestId();\n\n return asyncMap(\n this.getObservableFromLink(\n queryInfo.document!,\n options.context,\n options.variables,\n ),\n\n result => {\n const hasErrors = isNonEmptyArray(result.errors);\n\n // If we interrupted this request by calling getResultsFromLink again\n // with the same QueryInfo object, we ignore the old results.\n if (requestId >= queryInfo.lastRequestId) {\n if (hasErrors && options.errorPolicy === \"none\") {\n // Throwing here effectively calls observer.error.\n throw queryInfo.markError(new ApolloError({\n graphQLErrors: result.errors,\n }));\n }\n queryInfo.markResult(result, options, cacheWriteBehavior);\n queryInfo.markReady();\n }\n\n const aqr: ApolloQueryResult<TData> = {\n data: result.data,\n loading: false,\n networkStatus: NetworkStatus.ready,\n };\n\n if (hasErrors && options.errorPolicy !== \"ignore\") {\n aqr.errors = result.errors;\n aqr.networkStatus = NetworkStatus.error;\n }\n\n return aqr;\n },\n\n networkError => {\n const error = isApolloError(networkError)\n ? networkError\n : new ApolloError({ networkError });\n\n // Avoid storing errors from older interrupted queries.\n if (requestId >= queryInfo.lastRequestId) {\n queryInfo.markError(error);\n }\n\n throw error;\n },\n );\n }\n\n public fetchQueryObservable<TData, TVars>(\n queryId: string,\n options: WatchQueryOptions<TVars, TData>,\n // The initial networkStatus for this fetch, most often\n // NetworkStatus.loading, but also possibly fetchMore, poll, refetch,\n // or setVariables.\n networkStatus = NetworkStatus.loading,\n ): Concast<ApolloQueryResult<TData>> {\n const query = this.transform(options.query).document;\n const variables = this.getVariables(query, options.variables) as TVars;\n const queryInfo = this.getQuery(queryId);\n\n const defaults = this.defaultOptions.watchQuery;\n let {\n fetchPolicy = defaults && defaults.fetchPolicy || \"cache-first\",\n errorPolicy = defaults && defaults.errorPolicy || \"none\",\n returnPartialData = false,\n notifyOnNetworkStatusChange = false,\n context = {},\n } = options;\n\n const normalized = Object.assign({}, options, {\n query,\n variables,\n fetchPolicy,\n errorPolicy,\n returnPartialData,\n notifyOnNetworkStatusChange,\n context,\n });\n\n const fromVariables = (variables: TVars) => {\n // Since normalized is always a fresh copy of options, it's safe to\n // modify its properties here, rather than creating yet another new\n // WatchQueryOptions object.\n normalized.variables = variables;\n\n const concastSources = this.fetchQueryByPolicy<TData, TVars>(\n queryInfo,\n normalized,\n networkStatus,\n );\n\n if (\n // If we're in standby, postpone advancing options.fetchPolicy using\n // applyNextFetchPolicy.\n normalized.fetchPolicy !== \"standby\" &&\n // The \"standby\" policy currently returns [] from fetchQueryByPolicy, so\n // this is another way to detect when nothing was done/fetched.\n concastSources.length > 0 &&\n queryInfo.observableQuery\n ) {\n queryInfo.observableQuery[\"applyNextFetchPolicy\"](\"after-fetch\", options);\n }\n\n return concastSources;\n };\n\n // This cancel function needs to be set before the concast is created,\n // in case concast creation synchronously cancels the request.\n const cleanupCancelFn = () => this.fetchCancelFns.delete(queryId);\n this.fetchCancelFns.set(queryId, reason => {\n cleanupCancelFn();\n // This delay ensures the concast variable has been initialized.\n setTimeout(() => concast.cancel(reason));\n });\n\n // A Concast<T> can be created either from an Iterable<Observable<T>>\n // or from a PromiseLike<Iterable<Observable<T>>>, where T in this\n // case is ApolloQueryResult<TData>.\n const concast = new Concast(\n // If the query has @export(as: ...) directives, then we need to\n // process those directives asynchronously. When there are no\n // @export directives (the common case), we deliberately avoid\n // wrapping the result of this.fetchQueryByPolicy in a Promise,\n // since the timing of result delivery is (unfortunately) important\n // for backwards compatibility. TODO This code could be simpler if\n // we deprecated and removed LocalState.\n this.transform(normalized.query).hasClientExports\n ? this.localState.addExportedVariables(\n normalized.query,\n normalized.variables,\n normalized.context,\n ).then(fromVariables)\n : fromVariables(normalized.variables!)\n );\n\n concast.promise.then(cleanupCancelFn, cleanupCancelFn);\n\n return concast;\n }\n\n public refetchQueries<TResult>({\n updateCache,\n include,\n optimistic = false,\n removeOptimistic = optimistic ? makeUniqueId(\"refetchQueries\") : void 0,\n onQueryUpdated,\n }: InternalRefetchQueriesOptions<ApolloCache<TStore>, TResult>\n ): InternalRefetchQueriesMap<TResult> {\n const includedQueriesById = new Map<string, {\n oq: ObservableQuery<any>;\n lastDiff?: Cache.DiffResult<any>;\n diff?: Cache.DiffResult<any>;\n }>();\n\n if (include) {\n this.getObservableQueries(include).forEach((oq, queryId) => {\n includedQueriesById.set(queryId, {\n oq,\n lastDiff: this.getQuery(queryId).getDiff(),\n });\n });\n }\n\n const results: InternalRefetchQueriesMap<TResult> = new Map;\n\n if (updateCache) {\n this.cache.batch({\n update: updateCache,\n\n // Since you can perform any combination of cache reads and/or writes in\n // the cache.batch update function, its optimistic option can be either\n // a boolean or a string, representing three distinct modes of\n // operation:\n //\n // * false: read/write only the root layer\n // * true: read/write the topmost layer\n // * string: read/write a fresh optimistic layer with that ID string\n //\n // When typeof optimistic === \"string\", a new optimistic layer will be\n // temporarily created within cache.batch with that string as its ID. If\n // we then pass that same string as the removeOptimistic option, we can\n // make cache.batch immediately remove the optimistic layer after\n // running the updateCache function, triggering only one broadcast.\n //\n // However, the refetchQueries method accepts only true or false for its\n // optimistic option (not string). We interpret true to mean a temporary\n // optimistic layer should be created, to allow efficiently rolling back\n // the effect of the updateCache function, which involves passing a\n // string instead of true as the optimistic option to cache.batch, when\n // refetchQueries receives optimistic: true.\n //\n // In other words, we are deliberately not supporting the use case of\n // writing to an *existing* optimistic layer (using the refetchQueries\n // updateCache function), since that would potentially interfere with\n // other optimistic updates in progress. Instead, you can read/write\n // only the root layer by passing optimistic: false to refetchQueries,\n // or you can read/write a brand new optimistic layer that will be\n // automatically removed by passing optimistic: true.\n optimistic: optimistic && removeOptimistic || false,\n\n // The removeOptimistic option can also be provided by itself, even if\n // optimistic === false, to remove some previously-added optimistic\n // layer safely and efficiently, like we do in markMutationResult.\n //\n // If an explicit removeOptimistic string is provided with optimistic:\n // true, the removeOptimistic string will determine the ID of the\n // temporary optimistic layer, in case that ever matters.\n removeOptimistic,\n\n onWatchUpdated(watch, diff, lastDiff) {\n const oq =\n watch.watcher instanceof QueryInfo &&\n watch.watcher.observableQuery;\n\n if (oq) {\n if (onQueryUpdated) {\n // Since we're about to handle this query now, remove it from\n // includedQueriesById, in case it was added earlier because of\n // options.include.\n includedQueriesById.delete(oq.queryId);\n\n let result: TResult | boolean | Promise<ApolloQueryResult<any>> =\n onQueryUpdated(oq, diff, lastDiff);\n\n if (result === true) {\n // The onQueryUpdated function requested the default refetching\n // behavior by returning true.\n result = oq.refetch();\n }\n\n // Record the result in the results Map, as long as onQueryUpdated\n // did not return false to skip/ignore this result.\n if (result !== false) {\n results.set(oq, result as InternalRefetchQueriesResult<TResult>);\n }\n\n // Allow the default cache broadcast to happen, except when\n // onQueryUpdated returns false.\n return result;\n }\n\n if (onQueryUpdated !== null) {\n // If we don't have an onQueryUpdated function, and onQueryUpdated\n // was not disabled by passing null, make sure this query is\n // \"included\" like any other options.include-specified query.\n includedQueriesById.set(oq.queryId, { oq, lastDiff, diff });\n }\n }\n },\n });\n }\n\n if (includedQueriesById.size) {\n includedQueriesById.forEach(({ oq, lastDiff, diff }, queryId) => {\n let result: TResult | boolean | Promise<ApolloQueryResult<any>> | undefined;\n\n // If onQueryUpdated is provided, we want to use it for all included\n // queries, even the QueryOptions ones.\n if (onQueryUpdated) {\n if (!diff) {\n const info = oq[\"queryInfo\"];\n info.reset(); // Force info.getDiff() to read from cache.\n diff = info.getDiff();\n }\n result = onQueryUpdated(oq, diff, lastDiff);\n }\n\n // Otherwise, we fall back to refetching.\n if (!onQueryUpdated || result === true) {\n result = oq.refetch();\n }\n\n if (result !== false) {\n results.set(oq, result as InternalRefetchQueriesResult<TResult>);\n }\n\n if (queryId.indexOf(\"legacyOneTimeQuery\") >= 0) {\n this.stopQueryNoBroadcast(queryId);\n }\n });\n }\n\n if (removeOptimistic) {\n // In case no updateCache callback was provided (so cache.batch was not\n // called above, and thus did not already remove the optimistic layer),\n // remove it here. Since this is a no-op when the layer has already been\n // removed, we do it even if we called cache.batch above, since it's\n // possible this.cache is an instance of some ApolloCache subclass other\n // than InMemoryCache, and does not fully support the removeOptimistic\n // option for cache.batch.\n this.cache.removeOptimistic(removeOptimistic);\n }\n\n return results;\n }\n\n private fetchQueryByPolicy<TData, TVars>(\n queryInfo: QueryInfo,\n { query,\n variables,\n fetchPolicy,\n refetchWritePolicy,\n errorPolicy,\n returnPartialData,\n context,\n notifyOnNetworkStatusChange,\n }: WatchQueryOptions<TVars, TData>,\n // The initial networkStatus for this fetch, most often\n // NetworkStatus.loading, but also possibly fetchMore, poll, refetch,\n // or setVariables.\n networkStatus: NetworkStatus,\n ): ConcastSourcesArray<ApolloQueryResult<TData>> {\n const oldNetworkStatus = queryInfo.networkStatus;\n\n queryInfo.init({\n document: this.transform(query).document,\n variables,\n networkStatus,\n });\n\n const readCache = () => queryInfo.getDiff(variables);\n\n const resultsFromCache = (\n diff: Cache.DiffResult<TData>,\n networkStatus = queryInfo.networkStatus || NetworkStatus.loading,\n ) => {\n const data = diff.result;\n\n if (__DEV__ &&\n !returnPartialData &&\n !equal(data, {})) {\n logMissingFieldErrors(diff.missing);\n }\n\n const fromData = (data: TData | undefined) => Observable.of({\n data,\n loading: isNetworkRequestInFlight(networkStatus),\n networkStatus,\n ...(diff.complete ? null : { partial: true }),\n } as ApolloQueryResult<TData>);\n\n if (data && this.transform(query).hasForcedResolvers) {\n return this.localState.runResolvers({\n document: query,\n remoteResult: { data },\n context,\n variables,\n onlyRunForcedResolvers: true,\n }).then(resolved => fromData(resolved.data || void 0));\n }\n\n return fromData(data);\n };\n\n const cacheWriteBehavior =\n fetchPolicy === \"no-cache\" ? CacheWriteBehavior.FORBID :\n ( // Watched queries must opt into overwriting existing data on refetch,\n // by passing refetchWritePolicy: \"overwrite\" in their WatchQueryOptions.\n networkStatus === NetworkStatus.refetch &&\n refetchWritePolicy !== \"merge\"\n ) ? CacheWriteBehavior.OVERWRITE\n : CacheWriteBehavior.MERGE;\n\n const resultsFromLink = () => this.getResultsFromLink<TData, TVars>(\n queryInfo,\n cacheWriteBehavior,\n {\n variables,\n context,\n fetchPolicy,\n errorPolicy,\n },\n );\n\n const shouldNotify =\n notifyOnNetworkStatusChange &&\n typeof oldNetworkStatus === \"number\" &&\n oldNetworkStatus !== networkStatus &&\n isNetworkRequestInFlight(networkStatus);\n\n switch (fetchPolicy) {\n default: case \"cache-first\": {\n const diff = readCache();\n\n if (diff.complete) {\n return [\n resultsFromCache(diff, queryInfo.markReady()),\n ];\n }\n\n if (returnPartialData || shouldNotify) {\n return [\n resultsFromCache(diff),\n resultsFromLink(),\n ];\n }\n\n return [\n resultsFromLink(),\n ];\n }\n\n case \"cache-and-network\": {\n const diff = readCache();\n\n if (diff.complete || returnPartialData || shouldNotify) {\n return [\n resultsFromCache(diff),\n resultsFromLink(),\n ];\n }\n\n return [\n resultsFromLink(),\n ];\n }\n\n case \"cache-only\":\n return [\n resultsFromCache(readCache(), queryInfo.markReady()),\n ];\n\n case \"network-only\":\n if (shouldNotify) {\n return [\n resultsFromCache(readCache()),\n resultsFromLink(),\n ];\n }\n\n return [resultsFromLink()];\n\n case \"no-cache\":\n if (shouldNotify) {\n return [\n // Note that queryInfo.getDiff() for no-cache queries does not call\n // cache.diff, but instead returns a { complete: false } stub result\n // when there is no queryInfo.diff already defined.\n resultsFromCache(queryInfo.getDiff()),\n resultsFromLink(),\n ];\n }\n\n return [resultsFromLink()];\n\n case \"standby\":\n return [];\n }\n }\n\n private getQuery(queryId: string): QueryInfo {\n if (queryId && !this.queries.has(queryId)) {\n this.queries.set(queryId, new QueryInfo(this, queryId));\n }\n return this.queries.get(queryId)!;\n }\n\n private prepareContext(context = {}) {\n const newContext = this.localState.prepareContext(context);\n return {\n ...newContext,\n clientAwareness: this.clientAwareness,\n };\n }\n}\n","import { invariant, InvariantError } from '../utilities/globals';\n\nimport { ExecutionResult, DocumentNode } from 'graphql';\n\nimport { ApolloLink, FetchResult, GraphQLRequest, execute } from '../link/core';\nimport { ApolloCache, DataProxy } from '../cache';\nimport { Observable } from '../utilities';\nimport { version } from '../version';\nimport { HttpLink, UriFunction } from '../link/http';\n\nimport { QueryManager } from './QueryManager';\nimport { ObservableQuery } from './ObservableQuery';\n\nimport {\n ApolloQueryResult,\n DefaultContext,\n OperationVariables,\n Resolvers,\n RefetchQueriesOptions,\n RefetchQueriesResult,\n InternalRefetchQueriesResult,\n RefetchQueriesInclude,\n} from './types';\n\nimport {\n QueryOptions,\n WatchQueryOptions,\n MutationOptions,\n SubscriptionOptions,\n WatchQueryFetchPolicy,\n} from './watchQueryOptions';\n\nimport {\n LocalState,\n FragmentMatcher,\n} from './LocalState';\n\nexport interface DefaultOptions {\n watchQuery?: Partial<WatchQueryOptions<any, any>>;\n query?: Partial<QueryOptions<any, any>>;\n mutate?: Partial<MutationOptions<any, any, any>>;\n}\n\nlet hasSuggestedDevtools = false;\n\nexport type ApolloClientOptions<TCacheShape> = {\n uri?: string | UriFunction;\n credentials?: string;\n headers?: Record<string, string>;\n link?: ApolloLink;\n cache: ApolloCache<TCacheShape>;\n ssrForceFetchDelay?: number;\n ssrMode?: boolean;\n connectToDevTools?: boolean;\n queryDeduplication?: boolean;\n defaultOptions?: DefaultOptions;\n assumeImmutableResults?: boolean;\n resolvers?: Resolvers | Resolvers[];\n typeDefs?: string | string[] | DocumentNode | DocumentNode[];\n fragmentMatcher?: FragmentMatcher;\n name?: string;\n version?: string;\n};\n\n// Though mergeOptions now resides in @apollo/client/utilities, it was\n// previously declared and exported from this module, and then reexported from\n// @apollo/client/core. Since we need to preserve that API anyway, the easiest\n// solution is to reexport mergeOptions where it was previously declared (here).\nimport { mergeOptions } from \"../utilities\";\nexport { mergeOptions }\n\n/**\n * This is the primary Apollo Client class. It is used to send GraphQL documents (i.e. queries\n * and mutations) to a GraphQL spec-compliant server over a {@link NetworkInterface} instance,\n * receive results from the server and cache the results in a store. It also delivers updates\n * to GraphQL queries through {@link Observable} instances.\n */\nexport class ApolloClient<TCacheShape> implements DataProxy {\n public link: ApolloLink;\n public cache: ApolloCache<TCacheShape>;\n public disableNetworkFetches: boolean;\n public version: string;\n public queryDeduplication: boolean;\n public defaultOptions: DefaultOptions;\n public readonly typeDefs: ApolloClientOptions<TCacheShape>['typeDefs'];\n\n private queryManager: QueryManager<TCacheShape>;\n private devToolsHookCb: Function;\n private resetStoreCallbacks: Array<() => Promise<any>> = [];\n private clearStoreCallbacks: Array<() => Promise<any>> = [];\n private localState: LocalState<TCacheShape>;\n\n /**\n * Constructs an instance of {@link ApolloClient}.\n *\n * @param uri The GraphQL endpoint that Apollo Client will connect to. If\n * `link` is configured, this option is ignored.\n * @param link The {@link ApolloLink} over which GraphQL documents will be resolved into a response.\n *\n * @param cache The initial cache to use in the data store.\n *\n * @param ssrMode Determines whether this is being run in Server Side Rendering (SSR) mode.\n *\n * @param ssrForceFetchDelay Determines the time interval before we force fetch queries for a\n * server side render.\n *\n * @param queryDeduplication If set to false, a query will still be sent to the server even if a query\n * with identical parameters (query, variables, operationName) is already in flight.\n *\n * @param defaultOptions Used to set application wide defaults for the\n * options supplied to `watchQuery`, `query`, or\n * `mutate`.\n *\n * @param assumeImmutableResults When this option is true, the client will assume results\n * read from the cache are never mutated by application code,\n * which enables substantial performance optimizations.\n *\n * @param name A custom name that can be used to identify this client, when\n * using Apollo client awareness features. E.g. \"iOS\".\n *\n * @param version A custom version that can be used to identify this client,\n * when using Apollo client awareness features. This is the\n * version of your client, which you may want to increment on\n * new builds. This is NOT the version of Apollo Client that\n * you are using.\n */\n constructor(options: ApolloClientOptions<TCacheShape>) {\n const {\n uri,\n credentials,\n headers,\n cache,\n ssrMode = false,\n ssrForceFetchDelay = 0,\n connectToDevTools =\n // Expose the client instance as window.__APOLLO_CLIENT__ and call\n // onBroadcast in queryManager.broadcastQueries to enable browser\n // devtools, but disable them by default in production.\n typeof window === 'object' &&\n !(window as any).__APOLLO_CLIENT__ &&\n __DEV__,\n queryDeduplication = true,\n defaultOptions,\n assumeImmutableResults = false,\n resolvers,\n typeDefs,\n fragmentMatcher,\n name: clientAwarenessName,\n version: clientAwarenessVersion,\n } = options;\n\n let { link } = options;\n\n if (!link) {\n link = uri\n ? new HttpLink({ uri, credentials, headers })\n : ApolloLink.empty();\n }\n\n if (!cache) {\n throw new InvariantError(\n \"To initialize Apollo Client, you must specify a 'cache' property \" +\n \"in the options object. \\n\" +\n \"For more information, please visit: https://go.apollo.dev/c/docs\"\n );\n }\n\n this.link = link;\n this.cache = cache;\n this.disableNetworkFetches = ssrMode || ssrForceFetchDelay > 0;\n this.queryDeduplication = queryDeduplication;\n this.defaultOptions = defaultOptions || Object.create(null);\n this.typeDefs = typeDefs;\n\n if (ssrForceFetchDelay) {\n setTimeout(\n () => (this.disableNetworkFetches = false),\n ssrForceFetchDelay,\n );\n }\n\n this.watchQuery = this.watchQuery.bind(this);\n this.query = this.query.bind(this);\n this.mutate = this.mutate.bind(this);\n this.resetStore = this.resetStore.bind(this);\n this.reFetchObservableQueries = this.reFetchObservableQueries.bind(this);\n\n if (connectToDevTools && typeof window === 'object') {\n (window as any).__APOLLO_CLIENT__ = this;\n }\n\n /**\n * Suggest installing the devtools for developers who don't have them\n */\n if (!hasSuggestedDevtools && __DEV__) {\n hasSuggestedDevtools = true;\n if (\n typeof window !== 'undefined' &&\n window.document &&\n window.top === window.self &&\n !(window as any).__APOLLO_DEVTOOLS_GLOBAL_HOOK__\n ) {\n const nav = window.navigator;\n const ua = nav && nav.userAgent;\n let url: string | undefined;\n if (typeof ua === \"string\") {\n if (ua.indexOf(\"Chrome/\") > -1) {\n url = \"https://chrome.google.com/webstore/detail/\" +\n \"apollo-client-developer-t/jdkknkkbebbapilgoeccciglkfbmbnfm\";\n } else if (ua.indexOf(\"Firefox/\") > -1) {\n url = \"https://addons.mozilla.org/en-US/firefox/addon/apollo-developer-tools/\";\n }\n }\n if (url) {\n invariant.log(\n \"Download the Apollo DevTools for a better development \" +\n \"experience: \" + url\n );\n }\n }\n }\n\n this.version = version;\n\n this.localState = new LocalState({\n cache,\n client: this,\n resolvers,\n fragmentMatcher,\n });\n\n this.queryManager = new QueryManager({\n cache: this.cache,\n link: this.link,\n defaultOptions: this.defaultOptions,\n queryDeduplication,\n ssrMode,\n clientAwareness: {\n name: clientAwarenessName!,\n version: clientAwarenessVersion!,\n },\n localState: this.localState,\n assumeImmutableResults,\n onBroadcast: connectToDevTools ? () => {\n if (this.devToolsHookCb) {\n this.devToolsHookCb({\n action: {},\n state: {\n queries: this.queryManager.getQueryStore(),\n mutations: this.queryManager.mutationStore || {},\n },\n dataWithOptimisticResults: this.cache.extract(true),\n });\n }\n } : void 0,\n });\n }\n\n /**\n * Call this method to terminate any active client processes, making it safe\n * to dispose of this `ApolloClient` instance.\n */\n public stop() {\n this.queryManager.stop();\n }\n\n /**\n * This watches the cache store of the query according to the options specified and\n * returns an {@link ObservableQuery}. We can subscribe to this {@link ObservableQuery} and\n * receive updated results through a GraphQL observer when the cache store changes.\n *\n * Note that this method is not an implementation of GraphQL subscriptions. Rather,\n * it uses Apollo's store in order to reactively deliver updates to your query results.\n *\n * For example, suppose you call watchQuery on a GraphQL query that fetches a person's\n * first and last name and this person has a particular object identifier, provided by\n * dataIdFromObject. Later, a different query fetches that same person's\n * first and last name and the first name has now changed. Then, any observers associated\n * with the results of the first query will be updated with a new result object.\n *\n * Note that if the cache does not change, the subscriber will *not* be notified.\n *\n * See [here](https://medium.com/apollo-stack/the-concepts-of-graphql-bc68bd819be3#.3mb0cbcmc) for\n * a description of store reactivity.\n */\n public watchQuery<T = any, TVariables = OperationVariables>(\n options: WatchQueryOptions<TVariables, T>,\n ): ObservableQuery<T, TVariables> {\n if (this.defaultOptions.watchQuery) {\n options = mergeOptions(this.defaultOptions.watchQuery, options);\n }\n\n // XXX Overwriting options is probably not the best way to do this long term...\n if (\n this.disableNetworkFetches &&\n (options.fetchPolicy === 'network-only' ||\n options.fetchPolicy === 'cache-and-network')\n ) {\n options = { ...options, fetchPolicy: 'cache-first' };\n }\n\n return this.queryManager.watchQuery<T, TVariables>(options);\n }\n\n /**\n * This resolves a single query according to the options specified and\n * returns a {@link Promise} which is either resolved with the resulting data\n * or rejected with an error.\n *\n * @param options An object of type {@link QueryOptions} that allows us to\n * describe how this query should be treated e.g. whether it should hit the\n * server at all or just resolve from the cache, etc.\n */\n public query<T = any, TVariables = OperationVariables>(\n options: QueryOptions<TVariables, T>,\n ): Promise<ApolloQueryResult<T>> {\n if (this.defaultOptions.query) {\n options = mergeOptions(this.defaultOptions.query, options);\n }\n\n invariant(\n (options.fetchPolicy as WatchQueryFetchPolicy) !== 'cache-and-network',\n 'The cache-and-network fetchPolicy does not work with client.query, because ' +\n 'client.query can only return a single result. Please use client.watchQuery ' +\n 'to receive multiple results from the cache and the network, or consider ' +\n 'using a different fetchPolicy, such as cache-first or network-only.'\n );\n\n if (this.disableNetworkFetches && options.fetchPolicy === 'network-only') {\n options = { ...options, fetchPolicy: 'cache-first' };\n }\n\n return this.queryManager.query<T, TVariables>(options);\n }\n\n /**\n * This resolves a single mutation according to the options specified and returns a\n * {@link Promise} which is either resolved with the resulting data or rejected with an\n * error.\n *\n * It takes options as an object with the following keys and values:\n */\n public mutate<\n TData = any,\n TVariables = OperationVariables,\n TContext = DefaultContext,\n TCache extends ApolloCache<any> = ApolloCache<any>\n >(\n options: MutationOptions<TData, TVariables, TContext>,\n ): Promise<FetchResult<TData>> {\n if (this.defaultOptions.mutate) {\n options = mergeOptions(this.defaultOptions.mutate, options);\n }\n return this.queryManager.mutate<TData, TVariables, TContext, TCache>(options);\n }\n\n /**\n * This subscribes to a graphql subscription according to the options specified and returns an\n * {@link Observable} which either emits received data or an error.\n */\n public subscribe<T = any, TVariables = OperationVariables>(\n options: SubscriptionOptions<TVariables, T>,\n ): Observable<FetchResult<T>> {\n return this.queryManager.startGraphQLSubscription<T>(options);\n }\n\n /**\n * Tries to read some data from the store in the shape of the provided\n * GraphQL query without making a network request. This method will start at\n * the root query. To start at a specific id returned by `dataIdFromObject`\n * use `readFragment`.\n *\n * @param optimistic Set to `true` to allow `readQuery` to return\n * optimistic results. Is `false` by default.\n */\n public readQuery<T = any, TVariables = OperationVariables>(\n options: DataProxy.Query<TVariables, T>,\n optimistic: boolean = false,\n ): T | null {\n return this.cache.readQuery<T, TVariables>(options, optimistic);\n }\n\n /**\n * Tries to read some data from the store in the shape of the provided\n * GraphQL fragment without making a network request. This method will read a\n * GraphQL fragment from any arbitrary id that is currently cached, unlike\n * `readQuery` which will only read from the root query.\n *\n * You must pass in a GraphQL document with a single fragment or a document\n * with multiple fragments that represent what you are reading. If you pass\n * in a document with multiple fragments then you must also specify a\n * `fragmentName`.\n *\n * @param optimistic Set to `true` to allow `readFragment` to return\n * optimistic results. Is `false` by default.\n */\n public readFragment<T = any, TVariables = OperationVariables>(\n options: DataProxy.Fragment<TVariables, T>,\n optimistic: boolean = false,\n ): T | null {\n return this.cache.readFragment<T, TVariables>(options, optimistic);\n }\n\n /**\n * Writes some data in the shape of the provided GraphQL query directly to\n * the store. This method will start at the root query. To start at a\n * specific id returned by `dataIdFromObject` then use `writeFragment`.\n */\n public writeQuery<TData = any, TVariables = OperationVariables>(\n options: DataProxy.WriteQueryOptions<TData, TVariables>,\n ): void {\n this.cache.writeQuery<TData, TVariables>(options);\n this.queryManager.broadcastQueries();\n }\n\n /**\n * Writes some data in the shape of the provided GraphQL fragment directly to\n * the store. This method will write to a GraphQL fragment from any arbitrary\n * id that is currently cached, unlike `writeQuery` which will only write\n * from the root query.\n *\n * You must pass in a GraphQL document with a single fragment or a document\n * with multiple fragments that represent what you are writing. If you pass\n * in a document with multiple fragments then you must also specify a\n * `fragmentName`.\n */\n public writeFragment<TData = any, TVariables = OperationVariables>(\n options: DataProxy.WriteFragmentOptions<TData, TVariables>,\n ): void {\n this.cache.writeFragment<TData, TVariables>(options);\n this.queryManager.broadcastQueries();\n }\n\n public __actionHookForDevTools(cb: () => any) {\n this.devToolsHookCb = cb;\n }\n\n public __requestRaw(payload: GraphQLRequest): Observable<ExecutionResult> {\n return execute(this.link, payload);\n }\n\n /**\n * Resets your entire store by clearing out your cache and then re-executing\n * all of your active queries. This makes it so that you may guarantee that\n * there is no data left in your store from a time before you called this\n * method.\n *\n * `resetStore()` is useful when your user just logged out. You’ve removed the\n * user session, and you now want to make sure that any references to data you\n * might have fetched while the user session was active is gone.\n *\n * It is important to remember that `resetStore()` *will* refetch any active\n * queries. This means that any components that might be mounted will execute\n * their queries again using your network interface. If you do not want to\n * re-execute any queries then you should make sure to stop watching any\n * active queries.\n */\n public resetStore(): Promise<ApolloQueryResult<any>[] | null> {\n return Promise.resolve()\n .then(() => this.queryManager.clearStore({\n discardWatches: false,\n }))\n .then(() => Promise.all(this.resetStoreCallbacks.map(fn => fn())))\n .then(() => this.reFetchObservableQueries());\n }\n\n /**\n * Remove all data from the store. Unlike `resetStore`, `clearStore` will\n * not refetch any active queries.\n */\n public clearStore(): Promise<any[]> {\n return Promise.resolve()\n .then(() => this.queryManager.clearStore({\n discardWatches: true,\n }))\n .then(() => Promise.all(this.clearStoreCallbacks.map(fn => fn())));\n }\n\n /**\n * Allows callbacks to be registered that are executed when the store is\n * reset. `onResetStore` returns an unsubscribe function that can be used\n * to remove registered callbacks.\n */\n public onResetStore(cb: () => Promise<any>): () => void {\n this.resetStoreCallbacks.push(cb);\n return () => {\n this.resetStoreCallbacks = this.resetStoreCallbacks.filter(c => c !== cb);\n };\n }\n\n /**\n * Allows callbacks to be registered that are executed when the store is\n * cleared. `onClearStore` returns an unsubscribe function that can be used\n * to remove registered callbacks.\n */\n public onClearStore(cb: () => Promise<any>): () => void {\n this.clearStoreCallbacks.push(cb);\n return () => {\n this.clearStoreCallbacks = this.clearStoreCallbacks.filter(c => c !== cb);\n };\n }\n\n /**\n * Refetches all of your active queries.\n *\n * `reFetchObservableQueries()` is useful if you want to bring the client back to proper state in case of a network outage\n *\n * It is important to remember that `reFetchObservableQueries()` *will* refetch any active\n * queries. This means that any components that might be mounted will execute\n * their queries again using your network interface. If you do not want to\n * re-execute any queries then you should make sure to stop watching any\n * active queries.\n * Takes optional parameter `includeStandby` which will include queries in standby-mode when refetching.\n */\n public reFetchObservableQueries(\n includeStandby?: boolean,\n ): Promise<ApolloQueryResult<any>[]> {\n return this.queryManager.reFetchObservableQueries(includeStandby);\n }\n\n /**\n * Refetches specified active queries. Similar to \"reFetchObservableQueries()\" but with a specific list of queries.\n *\n * `refetchQueries()` is useful for use cases to imperatively refresh a selection of queries.\n *\n * It is important to remember that `refetchQueries()` *will* refetch specified active\n * queries. This means that any components that might be mounted will execute\n * their queries again using your network interface. If you do not want to\n * re-execute any queries then you should make sure to stop watching any\n * active queries.\n */\n public refetchQueries<\n TCache extends ApolloCache<any> = ApolloCache<TCacheShape>,\n TResult = Promise<ApolloQueryResult<any>>,\n >(\n options: RefetchQueriesOptions<TCache, TResult>,\n ): RefetchQueriesResult<TResult> {\n const map = this.queryManager.refetchQueries(options);\n const queries: ObservableQuery<any>[] = [];\n const results: InternalRefetchQueriesResult<TResult>[] = [];\n\n map.forEach((result, obsQuery) => {\n queries.push(obsQuery);\n results.push(result);\n });\n\n const result = Promise.all<TResult>(\n results as TResult[]\n ) as RefetchQueriesResult<TResult>;\n\n // In case you need the raw results immediately, without awaiting\n // Promise.all(results):\n result.queries = queries;\n result.results = results;\n\n // If you decide to ignore the result Promise because you're using\n // result.queries and result.results instead, you shouldn't have to worry\n // about preventing uncaught rejections for the Promise.all result.\n result.catch(error => {\n invariant.debug(`In client.refetchQueries, Promise.all promise rejected with error ${error}`);\n });\n\n return result;\n }\n\n /**\n * Get all currently active `ObservableQuery` objects, in a `Map` keyed by\n * query ID strings. An \"active\" query is one that has observers and a\n * `fetchPolicy` other than \"standby\" or \"cache-only\". You can include all\n * `ObservableQuery` objects (including the inactive ones) by passing \"all\"\n * instead of \"active\", or you can include just a subset of active queries by\n * passing an array of query names or DocumentNode objects.\n */\n public getObservableQueries(\n include: RefetchQueriesInclude = \"active\",\n ): Map<string, ObservableQuery<any>> {\n return this.queryManager.getObservableQueries(include);\n }\n\n /**\n * Exposes the cache's complete state, in a serializable format for later restoration.\n */\n public extract(optimistic?: boolean): TCacheShape {\n return this.cache.extract(optimistic);\n }\n\n /**\n * Replaces existing state in the cache (if any) with the values expressed by\n * `serializedState`.\n *\n * Called when hydrating a cache (server side rendering, or offline storage),\n * and also (potentially) during hot reloads.\n */\n public restore(serializedState: TCacheShape): ApolloCache<TCacheShape> {\n return this.cache.restore(serializedState);\n }\n\n /**\n * Add additional local resolvers.\n */\n public addResolvers(resolvers: Resolvers | Resolvers[]) {\n this.localState.addResolvers(resolvers);\n }\n\n /**\n * Set (override existing) local resolvers.\n */\n public setResolvers(resolvers: Resolvers | Resolvers[]) {\n this.localState.setResolvers(resolvers);\n }\n\n /**\n * Get all registered local resolvers.\n */\n public getResolvers() {\n return this.localState.getResolvers();\n }\n\n /**\n * Set a custom local state fragment matcher.\n */\n public setLocalStateFragmentMatcher(fragmentMatcher: FragmentMatcher) {\n this.localState.setFragmentMatcher(fragmentMatcher);\n }\n\n /**\n * Define a new ApolloLink (or link chain) that Apollo Client will use.\n */\n public setLink(newLink: ApolloLink) {\n this.link = this.queryManager.link = newLink;\n }\n}\n","export const version = 'local';\n","import { DocumentNode } from 'graphql';\nimport { wrap } from 'optimism';\n\nimport {\n StoreObject,\n Reference,\n getFragmentQueryDocument,\n} from '../../utilities';\nimport { DataProxy } from './types/DataProxy';\nimport { Cache } from './types/Cache';\n\nexport type Transaction<T> = (c: ApolloCache<T>) => void;\n\nexport abstract class ApolloCache<TSerialized> implements DataProxy {\n // required to implement\n // core API\n public abstract read<TData = any, TVariables = any>(\n query: Cache.ReadOptions<TVariables, TData>,\n ): TData | null;\n public abstract write<TData = any, TVariables = any>(\n write: Cache.WriteOptions<TData, TVariables>,\n ): Reference | undefined;\n public abstract diff<T>(query: Cache.DiffOptions): Cache.DiffResult<T>;\n public abstract watch<TData = any, TVariables = any>(\n watch: Cache.WatchOptions<TData, TVariables>,\n ): () => void;\n\n // Empty the cache and restart all current watches (unless\n // options.discardWatches is true).\n public abstract reset(options?: Cache.ResetOptions): Promise<void>;\n\n // Remove whole objects from the cache by passing just options.id, or\n // specific fields by passing options.field and/or options.args. If no\n // options.args are provided, all fields matching options.field (even\n // those with arguments) will be removed. Returns true iff any data was\n // removed from the cache.\n public abstract evict(options: Cache.EvictOptions): boolean;\n\n // initializer / offline / ssr API\n /**\n * Replaces existing state in the cache (if any) with the values expressed by\n * `serializedState`.\n *\n * Called when hydrating a cache (server side rendering, or offline storage),\n * and also (potentially) during hot reloads.\n */\n public abstract restore(\n serializedState: TSerialized,\n ): ApolloCache<TSerialized>;\n\n /**\n * Exposes the cache's complete state, in a serializable format for later restoration.\n */\n public abstract extract(optimistic?: boolean): TSerialized;\n\n // Optimistic API\n\n public abstract removeOptimistic(id: string): void;\n\n // Transactional API\n\n // The batch method is intended to replace/subsume both performTransaction\n // and recordOptimisticTransaction, but performTransaction came first, so we\n // provide a default batch implementation that's just another way of calling\n // performTransaction. Subclasses of ApolloCache (such as InMemoryCache) can\n // override the batch method to do more interesting things with its options.\n public batch<U>(options: Cache.BatchOptions<this, U>): U {\n const optimisticId =\n typeof options.optimistic === \"string\" ? options.optimistic :\n options.optimistic === false ? null : void 0;\n let updateResult: U;\n this.performTransaction(\n () => updateResult = options.update(this),\n optimisticId,\n );\n return updateResult!;\n }\n\n public abstract performTransaction(\n transaction: Transaction<TSerialized>,\n // Although subclasses may implement recordOptimisticTransaction\n // however they choose, the default implementation simply calls\n // performTransaction with a string as the second argument, allowing\n // performTransaction to handle both optimistic and non-optimistic\n // (broadcast-batching) transactions. Passing null for optimisticId is\n // also allowed, and indicates that performTransaction should apply\n // the transaction non-optimistically (ignoring optimistic data).\n optimisticId?: string | null,\n ): void;\n\n public recordOptimisticTransaction(\n transaction: Transaction<TSerialized>,\n optimisticId: string,\n ) {\n this.performTransaction(transaction, optimisticId);\n }\n\n // Optional API\n\n public transformDocument(document: DocumentNode): DocumentNode {\n return document;\n }\n\n public identify(object: StoreObject | Reference): string | undefined {\n return;\n }\n\n public gc(): string[] {\n return [];\n }\n\n public modify(options: Cache.ModifyOptions): boolean {\n return false;\n }\n\n // Experimental API\n\n public transformForLink(document: DocumentNode): DocumentNode {\n return document;\n }\n\n // DataProxy API\n /**\n *\n * @param options\n * @param optimistic\n */\n public readQuery<QueryType, TVariables = any>(\n options: Cache.ReadQueryOptions<QueryType, TVariables>,\n optimistic = !!options.optimistic,\n ): QueryType | null {\n return this.read({\n ...options,\n rootId: options.id || 'ROOT_QUERY',\n optimistic,\n });\n }\n\n // Make sure we compute the same (===) fragment query document every\n // time we receive the same fragment in readFragment.\n private getFragmentDoc = wrap(getFragmentQueryDocument);\n\n public readFragment<FragmentType, TVariables = any>(\n options: Cache.ReadFragmentOptions<FragmentType, TVariables>,\n optimistic = !!options.optimistic,\n ): FragmentType | null {\n return this.read({\n ...options,\n query: this.getFragmentDoc(options.fragment, options.fragmentName),\n rootId: options.id,\n optimistic,\n });\n }\n\n public writeQuery<TData = any, TVariables = any>({\n id,\n data,\n ...options\n }: Cache.WriteQueryOptions<TData, TVariables>): Reference | undefined {\n return this.write(Object.assign(options, {\n dataId: id || 'ROOT_QUERY',\n result: data,\n }));\n }\n\n public writeFragment<TData = any, TVariables = any>({\n id,\n data,\n fragment,\n fragmentName,\n ...options\n }: Cache.WriteFragmentOptions<TData, TVariables>): Reference | undefined {\n return this.write(Object.assign(options, {\n query: this.getFragmentDoc(fragment, fragmentName),\n dataId: id,\n result: data,\n }));\n }\n\n public updateQuery<TData = any, TVariables = any>(\n options: Cache.UpdateQueryOptions<TData, TVariables>,\n update: (data: TData | null) => TData | null | void,\n ): TData | null {\n return this.batch({\n update(cache) {\n const value = cache.readQuery<TData, TVariables>(options);\n const data = update(value);\n if (data === void 0 || data === null) return value;\n cache.writeQuery<TData, TVariables>({ ...options, data });\n return data;\n },\n });\n }\n\n public updateFragment<TData = any, TVariables = any>(\n options: Cache.UpdateFragmentOptions<TData, TVariables>,\n update: (data: TData | null) => TData | null | void,\n ): TData | null {\n return this.batch({\n update(cache) {\n const value = cache.readFragment<TData, TVariables>(options);\n const data = update(value);\n if (data === void 0 || data === null) return value;\n cache.writeFragment<TData, TVariables>({ ...options, data });\n return data;\n },\n });\n }\n}\n","import { DocumentNode, FieldNode } from 'graphql';\n\nimport {\n Reference,\n StoreObject,\n StoreValue,\n isReference,\n} from '../../../utilities';\n\nimport { StorageType } from '../../inmemory/policies';\n\n// The Readonly<T> type only really works for object types, since it marks\n// all of the object's properties as readonly, but there are many cases when\n// a generic type parameter like TExisting might be a string or some other\n// primitive type, in which case we need to avoid wrapping it with Readonly.\n// SafeReadonly<string> collapses to just string, which makes string\n// assignable to SafeReadonly<any>, whereas string is not assignable to\n// Readonly<any>, somewhat surprisingly.\nexport type SafeReadonly<T> = T extends object ? Readonly<T> : T;\n\nexport type MissingTree = string | {\n readonly [key: string]: MissingTree;\n};\n\nexport class MissingFieldError {\n constructor(\n public readonly message: string,\n public readonly path: MissingTree | Array<string | number>,\n public readonly query: DocumentNode,\n public readonly variables?: Record<string, any>,\n ) {}\n}\n\nexport interface FieldSpecifier {\n typename?: string;\n fieldName: string;\n field?: FieldNode;\n args?: Record<string, any>;\n variables?: Record<string, any>;\n}\n\nexport interface ReadFieldOptions extends FieldSpecifier {\n from?: StoreObject | Reference;\n}\n\nexport interface ReadFieldFunction {\n <V = StoreValue>(options: ReadFieldOptions): SafeReadonly<V> | undefined;\n <V = StoreValue>(\n fieldName: string,\n from?: StoreObject | Reference,\n ): SafeReadonly<V> | undefined;\n}\n\nexport type ToReferenceFunction = (\n objOrIdOrRef: StoreObject | string | Reference,\n mergeIntoStore?: boolean,\n) => Reference | undefined;\n\nexport type CanReadFunction = (value: StoreValue) => boolean;\n\nexport type Modifier<T> = (value: T, details: {\n DELETE: any;\n INVALIDATE: any;\n fieldName: string;\n storeFieldName: string;\n readField: ReadFieldFunction;\n canRead: CanReadFunction;\n isReference: typeof isReference;\n toReference: ToReferenceFunction;\n storage: StorageType;\n}) => T;\n\nexport type Modifiers = {\n [fieldName: string]: Modifier<any>;\n};\n","import { invariant } from '../../utilities/globals';\nimport { dep, OptimisticDependencyFunction } from 'optimism';\nimport { equal } from '@wry/equality';\nimport { Trie } from '@wry/trie';\n\nimport {\n isReference,\n StoreValue,\n StoreObject,\n Reference,\n makeReference,\n DeepMerger,\n maybeDeepFreeze,\n canUseWeakMap,\n isNonNullObject,\n} from '../../utilities';\nimport { NormalizedCache, NormalizedCacheObject } from './types';\nimport { hasOwn, fieldNameFromStoreName } from './helpers';\nimport { Policies, StorageType } from './policies';\nimport { Cache } from '../core/types/Cache';\nimport {\n SafeReadonly,\n Modifier,\n Modifiers,\n ReadFieldOptions,\n ToReferenceFunction,\n CanReadFunction,\n} from '../core/types/common';\n\nconst DELETE: any = Object.create(null);\nconst delModifier: Modifier<any> = () => DELETE;\nconst INVALIDATE: any = Object.create(null);\n\nexport abstract class EntityStore implements NormalizedCache {\n protected data: NormalizedCacheObject = Object.create(null);\n\n constructor(\n public readonly policies: Policies,\n public readonly group: CacheGroup,\n ) {}\n\n public abstract addLayer(\n layerId: string,\n replay: (layer: EntityStore) => any,\n ): Layer;\n\n public abstract removeLayer(layerId: string): EntityStore;\n\n // Although the EntityStore class is abstract, it contains concrete\n // implementations of the various NormalizedCache interface methods that\n // are inherited by the Root and Layer subclasses.\n\n public toObject(): NormalizedCacheObject {\n return { ...this.data };\n }\n\n public has(dataId: string): boolean {\n return this.lookup(dataId, true) !== void 0;\n }\n\n public get(dataId: string, fieldName: string): StoreValue {\n this.group.depend(dataId, fieldName);\n if (hasOwn.call(this.data, dataId)) {\n const storeObject = this.data[dataId];\n if (storeObject && hasOwn.call(storeObject, fieldName)) {\n return storeObject[fieldName];\n }\n }\n if (fieldName === \"__typename\" &&\n hasOwn.call(this.policies.rootTypenamesById, dataId)) {\n return this.policies.rootTypenamesById[dataId];\n }\n if (this instanceof Layer) {\n return this.parent.get(dataId, fieldName);\n }\n }\n\n protected lookup(dataId: string, dependOnExistence?: boolean): StoreObject | undefined {\n // The has method (above) calls lookup with dependOnExistence = true, so\n // that it can later be invalidated when we add or remove a StoreObject for\n // this dataId. Any consumer who cares about the contents of the StoreObject\n // should not rely on this dependency, since the contents could change\n // without the object being added or removed.\n if (dependOnExistence) this.group.depend(dataId, \"__exists\");\n\n if (hasOwn.call(this.data, dataId)) {\n return this.data[dataId];\n }\n\n if (this instanceof Layer) {\n return this.parent.lookup(dataId, dependOnExistence);\n }\n\n if (this.policies.rootTypenamesById[dataId]) {\n return Object.create(null);\n }\n }\n\n public merge(\n older: string | StoreObject,\n newer: StoreObject | string,\n ): void {\n let dataId: string | undefined;\n\n // Convert unexpected references to ID strings.\n if (isReference(older)) older = older.__ref;\n if (isReference(newer)) newer = newer.__ref;\n\n const existing: StoreObject | undefined =\n typeof older === \"string\"\n ? this.lookup(dataId = older)\n : older;\n\n const incoming: StoreObject | undefined =\n typeof newer === \"string\"\n ? this.lookup(dataId = newer)\n : newer;\n\n // If newer was a string ID, but that ID was not defined in this store,\n // then there are no fields to be merged, so we're done.\n if (!incoming) return;\n\n invariant(\n typeof dataId === \"string\",\n \"store.merge expects a string ID\",\n );\n\n const merged: StoreObject =\n new DeepMerger(storeObjectReconciler).merge(existing, incoming);\n\n // Even if merged === existing, existing may have come from a lower\n // layer, so we always need to set this.data[dataId] on this level.\n this.data[dataId] = merged;\n\n if (merged !== existing) {\n delete this.refs[dataId];\n if (this.group.caching) {\n const fieldsToDirty: Record<string, 1> = Object.create(null);\n\n // If we added a new StoreObject where there was previously none, dirty\n // anything that depended on the existence of this dataId, such as the\n // EntityStore#has method.\n if (!existing) fieldsToDirty.__exists = 1;\n\n // Now invalidate dependents who called getFieldValue for any fields\n // that are changing as a result of this merge.\n Object.keys(incoming).forEach(storeFieldName => {\n if (!existing || existing[storeFieldName] !== merged[storeFieldName]) {\n // Always dirty the full storeFieldName, which may include\n // serialized arguments following the fieldName prefix.\n fieldsToDirty[storeFieldName] = 1;\n\n // Also dirty fieldNameFromStoreName(storeFieldName) if it's\n // different from storeFieldName and this field does not have\n // keyArgs configured, because that means the cache can't make\n // any assumptions about how field values with the same field\n // name but different arguments might be interrelated, so it\n // must err on the side of invalidating all field values that\n // share the same short fieldName, regardless of arguments.\n const fieldName = fieldNameFromStoreName(storeFieldName);\n if (fieldName !== storeFieldName &&\n !this.policies.hasKeyArgs(merged.__typename, fieldName)) {\n fieldsToDirty[fieldName] = 1;\n }\n\n // If merged[storeFieldName] has become undefined, and this is the\n // Root layer, actually delete the property from the merged object,\n // which is guaranteed to have been created fresh in this method.\n if (merged[storeFieldName] === void 0 && !(this instanceof Layer)) {\n delete merged[storeFieldName];\n }\n }\n });\n\n if (fieldsToDirty.__typename &&\n !(existing && existing.__typename) &&\n // Since we return default root __typename strings\n // automatically from store.get, we don't need to dirty the\n // ROOT_QUERY.__typename field if merged.__typename is equal\n // to the default string (usually \"Query\").\n this.policies.rootTypenamesById[dataId] === merged.__typename) {\n delete fieldsToDirty.__typename;\n }\n\n Object.keys(fieldsToDirty).forEach(\n fieldName => this.group.dirty(dataId as string, fieldName));\n }\n }\n }\n\n public modify(\n dataId: string,\n fields: Modifier<any> | Modifiers,\n ): boolean {\n const storeObject = this.lookup(dataId);\n\n if (storeObject) {\n const changedFields: Record<string, any> = Object.create(null);\n let needToMerge = false;\n let allDeleted = true;\n\n const sharedDetails = {\n DELETE,\n INVALIDATE,\n isReference,\n toReference: this.toReference,\n canRead: this.canRead,\n readField: <V = StoreValue>(\n fieldNameOrOptions: string | ReadFieldOptions,\n from?: StoreObject | Reference,\n ) => this.policies.readField<V>(\n typeof fieldNameOrOptions === \"string\" ? {\n fieldName: fieldNameOrOptions,\n from: from || makeReference(dataId),\n } : fieldNameOrOptions,\n { store: this },\n ),\n };\n\n Object.keys(storeObject).forEach(storeFieldName => {\n const fieldName = fieldNameFromStoreName(storeFieldName);\n let fieldValue = storeObject[storeFieldName];\n if (fieldValue === void 0) return;\n const modify: Modifier<StoreValue> = typeof fields === \"function\"\n ? fields\n : fields[storeFieldName] || fields[fieldName];\n if (modify) {\n let newValue = modify === delModifier ? DELETE :\n modify(maybeDeepFreeze(fieldValue), {\n ...sharedDetails,\n fieldName,\n storeFieldName,\n storage: this.getStorage(dataId, storeFieldName),\n });\n if (newValue === INVALIDATE) {\n this.group.dirty(dataId, storeFieldName);\n } else {\n if (newValue === DELETE) newValue = void 0;\n if (newValue !== fieldValue) {\n changedFields[storeFieldName] = newValue;\n needToMerge = true;\n fieldValue = newValue;\n }\n }\n }\n if (fieldValue !== void 0) {\n allDeleted = false;\n }\n });\n\n if (needToMerge) {\n this.merge(dataId, changedFields);\n\n if (allDeleted) {\n if (this instanceof Layer) {\n this.data[dataId] = void 0;\n } else {\n delete this.data[dataId];\n }\n this.group.dirty(dataId, \"__exists\");\n }\n\n return true;\n }\n }\n\n return false;\n }\n\n // If called with only one argument, removes the entire entity\n // identified by dataId. If called with a fieldName as well, removes all\n // fields of that entity whose names match fieldName according to the\n // fieldNameFromStoreName helper function. If called with a fieldName\n // and variables, removes all fields of that entity whose names match fieldName\n // and whose arguments when cached exactly match the variables passed.\n public delete(\n dataId: string,\n fieldName?: string,\n args?: Record<string, any>,\n ) {\n const storeObject = this.lookup(dataId);\n if (storeObject) {\n const typename = this.getFieldValue<string>(storeObject, \"__typename\");\n const storeFieldName = fieldName && args\n ? this.policies.getStoreFieldName({ typename, fieldName, args })\n : fieldName;\n return this.modify(dataId, storeFieldName ? {\n [storeFieldName]: delModifier,\n } : delModifier);\n }\n return false;\n }\n\n public evict(\n options: Cache.EvictOptions,\n limit: EntityStore,\n ): boolean {\n let evicted = false;\n if (options.id) {\n if (hasOwn.call(this.data, options.id)) {\n evicted = this.delete(options.id, options.fieldName, options.args);\n }\n if (this instanceof Layer && this !== limit) {\n evicted = this.parent.evict(options, limit) || evicted;\n }\n // Always invalidate the field to trigger rereading of watched\n // queries, even if no cache data was modified by the eviction,\n // because queries may depend on computed fields with custom read\n // functions, whose values are not stored in the EntityStore.\n if (options.fieldName || evicted) {\n this.group.dirty(options.id, options.fieldName || \"__exists\");\n }\n }\n return evicted;\n }\n\n public clear(): void {\n this.replace(null);\n }\n\n public extract(): NormalizedCacheObject {\n const obj = this.toObject();\n const extraRootIds: string[] = [];\n this.getRootIdSet().forEach(id => {\n if (!hasOwn.call(this.policies.rootTypenamesById, id)) {\n extraRootIds.push(id);\n }\n });\n if (extraRootIds.length) {\n obj.__META = { extraRootIds: extraRootIds.sort() };\n }\n return obj;\n }\n\n public replace(newData: NormalizedCacheObject | null): void {\n Object.keys(this.data).forEach(dataId => {\n if (!(newData && hasOwn.call(newData, dataId))) {\n this.delete(dataId);\n }\n });\n if (newData) {\n const { __META, ...rest } = newData;\n Object.keys(rest).forEach(dataId => {\n this.merge(dataId, rest[dataId] as StoreObject);\n });\n if (__META) {\n __META.extraRootIds.forEach(this.retain, this);\n }\n }\n }\n\n public abstract getStorage(\n idOrObj: string | StoreObject,\n ...storeFieldNames: (string | number)[]\n ): StorageType;\n\n // Maps root entity IDs to the number of times they have been retained, minus\n // the number of times they have been released. Retained entities keep other\n // entities they reference (even indirectly) from being garbage collected.\n private rootIds: {\n [rootId: string]: number;\n } = Object.create(null);\n\n public retain(rootId: string): number {\n return this.rootIds[rootId] = (this.rootIds[rootId] || 0) + 1;\n }\n\n public release(rootId: string): number {\n if (this.rootIds[rootId] > 0) {\n const count = --this.rootIds[rootId];\n if (!count) delete this.rootIds[rootId];\n return count;\n }\n return 0;\n }\n\n // Return a Set<string> of all the ID strings that have been retained by\n // this layer/root *and* any layers/roots beneath it.\n public getRootIdSet(ids = new Set<string>()) {\n Object.keys(this.rootIds).forEach(ids.add, ids);\n if (this instanceof Layer) {\n this.parent.getRootIdSet(ids);\n } else {\n // Official singleton IDs like ROOT_QUERY and ROOT_MUTATION are\n // always considered roots for garbage collection, regardless of\n // their retainment counts in this.rootIds.\n Object.keys(this.policies.rootTypenamesById).forEach(ids.add, ids);\n }\n return ids;\n }\n\n // The goal of garbage collection is to remove IDs from the Root layer of the\n // store that are no longer reachable starting from any IDs that have been\n // explicitly retained (see retain and release, above). Returns an array of\n // dataId strings that were removed from the store.\n public gc() {\n const ids = this.getRootIdSet();\n const snapshot = this.toObject();\n ids.forEach(id => {\n if (hasOwn.call(snapshot, id)) {\n // Because we are iterating over an ECMAScript Set, the IDs we add here\n // will be visited in later iterations of the forEach loop only if they\n // were not previously contained by the Set.\n Object.keys(this.findChildRefIds(id)).forEach(ids.add, ids);\n // By removing IDs from the snapshot object here, we protect them from\n // getting removed from the root store layer below.\n delete snapshot[id];\n }\n });\n const idsToRemove = Object.keys(snapshot);\n if (idsToRemove.length) {\n let root: EntityStore = this;\n while (root instanceof Layer) root = root.parent;\n idsToRemove.forEach(id => root.delete(id));\n }\n return idsToRemove;\n }\n\n // Lazily tracks { __ref: <dataId> } strings contained by this.data[dataId].\n private refs: {\n [dataId: string]: Record<string, true>;\n } = Object.create(null);\n\n public findChildRefIds(dataId: string): Record<string, true> {\n if (!hasOwn.call(this.refs, dataId)) {\n const found = this.refs[dataId] = Object.create(null);\n const root = this.data[dataId];\n if (!root) return found;\n\n const workSet = new Set<Record<string | number, any>>([root]);\n // Within the store, only arrays and objects can contain child entity\n // references, so we can prune the traversal using this predicate:\n workSet.forEach(obj => {\n if (isReference(obj)) {\n found[obj.__ref] = true;\n // In rare cases, a { __ref } Reference object may have other fields.\n // This often indicates a mismerging of References with StoreObjects,\n // but garbage collection should not be fooled by a stray __ref\n // property in a StoreObject (ignoring all the other fields just\n // because the StoreObject looks like a Reference). To avoid this\n // premature termination of findChildRefIds recursion, we fall through\n // to the code below, which will handle any other properties of obj.\n }\n if (isNonNullObject(obj)) {\n Object.keys(obj).forEach(key => {\n const child = obj[key];\n // No need to add primitive values to the workSet, since they cannot\n // contain reference objects.\n if (isNonNullObject(child)) {\n workSet.add(child);\n }\n });\n }\n });\n }\n return this.refs[dataId];\n }\n\n // Used to compute cache keys specific to this.group.\n public makeCacheKey(...args: any[]): object;\n public makeCacheKey() {\n return this.group.keyMaker.lookupArray(arguments);\n }\n\n // Bound function that can be passed around to provide easy access to fields\n // of Reference objects as well as ordinary objects.\n public getFieldValue = <T = StoreValue>(\n objectOrReference: StoreObject | Reference | undefined,\n storeFieldName: string,\n ) => maybeDeepFreeze(\n isReference(objectOrReference)\n ? this.get(objectOrReference.__ref, storeFieldName)\n : objectOrReference && objectOrReference[storeFieldName]\n ) as SafeReadonly<T>;\n\n // Returns true for non-normalized StoreObjects and non-dangling\n // References, indicating that readField(name, objOrRef) has a chance of\n // working. Useful for filtering out dangling references from lists.\n public canRead: CanReadFunction = objOrRef => {\n return isReference(objOrRef)\n ? this.has(objOrRef.__ref)\n : typeof objOrRef === \"object\";\n };\n\n // Bound function that converts an id or an object with a __typename and\n // primary key fields to a Reference object. If called with a Reference object,\n // that same Reference object is returned. Pass true for mergeIntoStore to persist\n // an object into the store.\n public toReference: ToReferenceFunction = (\n objOrIdOrRef,\n mergeIntoStore,\n ) => {\n if (typeof objOrIdOrRef === \"string\") {\n return makeReference(objOrIdOrRef);\n }\n\n if (isReference(objOrIdOrRef)) {\n return objOrIdOrRef;\n }\n\n const [id] = this.policies.identify(objOrIdOrRef);\n\n if (id) {\n const ref = makeReference(id);\n if (mergeIntoStore) {\n this.merge(id, objOrIdOrRef);\n }\n return ref;\n }\n };\n}\n\nexport type FieldValueGetter = EntityStore[\"getFieldValue\"];\n\n// A single CacheGroup represents a set of one or more EntityStore objects,\n// typically the Root store in a CacheGroup by itself, and all active Layer\n// stores in a group together. A single EntityStore object belongs to only\n// one CacheGroup, store.group. The CacheGroup is responsible for tracking\n// dependencies, so store.group is helpful for generating unique keys for\n// cached results that need to be invalidated when/if those dependencies\n// change. If we used the EntityStore objects themselves as cache keys (that\n// is, store rather than store.group), the cache would become unnecessarily\n// fragmented by all the different Layer objects. Instead, the CacheGroup\n// approach allows all optimistic Layer objects in the same linked list to\n// belong to one CacheGroup, with the non-optimistic Root object belonging\n// to another CacheGroup, allowing resultCaching dependencies to be tracked\n// separately for optimistic and non-optimistic entity data.\nclass CacheGroup {\n private d: OptimisticDependencyFunction<string> | null = null;\n\n // Used by the EntityStore#makeCacheKey method to compute cache keys\n // specific to this CacheGroup.\n public keyMaker: Trie<object>;\n\n constructor(\n public readonly caching: boolean,\n private parent: CacheGroup | null = null,\n ) {\n this.resetCaching();\n }\n\n public resetCaching() {\n this.d = this.caching ? dep<string>() : null;\n this.keyMaker = new Trie(canUseWeakMap);\n }\n\n public depend(dataId: string, storeFieldName: string) {\n if (this.d) {\n this.d(makeDepKey(dataId, storeFieldName));\n const fieldName = fieldNameFromStoreName(storeFieldName);\n if (fieldName !== storeFieldName) {\n // Fields with arguments that contribute extra identifying\n // information to the fieldName (thus forming the storeFieldName)\n // depend not only on the full storeFieldName but also on the\n // short fieldName, so the field can be invalidated using either\n // level of specificity.\n this.d(makeDepKey(dataId, fieldName));\n }\n if (this.parent) {\n this.parent.depend(dataId, storeFieldName);\n }\n }\n }\n\n public dirty(dataId: string, storeFieldName: string) {\n if (this.d) {\n this.d.dirty(\n makeDepKey(dataId, storeFieldName),\n // When storeFieldName === \"__exists\", that means the entity identified\n // by dataId has either disappeared from the cache or was newly added,\n // so the result caching system would do well to \"forget everything it\n // knows\" about that object. To achieve that kind of invalidation, we\n // not only dirty the associated result cache entry, but also remove it\n // completely from the dependency graph. For the optimism implementation\n // details, see https://github.com/benjamn/optimism/pull/195.\n storeFieldName === \"__exists\" ? \"forget\" : \"setDirty\",\n );\n }\n }\n}\n\nfunction makeDepKey(dataId: string, storeFieldName: string) {\n // Since field names cannot have '#' characters in them, this method\n // of joining the field name and the ID should be unambiguous, and much\n // cheaper than JSON.stringify([dataId, fieldName]).\n return storeFieldName + '#' + dataId;\n}\n\nexport function maybeDependOnExistenceOfEntity(\n store: NormalizedCache,\n entityId: string,\n) {\n if (supportsResultCaching(store)) {\n // We use this pseudo-field __exists elsewhere in the EntityStore code to\n // represent changes in the existence of the entity object identified by\n // entityId. This dependency gets reliably dirtied whenever an object with\n // this ID is deleted (or newly created) within this group, so any result\n // cache entries (for example, StoreReader#executeSelectionSet results) that\n // depend on __exists for this entityId will get dirtied as well, leading to\n // the eventual recomputation (instead of reuse) of those result objects the\n // next time someone reads them from the cache.\n store.group.depend(entityId, \"__exists\");\n }\n}\n\nexport namespace EntityStore {\n // Refer to this class as EntityStore.Root outside this namespace.\n export class Root extends EntityStore {\n constructor({\n policies,\n resultCaching = true,\n seed,\n }: {\n policies: Policies;\n resultCaching?: boolean;\n seed?: NormalizedCacheObject;\n }) {\n super(policies, new CacheGroup(resultCaching));\n if (seed) this.replace(seed);\n }\n\n public readonly stump = new Stump(this);\n\n public addLayer(\n layerId: string,\n replay: (layer: EntityStore) => any,\n ): Layer {\n // Adding an optimistic Layer on top of the Root actually adds the Layer\n // on top of the Stump, so the Stump always comes between the Root and\n // any Layer objects that we've added.\n return this.stump.addLayer(layerId, replay);\n }\n\n public removeLayer(): Root {\n // Never remove the root layer.\n return this;\n }\n\n public readonly storageTrie = new Trie<StorageType>(canUseWeakMap);\n public getStorage(): StorageType {\n return this.storageTrie.lookupArray(arguments);\n }\n }\n}\n\n// Not exported, since all Layer instances are created by the addLayer method\n// of the EntityStore.Root class.\nclass Layer extends EntityStore {\n constructor(\n public readonly id: string,\n public readonly parent: EntityStore,\n public readonly replay: (layer: EntityStore) => any,\n public readonly group: CacheGroup,\n ) {\n super(parent.policies, group);\n replay(this);\n }\n\n public addLayer(\n layerId: string,\n replay: (layer: EntityStore) => any,\n ): Layer {\n return new Layer(layerId, this, replay, this.group);\n }\n\n public removeLayer(layerId: string): EntityStore {\n // Remove all instances of the given id, not just the first one.\n const parent = this.parent.removeLayer(layerId);\n\n if (layerId === this.id) {\n if (this.group.caching) {\n // Dirty every ID we're removing. Technically we might be able to avoid\n // dirtying fields that have values in higher layers, but we don't have\n // easy access to higher layers here, and we're about to recreate those\n // layers anyway (see parent.addLayer below).\n Object.keys(this.data).forEach(dataId => {\n const ownStoreObject = this.data[dataId];\n const parentStoreObject = parent[\"lookup\"](dataId);\n if (!parentStoreObject) {\n // The StoreObject identified by dataId was defined in this layer\n // but will be undefined in the parent layer, so we can delete the\n // whole entity using this.delete(dataId). Since we're about to\n // throw this layer away, the only goal of this deletion is to dirty\n // the removed fields.\n this.delete(dataId);\n } else if (!ownStoreObject) {\n // This layer had an entry for dataId but it was undefined, which\n // means the entity was deleted in this layer, and it's about to\n // become undeleted when we remove this layer, so we need to dirty\n // all fields that are about to be reexposed.\n this.group.dirty(dataId, \"__exists\");\n Object.keys(parentStoreObject).forEach(storeFieldName => {\n this.group.dirty(dataId, storeFieldName);\n });\n } else if (ownStoreObject !== parentStoreObject) {\n // If ownStoreObject is not exactly the same as parentStoreObject,\n // dirty any fields whose values will change as a result of this\n // removal.\n Object.keys(ownStoreObject).forEach(storeFieldName => {\n if (!equal(ownStoreObject[storeFieldName],\n parentStoreObject[storeFieldName])) {\n this.group.dirty(dataId, storeFieldName);\n }\n });\n }\n });\n }\n\n return parent;\n }\n\n // No changes are necessary if the parent chain remains identical.\n if (parent === this.parent) return this;\n\n // Recreate this layer on top of the new parent.\n return parent.addLayer(this.id, this.replay);\n }\n\n public toObject(): NormalizedCacheObject {\n return {\n ...this.parent.toObject(),\n ...this.data,\n };\n }\n\n public findChildRefIds(dataId: string): Record<string, true> {\n const fromParent = this.parent.findChildRefIds(dataId);\n return hasOwn.call(this.data, dataId) ? {\n ...fromParent,\n ...super.findChildRefIds(dataId),\n } : fromParent;\n }\n\n public getStorage(): StorageType {\n let p: EntityStore = this.parent;\n while ((p as Layer).parent) p = (p as Layer).parent;\n return p.getStorage.apply(p, arguments);\n }\n}\n\n// Represents a Layer permanently installed just above the Root, which allows\n// reading optimistically (and registering optimistic dependencies) even when\n// no optimistic layers are currently active. The stump.group CacheGroup object\n// is shared by any/all Layer objects added on top of the Stump.\nclass Stump extends Layer {\n constructor(root: EntityStore.Root) {\n super(\n \"EntityStore.Stump\",\n root,\n () => {},\n new CacheGroup(root.group.caching, root.group),\n );\n }\n\n public removeLayer() {\n // Never remove the Stump layer.\n return this;\n }\n\n public merge() {\n // We never want to write any data into the Stump, so we forward any merge\n // calls to the Root instead. Another option here would be to throw an\n // exception, but the toReference(object, true) function can sometimes\n // trigger Stump writes (which used to be Root writes, before the Stump\n // concept was introduced).\n return this.parent.merge.apply(this.parent, arguments);\n }\n}\n\nfunction storeObjectReconciler(\n existingObject: StoreObject,\n incomingObject: StoreObject,\n property: string,\n): StoreValue {\n const existingValue = existingObject[property];\n const incomingValue = incomingObject[property];\n // Wherever there is a key collision, prefer the incoming value, unless\n // it is deeply equal to the existing value. It's worth checking deep\n // equality here (even though blindly returning incoming would be\n // logically correct) because preserving the referential identity of\n // existing data can prevent needless rereading and rerendering.\n return equal(existingValue, incomingValue) ? existingValue : incomingValue;\n}\n\nexport function supportsResultCaching(store: any): store is EntityStore {\n // When result caching is disabled, store.depend will be null.\n return !!(store instanceof EntityStore && store.group.caching);\n}\n","import { invariant } from '../../utilities/globals';\n\nimport {\n DocumentNode,\n FieldNode,\n SelectionSetNode,\n} from 'graphql';\nimport { wrap, OptimisticWrapperFunction } from 'optimism';\n\nimport {\n isField,\n resultKeyNameFromField,\n Reference,\n isReference,\n makeReference,\n StoreObject,\n createFragmentMap,\n FragmentMap,\n shouldInclude,\n addTypenameToDocument,\n getDefaultValues,\n getFragmentDefinitions,\n getMainDefinition,\n getQueryDefinition,\n getFragmentFromSelection,\n maybeDeepFreeze,\n mergeDeepArray,\n DeepMerger,\n isNonNullObject,\n canUseWeakMap,\n compact,\n} from '../../utilities';\nimport { Cache } from '../core/types/Cache';\nimport {\n DiffQueryAgainstStoreOptions,\n NormalizedCache,\n ReadMergeModifyContext,\n} from './types';\nimport { maybeDependOnExistenceOfEntity, supportsResultCaching } from './entityStore';\nimport { getTypenameFromStoreObject, isArray, shouldCanonizeResults } from './helpers';\nimport { Policies } from './policies';\nimport { InMemoryCache } from './inMemoryCache';\nimport { MissingFieldError, MissingTree } from '../core/types/common';\nimport { canonicalStringify, ObjectCanon } from './object-canon';\n\nexport type VariableMap = { [name: string]: any };\n\ninterface ReadContext extends ReadMergeModifyContext {\n query: DocumentNode;\n policies: Policies;\n canonizeResults: boolean;\n fragmentMap: FragmentMap;\n};\n\nexport type ExecResult<R = any> = {\n result: R;\n missing?: MissingTree;\n};\n\ntype ExecSelectionSetOptions = {\n selectionSet: SelectionSetNode;\n objectOrReference: StoreObject | Reference;\n enclosingRef: Reference;\n context: ReadContext;\n};\n\ntype ExecSubSelectedArrayOptions = {\n field: FieldNode;\n array: readonly any[];\n enclosingRef: Reference;\n context: ReadContext;\n};\n\nexport interface StoreReaderConfig {\n cache: InMemoryCache,\n addTypename?: boolean;\n resultCacheMaxSize?: number;\n canonizeResults?: boolean;\n canon?: ObjectCanon;\n}\n\n// Arguments type after keyArgs translation.\ntype ExecSelectionSetKeyArgs = [\n SelectionSetNode,\n StoreObject | Reference,\n ReadMergeModifyContext,\n boolean,\n];\n\nfunction execSelectionSetKeyArgs(\n options: ExecSelectionSetOptions,\n): ExecSelectionSetKeyArgs {\n return [\n options.selectionSet,\n options.objectOrReference,\n options.context,\n // We split out this property so we can pass different values\n // independently without modifying options.context itself.\n options.context.canonizeResults,\n ];\n}\n\nexport class StoreReader {\n // cached version of executeSelectionSet\n private executeSelectionSet: OptimisticWrapperFunction<\n [ExecSelectionSetOptions], // Actual arguments tuple type.\n ExecResult, // Actual return type.\n ExecSelectionSetKeyArgs\n >;\n\n // cached version of executeSubSelectedArray\n private executeSubSelectedArray: OptimisticWrapperFunction<\n [ExecSubSelectedArrayOptions],\n ExecResult<any>,\n [ExecSubSelectedArrayOptions]>;\n\n private config: {\n cache: InMemoryCache,\n addTypename: boolean;\n resultCacheMaxSize?: number;\n canonizeResults: boolean;\n };\n\n private knownResults = new (\n canUseWeakMap ? WeakMap : Map\n )<Record<string, any>, SelectionSetNode>();\n\n public canon: ObjectCanon;\n public resetCanon() {\n this.canon = new ObjectCanon;\n }\n\n constructor(config: StoreReaderConfig) {\n this.config = compact(config, {\n addTypename: config.addTypename !== false,\n canonizeResults: shouldCanonizeResults(config),\n });\n\n this.canon = config.canon || new ObjectCanon;\n\n this.executeSelectionSet = wrap(options => {\n const { canonizeResults } = options.context;\n\n const peekArgs = execSelectionSetKeyArgs(options);\n\n // Negate this boolean option so we can find out if we've already read\n // this result using the other boolean value.\n peekArgs[3] = !canonizeResults;\n\n const other = this.executeSelectionSet.peek(...peekArgs);\n\n if (other) {\n if (canonizeResults) {\n return {\n ...other,\n // If we previously read this result without canonizing it, we can\n // reuse that result simply by canonizing it now.\n result: this.canon.admit(other.result),\n };\n }\n // If we previously read this result with canonization enabled, we can\n // return that canonized result as-is.\n return other;\n }\n\n maybeDependOnExistenceOfEntity(\n options.context.store,\n options.enclosingRef.__ref,\n );\n\n // Finally, if we didn't find any useful previous results, run the real\n // execSelectionSetImpl method with the given options.\n return this.execSelectionSetImpl(options);\n\n }, {\n max: this.config.resultCacheMaxSize,\n keyArgs: execSelectionSetKeyArgs,\n // Note that the parameters of makeCacheKey are determined by the\n // array returned by keyArgs.\n makeCacheKey(selectionSet, parent, context, canonizeResults) {\n if (supportsResultCaching(context.store)) {\n return context.store.makeCacheKey(\n selectionSet,\n isReference(parent) ? parent.__ref : parent,\n context.varString,\n canonizeResults,\n );\n }\n }\n });\n\n this.executeSubSelectedArray = wrap((options: ExecSubSelectedArrayOptions) => {\n maybeDependOnExistenceOfEntity(\n options.context.store,\n options.enclosingRef.__ref,\n );\n return this.execSubSelectedArrayImpl(options);\n }, {\n max: this.config.resultCacheMaxSize,\n makeCacheKey({ field, array, context }) {\n if (supportsResultCaching(context.store)) {\n return context.store.makeCacheKey(\n field,\n array,\n context.varString,\n );\n }\n }\n });\n }\n\n /**\n * Given a store and a query, return as much of the result as possible and\n * identify if any data was missing from the store.\n * @param {DocumentNode} query A parsed GraphQL query document\n * @param {Store} store The Apollo Client store object\n * @return {result: Object, complete: [boolean]}\n */\n public diffQueryAgainstStore<T>({\n store,\n query,\n rootId = 'ROOT_QUERY',\n variables,\n returnPartialData = true,\n canonizeResults = this.config.canonizeResults,\n }: DiffQueryAgainstStoreOptions): Cache.DiffResult<T> {\n const policies = this.config.cache.policies;\n\n variables = {\n ...getDefaultValues(getQueryDefinition(query)),\n ...variables!,\n };\n\n const rootRef = makeReference(rootId);\n const execResult = this.executeSelectionSet({\n selectionSet: getMainDefinition(query).selectionSet,\n objectOrReference: rootRef,\n enclosingRef: rootRef,\n context: {\n store,\n query,\n policies,\n variables,\n varString: canonicalStringify(variables),\n canonizeResults,\n fragmentMap: createFragmentMap(getFragmentDefinitions(query)),\n },\n });\n\n let missing: MissingFieldError[] | undefined;\n if (execResult.missing) {\n // For backwards compatibility we still report an array of\n // MissingFieldError objects, even though there will only ever be at most\n // one of them, now that all missing field error messages are grouped\n // together in the execResult.missing tree.\n missing = [new MissingFieldError(\n firstMissing(execResult.missing)!,\n execResult.missing,\n query,\n variables,\n )];\n if (!returnPartialData) {\n throw missing[0];\n }\n }\n\n return {\n result: execResult.result,\n complete: !missing,\n missing,\n };\n }\n\n public isFresh(\n result: Record<string, any>,\n parent: StoreObject | Reference,\n selectionSet: SelectionSetNode,\n context: ReadMergeModifyContext,\n ): boolean {\n if (supportsResultCaching(context.store) &&\n this.knownResults.get(result) === selectionSet) {\n const latest = this.executeSelectionSet.peek(\n selectionSet,\n parent,\n context,\n // If result is canonical, then it could only have been previously\n // cached by the canonizing version of executeSelectionSet, so we can\n // avoid checking both possibilities here.\n this.canon.isKnown(result),\n );\n if (latest && result === latest.result) {\n return true;\n }\n }\n return false;\n }\n\n // Uncached version of executeSelectionSet.\n private execSelectionSetImpl({\n selectionSet,\n objectOrReference,\n enclosingRef,\n context,\n }: ExecSelectionSetOptions): ExecResult {\n if (isReference(objectOrReference) &&\n !context.policies.rootTypenamesById[objectOrReference.__ref] &&\n !context.store.has(objectOrReference.__ref)) {\n return {\n result: this.canon.empty,\n missing: `Dangling reference to missing ${objectOrReference.__ref} object`,\n };\n }\n\n const { variables, policies, store } = context;\n const typename = store.getFieldValue<string>(objectOrReference, \"__typename\");\n\n const objectsToMerge: Record<string, any>[] = [];\n let missing: MissingTree | undefined;\n const missingMerger = new DeepMerger();\n\n if (this.config.addTypename &&\n typeof typename === \"string\" &&\n !policies.rootIdsByTypename[typename]) {\n // Ensure we always include a default value for the __typename\n // field, if we have one, and this.config.addTypename is true. Note\n // that this field can be overridden by other merged objects.\n objectsToMerge.push({ __typename: typename });\n }\n\n function handleMissing<T>(result: ExecResult<T>, resultName: string): T {\n if (result.missing) {\n missing = missingMerger.merge(missing, { [resultName]: result.missing });\n }\n return result.result;\n }\n\n const workSet = new Set(selectionSet.selections);\n\n workSet.forEach(selection => {\n // Omit fields with directives @skip(if: <truthy value>) or\n // @include(if: <falsy value>).\n if (!shouldInclude(selection, variables)) return;\n\n if (isField(selection)) {\n let fieldValue = policies.readField({\n fieldName: selection.name.value,\n field: selection,\n variables: context.variables,\n from: objectOrReference,\n }, context);\n\n const resultName = resultKeyNameFromField(selection);\n\n if (fieldValue === void 0) {\n if (!addTypenameToDocument.added(selection)) {\n missing = missingMerger.merge(missing, {\n [resultName]: `Can't find field '${\n selection.name.value\n }' on ${\n isReference(objectOrReference)\n ? objectOrReference.__ref + \" object\"\n : \"object \" + JSON.stringify(objectOrReference, null, 2)\n }`\n });\n }\n\n } else if (isArray(fieldValue)) {\n fieldValue = handleMissing(this.executeSubSelectedArray({\n field: selection,\n array: fieldValue,\n enclosingRef,\n context,\n }), resultName);\n\n } else if (!selection.selectionSet) {\n // If the field does not have a selection set, then we handle it\n // as a scalar value. To keep this.canon from canonicalizing\n // this value, we use this.canon.pass to wrap fieldValue in a\n // Pass object that this.canon.admit will later unwrap as-is.\n if (context.canonizeResults) {\n fieldValue = this.canon.pass(fieldValue);\n }\n\n } else if (fieldValue != null) {\n // In this case, because we know the field has a selection set,\n // it must be trying to query a GraphQLObjectType, which is why\n // fieldValue must be != null.\n fieldValue = handleMissing(this.executeSelectionSet({\n selectionSet: selection.selectionSet,\n objectOrReference: fieldValue as StoreObject | Reference,\n enclosingRef: isReference(fieldValue) ? fieldValue : enclosingRef,\n context,\n }), resultName);\n }\n\n if (fieldValue !== void 0) {\n objectsToMerge.push({ [resultName]: fieldValue });\n }\n\n } else {\n const fragment = getFragmentFromSelection(\n selection,\n context.fragmentMap,\n );\n\n if (fragment && policies.fragmentMatches(fragment, typename)) {\n fragment.selectionSet.selections.forEach(workSet.add, workSet);\n }\n }\n });\n\n const result = mergeDeepArray(objectsToMerge);\n const finalResult: ExecResult = { result, missing };\n const frozen = context.canonizeResults\n ? this.canon.admit(finalResult)\n // Since this.canon is normally responsible for freezing results (only in\n // development), freeze them manually if canonization is disabled.\n : maybeDeepFreeze(finalResult);\n\n // Store this result with its selection set so that we can quickly\n // recognize it again in the StoreReader#isFresh method.\n if (frozen.result) {\n this.knownResults.set(frozen.result, selectionSet);\n }\n\n return frozen;\n }\n\n // Uncached version of executeSubSelectedArray.\n private execSubSelectedArrayImpl({\n field,\n array,\n enclosingRef,\n context,\n }: ExecSubSelectedArrayOptions): ExecResult {\n let missing: MissingTree | undefined;\n let missingMerger = new DeepMerger<MissingTree[]>();\n\n function handleMissing<T>(childResult: ExecResult<T>, i: number): T {\n if (childResult.missing) {\n missing = missingMerger.merge(missing, { [i]: childResult.missing });\n }\n return childResult.result;\n }\n\n if (field.selectionSet) {\n array = array.filter(context.store.canRead);\n }\n\n array = array.map((item, i) => {\n // null value in array\n if (item === null) {\n return null;\n }\n\n // This is a nested array, recurse\n if (isArray(item)) {\n return handleMissing(this.executeSubSelectedArray({\n field,\n array: item,\n enclosingRef,\n context,\n }), i);\n }\n\n // This is an object, run the selection set on it\n if (field.selectionSet) {\n return handleMissing(this.executeSelectionSet({\n selectionSet: field.selectionSet,\n objectOrReference: item,\n enclosingRef: isReference(item) ? item : enclosingRef,\n context,\n }), i);\n }\n\n if (__DEV__) {\n assertSelectionSetForIdValue(context.store, field, item);\n }\n\n return item;\n });\n\n return {\n result: context.canonizeResults ? this.canon.admit(array) : array,\n missing,\n };\n }\n}\n\nfunction firstMissing(tree: MissingTree): string | undefined {\n try {\n JSON.stringify(tree, (_, value) => {\n if (typeof value === \"string\") throw value;\n return value;\n });\n } catch (result) {\n return result;\n }\n}\n\nfunction assertSelectionSetForIdValue(\n store: NormalizedCache,\n field: FieldNode,\n fieldValue: any,\n) {\n if (!field.selectionSet) {\n const workSet = new Set([fieldValue]);\n workSet.forEach(value => {\n if (isNonNullObject(value)) {\n invariant(\n !isReference(value),\n `Missing selection set for object of type ${\n getTypenameFromStoreObject(store, value)\n } returned for query field ${field.name.value}`,\n );\n Object.values(value).forEach(workSet.add, workSet);\n }\n });\n }\n}\n","import { invariant } from \"../../utilities/globals\";\n\nimport {\n argumentsObjectFromField,\n DeepMerger,\n isNonEmptyArray,\n isNonNullObject,\n} from \"../../utilities\";\n\nimport { hasOwn, isArray } from \"./helpers\";\nimport {\n KeySpecifier,\n KeyFieldsFunction,\n KeyArgsFunction,\n} from \"./policies\";\n\n// Mapping from JSON-encoded KeySpecifier strings to associated information.\nconst specifierInfoCache: Record<string, {\n paths?: string[][];\n keyFieldsFn?: KeyFieldsFunction;\n keyArgsFn?: KeyArgsFunction;\n}> = Object.create(null);\n\nfunction lookupSpecifierInfo(spec: KeySpecifier) {\n // It's safe to encode KeySpecifier arrays with JSON.stringify, since they're\n // just arrays of strings or nested KeySpecifier arrays, and the order of the\n // array elements is important (and suitably preserved by JSON.stringify).\n const cacheKey = JSON.stringify(spec);\n return specifierInfoCache[cacheKey] ||\n (specifierInfoCache[cacheKey] = Object.create(null));\n}\n\nexport function keyFieldsFnFromSpecifier(\n specifier: KeySpecifier,\n): KeyFieldsFunction {\n const info = lookupSpecifierInfo(specifier);\n\n return info.keyFieldsFn || (info.keyFieldsFn = (\n object,\n context,\n ) => {\n const extract: typeof extractKey =\n (from, key) => context.readField(key, from);\n\n const keyObject = context.keyObject = collectSpecifierPaths(\n specifier,\n schemaKeyPath => {\n let extracted = extractKeyPath(\n context.storeObject,\n schemaKeyPath,\n // Using context.readField to extract paths from context.storeObject\n // allows the extraction to see through Reference objects and respect\n // custom read functions.\n extract,\n );\n\n if (\n extracted === void 0 &&\n object !== context.storeObject &&\n hasOwn.call(object, schemaKeyPath[0])\n ) {\n // If context.storeObject fails to provide a value for the requested\n // path, fall back to the raw result object, if it has a top-level key\n // matching the first key in the path (schemaKeyPath[0]). This allows\n // key fields included in the written data to be saved in the cache\n // even if they are not selected explicitly in context.selectionSet.\n // Not being mentioned by context.selectionSet is convenient here,\n // since it means these extra fields cannot be affected by field\n // aliasing, which is why we can use extractKey instead of\n // context.readField for this extraction.\n extracted = extractKeyPath(object, schemaKeyPath, extractKey);\n }\n\n invariant(\n extracted !== void 0,\n `Missing field '${schemaKeyPath.join('.')}' while extracting keyFields from ${\n JSON.stringify(object)\n }`,\n );\n\n return extracted;\n },\n );\n\n return `${context.typename}:${JSON.stringify(keyObject)}`;\n });\n}\n\n// The keyArgs extraction process is roughly analogous to keyFields extraction,\n// but there are no aliases involved, missing fields are tolerated (by merely\n// omitting them from the key), and drawing from field.directives or variables\n// is allowed (in addition to drawing from the field's arguments object).\n// Concretely, these differences mean passing a different key path extractor\n// function to collectSpecifierPaths, reusing the shared extractKeyPath helper\n// wherever possible.\nexport function keyArgsFnFromSpecifier(specifier: KeySpecifier): KeyArgsFunction {\n const info = lookupSpecifierInfo(specifier);\n\n return info.keyArgsFn || (info.keyArgsFn = (args, {\n field,\n variables,\n fieldName,\n }) => {\n const collected = collectSpecifierPaths(specifier, keyPath => {\n const firstKey = keyPath[0];\n const firstChar = firstKey.charAt(0);\n\n if (firstChar === \"@\") {\n if (field && isNonEmptyArray(field.directives)) {\n const directiveName = firstKey.slice(1);\n // If the directive appears multiple times, only the first\n // occurrence's arguments will be used. TODO Allow repetition?\n // TODO Cache this work somehow, a la aliasMap?\n const d = field.directives.find(d => d.name.value === directiveName);\n // Fortunately argumentsObjectFromField works for DirectiveNode!\n const directiveArgs = d && argumentsObjectFromField(d, variables);\n // For directives without arguments (d defined, but directiveArgs ===\n // null), the presence or absence of the directive still counts as\n // part of the field key, so we return null in those cases. If no\n // directive with this name was found for this field (d undefined and\n // thus directiveArgs undefined), we return undefined, which causes\n // this value to be omitted from the key object returned by\n // collectSpecifierPaths.\n return directiveArgs && extractKeyPath(\n directiveArgs,\n // If keyPath.length === 1, this code calls extractKeyPath with an\n // empty path, which works because it uses directiveArgs as the\n // extracted value.\n keyPath.slice(1),\n );\n }\n // If the key started with @ but there was no corresponding directive,\n // we want to omit this value from the key object, not fall through to\n // treating @whatever as a normal argument name.\n return;\n }\n\n if (firstChar === \"$\") {\n const variableName = firstKey.slice(1);\n if (variables && hasOwn.call(variables, variableName)) {\n const varKeyPath = keyPath.slice(0);\n varKeyPath[0] = variableName;\n return extractKeyPath(variables, varKeyPath);\n }\n // If the key started with $ but there was no corresponding variable, we\n // want to omit this value from the key object, not fall through to\n // treating $whatever as a normal argument name.\n return;\n }\n\n if (args) {\n return extractKeyPath(args, keyPath);\n }\n });\n\n const suffix = JSON.stringify(collected);\n\n // If no arguments were passed to this field, and it didn't have any other\n // field key contributions from directives or variables, hide the empty\n // :{} suffix from the field key. However, a field passed no arguments can\n // still end up with a non-empty :{...} suffix if its key configuration\n // refers to directives or variables.\n if (args || suffix !== \"{}\") {\n fieldName += \":\" + suffix;\n }\n\n return fieldName;\n });\n}\n\nexport function collectSpecifierPaths(\n specifier: KeySpecifier,\n extractor: (path: string[]) => any,\n): Record<string, any> {\n // For each path specified by specifier, invoke the extractor, and repeatedly\n // merge the results together, with appropriate ancestor context.\n const merger = new DeepMerger;\n return getSpecifierPaths(specifier).reduce((collected, path) => {\n let toMerge = extractor(path);\n if (toMerge !== void 0) {\n // This path is not expected to contain array indexes, so the toMerge\n // reconstruction will not contain arrays. TODO Fix this?\n for (let i = path.length - 1; i >= 0; --i) {\n toMerge = { [path[i]]: toMerge };\n }\n collected = merger.merge(collected, toMerge);\n }\n return collected;\n }, Object.create(null));\n}\n\nexport function getSpecifierPaths(spec: KeySpecifier): string[][] {\n const info = lookupSpecifierInfo(spec);\n\n if (!info.paths) {\n const paths: string[][] = info.paths = [];\n const currentPath: string[] = [];\n\n spec.forEach((s, i) => {\n if (isArray(s)) {\n getSpecifierPaths(s).forEach(p => paths.push(currentPath.concat(p)));\n currentPath.length = 0;\n } else {\n currentPath.push(s);\n if (!isArray(spec[i + 1])) {\n paths.push(currentPath.slice(0));\n currentPath.length = 0;\n }\n }\n });\n }\n\n return info.paths!;\n}\n\nfunction extractKey<\n TObj extends Record<string, any>,\n TKey extends string,\n>(object: TObj, key: TKey): TObj[TKey] | undefined {\n return object[key];\n}\n\nexport function extractKeyPath(\n object: Record<string, any>,\n path: string[],\n extract?: typeof extractKey,\n): any {\n // For each key in path, extract the corresponding child property from obj,\n // flattening arrays if encountered (uncommon for keyFields and keyArgs, but\n // possible). The final result of path.reduce is normalized so unexpected leaf\n // objects have their keys safely sorted. That final result is difficult to\n // type as anything other than any. You're welcome to try to improve the\n // return type, but keep in mind extractKeyPath is not a public function\n // (exported only for testing), so the effort may not be worthwhile unless the\n // limited set of actual callers (see above) pass arguments that TypeScript\n // can statically type. If we know only that path is some array of strings\n // (and not, say, a specific tuple of statically known strings), any (or\n // possibly unknown) is the honest answer.\n extract = extract || extractKey;\n return normalize(path.reduce(function reducer(obj, key): any {\n return isArray(obj)\n ? obj.map(child => reducer(child, key))\n : obj && extract!(obj, key);\n }, object));\n}\n\nfunction normalize<T>(value: T): T {\n // Usually the extracted value will be a scalar value, since most primary\n // key fields are scalar, but just in case we get an object or an array, we\n // need to do some normalization of the order of (nested) keys.\n if (isNonNullObject(value)) {\n if (isArray(value)) {\n return value.map(normalize) as any;\n }\n return collectSpecifierPaths(\n Object.keys(value).sort(),\n path => extractKeyPath(value, path),\n ) as T;\n }\n return value;\n}\n","import { invariant, InvariantError } from '../../utilities/globals';\n\nimport {\n InlineFragmentNode,\n FragmentDefinitionNode,\n SelectionSetNode,\n FieldNode,\n} from 'graphql';\n\nimport {\n FragmentMap,\n storeKeyNameFromField,\n StoreValue,\n StoreObject,\n argumentsObjectFromField,\n Reference,\n isReference,\n getStoreKeyName,\n isNonNullObject,\n stringifyForDisplay,\n} from '../../utilities';\nimport {\n IdGetter,\n MergeInfo,\n NormalizedCache,\n ReadMergeModifyContext,\n} from \"./types\";\nimport {\n hasOwn,\n fieldNameFromStoreName,\n storeValueIsStoreObject,\n selectionSetMatchesResult,\n TypeOrFieldNameRegExp,\n defaultDataIdFromObject,\n isArray,\n} from './helpers';\nimport { cacheSlot } from './reactiveVars';\nimport { InMemoryCache } from './inMemoryCache';\nimport {\n SafeReadonly,\n FieldSpecifier,\n ToReferenceFunction,\n ReadFieldFunction,\n ReadFieldOptions,\n CanReadFunction,\n} from '../core/types/common';\nimport { WriteContext } from './writeToStore';\n\n// Upgrade to a faster version of the default stable JSON.stringify function\n// used by getStoreKeyName. This function is used when computing storeFieldName\n// strings (when no keyArgs has been configured for a field).\nimport { canonicalStringify } from './object-canon';\nimport { keyArgsFnFromSpecifier, keyFieldsFnFromSpecifier } from './key-extractor';\n\ngetStoreKeyName.setStringify(canonicalStringify);\n\nexport type TypePolicies = {\n [__typename: string]: TypePolicy;\n}\n\n// TypeScript 3.7 will allow recursive type aliases, so this should work:\n// type KeySpecifier = (string | KeySpecifier)[]\nexport type KeySpecifier = ReadonlyArray<string | KeySpecifier>;\n\nexport type KeyFieldsContext = {\n // The __typename of the incoming object, even if the __typename field was\n // aliased to another name in the raw result object. May be undefined when\n // dataIdFromObject is called for objects without __typename fields.\n typename: string | undefined;\n\n // The object to be identified, after processing to remove aliases and\n // normalize identifiable child objects with references.\n storeObject: StoreObject;\n\n // Handy tool for reading additional fields from context.storeObject, either\n // readField(\"fieldName\") to read storeObject[fieldName], or readField(\"name\",\n // objectOrReference) to read from another object or Reference. If you read a\n // field with a read function, that function will be invoked.\n readField: ReadFieldFunction;\n\n // If you are writing a custom keyFields function, and you plan to use the raw\n // result object passed as the first argument, you may also need access to the\n // selection set and available fragments for this object, just in case any\n // fields have aliases. Since this logic is tricky to get right, and these\n // context properties are not even always provided (for example, they are\n // omitted when calling cache.identify(object), where object is assumed to be\n // a StoreObject), we recommend you use context.storeObject (which has already\n // been de-aliased) and context.readField (which can read from references as\n // well as objects) instead of the raw result object in your keyFields\n // functions, or just rely on the internal implementation of keyFields:[...]\n // syntax to get these details right for you.\n selectionSet?: SelectionSetNode;\n fragmentMap?: FragmentMap;\n\n // Internal. May be set by the KeyFieldsFunction to report fields that were\n // involved in computing the ID. Never passed in by the caller.\n keyObject?: Record<string, any>;\n};\n\nexport type KeyFieldsFunction = (\n object: Readonly<StoreObject>,\n context: KeyFieldsContext,\n) => KeySpecifier | false | ReturnType<IdGetter>;\n\ntype KeyFieldsResult = Exclude<ReturnType<KeyFieldsFunction>, KeySpecifier>;\n\n// TODO Should TypePolicy be a generic type, with a TObject or TEntity\n// type parameter?\nexport type TypePolicy = {\n // Allows defining the primary key fields for this type, either using an\n // array of field names or a function that returns an arbitrary string.\n keyFields?: KeySpecifier | KeyFieldsFunction | false;\n\n // Allows defining a merge function (or merge:true/false shorthand) to\n // be used for merging objects of this type wherever they appear, unless\n // the parent field also defines a merge function/boolean (that is,\n // parent field merge functions take precedence over type policy merge\n // functions). In many cases, defining merge:true for a given type\n // policy can save you from specifying merge:true for all the field\n // policies where that type might be encountered.\n merge?: FieldMergeFunction | boolean;\n\n // In the rare event that your schema happens to use a different\n // __typename for the root Query, Mutation, and/or Schema types, you can\n // express your deviant preferences by enabling one of these options.\n queryType?: true,\n mutationType?: true,\n subscriptionType?: true,\n\n fields?: {\n [fieldName: string]:\n | FieldPolicy<any>\n | FieldReadFunction<any>;\n }\n};\n\nexport type KeyArgsFunction = (\n args: Record<string, any> | null,\n context: {\n typename: string;\n fieldName: string;\n field: FieldNode | null;\n variables?: Record<string, any>;\n },\n) => KeySpecifier | false | ReturnType<IdGetter>;\n\nexport type FieldPolicy<\n // The internal representation used to store the field's data in the\n // cache. Must be JSON-serializable if you plan to serialize the result\n // of cache.extract() using JSON.\n TExisting = any,\n // The type of the incoming parameter passed to the merge function,\n // typically matching the GraphQL response format, but with Reference\n // objects substituted for any identifiable child objects. Often the\n // same as TExisting, but not necessarily.\n TIncoming = TExisting,\n // The type that the read function actually returns, using TExisting\n // data and options.args as input. Usually the same as TIncoming.\n TReadResult = TIncoming,\n // Allows FieldFunctionOptions definition to be overwritten by the\n // developer\n TOptions extends FieldFunctionOptions = FieldFunctionOptions\n> = {\n keyArgs?: KeySpecifier | KeyArgsFunction | false;\n read?: FieldReadFunction<TExisting, TReadResult, TOptions>;\n merge?: FieldMergeFunction<TExisting, TIncoming, TOptions> | boolean;\n};\n\nexport type StorageType = Record<string, any>;\n\nfunction argsFromFieldSpecifier(spec: FieldSpecifier) {\n return spec.args !== void 0 ? spec.args :\n spec.field ? argumentsObjectFromField(spec.field, spec.variables) : null;\n}\n\nexport interface FieldFunctionOptions<\n TArgs = Record<string, any>,\n TVars = Record<string, any>,\n> {\n args: TArgs | null;\n\n // The name of the field, equal to options.field.name.value when\n // options.field is available. Useful if you reuse the same function for\n // multiple fields, and you need to know which field you're currently\n // processing. Always a string, even when options.field is null.\n fieldName: string;\n\n // The full field key used internally, including serialized key arguments.\n storeFieldName: string;\n\n // The FieldNode object used to read this field. Useful if you need to\n // know about other attributes of the field, such as its directives. This\n // option will be null when a string was passed to options.readField.\n field: FieldNode | null;\n\n variables?: TVars;\n\n // Utilities for dealing with { __ref } objects.\n isReference: typeof isReference;\n toReference: ToReferenceFunction;\n\n // A handy place to put field-specific data that you want to survive\n // across multiple read function calls. Useful for field-level caching,\n // if your read function does any expensive work.\n storage: StorageType;\n\n cache: InMemoryCache;\n\n // Helper function for reading other fields within the current object.\n // If a foreign object or reference is provided, the field will be read\n // from that object instead of the current object, so this function can\n // be used (together with isReference) to examine the cache outside the\n // current object. If a FieldNode is passed instead of a string, and\n // that FieldNode has arguments, the same options.variables will be used\n // to compute the argument values. Note that this function will invoke\n // custom read functions for other fields, if defined. Always returns\n // immutable data (enforced with Object.freeze in development).\n readField: ReadFieldFunction;\n\n // Returns true for non-normalized StoreObjects and non-dangling\n // References, indicating that readField(name, objOrRef) has a chance of\n // working. Useful for filtering out dangling references from lists.\n canRead: CanReadFunction;\n\n // Instead of just merging objects with { ...existing, ...incoming }, this\n // helper function can be used to merge objects in a way that respects any\n // custom merge functions defined for their fields.\n mergeObjects: MergeObjectsFunction;\n}\n\ntype MergeObjectsFunction = <T extends StoreObject | Reference>(\n existing: T,\n incoming: T,\n) => T;\n\nexport type FieldReadFunction<\n TExisting = any,\n TReadResult = TExisting,\n TOptions extends FieldFunctionOptions = FieldFunctionOptions\n> = (\n // When reading a field, one often needs to know about any existing\n // value stored for that field. If the field is read before any value\n // has been written to the cache, this existing parameter will be\n // undefined, which makes it easy to use a default parameter expression\n // to supply the initial value. This parameter is positional (rather\n // than one of the named options) because that makes it possible for the\n // developer to annotate it with a type, without also having to provide\n // a whole new type for the options object.\n existing: SafeReadonly<TExisting> | undefined,\n options: TOptions,\n) => TReadResult | undefined;\n\nexport type FieldMergeFunction<\n TExisting = any,\n TIncoming = TExisting,\n // Passing the whole FieldFunctionOptions makes the current definition\n // independent from its implementation\n TOptions extends FieldFunctionOptions = FieldFunctionOptions\n> = (\n existing: SafeReadonly<TExisting> | undefined,\n // The incoming parameter needs to be positional as well, for the same\n // reasons discussed in FieldReadFunction above.\n incoming: SafeReadonly<TIncoming>,\n options: TOptions,\n) => SafeReadonly<TExisting>;\n\nconst nullKeyFieldsFn: KeyFieldsFunction = () => void 0;\nconst simpleKeyArgsFn: KeyArgsFunction = (_args, context) => context.fieldName;\n\n// These merge functions can be selected by specifying merge:true or\n// merge:false in a field policy.\nconst mergeTrueFn: FieldMergeFunction<any> =\n (existing, incoming, { mergeObjects }) => mergeObjects(existing, incoming);\nconst mergeFalseFn: FieldMergeFunction<any> = (_, incoming) => incoming;\n\nexport type PossibleTypesMap = {\n [supertype: string]: string[];\n};\n\nexport class Policies {\n private typePolicies: {\n [__typename: string]: {\n keyFn?: KeyFieldsFunction;\n merge?: FieldMergeFunction<any>;\n fields: {\n [fieldName: string]: {\n keyFn?: KeyArgsFunction;\n read?: FieldReadFunction<any>;\n merge?: FieldMergeFunction<any>;\n };\n };\n };\n } = Object.create(null);\n\n private toBeAdded: {\n [__typename: string]: TypePolicy[];\n } = Object.create(null);\n\n // Map from subtype names to sets of supertype names. Note that this\n // representation inverts the structure of possibleTypes (whose keys are\n // supertypes and whose values are arrays of subtypes) because it tends\n // to be much more efficient to search upwards than downwards.\n private supertypeMap = new Map<string, Set<string>>();\n\n // Any fuzzy subtypes specified by possibleTypes will be converted to\n // RegExp objects and recorded here. Every key of this map can also be\n // found in supertypeMap. In many cases this Map will be empty, which\n // means no fuzzy subtype checking will happen in fragmentMatches.\n private fuzzySubtypes = new Map<string, RegExp>();\n\n public readonly cache: InMemoryCache;\n\n public readonly rootIdsByTypename: Record<string, string> = Object.create(null);\n public readonly rootTypenamesById: Record<string, string> = Object.create(null);\n\n public readonly usingPossibleTypes = false;\n\n constructor(private config: {\n cache: InMemoryCache;\n dataIdFromObject?: KeyFieldsFunction;\n possibleTypes?: PossibleTypesMap;\n typePolicies?: TypePolicies;\n }) {\n this.config = {\n dataIdFromObject: defaultDataIdFromObject,\n ...config,\n };\n\n this.cache = this.config.cache;\n\n this.setRootTypename(\"Query\");\n this.setRootTypename(\"Mutation\");\n this.setRootTypename(\"Subscription\");\n\n if (config.possibleTypes) {\n this.addPossibleTypes(config.possibleTypes);\n }\n\n if (config.typePolicies) {\n this.addTypePolicies(config.typePolicies);\n }\n }\n\n public identify(\n object: StoreObject,\n partialContext?: Partial<KeyFieldsContext>,\n ): [string?, StoreObject?] {\n const policies = this;\n\n const typename = partialContext && (\n partialContext.typename ||\n partialContext.storeObject?.__typename\n ) || object.__typename;\n\n // It should be possible to write root Query fields with writeFragment,\n // using { __typename: \"Query\", ... } as the data, but it does not make\n // sense to allow the same identification behavior for the Mutation and\n // Subscription types, since application code should never be writing\n // directly to (or reading directly from) those root objects.\n if (typename === this.rootTypenamesById.ROOT_QUERY) {\n return [\"ROOT_QUERY\"];\n }\n\n // Default context.storeObject to object if not otherwise provided.\n const storeObject = partialContext && partialContext.storeObject || object;\n\n const context: KeyFieldsContext = {\n ...partialContext,\n typename,\n storeObject,\n readField: partialContext && partialContext.readField || function () {\n const options = normalizeReadFieldOptions(arguments, storeObject);\n return policies.readField(options, {\n store: policies.cache[\"data\"],\n variables: options.variables,\n });\n },\n };\n\n let id: KeyFieldsResult;\n\n const policy = typename && this.getTypePolicy(typename);\n let keyFn = policy && policy.keyFn || this.config.dataIdFromObject;\n while (keyFn) {\n const specifierOrId = keyFn(object, context);\n if (isArray(specifierOrId)) {\n keyFn = keyFieldsFnFromSpecifier(specifierOrId);\n } else {\n id = specifierOrId;\n break;\n }\n }\n\n id = id ? String(id) : void 0;\n return context.keyObject ? [id, context.keyObject] : [id];\n }\n\n public addTypePolicies(typePolicies: TypePolicies) {\n Object.keys(typePolicies).forEach(typename => {\n const {\n queryType,\n mutationType,\n subscriptionType,\n ...incoming\n } = typePolicies[typename];\n\n // Though {query,mutation,subscription}Type configurations are rare,\n // it's important to call setRootTypename as early as possible,\n // since these configurations should apply consistently for the\n // entire lifetime of the cache. Also, since only one __typename can\n // qualify as one of these root types, these three properties cannot\n // be inherited, unlike the rest of the incoming properties. That\n // restriction is convenient, because the purpose of this.toBeAdded\n // is to delay the processing of type/field policies until the first\n // time they're used, allowing policies to be added in any order as\n // long as all relevant policies (including policies for supertypes)\n // have been added by the time a given policy is used for the first\n // time. In other words, since inheritance doesn't matter for these\n // properties, there's also no need to delay their processing using\n // the this.toBeAdded queue.\n if (queryType) this.setRootTypename(\"Query\", typename);\n if (mutationType) this.setRootTypename(\"Mutation\", typename);\n if (subscriptionType) this.setRootTypename(\"Subscription\", typename);\n\n if (hasOwn.call(this.toBeAdded, typename)) {\n this.toBeAdded[typename].push(incoming);\n } else {\n this.toBeAdded[typename] = [incoming];\n }\n });\n }\n\n private updateTypePolicy(typename: string, incoming: TypePolicy) {\n const existing = this.getTypePolicy(typename);\n const { keyFields, fields } = incoming;\n\n function setMerge(\n existing: { merge?: FieldMergeFunction | boolean; },\n merge?: FieldMergeFunction | boolean,\n ) {\n existing.merge =\n typeof merge === \"function\" ? merge :\n // Pass merge:true as a shorthand for a merge implementation\n // that returns options.mergeObjects(existing, incoming).\n merge === true ? mergeTrueFn :\n // Pass merge:false to make incoming always replace existing\n // without any warnings about data clobbering.\n merge === false ? mergeFalseFn :\n existing.merge;\n }\n\n // Type policies can define merge functions, as an alternative to\n // using field policies to merge child objects.\n setMerge(existing, incoming.merge);\n\n existing.keyFn =\n // Pass false to disable normalization for this typename.\n keyFields === false ? nullKeyFieldsFn :\n // Pass an array of strings to use those fields to compute a\n // composite ID for objects of this typename.\n isArray(keyFields) ? keyFieldsFnFromSpecifier(keyFields) :\n // Pass a function to take full control over identification.\n typeof keyFields === \"function\" ? keyFields :\n // Leave existing.keyFn unchanged if above cases fail.\n existing.keyFn;\n\n if (fields) {\n Object.keys(fields).forEach(fieldName => {\n const existing = this.getFieldPolicy(typename, fieldName, true)!;\n const incoming = fields[fieldName];\n\n if (typeof incoming === \"function\") {\n existing.read = incoming;\n } else {\n const { keyArgs, read, merge } = incoming;\n\n existing.keyFn =\n // Pass false to disable argument-based differentiation of\n // field identities.\n keyArgs === false ? simpleKeyArgsFn :\n // Pass an array of strings to use named arguments to\n // compute a composite identity for the field.\n isArray(keyArgs) ? keyArgsFnFromSpecifier(keyArgs) :\n // Pass a function to take full control over field identity.\n typeof keyArgs === \"function\" ? keyArgs :\n // Leave existing.keyFn unchanged if above cases fail.\n existing.keyFn;\n\n if (typeof read === \"function\") {\n existing.read = read;\n }\n\n setMerge(existing, merge);\n }\n\n if (existing.read && existing.merge) {\n // If we have both a read and a merge function, assume\n // keyArgs:false, because read and merge together can take\n // responsibility for interpreting arguments in and out. This\n // default assumption can always be overridden by specifying\n // keyArgs explicitly in the FieldPolicy.\n existing.keyFn = existing.keyFn || simpleKeyArgsFn;\n }\n });\n }\n }\n\n private setRootTypename(\n which: \"Query\" | \"Mutation\" | \"Subscription\",\n typename: string = which,\n ) {\n const rootId = \"ROOT_\" + which.toUpperCase();\n const old = this.rootTypenamesById[rootId];\n if (typename !== old) {\n invariant(!old || old === which, `Cannot change root ${which} __typename more than once`);\n // First, delete any old __typename associated with this rootId from\n // rootIdsByTypename.\n if (old) delete this.rootIdsByTypename[old];\n // Now make this the only __typename that maps to this rootId.\n this.rootIdsByTypename[typename] = rootId;\n // Finally, update the __typename associated with this rootId.\n this.rootTypenamesById[rootId] = typename;\n }\n }\n\n public addPossibleTypes(possibleTypes: PossibleTypesMap) {\n (this.usingPossibleTypes as boolean) = true;\n Object.keys(possibleTypes).forEach(supertype => {\n // Make sure all types have an entry in this.supertypeMap, even if\n // their supertype set is empty, so we can return false immediately\n // from policies.fragmentMatches for unknown supertypes.\n this.getSupertypeSet(supertype, true);\n\n possibleTypes[supertype].forEach(subtype => {\n this.getSupertypeSet(subtype, true)!.add(supertype);\n const match = subtype.match(TypeOrFieldNameRegExp);\n if (!match || match[0] !== subtype) {\n // TODO Don't interpret just any invalid typename as a RegExp.\n this.fuzzySubtypes.set(subtype, new RegExp(subtype));\n }\n });\n });\n }\n\n private getTypePolicy(typename: string): Policies[\"typePolicies\"][string] {\n if (!hasOwn.call(this.typePolicies, typename)) {\n const policy: Policies[\"typePolicies\"][string] =\n this.typePolicies[typename] = Object.create(null);\n policy.fields = Object.create(null);\n\n // When the TypePolicy for typename is first accessed, instead of\n // starting with an empty policy object, inherit any properties or\n // fields from the type policies of the supertypes of typename.\n //\n // Any properties or fields defined explicitly within the TypePolicy\n // for typename will take precedence, and if there are multiple\n // supertypes, the properties of policies whose types were added\n // later via addPossibleTypes will take precedence over those of\n // earlier supertypes. TODO Perhaps we should warn about these\n // conflicts in development, and recommend defining the property\n // explicitly in the subtype policy?\n //\n // Field policy inheritance is atomic/shallow: you can't inherit a\n // field policy and then override just its read function, since read\n // and merge functions often need to cooperate, so changing only one\n // of them would be a recipe for inconsistency.\n //\n // Once the TypePolicy for typename has been accessed, its\n // properties can still be updated directly using addTypePolicies,\n // but future changes to supertype policies will not be reflected in\n // this policy, because this code runs at most once per typename.\n const supertypes = this.supertypeMap.get(typename);\n if (supertypes && supertypes.size) {\n supertypes.forEach(supertype => {\n const { fields, ...rest } = this.getTypePolicy(supertype);\n Object.assign(policy, rest);\n Object.assign(policy.fields, fields);\n });\n }\n }\n\n const inbox = this.toBeAdded[typename];\n if (inbox && inbox.length) {\n // Merge the pending policies into this.typePolicies, in the order they\n // were originally passed to addTypePolicy.\n inbox.splice(0).forEach(policy => {\n this.updateTypePolicy(typename, policy);\n });\n }\n\n return this.typePolicies[typename];\n }\n\n private getFieldPolicy(\n typename: string | undefined,\n fieldName: string,\n createIfMissing: boolean,\n ): {\n keyFn?: KeyArgsFunction;\n read?: FieldReadFunction<any>;\n merge?: FieldMergeFunction<any>;\n } | undefined {\n if (typename) {\n const fieldPolicies = this.getTypePolicy(typename).fields;\n return fieldPolicies[fieldName] || (\n createIfMissing && (fieldPolicies[fieldName] = Object.create(null)));\n }\n }\n\n private getSupertypeSet(\n subtype: string,\n createIfMissing: boolean,\n ): Set<string> | undefined {\n let supertypeSet = this.supertypeMap.get(subtype);\n if (!supertypeSet && createIfMissing) {\n this.supertypeMap.set(subtype, supertypeSet = new Set<string>());\n }\n return supertypeSet;\n }\n\n public fragmentMatches(\n fragment: InlineFragmentNode | FragmentDefinitionNode,\n typename: string | undefined,\n result?: Record<string, any>,\n variables?: Record<string, any>,\n ): boolean {\n if (!fragment.typeCondition) return true;\n\n // If the fragment has a type condition but the object we're matching\n // against does not have a __typename, the fragment cannot match.\n if (!typename) return false;\n\n const supertype = fragment.typeCondition.name.value;\n // Common case: fragment type condition and __typename are the same.\n if (typename === supertype) return true;\n\n if (this.usingPossibleTypes &&\n this.supertypeMap.has(supertype)) {\n const typenameSupertypeSet = this.getSupertypeSet(typename, true)!;\n const workQueue = [typenameSupertypeSet];\n const maybeEnqueue = (subtype: string) => {\n const supertypeSet = this.getSupertypeSet(subtype, false);\n if (supertypeSet &&\n supertypeSet.size &&\n workQueue.indexOf(supertypeSet) < 0) {\n workQueue.push(supertypeSet);\n }\n };\n\n // We need to check fuzzy subtypes only if we encountered fuzzy\n // subtype strings in addPossibleTypes, and only while writing to\n // the cache, since that's when selectionSetMatchesResult gives a\n // strong signal of fragment matching. The StoreReader class calls\n // policies.fragmentMatches without passing a result object, so\n // needToCheckFuzzySubtypes is always false while reading.\n let needToCheckFuzzySubtypes = !!(result && this.fuzzySubtypes.size);\n let checkingFuzzySubtypes = false;\n\n // It's important to keep evaluating workQueue.length each time through\n // the loop, because the queue can grow while we're iterating over it.\n for (let i = 0; i < workQueue.length; ++i) {\n const supertypeSet = workQueue[i];\n\n if (supertypeSet.has(supertype)) {\n if (!typenameSupertypeSet.has(supertype)) {\n if (checkingFuzzySubtypes) {\n invariant.warn(`Inferring subtype ${typename} of supertype ${supertype}`);\n }\n // Record positive results for faster future lookup.\n // Unfortunately, we cannot safely cache negative results,\n // because new possibleTypes data could always be added to the\n // Policies class.\n typenameSupertypeSet.add(supertype);\n }\n return true;\n }\n\n supertypeSet.forEach(maybeEnqueue);\n\n if (needToCheckFuzzySubtypes &&\n // Start checking fuzzy subtypes only after exhausting all\n // non-fuzzy subtypes (after the final iteration of the loop).\n i === workQueue.length - 1 &&\n // We could wait to compare fragment.selectionSet to result\n // after we verify the supertype, but this check is often less\n // expensive than that search, and we will have to do the\n // comparison anyway whenever we find a potential match.\n selectionSetMatchesResult(fragment.selectionSet, result!, variables)) {\n // We don't always need to check fuzzy subtypes (if no result\n // was provided, or !this.fuzzySubtypes.size), but, when we do,\n // we only want to check them once.\n needToCheckFuzzySubtypes = false;\n checkingFuzzySubtypes = true;\n\n // If we find any fuzzy subtypes that match typename, extend the\n // workQueue to search through the supertypes of those fuzzy\n // subtypes. Otherwise the for-loop will terminate and we'll\n // return false below.\n this.fuzzySubtypes.forEach((regExp, fuzzyString) => {\n const match = typename.match(regExp);\n if (match && match[0] === typename) {\n maybeEnqueue(fuzzyString);\n }\n });\n }\n }\n }\n\n return false;\n }\n\n public hasKeyArgs(typename: string | undefined, fieldName: string) {\n const policy = this.getFieldPolicy(typename, fieldName, false);\n return !!(policy && policy.keyFn);\n }\n\n public getStoreFieldName(fieldSpec: FieldSpecifier): string {\n const { typename, fieldName } = fieldSpec;\n const policy = this.getFieldPolicy(typename, fieldName, false);\n let storeFieldName: Exclude<ReturnType<KeyArgsFunction>, KeySpecifier>;\n\n let keyFn = policy && policy.keyFn;\n if (keyFn && typename) {\n const context: Parameters<KeyArgsFunction>[1] = {\n typename,\n fieldName,\n field: fieldSpec.field || null,\n variables: fieldSpec.variables,\n };\n const args = argsFromFieldSpecifier(fieldSpec);\n while (keyFn) {\n const specifierOrString = keyFn(args, context);\n if (isArray(specifierOrString)) {\n keyFn = keyArgsFnFromSpecifier(specifierOrString);\n } else {\n // If the custom keyFn returns a falsy value, fall back to\n // fieldName instead.\n storeFieldName = specifierOrString || fieldName;\n break;\n }\n }\n }\n\n if (storeFieldName === void 0) {\n storeFieldName = fieldSpec.field\n ? storeKeyNameFromField(fieldSpec.field, fieldSpec.variables)\n : getStoreKeyName(fieldName, argsFromFieldSpecifier(fieldSpec));\n }\n\n // Returning false from a keyArgs function is like configuring\n // keyArgs: false, but more dynamic.\n if (storeFieldName === false) {\n return fieldName;\n }\n\n // Make sure custom field names start with the actual field.name.value\n // of the field, so we can always figure out which properties of a\n // StoreObject correspond to which original field names.\n return fieldName === fieldNameFromStoreName(storeFieldName)\n ? storeFieldName\n : fieldName + \":\" + storeFieldName;\n }\n\n public readField<V = StoreValue>(\n options: ReadFieldOptions,\n context: ReadMergeModifyContext,\n ): SafeReadonly<V> | undefined {\n const objectOrReference = options.from;\n if (!objectOrReference) return;\n\n const nameOrField = options.field || options.fieldName;\n if (!nameOrField) return;\n\n if (options.typename === void 0) {\n const typename = context.store.getFieldValue<string>(objectOrReference, \"__typename\");\n if (typename) options.typename = typename;\n }\n\n const storeFieldName = this.getStoreFieldName(options);\n const fieldName = fieldNameFromStoreName(storeFieldName);\n const existing = context.store.getFieldValue<V>(objectOrReference, storeFieldName);\n const policy = this.getFieldPolicy(options.typename, fieldName, false);\n const read = policy && policy.read;\n\n if (read) {\n const readOptions = makeFieldFunctionOptions(\n this,\n objectOrReference,\n options,\n context,\n context.store.getStorage(\n isReference(objectOrReference)\n ? objectOrReference.__ref\n : objectOrReference,\n storeFieldName,\n ),\n );\n\n // Call read(existing, readOptions) with cacheSlot holding this.cache.\n return cacheSlot.withValue(\n this.cache,\n read,\n [existing, readOptions],\n ) as SafeReadonly<V>;\n }\n\n return existing;\n }\n\n public getReadFunction(\n typename: string | undefined,\n fieldName: string,\n ): FieldReadFunction | undefined {\n const policy = this.getFieldPolicy(typename, fieldName, false);\n return policy && policy.read;\n }\n\n public getMergeFunction(\n parentTypename: string | undefined,\n fieldName: string,\n childTypename: string | undefined,\n ): FieldMergeFunction | undefined {\n let policy:\n | Policies[\"typePolicies\"][string]\n | Policies[\"typePolicies\"][string][\"fields\"][string]\n | undefined =\n this.getFieldPolicy(parentTypename, fieldName, false);\n let merge = policy && policy.merge;\n if (!merge && childTypename) {\n policy = this.getTypePolicy(childTypename);\n merge = policy && policy.merge;\n }\n return merge;\n }\n\n public runMergeFunction(\n existing: StoreValue,\n incoming: StoreValue,\n { field, typename, merge }: MergeInfo,\n context: WriteContext,\n storage?: StorageType,\n ) {\n if (merge === mergeTrueFn) {\n // Instead of going to the trouble of creating a full\n // FieldFunctionOptions object and calling mergeTrueFn, we can\n // simply call mergeObjects, as mergeTrueFn would.\n return makeMergeObjectsFunction(\n context.store,\n )(existing as StoreObject,\n incoming as StoreObject);\n }\n\n if (merge === mergeFalseFn) {\n // Likewise for mergeFalseFn, whose implementation is even simpler.\n return incoming;\n }\n\n // If cache.writeQuery or cache.writeFragment was called with\n // options.overwrite set to true, we still call merge functions, but\n // the existing data is always undefined, so the merge function will\n // not attempt to combine the incoming data with the existing data.\n if (context.overwrite) {\n existing = void 0;\n }\n\n return merge(existing, incoming, makeFieldFunctionOptions(\n this,\n // Unlike options.readField for read functions, we do not fall\n // back to the current object if no foreignObjOrRef is provided,\n // because it's not clear what the current object should be for\n // merge functions: the (possibly undefined) existing object, or\n // the incoming object? If you think your merge function needs\n // to read sibling fields in order to produce a new value for\n // the current field, you might want to rethink your strategy,\n // because that's a recipe for making merge behavior sensitive\n // to the order in which fields are written into the cache.\n // However, readField(name, ref) is useful for merge functions\n // that need to deduplicate child objects and references.\n void 0,\n { typename,\n fieldName: field.name.value,\n field,\n variables: context.variables },\n context,\n storage || Object.create(null),\n ));\n }\n}\n\nfunction makeFieldFunctionOptions(\n policies: Policies,\n objectOrReference: StoreObject | Reference | undefined,\n fieldSpec: FieldSpecifier,\n context: ReadMergeModifyContext,\n storage: StorageType,\n): FieldFunctionOptions {\n const storeFieldName = policies.getStoreFieldName(fieldSpec);\n const fieldName = fieldNameFromStoreName(storeFieldName);\n const variables = fieldSpec.variables || context.variables;\n const { toReference, canRead } = context.store;\n\n return {\n args: argsFromFieldSpecifier(fieldSpec),\n field: fieldSpec.field || null,\n fieldName,\n storeFieldName,\n variables,\n isReference,\n toReference,\n storage,\n cache: policies.cache,\n canRead,\n readField<T>() {\n return policies.readField<T>(\n normalizeReadFieldOptions(arguments, objectOrReference, variables),\n context,\n );\n },\n mergeObjects: makeMergeObjectsFunction(context.store),\n };\n}\n\nexport function normalizeReadFieldOptions(\n readFieldArgs: IArguments,\n objectOrReference: StoreObject | Reference | undefined,\n variables?: ReadMergeModifyContext[\"variables\"],\n): ReadFieldOptions {\n const {\n 0: fieldNameOrOptions,\n 1: from,\n length: argc,\n } = readFieldArgs;\n\n let options: ReadFieldOptions;\n\n if (typeof fieldNameOrOptions === \"string\") {\n options = {\n fieldName: fieldNameOrOptions,\n // Default to objectOrReference only when no second argument was\n // passed for the from parameter, not when undefined is explicitly\n // passed as the second argument.\n from: argc > 1 ? from : objectOrReference,\n };\n } else {\n options = { ...fieldNameOrOptions };\n // Default to objectOrReference only when fieldNameOrOptions.from is\n // actually omitted, rather than just undefined.\n if (!hasOwn.call(options, \"from\")) {\n options.from = objectOrReference;\n }\n }\n\n if (__DEV__ && options.from === void 0) {\n invariant.warn(`Undefined 'from' passed to readField with arguments ${\n stringifyForDisplay(Array.from(readFieldArgs))\n }`);\n }\n\n if (void 0 === options.variables) {\n options.variables = variables;\n }\n\n return options;\n}\n\nfunction makeMergeObjectsFunction(\n store: NormalizedCache,\n): MergeObjectsFunction {\n return function mergeObjects(existing, incoming) {\n if (isArray(existing) || isArray(incoming)) {\n throw new InvariantError(\"Cannot automatically merge arrays\");\n }\n\n // These dynamic checks are necessary because the parameters of a\n // custom merge function can easily have the any type, so the type\n // system cannot always enforce the StoreObject | Reference parameter\n // types of options.mergeObjects.\n if (isNonNullObject(existing) &&\n isNonNullObject(incoming)) {\n const eType = store.getFieldValue(existing, \"__typename\");\n const iType = store.getFieldValue(incoming, \"__typename\");\n const typesDiffer = eType && iType && eType !== iType;\n\n if (typesDiffer) {\n return incoming;\n }\n\n if (isReference(existing) &&\n storeValueIsStoreObject(incoming)) {\n // Update the normalized EntityStore for the entity identified by\n // existing.__ref, preferring/overwriting any fields contributed by the\n // newer incoming StoreObject.\n store.merge(existing.__ref, incoming);\n return existing;\n }\n\n if (storeValueIsStoreObject(existing) &&\n isReference(incoming)) {\n // Update the normalized EntityStore for the entity identified by\n // incoming.__ref, taking fields from the older existing object only if\n // those fields are not already present in the newer StoreObject\n // identified by incoming.__ref.\n store.merge(existing, incoming.__ref);\n return incoming;\n }\n\n if (storeValueIsStoreObject(existing) &&\n storeValueIsStoreObject(incoming)) {\n return { ...existing, ...incoming };\n }\n }\n\n return incoming;\n };\n}\n","import { makeUniqueId } from \"./makeUniqueId\";\n\nexport function stringifyForDisplay(value: any): string {\n const undefId = makeUniqueId(\"stringifyForDisplay\");\n return JSON.stringify(value, (key, value) => {\n return value === void 0 ? undefId : value;\n }).split(JSON.stringify(undefId)).join(\"<undefined>\");\n}\n","import { invariant, InvariantError } from '../../utilities/globals';\nimport { equal } from '@wry/equality';\nimport { Trie } from '@wry/trie';\nimport {\n SelectionSetNode,\n FieldNode,\n} from 'graphql';\n\nimport {\n createFragmentMap,\n FragmentMap,\n getFragmentFromSelection,\n getDefaultValues,\n getFragmentDefinitions,\n getOperationDefinition,\n getTypenameFromResult,\n makeReference,\n isField,\n resultKeyNameFromField,\n StoreValue,\n StoreObject,\n Reference,\n isReference,\n shouldInclude,\n cloneDeep,\n addTypenameToDocument,\n isNonEmptyArray,\n argumentsObjectFromField,\n} from '../../utilities';\n\nimport { NormalizedCache, ReadMergeModifyContext, MergeTree } from './types';\nimport { makeProcessedFieldsMerger, fieldNameFromStoreName, storeValueIsStoreObject, isArray } from './helpers';\nimport { StoreReader } from './readFromStore';\nimport { InMemoryCache } from './inMemoryCache';\nimport { EntityStore } from './entityStore';\nimport { Cache } from '../../core';\nimport { canonicalStringify } from './object-canon';\nimport { normalizeReadFieldOptions } from './policies';\nimport { ReadFieldFunction } from '../core/types/common';\n\nexport interface WriteContext extends ReadMergeModifyContext {\n readonly written: {\n [dataId: string]: SelectionSetNode[];\n };\n readonly fragmentMap?: FragmentMap;\n // General-purpose deep-merge function for use during writes.\n merge<T>(existing: T, incoming: T): T;\n // If true, merge functions will be called with undefined existing data.\n overwrite: boolean;\n incomingById: Map<string, {\n storeObject: StoreObject;\n mergeTree?: MergeTree;\n fieldNodeSet: Set<FieldNode>;\n }>;\n // Directive metadata for @client and @defer. We could use a bitfield for this\n // information to save some space, and use that bitfield number as the keys in\n // the context.flavors Map.\n clientOnly: boolean;\n deferred: boolean;\n flavors: Map<string, FlavorableWriteContext>;\n};\n\ntype FlavorableWriteContext = Pick<\n WriteContext,\n | \"clientOnly\"\n | \"deferred\"\n | \"flavors\"\n>;\n\n// Since there are only four possible combinations of context.clientOnly and\n// context.deferred values, we should need at most four \"flavors\" of any given\n// WriteContext. To avoid creating multiple copies of the same context, we cache\n// the contexts in the context.flavors Map (shared by all flavors) according to\n// their clientOnly and deferred values (always in that order).\nfunction getContextFlavor<TContext extends FlavorableWriteContext>(\n context: TContext,\n clientOnly: TContext[\"clientOnly\"],\n deferred: TContext[\"deferred\"],\n): TContext {\n const key = `${clientOnly}${deferred}`;\n let flavored = context.flavors.get(key);\n if (!flavored) {\n context.flavors.set(key, flavored = (\n context.clientOnly === clientOnly &&\n context.deferred === deferred\n ) ? context : {\n ...context,\n clientOnly,\n deferred,\n });\n }\n return flavored as TContext;\n}\n\ninterface ProcessSelectionSetOptions {\n dataId?: string,\n result: Record<string, any>;\n selectionSet: SelectionSetNode;\n context: WriteContext;\n mergeTree: MergeTree;\n}\n\nexport class StoreWriter {\n constructor(\n public readonly cache: InMemoryCache,\n private reader?: StoreReader,\n ) {}\n\n public writeToStore(store: NormalizedCache, {\n query,\n result,\n dataId,\n variables,\n overwrite,\n }: Cache.WriteOptions): Reference | undefined {\n const operationDefinition = getOperationDefinition(query)!;\n const merger = makeProcessedFieldsMerger();\n\n variables = {\n ...getDefaultValues(operationDefinition),\n ...variables!,\n };\n\n const context: WriteContext = {\n store,\n written: Object.create(null),\n merge<T>(existing: T, incoming: T) {\n return merger.merge(existing, incoming) as T;\n },\n variables,\n varString: canonicalStringify(variables),\n fragmentMap: createFragmentMap(getFragmentDefinitions(query)),\n overwrite: !!overwrite,\n incomingById: new Map,\n clientOnly: false,\n deferred: false,\n flavors: new Map,\n };\n\n const ref = this.processSelectionSet({\n result: result || Object.create(null),\n dataId,\n selectionSet: operationDefinition.selectionSet,\n mergeTree: { map: new Map },\n context,\n });\n\n if (!isReference(ref)) {\n throw new InvariantError(`Could not identify object ${JSON.stringify(result)}`);\n }\n\n // So far, the store has not been modified, so now it's time to process\n // context.incomingById and merge those incoming fields into context.store.\n context.incomingById.forEach(({ storeObject, mergeTree, fieldNodeSet }, dataId) => {\n const entityRef = makeReference(dataId);\n\n if (mergeTree && mergeTree.map.size) {\n const applied = this.applyMerges(mergeTree, entityRef, storeObject, context);\n if (isReference(applied)) {\n // Assume References returned by applyMerges have already been merged\n // into the store. See makeMergeObjectsFunction in policies.ts for an\n // example of how this can happen.\n return;\n }\n // Otherwise, applyMerges returned a StoreObject, whose fields we should\n // merge into the store (see store.merge statement below).\n storeObject = applied;\n }\n\n if (__DEV__ && !context.overwrite) {\n const fieldsWithSelectionSets: Record<string, true> = Object.create(null);\n fieldNodeSet.forEach(field => {\n if (field.selectionSet) {\n fieldsWithSelectionSets[field.name.value] = true;\n }\n });\n\n const hasSelectionSet = (storeFieldName: string) =>\n fieldsWithSelectionSets[\n fieldNameFromStoreName(storeFieldName)\n ] === true;\n\n const hasMergeFunction = (storeFieldName: string) => {\n const childTree = mergeTree && mergeTree.map.get(storeFieldName);\n return Boolean(childTree && childTree.info && childTree.info.merge);\n };\n\n Object.keys(storeObject).forEach(storeFieldName => {\n // If a merge function was defined for this field, trust that it\n // did the right thing about (not) clobbering data. If the field\n // has no selection set, it's a scalar field, so it doesn't need\n // a merge function (even if it's an object, like JSON data).\n if (hasSelectionSet(storeFieldName) &&\n !hasMergeFunction(storeFieldName)) {\n warnAboutDataLoss(\n entityRef,\n storeObject,\n storeFieldName,\n context.store,\n );\n }\n });\n }\n\n store.merge(dataId, storeObject);\n });\n\n // Any IDs written explicitly to the cache will be retained as\n // reachable root IDs for garbage collection purposes. Although this\n // logic includes root IDs like ROOT_QUERY and ROOT_MUTATION, their\n // retainment counts are effectively ignored because cache.gc() always\n // includes them in its root ID set.\n store.retain(ref.__ref);\n\n return ref;\n }\n\n private processSelectionSet({\n dataId,\n result,\n selectionSet,\n context,\n // This object allows processSelectionSet to report useful information\n // to its callers without explicitly returning that information.\n mergeTree,\n }: ProcessSelectionSetOptions): StoreObject | Reference {\n const { policies } = this.cache;\n\n // This variable will be repeatedly updated using context.merge to\n // accumulate all fields that need to be written into the store.\n let incoming: StoreObject = Object.create(null);\n\n // If typename was not passed in, infer it. Note that typename is\n // always passed in for tricky-to-infer cases such as \"Query\" for\n // ROOT_QUERY.\n const typename: string | undefined =\n (dataId && policies.rootTypenamesById[dataId]) ||\n getTypenameFromResult(result, selectionSet, context.fragmentMap) ||\n (dataId && context.store.get(dataId, \"__typename\") as string);\n\n if (\"string\" === typeof typename) {\n incoming.__typename = typename;\n }\n\n // This readField function will be passed as context.readField in the\n // KeyFieldsContext object created within policies.identify (called below).\n // In addition to reading from the existing context.store (thanks to the\n // policies.readField(options, context) line at the very bottom), this\n // version of readField can read from Reference objects that are currently\n // pending in context.incomingById, which is important whenever keyFields\n // need to be extracted from a child object that processSelectionSet has\n // turned into a Reference.\n const readField: ReadFieldFunction = function (this: void) {\n const options = normalizeReadFieldOptions(\n arguments,\n incoming,\n context.variables,\n );\n\n if (isReference(options.from)) {\n const info = context.incomingById.get(options.from.__ref);\n if (info) {\n const result = policies.readField({\n ...options,\n from: info.storeObject\n }, context);\n\n if (result !== void 0) {\n return result;\n }\n }\n }\n\n return policies.readField(options, context);\n };\n\n const fieldNodeSet = new Set<FieldNode>();\n\n this.flattenFields(\n selectionSet,\n result,\n // This WriteContext will be the default context value for fields returned\n // by the flattenFields method, but some fields may be assigned a modified\n // context, depending on the presence of @client and other directives.\n context,\n typename,\n ).forEach((context, field) => {\n const resultFieldKey = resultKeyNameFromField(field);\n const value = result[resultFieldKey];\n\n fieldNodeSet.add(field);\n\n if (value !== void 0) {\n const storeFieldName = policies.getStoreFieldName({\n typename,\n fieldName: field.name.value,\n field,\n variables: context.variables,\n });\n\n const childTree = getChildMergeTree(mergeTree, storeFieldName);\n\n let incomingValue = this.processFieldValue(\n value,\n field,\n // Reset context.clientOnly and context.deferred to their default\n // values before processing nested selection sets.\n field.selectionSet\n ? getContextFlavor(context, false, false)\n : context,\n childTree,\n );\n\n // To determine if this field holds a child object with a merge function\n // defined in its type policy (see PR #7070), we need to figure out the\n // child object's __typename.\n let childTypename: string | undefined;\n\n // The field's value can be an object that has a __typename only if the\n // field has a selection set. Otherwise incomingValue is scalar.\n if (field.selectionSet &&\n (isReference(incomingValue) ||\n storeValueIsStoreObject(incomingValue))) {\n childTypename = readField<string>(\"__typename\", incomingValue);\n }\n\n const merge = policies.getMergeFunction(\n typename,\n field.name.value,\n childTypename,\n );\n\n if (merge) {\n childTree.info = {\n // TODO Check compatibility against any existing childTree.field?\n field,\n typename,\n merge,\n };\n } else {\n maybeRecycleChildMergeTree(mergeTree, storeFieldName);\n }\n\n incoming = context.merge(incoming, {\n [storeFieldName]: incomingValue,\n });\n\n } else if (\n __DEV__ &&\n !context.clientOnly &&\n !context.deferred &&\n !addTypenameToDocument.added(field) &&\n // If the field has a read function, it may be a synthetic field or\n // provide a default value, so its absence from the written data should\n // not be cause for alarm.\n !policies.getReadFunction(typename, field.name.value)\n ) {\n invariant.error(`Missing field '${\n resultKeyNameFromField(field)\n }' while writing result ${\n JSON.stringify(result, null, 2)\n }`.substring(0, 1000));\n }\n });\n\n // Identify the result object, even if dataId was already provided,\n // since we always need keyObject below.\n try {\n const [id, keyObject] = policies.identify(result, {\n typename,\n selectionSet,\n fragmentMap: context.fragmentMap,\n storeObject: incoming,\n readField,\n });\n\n // If dataId was not provided, fall back to the id just generated by\n // policies.identify.\n dataId = dataId || id;\n\n // Write any key fields that were used during identification, even if\n // they were not mentioned in the original query.\n if (keyObject) {\n // TODO Reverse the order of the arguments?\n incoming = context.merge(incoming, keyObject);\n }\n } catch (e) {\n // If dataId was provided, tolerate failure of policies.identify.\n if (!dataId) throw e;\n }\n\n if (\"string\" === typeof dataId) {\n const dataRef = makeReference(dataId);\n\n // Avoid processing the same entity object using the same selection\n // set more than once. We use an array instead of a Set since most\n // entity IDs will be written using only one selection set, so the\n // size of this array is likely to be very small, meaning indexOf is\n // likely to be faster than Set.prototype.has.\n const sets = context.written[dataId] || (context.written[dataId] = []);\n if (sets.indexOf(selectionSet) >= 0) return dataRef;\n sets.push(selectionSet);\n\n // If we're about to write a result object into the store, but we\n // happen to know that the exact same (===) result object would be\n // returned if we were to reread the result with the same inputs,\n // then we can skip the rest of the processSelectionSet work for\n // this object, and immediately return a Reference to it.\n if (this.reader && this.reader.isFresh(\n result,\n dataRef,\n selectionSet,\n context,\n )) {\n return dataRef;\n }\n\n const previous = context.incomingById.get(dataId);\n if (previous) {\n previous.storeObject = context.merge(previous.storeObject, incoming);\n previous.mergeTree = mergeMergeTrees(previous.mergeTree, mergeTree);\n fieldNodeSet.forEach(field => previous.fieldNodeSet.add(field));\n } else {\n context.incomingById.set(dataId, {\n storeObject: incoming,\n // Save a reference to mergeTree only if it is not empty, because\n // empty MergeTrees may be recycled by maybeRecycleChildMergeTree and\n // reused for entirely different parts of the result tree.\n mergeTree: mergeTreeIsEmpty(mergeTree) ? void 0 : mergeTree,\n fieldNodeSet,\n });\n }\n\n return dataRef;\n }\n\n return incoming;\n }\n\n private processFieldValue(\n value: any,\n field: FieldNode,\n context: WriteContext,\n mergeTree: MergeTree,\n ): StoreValue {\n if (!field.selectionSet || value === null) {\n // In development, we need to clone scalar values so that they can be\n // safely frozen with maybeDeepFreeze in readFromStore.ts. In production,\n // it's cheaper to store the scalar values directly in the cache.\n return __DEV__ ? cloneDeep(value) : value;\n }\n\n if (isArray(value)) {\n return value.map((item, i) => {\n const value = this.processFieldValue(\n item, field, context, getChildMergeTree(mergeTree, i));\n maybeRecycleChildMergeTree(mergeTree, i);\n return value;\n });\n }\n\n return this.processSelectionSet({\n result: value,\n selectionSet: field.selectionSet,\n context,\n mergeTree,\n });\n }\n\n // Implements https://spec.graphql.org/draft/#sec-Field-Collection, but with\n // some additions for tracking @client and @defer directives.\n private flattenFields<TContext extends Pick<\n WriteContext,\n | \"clientOnly\"\n | \"deferred\"\n | \"flavors\"\n | \"fragmentMap\"\n | \"variables\"\n >>(\n selectionSet: SelectionSetNode,\n result: Record<string, any>,\n context: TContext,\n typename = getTypenameFromResult(result, selectionSet, context.fragmentMap),\n ): Map<FieldNode, TContext> {\n const fieldMap = new Map<FieldNode, TContext>();\n const { policies } = this.cache;\n\n const limitingTrie = new Trie<{\n // Tracks whether (selectionSet, clientOnly, deferred) has been flattened\n // before. The GraphQL specification only uses the fragment name for\n // skipping previously visited fragments, but the top-level fragment\n // selection set corresponds 1:1 with the fagment name (and is slightly\n // easier too work with), and we need to consider clientOnly and deferred\n // values as well, potentially revisiting selection sets that were\n // previously visited with different inherited configurations of those\n // directives.\n visited?: boolean;\n }>(false); // No need for WeakMap, since limitingTrie does not escape.\n\n (function flatten(\n this: void,\n selectionSet: SelectionSetNode,\n inheritedContext: TContext,\n ) {\n const visitedNode = limitingTrie.lookup(\n selectionSet,\n // Because we take inheritedClientOnly and inheritedDeferred into\n // consideration here (in addition to selectionSet), it's possible for\n // the same selection set to be flattened more than once, if it appears\n // in the query with different @client and/or @directive configurations.\n inheritedContext.clientOnly,\n inheritedContext.deferred,\n );\n if (visitedNode.visited) return;\n visitedNode.visited = true;\n\n selectionSet.selections.forEach(selection => {\n if (!shouldInclude(selection, context.variables)) return;\n\n let { clientOnly, deferred } = inheritedContext;\n if (\n // Since the presence of @client or @defer on this field can only\n // cause clientOnly or deferred to become true, we can skip the\n // forEach loop if both clientOnly and deferred are already true.\n !(clientOnly && deferred) &&\n isNonEmptyArray(selection.directives)\n ) {\n selection.directives.forEach(dir => {\n const name = dir.name.value;\n if (name === \"client\") clientOnly = true;\n if (name === \"defer\") {\n const args = argumentsObjectFromField(dir, context.variables);\n // The @defer directive takes an optional args.if boolean\n // argument, similar to @include(if: boolean). Note that\n // @defer(if: false) does not make context.deferred false, but\n // instead behaves as if there was no @defer directive.\n if (!args || (args as { if?: boolean }).if !== false) {\n deferred = true;\n }\n // TODO In the future, we may want to record args.label using\n // context.deferred, if a label is specified.\n }\n });\n }\n\n if (isField(selection)) {\n const existing = fieldMap.get(selection);\n if (existing) {\n // If this field has been visited along another recursive path\n // before, the final context should have clientOnly or deferred set\n // to true only if *all* paths have the directive (hence the &&).\n clientOnly = clientOnly && existing.clientOnly;\n deferred = deferred && existing.deferred;\n }\n\n fieldMap.set(\n selection,\n getContextFlavor(context, clientOnly, deferred),\n );\n\n } else {\n const fragment =\n getFragmentFromSelection(selection, context.fragmentMap);\n\n if (fragment &&\n policies.fragmentMatches(\n fragment, typename, result, context.variables)) {\n\n flatten(\n fragment.selectionSet,\n getContextFlavor(context, clientOnly, deferred),\n );\n }\n }\n });\n })(selectionSet, context);\n\n return fieldMap;\n }\n\n private applyMerges<T extends StoreValue>(\n mergeTree: MergeTree,\n existing: StoreValue,\n incoming: T,\n context: WriteContext,\n getStorageArgs?: Parameters<EntityStore[\"getStorage\"]>,\n ): T | Reference {\n if (mergeTree.map.size && !isReference(incoming)) {\n const e: StoreObject | Reference | undefined = (\n // Items in the same position in different arrays are not\n // necessarily related to each other, so when incoming is an array\n // we process its elements as if there was no existing data.\n !isArray(incoming) &&\n // Likewise, existing must be either a Reference or a StoreObject\n // in order for its fields to be safe to merge with the fields of\n // the incoming object.\n (isReference(existing) || storeValueIsStoreObject(existing))\n ) ? existing : void 0;\n\n // This narrowing is implied by mergeTree.map.size > 0 and\n // !isReference(incoming), though TypeScript understandably cannot\n // hope to infer this type.\n const i = incoming as StoreObject | StoreValue[];\n\n // The options.storage objects provided to read and merge functions\n // are derived from the identity of the parent object plus a\n // sequence of storeFieldName strings/numbers identifying the nested\n // field name path of each field value to be merged.\n if (e && !getStorageArgs) {\n getStorageArgs = [isReference(e) ? e.__ref : e];\n }\n\n // It's possible that applying merge functions to this subtree will\n // not change the incoming data, so this variable tracks the fields\n // that did change, so we can create a new incoming object when (and\n // only when) at least one incoming field has changed. We use a Map\n // to preserve the type of numeric keys.\n let changedFields: Map<string | number, StoreValue> | undefined;\n\n const getValue = (\n from: typeof e | typeof i,\n name: string | number,\n ): StoreValue => {\n return isArray(from)\n ? (typeof name === \"number\" ? from[name] : void 0)\n : context.store.getFieldValue(from, String(name))\n };\n\n mergeTree.map.forEach((childTree, storeFieldName) => {\n const eVal = getValue(e, storeFieldName);\n const iVal = getValue(i, storeFieldName);\n // If we have no incoming data, leave any existing data untouched.\n if (void 0 === iVal) return;\n if (getStorageArgs) {\n getStorageArgs.push(storeFieldName);\n }\n const aVal = this.applyMerges(\n childTree,\n eVal,\n iVal,\n context,\n getStorageArgs,\n );\n if (aVal !== iVal) {\n changedFields = changedFields || new Map;\n changedFields.set(storeFieldName, aVal);\n }\n if (getStorageArgs) {\n invariant(getStorageArgs.pop() === storeFieldName);\n }\n });\n\n if (changedFields) {\n // Shallow clone i so we can add changed fields to it.\n incoming = (isArray(i) ? i.slice(0) : { ...i }) as T;\n changedFields.forEach((value, name) => {\n (incoming as any)[name] = value;\n });\n }\n }\n\n if (mergeTree.info) {\n return this.cache.policies.runMergeFunction(\n existing,\n incoming,\n mergeTree.info,\n context,\n getStorageArgs && context.store.getStorage(...getStorageArgs),\n );\n }\n\n return incoming;\n }\n}\n\nconst emptyMergeTreePool: MergeTree[] = [];\n\nfunction getChildMergeTree(\n { map }: MergeTree,\n name: string | number,\n): MergeTree {\n if (!map.has(name)) {\n map.set(name, emptyMergeTreePool.pop() || { map: new Map });\n }\n return map.get(name)!;\n}\n\nfunction mergeMergeTrees(\n left: MergeTree | undefined,\n right: MergeTree | undefined,\n): MergeTree {\n if (left === right || !right || mergeTreeIsEmpty(right)) return left!;\n if (!left || mergeTreeIsEmpty(left)) return right;\n\n const info = left.info && right.info ? {\n ...left.info,\n ...right.info,\n } : left.info || right.info;\n\n const needToMergeMaps = left.map.size && right.map.size;\n const map = needToMergeMaps ? new Map :\n left.map.size ? left.map : right.map;\n\n const merged = { info, map };\n\n if (needToMergeMaps) {\n const remainingRightKeys = new Set(right.map.keys());\n\n left.map.forEach((leftTree, key) => {\n merged.map.set(\n key,\n mergeMergeTrees(leftTree, right.map.get(key)),\n );\n remainingRightKeys.delete(key);\n });\n\n remainingRightKeys.forEach(key => {\n merged.map.set(\n key,\n mergeMergeTrees(\n right.map.get(key),\n left.map.get(key),\n ),\n );\n });\n }\n\n return merged;\n}\n\nfunction mergeTreeIsEmpty(tree: MergeTree | undefined): boolean {\n return !tree || !(tree.info || tree.map.size);\n}\n\nfunction maybeRecycleChildMergeTree(\n { map }: MergeTree,\n name: string | number,\n) {\n const childTree = map.get(name);\n if (childTree && mergeTreeIsEmpty(childTree)) {\n emptyMergeTreePool.push(childTree);\n map.delete(name);\n }\n}\n\nconst warnings = new Set<string>();\n\n// Note that this function is unused in production, and thus should be\n// pruned by any well-configured minifier.\nfunction warnAboutDataLoss(\n existingRef: Reference,\n incomingObj: StoreObject,\n storeFieldName: string,\n store: NormalizedCache,\n) {\n const getChild = (objOrRef: StoreObject | Reference): StoreObject | false => {\n const child = store.getFieldValue<StoreObject>(objOrRef, storeFieldName);\n return typeof child === \"object\" && child;\n };\n\n const existing = getChild(existingRef);\n if (!existing) return;\n\n const incoming = getChild(incomingObj);\n if (!incoming) return;\n\n // It's always safe to replace a reference, since it refers to data\n // safely stored elsewhere.\n if (isReference(existing)) return;\n\n // If the values are structurally equivalent, we do not need to worry\n // about incoming replacing existing.\n if (equal(existing, incoming)) return;\n\n // If we're replacing every key of the existing object, then the\n // existing data would be overwritten even if the objects were\n // normalized, so warning would not be helpful here.\n if (Object.keys(existing).every(\n key => store.getFieldValue(incoming, key) !== void 0)) {\n return;\n }\n\n const parentType =\n store.getFieldValue<string>(existingRef, \"__typename\") ||\n store.getFieldValue<string>(incomingObj, \"__typename\");\n const fieldName = fieldNameFromStoreName(storeFieldName);\n const typeDotName = `${parentType}.${fieldName}`;\n // Avoid warning more than once for the same type and field name.\n if (warnings.has(typeDotName)) return;\n warnings.add(typeDotName);\n\n const childTypenames: string[] = [];\n // Arrays do not have __typename fields, and always need a custom merge\n // function, even if their elements are normalized entities.\n if (!isArray(existing) &&\n !isArray(incoming)) {\n [existing, incoming].forEach(child => {\n const typename = store.getFieldValue(child, \"__typename\");\n if (typeof typename === \"string\" &&\n !childTypenames.includes(typename)) {\n childTypenames.push(typename);\n }\n });\n }\n\n invariant.warn(\n`Cache data may be lost when replacing the ${fieldName} field of a ${parentType} object.\n\nTo address this problem (which is not a bug in Apollo Client), ${\n childTypenames.length\n ? \"either ensure all objects of type \" +\n childTypenames.join(\" and \") + \" have an ID or a custom merge function, or \"\n : \"\"\n}define a custom merge function for the ${\n typeDotName\n} field, so InMemoryCache can safely merge these objects:\n\n existing: ${JSON.stringify(existing).slice(0, 1000)}\n incoming: ${JSON.stringify(incoming).slice(0, 1000)}\n\nFor more information about these options, please refer to the documentation:\n\n * Ensuring entity objects have IDs: https://go.apollo.dev/c/generating-unique-identifiers\n * Defining custom merge functions: https://go.apollo.dev/c/merging-non-normalized-objects\n`);\n}\n","import { invariant } from '../../utilities/globals';\n\n// Make builtins like Map and Set safe to use with non-extensible objects.\nimport './fixPolyfills';\n\nimport { DocumentNode } from 'graphql';\nimport { OptimisticWrapperFunction, wrap } from 'optimism';\nimport { equal } from '@wry/equality';\n\nimport { ApolloCache } from '../core/cache';\nimport { Cache } from '../core/types/Cache';\nimport { MissingFieldError } from '../core/types/common';\nimport {\n addTypenameToDocument,\n StoreObject,\n Reference,\n isReference,\n} from '../../utilities';\nimport { InMemoryCacheConfig, NormalizedCacheObject } from './types';\nimport { StoreReader } from './readFromStore';\nimport { StoreWriter } from './writeToStore';\nimport { EntityStore, supportsResultCaching } from './entityStore';\nimport { makeVar, forgetCache, recallCache } from './reactiveVars';\nimport { Policies } from './policies';\nimport { hasOwn, normalizeConfig, shouldCanonizeResults } from './helpers';\nimport { canonicalStringify } from './object-canon';\n\ntype BroadcastOptions = Pick<\n Cache.BatchOptions<InMemoryCache>,\n | \"optimistic\"\n | \"onWatchUpdated\"\n>\n\nexport class InMemoryCache extends ApolloCache<NormalizedCacheObject> {\n private data: EntityStore;\n private optimisticData: EntityStore;\n\n protected config: InMemoryCacheConfig;\n private watches = new Set<Cache.WatchOptions>();\n private addTypename: boolean;\n\n private typenameDocumentCache = new Map<DocumentNode, DocumentNode>();\n private storeReader: StoreReader;\n private storeWriter: StoreWriter;\n\n private maybeBroadcastWatch: OptimisticWrapperFunction<\n [Cache.WatchOptions, BroadcastOptions?],\n any,\n [Cache.WatchOptions]>;\n\n // Dynamically imported code can augment existing typePolicies or\n // possibleTypes by calling cache.policies.addTypePolicies or\n // cache.policies.addPossibletypes.\n public readonly policies: Policies;\n\n public readonly makeVar = makeVar;\n\n constructor(config: InMemoryCacheConfig = {}) {\n super();\n this.config = normalizeConfig(config);\n this.addTypename = !!this.config.addTypename;\n\n this.policies = new Policies({\n cache: this,\n dataIdFromObject: this.config.dataIdFromObject,\n possibleTypes: this.config.possibleTypes,\n typePolicies: this.config.typePolicies,\n });\n\n this.init();\n }\n\n private init() {\n // Passing { resultCaching: false } in the InMemoryCache constructor options\n // will completely disable dependency tracking, which will improve memory\n // usage but worsen the performance of repeated reads.\n const rootStore = this.data = new EntityStore.Root({\n policies: this.policies,\n resultCaching: this.config.resultCaching,\n });\n\n // When no optimistic writes are currently active, cache.optimisticData ===\n // cache.data, so there are no additional layers on top of the actual data.\n // When an optimistic update happens, this.optimisticData will become a\n // linked list of EntityStore Layer objects that terminates with the\n // original this.data cache object.\n this.optimisticData = rootStore.stump;\n\n this.resetResultCache();\n }\n\n private resetResultCache(resetResultIdentities?: boolean) {\n const previousReader = this.storeReader;\n\n // The StoreWriter is mostly stateless and so doesn't really need to be\n // reset, but it does need to have its writer.storeReader reference updated,\n // so it's simpler to update this.storeWriter as well.\n this.storeWriter = new StoreWriter(\n this,\n 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 }),\n );\n\n this.maybeBroadcastWatch = wrap((\n c: Cache.WatchOptions,\n options?: BroadcastOptions,\n ) => {\n return this.broadcastWatch(c, options);\n }, {\n max: this.config.resultCacheMaxSize,\n makeCacheKey: (c: Cache.WatchOptions) => {\n // Return a cache key (thus enabling result caching) only if we're\n // currently using a data store that can track cache dependencies.\n const store = c.optimistic ? this.optimisticData : this.data;\n if (supportsResultCaching(store)) {\n const { optimistic, rootId, variables } = c;\n return store.makeCacheKey(\n c.query,\n // Different watches can have the same query, optimistic\n // status, rootId, and variables, but if their callbacks are\n // different, the (identical) result needs to be delivered to\n // each distinct callback. The easiest way to achieve that\n // separation is to include c.callback in the cache key for\n // maybeBroadcastWatch calls. See issue #5733.\n c.callback,\n canonicalStringify({ optimistic, rootId, variables }),\n );\n }\n }\n });\n\n // Since we have thrown away all the cached functions that depend on the\n // CacheGroup dependencies maintained by EntityStore, we should also reset\n // all CacheGroup dependency information.\n new Set([\n this.data.group,\n this.optimisticData.group,\n ]).forEach(group => group.resetCaching());\n }\n\n public restore(data: NormalizedCacheObject): this {\n this.init();\n // Since calling this.init() discards/replaces the entire StoreReader, along\n // with the result caches it maintains, this.data.replace(data) won't have\n // to bother deleting the old data.\n if (data) this.data.replace(data);\n return this;\n }\n\n public extract(optimistic: boolean = false): NormalizedCacheObject {\n return (optimistic ? this.optimisticData : this.data).extract();\n }\n\n public read<T>(options: Cache.ReadOptions): T | null {\n const {\n // Since read returns data or null, without any additional metadata\n // about whether/where there might have been missing fields, the\n // default behavior cannot be returnPartialData = true (like it is\n // for the diff method), since defaulting to true would violate the\n // integrity of the T in the return type. However, partial data may\n // be useful in some cases, so returnPartialData:true may be\n // specified explicitly.\n returnPartialData = false,\n } = options;\n try {\n return this.storeReader.diffQueryAgainstStore<T>({\n ...options,\n store: options.optimistic ? this.optimisticData : this.data,\n config: this.config,\n returnPartialData,\n }).result || null;\n } catch (e) {\n if (e instanceof MissingFieldError) {\n // Swallow MissingFieldError and return null, so callers do not\n // need to worry about catching \"normal\" exceptions resulting from\n // incomplete cache data. Unexpected errors will be re-thrown. If\n // you need more information about which fields were missing, use\n // cache.diff instead, and examine diffResult.missing.\n return null;\n }\n throw e;\n }\n }\n\n public write(options: Cache.WriteOptions): Reference | undefined {\n try {\n ++this.txCount;\n return this.storeWriter.writeToStore(this.data, options);\n } finally {\n if (!--this.txCount && options.broadcast !== false) {\n this.broadcastWatches();\n }\n }\n }\n\n public modify(options: Cache.ModifyOptions): boolean {\n if (hasOwn.call(options, \"id\") && !options.id) {\n // To my knowledge, TypeScript does not currently provide a way to\n // enforce that an optional property?:type must *not* be undefined\n // when present. That ability would be useful here, because we want\n // options.id to default to ROOT_QUERY only when no options.id was\n // provided. If the caller attempts to pass options.id with a\n // falsy/undefined value (perhaps because cache.identify failed), we\n // should not assume the goal was to modify the ROOT_QUERY object.\n // We could throw, but it seems natural to return false to indicate\n // that nothing was modified.\n return false;\n }\n const store = options.optimistic // Defaults to false.\n ? this.optimisticData\n : this.data;\n try {\n ++this.txCount;\n return store.modify(options.id || \"ROOT_QUERY\", options.fields);\n } finally {\n if (!--this.txCount && options.broadcast !== false) {\n this.broadcastWatches();\n }\n }\n }\n\n public diff<TData, TVariables = any>(\n options: Cache.DiffOptions<TData, TVariables>,\n ): Cache.DiffResult<TData> {\n return this.storeReader.diffQueryAgainstStore({\n ...options,\n store: options.optimistic ? this.optimisticData : this.data,\n rootId: options.id || \"ROOT_QUERY\",\n config: this.config,\n });\n }\n\n public watch<TData = any, TVariables = any>(\n watch: Cache.WatchOptions<TData, TVariables>,\n ): () => void {\n if (!this.watches.size) {\n // In case we previously called forgetCache(this) because\n // this.watches became empty (see below), reattach this cache to any\n // reactive variables on which it previously depended. It might seem\n // paradoxical that we're able to recall something we supposedly\n // forgot, but the point of calling forgetCache(this) is to silence\n // useless broadcasts while this.watches is empty, and to allow the\n // cache to be garbage collected. If, however, we manage to call\n // recallCache(this) here, this cache object must not have been\n // garbage collected yet, and should resume receiving updates from\n // reactive variables, now that it has a watcher to notify.\n recallCache(this);\n }\n this.watches.add(watch);\n if (watch.immediate) {\n this.maybeBroadcastWatch(watch);\n }\n return () => {\n // Once we remove the last watch from this.watches, cache.broadcastWatches\n // no longer does anything, so we preemptively tell the reactive variable\n // system to exclude this cache from future broadcasts.\n if (this.watches.delete(watch) && !this.watches.size) {\n forgetCache(this);\n }\n // Remove this watch from the LRU cache managed by the\n // maybeBroadcastWatch OptimisticWrapperFunction, to prevent memory\n // leaks involving the closure of watch.callback.\n this.maybeBroadcastWatch.forget(watch);\n };\n }\n\n public gc(options?: {\n // If true, also free non-essential result cache memory by bulk-releasing\n // this.{store{Reader,Writer},maybeBroadcastWatch}. Defaults to false.\n resetResultCache?: boolean;\n // If resetResultCache is true, this.storeReader.canon will be preserved by\n // default, but can also be discarded by passing resetResultIdentities:true.\n // Defaults to false.\n resetResultIdentities?: boolean;\n }) {\n canonicalStringify.reset();\n const ids = this.optimisticData.gc();\n if (options && !this.txCount) {\n if (options.resetResultCache) {\n this.resetResultCache(options.resetResultIdentities);\n } else if (options.resetResultIdentities) {\n this.storeReader.resetCanon();\n }\n }\n return ids;\n }\n\n // Call this method to ensure the given root ID remains in the cache after\n // garbage collection, along with its transitive child entities. Note that\n // the cache automatically retains all directly written entities. By default,\n // the retainment persists after optimistic updates are removed. Pass true\n // for the optimistic argument if you would prefer for the retainment to be\n // discarded when the top-most optimistic layer is removed. Returns the\n // resulting (non-negative) retainment count.\n public retain(rootId: string, optimistic?: boolean): number {\n return (optimistic ? this.optimisticData : this.data).retain(rootId);\n }\n\n // Call this method to undo the effect of the retain method, above. Once the\n // retainment count falls to zero, the given ID will no longer be preserved\n // during garbage collection, though it may still be preserved by other safe\n // entities that refer to it. Returns the resulting (non-negative) retainment\n // count, in case that's useful.\n public release(rootId: string, optimistic?: boolean): number {\n return (optimistic ? this.optimisticData : this.data).release(rootId);\n }\n\n // Returns the canonical ID for a given StoreObject, obeying typePolicies\n // and keyFields (and dataIdFromObject, if you still use that). At minimum,\n // the object must contain a __typename and any primary key fields required\n // to identify entities of that type. If you pass a query result object, be\n // sure that none of the primary key fields have been renamed by aliasing.\n // If you pass a Reference object, its __ref ID string will be returned.\n public identify(object: StoreObject | Reference): string | undefined {\n if (isReference(object)) return object.__ref;\n try {\n return this.policies.identify(object)[0];\n } catch (e) {\n invariant.warn(e);\n }\n }\n\n public evict(options: Cache.EvictOptions): boolean {\n if (!options.id) {\n if (hasOwn.call(options, \"id\")) {\n // See comment in modify method about why we return false when\n // options.id exists but is falsy/undefined.\n return false;\n }\n options = { ...options, id: \"ROOT_QUERY\" };\n }\n try {\n // It's unlikely that the eviction will end up invoking any other\n // cache update operations while it's running, but {in,de}crementing\n // this.txCount still seems like a good idea, for uniformity with\n // the other update methods.\n ++this.txCount;\n // Pass this.data as a limit on the depth of the eviction, so evictions\n // during optimistic updates (when this.data is temporarily set equal to\n // this.optimisticData) do not escape their optimistic Layer.\n return this.optimisticData.evict(options, this.data);\n } finally {\n if (!--this.txCount && options.broadcast !== false) {\n this.broadcastWatches();\n }\n }\n }\n\n public reset(options?: Cache.ResetOptions): Promise<void> {\n this.init();\n\n canonicalStringify.reset();\n\n if (options && options.discardWatches) {\n // Similar to what happens in the unsubscribe function returned by\n // cache.watch, applied to all current watches.\n this.watches.forEach(watch => this.maybeBroadcastWatch.forget(watch));\n this.watches.clear();\n forgetCache(this);\n } else {\n // Calling this.init() above unblocks all maybeBroadcastWatch caching, so\n // this.broadcastWatches() triggers a broadcast to every current watcher\n // (letting them know their data is now missing). This default behavior is\n // convenient because it means the watches do not have to be manually\n // reestablished after resetting the cache. To prevent this broadcast and\n // cancel all watches, pass true for options.discardWatches.\n this.broadcastWatches();\n }\n\n return Promise.resolve();\n }\n\n public removeOptimistic(idToRemove: string) {\n const newOptimisticData = this.optimisticData.removeLayer(idToRemove);\n if (newOptimisticData !== this.optimisticData) {\n this.optimisticData = newOptimisticData;\n this.broadcastWatches();\n }\n }\n\n private txCount = 0;\n\n public batch<TUpdateResult>(\n options: Cache.BatchOptions<InMemoryCache, TUpdateResult>,\n ): TUpdateResult {\n const {\n update,\n optimistic = true,\n removeOptimistic,\n onWatchUpdated,\n } = options;\n\n let updateResult: TUpdateResult;\n const perform = (layer?: EntityStore): TUpdateResult => {\n const { data, optimisticData } = this;\n ++this.txCount;\n if (layer) {\n this.data = this.optimisticData = layer;\n }\n try {\n return updateResult = update(this);\n } finally {\n --this.txCount;\n this.data = data;\n this.optimisticData = optimisticData;\n }\n };\n\n const alreadyDirty = new Set<Cache.WatchOptions>();\n\n if (onWatchUpdated && !this.txCount) {\n // If an options.onWatchUpdated callback is provided, we want to call it\n // with only the Cache.WatchOptions objects affected by options.update,\n // but there might be dirty watchers already waiting to be broadcast that\n // have nothing to do with the update. To prevent including those watchers\n // in the post-update broadcast, we perform this initial broadcast to\n // collect the dirty watchers, so we can re-dirty them later, after the\n // post-update broadcast, allowing them to receive their pending\n // broadcasts the next time broadcastWatches is called, just as they would\n // if we never called cache.batch.\n this.broadcastWatches({\n ...options,\n onWatchUpdated(watch) {\n alreadyDirty.add(watch);\n return false;\n },\n });\n }\n\n if (typeof optimistic === 'string') {\n // Note that there can be multiple layers with the same optimistic ID.\n // When removeOptimistic(id) is called for that id, all matching layers\n // will be removed, and the remaining layers will be reapplied.\n this.optimisticData = this.optimisticData.addLayer(optimistic, perform);\n } else if (optimistic === false) {\n // Ensure both this.data and this.optimisticData refer to the root\n // (non-optimistic) layer of the cache during the update. Note that\n // this.data could be a Layer if we are currently executing an optimistic\n // update function, but otherwise will always be an EntityStore.Root\n // instance.\n perform(this.data);\n } else {\n // Otherwise, leave this.data and this.optimisticData unchanged and run\n // the update with broadcast batching.\n perform();\n }\n\n if (typeof removeOptimistic === \"string\") {\n this.optimisticData = this.optimisticData.removeLayer(removeOptimistic);\n }\n\n // Note: if this.txCount > 0, then alreadyDirty.size === 0, so this code\n // takes the else branch and calls this.broadcastWatches(options), which\n // does nothing when this.txCount > 0.\n if (onWatchUpdated && alreadyDirty.size) {\n this.broadcastWatches({\n ...options,\n onWatchUpdated(watch, diff) {\n const result = onWatchUpdated.call(this, watch, diff);\n if (result !== false) {\n // Since onWatchUpdated did not return false, this diff is\n // about to be broadcast to watch.callback, so we don't need\n // to re-dirty it with the other alreadyDirty watches below.\n alreadyDirty.delete(watch);\n }\n return result;\n }\n });\n // Silently re-dirty any watches that were already dirty before the update\n // was performed, and were not broadcast just now.\n if (alreadyDirty.size) {\n alreadyDirty.forEach(watch => this.maybeBroadcastWatch.dirty(watch));\n }\n } else {\n // If alreadyDirty is empty or we don't have an onWatchUpdated\n // function, we don't need to go to the trouble of wrapping\n // options.onWatchUpdated.\n this.broadcastWatches(options);\n }\n\n return updateResult!;\n }\n\n public performTransaction(\n update: (cache: InMemoryCache) => any,\n optimisticId?: string | null,\n ) {\n return this.batch({\n update,\n optimistic: optimisticId || (optimisticId !== null),\n });\n }\n\n public transformDocument(document: DocumentNode): DocumentNode {\n if (this.addTypename) {\n let result = this.typenameDocumentCache.get(document);\n if (!result) {\n result = addTypenameToDocument(document);\n this.typenameDocumentCache.set(document, result);\n // If someone calls transformDocument and then mistakenly passes the\n // result back into an API that also calls transformDocument, make sure\n // we don't keep creating new query documents.\n this.typenameDocumentCache.set(result, result);\n }\n return result;\n }\n return document;\n }\n\n protected broadcastWatches(options?: BroadcastOptions) {\n if (!this.txCount) {\n this.watches.forEach(c => this.maybeBroadcastWatch(c, options));\n }\n }\n\n // This method is wrapped by maybeBroadcastWatch, which is called by\n // broadcastWatches, so that we compute and broadcast results only when\n // the data that would be broadcast might have changed. It would be\n // simpler to check for changes after recomputing a result but before\n // broadcasting it, but this wrapping approach allows us to skip both\n // the recomputation and the broadcast, in most cases.\n private broadcastWatch(\n c: Cache.WatchOptions,\n options?: BroadcastOptions,\n ) {\n const { lastDiff } = c;\n\n // Both WatchOptions and DiffOptions extend ReadOptions, and DiffOptions\n // currently requires no additional properties, so we can use c (a\n // WatchOptions object) as DiffOptions, without having to allocate a new\n // object, and without having to enumerate the relevant properties (query,\n // variables, etc.) explicitly. There will be some additional properties\n // (lastDiff, callback, etc.), but cache.diff ignores them.\n const diff = this.diff<any>(c);\n\n if (options) {\n if (c.optimistic &&\n typeof options.optimistic === \"string\") {\n diff.fromOptimisticTransaction = true;\n }\n\n if (options.onWatchUpdated &&\n options.onWatchUpdated.call(this, c, diff, lastDiff) === false) {\n // Returning false from the onWatchUpdated callback will prevent\n // calling c.callback(diff) for this watcher.\n return;\n }\n }\n\n if (!lastDiff || !equal(lastDiff.result, diff.result)) {\n c.callback(c.lastDiff = diff, lastDiff);\n }\n }\n}\n","import { ApolloClient, createHttpLink, InMemoryCache } from '@apollo/client'\nimport { setContext } from '@apollo/client/link/context'\n\nconst URL = 'https://cms.nicholaslazzerini.com/nicholaslazzerini/graphql'\n\nconst httplink = createHttpLink({\n uri: operation => `${URL}?name=${operation.operationName}`\n})\n\nconst authLink = setContext((_, { headers }) => {\n return {\n headers: {\n ...headers,\n },\n }\n})\n\nconst client = new ApolloClient({\n link: authLink.concat(httplink),\n cache: new InMemoryCache(),\n})\n\nexport default client\n","import { ApolloLink, Operation, GraphQLRequest, NextLink } from '../core';\nimport { Observable, ObservableSubscription } from '../../utilities';\n\nexport type ContextSetter = (\n operation: GraphQLRequest,\n prevContext: any,\n) => Promise<any> | any;\n\nexport function setContext(setter: ContextSetter): ApolloLink {\n return new ApolloLink((operation: Operation, forward: NextLink) => {\n const { ...request } = operation;\n\n return new Observable(observer => {\n let handle: ObservableSubscription;\n let closed = false;\n Promise.resolve(request)\n .then(req => setter(req, operation.getContext()))\n .then(operation.setContext)\n .then(() => {\n // if the observer is already closed, no need to subscribe.\n if (closed) return;\n handle = forward(operation).subscribe({\n next: observer.next.bind(observer),\n error: observer.error.bind(observer),\n complete: observer.complete.bind(observer),\n });\n })\n .catch(observer.error.bind(observer));\n\n return () => {\n closed = true;\n if (handle) handle.unsubscribe();\n };\n });\n });\n}\n","import { useMediaQuery, useWindowResizeListener } from '@libs/index'\nimport React, { useEffect, useMemo, useState } from 'react'\n\nexport interface WindowDimensions {\n\theight: number\n\twidth: number\n}\n\ninterface NavigationContextData {\n\tlandscapeNavigation: boolean\n\twindowDimensions: WindowDimensions\n\tisContactModalVisible: boolean\n\ttriggerContactModal: any\n}\n\nexport const NavigationContext = React.createContext<NavigationContextData>({\n\tlandscapeNavigation: false,\n\tisContactModalVisible: false,\n\ttriggerContactModal: () => null,\n\twindowDimensions: {\n\t\twidth: 0,\n\t\theight: 0,\n\t},\n})\n\n\nexport const NavigationProvider: React.FC = ({\n\tchildren,\n}) => {\n\tconst isLandscape = useMediaQuery('only screen and (orientation:landscape)')\n\tconst windowDimensions = useWindowResizeListener()\n\tconst landscapeNavigation = isLandscape || false\n\tconst [isContactModalVisible, setIsContactModalVisible] = useState<boolean>(false)\n\n\t// Toggle class with landscape navigation\n\tuseEffect(() => {\n\t\tdocument.body.classList.toggle('landscape-navigation', landscapeNavigation)\n\t}, [landscapeNavigation])\n\n\tconst triggerContactModal = useMemo(() => { setIsContactModalVisible(!isContactModalVisible) }, [])\n\n\n\treturn (\n\t\t<NavigationContext.Provider\n\t\t\tvalue={{\n\t\t\t\tlandscapeNavigation,\n\t\t\t\twindowDimensions,\n\t\t\t\tisContactModalVisible,\n\t\t\t\ttriggerContactModal\n\t\t\t}}\n\t\t>\n\t\t\t{children}\n\t\t</NavigationContext.Provider>\n\t)\n}\n","import React, { Fragment } from 'react'\nimport { Redirect, Route, RouteComponentProps, Switch } from 'react-router-dom'\n\nconst HomeContent = React.lazy(() => import('@contents/Home'))\nconst ProjectsContent = React.lazy(() => import('@contents/Projects'))\nconst AboutContent = React.lazy(() => import('@contents/About'))\nconst ProjectDetails = React.lazy(() => import('@contents/ProjectDetails'))\nconst NotFound = React.lazy(() => import('@contents/404'))\n// const Courtesy = React.lazy(() => import('@containers/Courtesy'))\n\nexport const Routes: React.FC<RouteComponentProps> = () => {\n return (\n <Fragment>\n <Switch>\n <Route exact path=\"/\">\n <Redirect to=\"/home\" />\n </Route>\n <Route exact path={'/home'} component={HomeContent} />\n <Route exact path={'/projects/:filter'} component={ProjectsContent} />\n <Route exact path={'/projects/:filter/:id'} component={ProjectDetails} />\n <Route exact path={'/about'} component={AboutContent} />\n {/* <Route exact path={`${match.url}/courtesy`} component={Courtesy} /> */}\n <Route component={NotFound} />\n </Switch>\n </Fragment>\n )\n}\n","import { ApolloProvider } from '@apollo/client'\nimport { BaseContainer } from '@components/BaseContainer'\nimport { Header } from '@components/Header'\nimport { Loading } from '@components/Loading'\nimport { useDarkMode } from '@hooks/useDarkMode'\nimport client from '@libs/apolloClient'\nimport { Suspense, useEffect } from 'react'\nimport { GlobalModal, GlobalModalWrapper } from 'react-global-modal'\nimport 'react-global-modal/dist/style.css'\nimport {\n BrowserRouter as Router, Route, RouteComponentProps, Switch\n} from 'react-router-dom'\nimport { ThemeProvider } from 'styled-components'\nimport { NavigationProvider } from './providers/NavigationProvider'\nimport { Routes } from './routes'\nimport { darkMode, GlobalStyles, lightMode } from './theme'\n\nconst BaseWrapper: React.FC<RouteComponentProps> = props => {\n const { theme, setMode } = useDarkMode()\n const themeMode = theme === 'light' ? lightMode : darkMode\n let globalModalRef: any = null\n\n const changeTheme = (isDark: boolean) => {\n setMode(isDark ? 'dark' : 'light')\n }\n\n useEffect(() => {\n GlobalModal.setUpModal(globalModalRef)\n }, [globalModalRef])\n\n return (\n <NavigationProvider>\n <ThemeProvider theme={themeMode}>\n <GlobalStyles />\n {/* <LoadingPage loading={showLoader}> */}\n <Suspense fallback={<Loading />}>\n <BaseContainer>\n <Header toggleTheme={(isDark: boolean) => changeTheme(isDark)} />\n <Routes {...props} />\n <GlobalModalWrapper ref={(el) => (globalModalRef = el)} />\n </BaseContainer>\n </Suspense>\n {/* </LoadingPage> */}\n </ThemeProvider>\n\n </NavigationProvider>\n )\n}\n\nfunction App() {\n return (\n\n <ApolloProvider client={client}>\n <Router>\n <Switch>\n <Route path=\"/\" render={props => <BaseWrapper {...props} />} />\n </Switch>\n </Router>\n </ApolloProvider >\n )\n}\n\nexport default App\n","export default function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, _typeof(obj);\n}","export default function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n\n return self;\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}","import _typeof from \"./typeof.js\";\nimport assertThisInitialized from \"./assertThisInitialized.js\";\nexport default function _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n\n return assertThisInitialized(self);\n}","export default function _getPrototypeOf(o) {\n _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n };\n return _getPrototypeOf(o);\n}","import arrayWithHoles from \"./arrayWithHoles.js\";\nimport iterableToArray from \"./iterableToArray.js\";\nimport unsupportedIterableToArray from \"./unsupportedIterableToArray.js\";\nimport nonIterableRest from \"./nonIterableRest.js\";\nexport default function _toArray(arr) {\n return arrayWithHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableRest();\n}","export default function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}","import _typeof from '@babel/runtime/helpers/esm/typeof';\nimport _classCallCheck from '@babel/runtime/helpers/esm/classCallCheck';\nimport _createClass from '@babel/runtime/helpers/esm/createClass';\nimport _assertThisInitialized from '@babel/runtime/helpers/esm/assertThisInitialized';\nimport _inherits from '@babel/runtime/helpers/esm/inherits';\nimport _possibleConstructorReturn from '@babel/runtime/helpers/esm/possibleConstructorReturn';\nimport _getPrototypeOf from '@babel/runtime/helpers/esm/getPrototypeOf';\nimport _defineProperty from '@babel/runtime/helpers/esm/defineProperty';\nimport _toArray from '@babel/runtime/helpers/esm/toArray';\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar consoleLogger = {\n type: 'logger',\n log: function log(args) {\n this.output('log', args);\n },\n warn: function warn(args) {\n this.output('warn', args);\n },\n error: function error(args) {\n this.output('error', args);\n },\n output: function output(type, args) {\n if (console && console[type]) console[type].apply(console, args);\n }\n};\n\nvar Logger = function () {\n function Logger(concreteLogger) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, Logger);\n\n this.init(concreteLogger, options);\n }\n\n _createClass(Logger, [{\n key: \"init\",\n value: function init(concreteLogger) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n this.prefix = options.prefix || 'i18next:';\n this.logger = concreteLogger || consoleLogger;\n this.options = options;\n this.debug = options.debug;\n }\n }, {\n key: \"setDebug\",\n value: function setDebug(bool) {\n this.debug = bool;\n }\n }, {\n key: \"log\",\n value: function log() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return this.forward(args, 'log', '', true);\n }\n }, {\n key: \"warn\",\n value: function warn() {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n return this.forward(args, 'warn', '', true);\n }\n }, {\n key: \"error\",\n value: function error() {\n for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n args[_key3] = arguments[_key3];\n }\n\n return this.forward(args, 'error', '');\n }\n }, {\n key: \"deprecate\",\n value: function deprecate() {\n for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {\n args[_key4] = arguments[_key4];\n }\n\n return this.forward(args, 'warn', 'WARNING DEPRECATED: ', true);\n }\n }, {\n key: \"forward\",\n value: function forward(args, lvl, prefix, debugOnly) {\n if (debugOnly && !this.debug) return null;\n if (typeof args[0] === 'string') args[0] = \"\".concat(prefix).concat(this.prefix, \" \").concat(args[0]);\n return this.logger[lvl](args);\n }\n }, {\n key: \"create\",\n value: function create(moduleName) {\n return new Logger(this.logger, _objectSpread(_objectSpread({}, {\n prefix: \"\".concat(this.prefix, \":\").concat(moduleName, \":\")\n }), this.options));\n }\n }]);\n\n return Logger;\n}();\n\nvar baseLogger = new Logger();\n\nvar EventEmitter = function () {\n function EventEmitter() {\n _classCallCheck(this, EventEmitter);\n\n this.observers = {};\n }\n\n _createClass(EventEmitter, [{\n key: \"on\",\n value: function on(events, listener) {\n var _this = this;\n\n events.split(' ').forEach(function (event) {\n _this.observers[event] = _this.observers[event] || [];\n\n _this.observers[event].push(listener);\n });\n return this;\n }\n }, {\n key: \"off\",\n value: function off(event, listener) {\n if (!this.observers[event]) return;\n\n if (!listener) {\n delete this.observers[event];\n return;\n }\n\n this.observers[event] = this.observers[event].filter(function (l) {\n return l !== listener;\n });\n }\n }, {\n key: \"emit\",\n value: function emit(event) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n if (this.observers[event]) {\n var cloned = [].concat(this.observers[event]);\n cloned.forEach(function (observer) {\n observer.apply(void 0, args);\n });\n }\n\n if (this.observers['*']) {\n var _cloned = [].concat(this.observers['*']);\n\n _cloned.forEach(function (observer) {\n observer.apply(observer, [event].concat(args));\n });\n }\n }\n }]);\n\n return EventEmitter;\n}();\n\nfunction defer() {\n var res;\n var rej;\n var promise = new Promise(function (resolve, reject) {\n res = resolve;\n rej = reject;\n });\n promise.resolve = res;\n promise.reject = rej;\n return promise;\n}\nfunction makeString(object) {\n if (object == null) return '';\n return '' + object;\n}\nfunction copy(a, s, t) {\n a.forEach(function (m) {\n if (s[m]) t[m] = s[m];\n });\n}\n\nfunction getLastOfPath(object, path, Empty) {\n function cleanKey(key) {\n return key && key.indexOf('###') > -1 ? key.replace(/###/g, '.') : key;\n }\n\n function canNotTraverseDeeper() {\n return !object || typeof object === 'string';\n }\n\n var stack = typeof path !== 'string' ? [].concat(path) : path.split('.');\n\n while (stack.length > 1) {\n if (canNotTraverseDeeper()) return {};\n var key = cleanKey(stack.shift());\n if (!object[key] && Empty) object[key] = new Empty();\n\n if (Object.prototype.hasOwnProperty.call(object, key)) {\n object = object[key];\n } else {\n object = {};\n }\n }\n\n if (canNotTraverseDeeper()) return {};\n return {\n obj: object,\n k: cleanKey(stack.shift())\n };\n}\n\nfunction setPath(object, path, newValue) {\n var _getLastOfPath = getLastOfPath(object, path, Object),\n obj = _getLastOfPath.obj,\n k = _getLastOfPath.k;\n\n obj[k] = newValue;\n}\nfunction pushPath(object, path, newValue, concat) {\n var _getLastOfPath2 = getLastOfPath(object, path, Object),\n obj = _getLastOfPath2.obj,\n k = _getLastOfPath2.k;\n\n obj[k] = obj[k] || [];\n if (concat) obj[k] = obj[k].concat(newValue);\n if (!concat) obj[k].push(newValue);\n}\nfunction getPath(object, path) {\n var _getLastOfPath3 = getLastOfPath(object, path),\n obj = _getLastOfPath3.obj,\n k = _getLastOfPath3.k;\n\n if (!obj) return undefined;\n return obj[k];\n}\nfunction getPathWithDefaults(data, defaultData, key) {\n var value = getPath(data, key);\n\n if (value !== undefined) {\n return value;\n }\n\n return getPath(defaultData, key);\n}\nfunction deepExtend(target, source, overwrite) {\n for (var prop in source) {\n if (prop !== '__proto__' && prop !== 'constructor') {\n if (prop in target) {\n if (typeof target[prop] === 'string' || target[prop] instanceof String || typeof source[prop] === 'string' || source[prop] instanceof String) {\n if (overwrite) target[prop] = source[prop];\n } else {\n deepExtend(target[prop], source[prop], overwrite);\n }\n } else {\n target[prop] = source[prop];\n }\n }\n }\n\n return target;\n}\nfunction regexEscape(str) {\n return str.replace(/[\\-\\[\\]\\/\\{\\}\\(\\)\\*\\+\\?\\.\\\\\\^\\$\\|]/g, '\\\\$&');\n}\nvar _entityMap = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": ''',\n '/': '/'\n};\nfunction escape(data) {\n if (typeof data === 'string') {\n return data.replace(/[&<>\"'\\/]/g, function (s) {\n return _entityMap[s];\n });\n }\n\n return data;\n}\nvar isIE10 = typeof window !== 'undefined' && window.navigator && typeof window.navigator.userAgentData === 'undefined' && window.navigator.userAgent && window.navigator.userAgent.indexOf('MSIE') > -1;\nvar chars = [' ', ',', '?', '!', ';'];\nfunction looksLikeObjectPath(key, nsSeparator, keySeparator) {\n nsSeparator = nsSeparator || '';\n keySeparator = keySeparator || '';\n var possibleChars = chars.filter(function (c) {\n return nsSeparator.indexOf(c) < 0 && keySeparator.indexOf(c) < 0;\n });\n if (possibleChars.length === 0) return true;\n var r = new RegExp(\"(\".concat(possibleChars.map(function (c) {\n return c === '?' ? '\\\\?' : c;\n }).join('|'), \")\"));\n var matched = !r.test(key);\n\n if (!matched) {\n var ki = key.indexOf(keySeparator);\n\n if (ki > 0 && !r.test(key.substring(0, ki))) {\n matched = true;\n }\n }\n\n return matched;\n}\n\nfunction ownKeys$1(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$1(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$1(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\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 _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction deepFind(obj, path) {\n var keySeparator = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '.';\n if (!obj) return undefined;\n if (obj[path]) return obj[path];\n var paths = path.split(keySeparator);\n var current = obj;\n\n for (var i = 0; i < paths.length; ++i) {\n if (!current) return undefined;\n\n if (typeof current[paths[i]] === 'string' && i + 1 < paths.length) {\n return undefined;\n }\n\n if (current[paths[i]] === undefined) {\n var j = 2;\n var p = paths.slice(i, i + j).join(keySeparator);\n var mix = current[p];\n\n while (mix === undefined && paths.length > i + j) {\n j++;\n p = paths.slice(i, i + j).join(keySeparator);\n mix = current[p];\n }\n\n if (mix === undefined) return undefined;\n if (mix === null) return null;\n\n if (path.endsWith(p)) {\n if (typeof mix === 'string') return mix;\n if (p && typeof mix[p] === 'string') return mix[p];\n }\n\n var joinedPath = paths.slice(i + j).join(keySeparator);\n if (joinedPath) return deepFind(mix, joinedPath, keySeparator);\n return undefined;\n }\n\n current = current[paths[i]];\n }\n\n return current;\n}\n\nvar ResourceStore = function (_EventEmitter) {\n _inherits(ResourceStore, _EventEmitter);\n\n var _super = _createSuper(ResourceStore);\n\n function ResourceStore(data) {\n var _this;\n\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n ns: ['translation'],\n defaultNS: 'translation'\n };\n\n _classCallCheck(this, ResourceStore);\n\n _this = _super.call(this);\n\n if (isIE10) {\n EventEmitter.call(_assertThisInitialized(_this));\n }\n\n _this.data = data || {};\n _this.options = options;\n\n if (_this.options.keySeparator === undefined) {\n _this.options.keySeparator = '.';\n }\n\n if (_this.options.ignoreJSONStructure === undefined) {\n _this.options.ignoreJSONStructure = true;\n }\n\n return _this;\n }\n\n _createClass(ResourceStore, [{\n key: \"addNamespaces\",\n value: function addNamespaces(ns) {\n if (this.options.ns.indexOf(ns) < 0) {\n this.options.ns.push(ns);\n }\n }\n }, {\n key: \"removeNamespaces\",\n value: function removeNamespaces(ns) {\n var index = this.options.ns.indexOf(ns);\n\n if (index > -1) {\n this.options.ns.splice(index, 1);\n }\n }\n }, {\n key: \"getResource\",\n value: function getResource(lng, ns, key) {\n var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n var keySeparator = options.keySeparator !== undefined ? options.keySeparator : this.options.keySeparator;\n var ignoreJSONStructure = options.ignoreJSONStructure !== undefined ? options.ignoreJSONStructure : this.options.ignoreJSONStructure;\n var path = [lng, ns];\n if (key && typeof key !== 'string') path = path.concat(key);\n if (key && typeof key === 'string') path = path.concat(keySeparator ? key.split(keySeparator) : key);\n\n if (lng.indexOf('.') > -1) {\n path = lng.split('.');\n }\n\n var result = getPath(this.data, path);\n if (result || !ignoreJSONStructure || typeof key !== 'string') return result;\n return deepFind(this.data && this.data[lng] && this.data[lng][ns], key, keySeparator);\n }\n }, {\n key: \"addResource\",\n value: function addResource(lng, ns, key, value) {\n var options = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {\n silent: false\n };\n var keySeparator = this.options.keySeparator;\n if (keySeparator === undefined) keySeparator = '.';\n var path = [lng, ns];\n if (key) path = path.concat(keySeparator ? key.split(keySeparator) : key);\n\n if (lng.indexOf('.') > -1) {\n path = lng.split('.');\n value = ns;\n ns = path[1];\n }\n\n this.addNamespaces(ns);\n setPath(this.data, path, value);\n if (!options.silent) this.emit('added', lng, ns, key, value);\n }\n }, {\n key: \"addResources\",\n value: function addResources(lng, ns, resources) {\n var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {\n silent: false\n };\n\n for (var m in resources) {\n if (typeof resources[m] === 'string' || Object.prototype.toString.apply(resources[m]) === '[object Array]') this.addResource(lng, ns, m, resources[m], {\n silent: true\n });\n }\n\n if (!options.silent) this.emit('added', lng, ns, resources);\n }\n }, {\n key: \"addResourceBundle\",\n value: function addResourceBundle(lng, ns, resources, deep, overwrite) {\n var options = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : {\n silent: false\n };\n var path = [lng, ns];\n\n if (lng.indexOf('.') > -1) {\n path = lng.split('.');\n deep = resources;\n resources = ns;\n ns = path[1];\n }\n\n this.addNamespaces(ns);\n var pack = getPath(this.data, path) || {};\n\n if (deep) {\n deepExtend(pack, resources, overwrite);\n } else {\n pack = _objectSpread$1(_objectSpread$1({}, pack), resources);\n }\n\n setPath(this.data, path, pack);\n if (!options.silent) this.emit('added', lng, ns, resources);\n }\n }, {\n key: \"removeResourceBundle\",\n value: function removeResourceBundle(lng, ns) {\n if (this.hasResourceBundle(lng, ns)) {\n delete this.data[lng][ns];\n }\n\n this.removeNamespaces(ns);\n this.emit('removed', lng, ns);\n }\n }, {\n key: \"hasResourceBundle\",\n value: function hasResourceBundle(lng, ns) {\n return this.getResource(lng, ns) !== undefined;\n }\n }, {\n key: \"getResourceBundle\",\n value: function getResourceBundle(lng, ns) {\n if (!ns) ns = this.options.defaultNS;\n if (this.options.compatibilityAPI === 'v1') return _objectSpread$1(_objectSpread$1({}, {}), this.getResource(lng, ns));\n return this.getResource(lng, ns);\n }\n }, {\n key: \"getDataByLanguage\",\n value: function getDataByLanguage(lng) {\n return this.data[lng];\n }\n }, {\n key: \"hasLanguageSomeTranslations\",\n value: function hasLanguageSomeTranslations(lng) {\n var data = this.getDataByLanguage(lng);\n var n = data && Object.keys(data) || [];\n return !!n.find(function (v) {\n return data[v] && Object.keys(data[v]).length > 0;\n });\n }\n }, {\n key: \"toJSON\",\n value: function toJSON() {\n return this.data;\n }\n }]);\n\n return ResourceStore;\n}(EventEmitter);\n\nvar postProcessor = {\n processors: {},\n addPostProcessor: function addPostProcessor(module) {\n this.processors[module.name] = module;\n },\n handle: function handle(processors, value, key, options, translator) {\n var _this = this;\n\n processors.forEach(function (processor) {\n if (_this.processors[processor]) value = _this.processors[processor].process(value, key, options, translator);\n });\n return value;\n }\n};\n\nfunction ownKeys$2(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$2(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$2(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _createSuper$1(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$1(); 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 _isNativeReflectConstruct$1() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\nvar checkedLoadedFor = {};\n\nvar Translator = function (_EventEmitter) {\n _inherits(Translator, _EventEmitter);\n\n var _super = _createSuper$1(Translator);\n\n function Translator(services) {\n var _this;\n\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, Translator);\n\n _this = _super.call(this);\n\n if (isIE10) {\n EventEmitter.call(_assertThisInitialized(_this));\n }\n\n copy(['resourceStore', 'languageUtils', 'pluralResolver', 'interpolator', 'backendConnector', 'i18nFormat', 'utils'], services, _assertThisInitialized(_this));\n _this.options = options;\n\n if (_this.options.keySeparator === undefined) {\n _this.options.keySeparator = '.';\n }\n\n _this.logger = baseLogger.create('translator');\n return _this;\n }\n\n _createClass(Translator, [{\n key: \"changeLanguage\",\n value: function changeLanguage(lng) {\n if (lng) this.language = lng;\n }\n }, {\n key: \"exists\",\n value: function exists(key) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n interpolation: {}\n };\n\n if (key === undefined || key === null) {\n return false;\n }\n\n var resolved = this.resolve(key, options);\n return resolved && resolved.res !== undefined;\n }\n }, {\n key: \"extractFromKey\",\n value: function extractFromKey(key, options) {\n var nsSeparator = options.nsSeparator !== undefined ? options.nsSeparator : this.options.nsSeparator;\n if (nsSeparator === undefined) nsSeparator = ':';\n var keySeparator = options.keySeparator !== undefined ? options.keySeparator : this.options.keySeparator;\n var namespaces = options.ns || this.options.defaultNS || [];\n var wouldCheckForNsInKey = nsSeparator && key.indexOf(nsSeparator) > -1;\n var seemsNaturalLanguage = !this.options.userDefinedKeySeparator && !options.keySeparator && !this.options.userDefinedNsSeparator && !options.nsSeparator && !looksLikeObjectPath(key, nsSeparator, keySeparator);\n\n if (wouldCheckForNsInKey && !seemsNaturalLanguage) {\n var m = key.match(this.interpolator.nestingRegexp);\n\n if (m && m.length > 0) {\n return {\n key: key,\n namespaces: namespaces\n };\n }\n\n var parts = key.split(nsSeparator);\n if (nsSeparator !== keySeparator || nsSeparator === keySeparator && this.options.ns.indexOf(parts[0]) > -1) namespaces = parts.shift();\n key = parts.join(keySeparator);\n }\n\n if (typeof namespaces === 'string') namespaces = [namespaces];\n return {\n key: key,\n namespaces: namespaces\n };\n }\n }, {\n key: \"translate\",\n value: function translate(keys, options, lastKey) {\n var _this2 = this;\n\n if (_typeof(options) !== 'object' && this.options.overloadTranslationOptionHandler) {\n options = this.options.overloadTranslationOptionHandler(arguments);\n }\n\n if (!options) options = {};\n if (keys === undefined || keys === null) return '';\n if (!Array.isArray(keys)) keys = [String(keys)];\n var returnDetails = options.returnDetails !== undefined ? options.returnDetails : this.options.returnDetails;\n var keySeparator = options.keySeparator !== undefined ? options.keySeparator : this.options.keySeparator;\n\n var _this$extractFromKey = this.extractFromKey(keys[keys.length - 1], options),\n key = _this$extractFromKey.key,\n namespaces = _this$extractFromKey.namespaces;\n\n var namespace = namespaces[namespaces.length - 1];\n var lng = options.lng || this.language;\n var appendNamespaceToCIMode = options.appendNamespaceToCIMode || this.options.appendNamespaceToCIMode;\n\n if (lng && lng.toLowerCase() === 'cimode') {\n if (appendNamespaceToCIMode) {\n var nsSeparator = options.nsSeparator || this.options.nsSeparator;\n\n if (returnDetails) {\n resolved.res = \"\".concat(namespace).concat(nsSeparator).concat(key);\n return resolved;\n }\n\n return \"\".concat(namespace).concat(nsSeparator).concat(key);\n }\n\n if (returnDetails) {\n resolved.res = key;\n return resolved;\n }\n\n return key;\n }\n\n var resolved = this.resolve(keys, options);\n var res = resolved && resolved.res;\n var resUsedKey = resolved && resolved.usedKey || key;\n var resExactUsedKey = resolved && resolved.exactUsedKey || key;\n var resType = Object.prototype.toString.apply(res);\n var noObject = ['[object Number]', '[object Function]', '[object RegExp]'];\n var joinArrays = options.joinArrays !== undefined ? options.joinArrays : this.options.joinArrays;\n var handleAsObjectInI18nFormat = !this.i18nFormat || this.i18nFormat.handleAsObject;\n var handleAsObject = typeof res !== 'string' && typeof res !== 'boolean' && typeof res !== 'number';\n\n if (handleAsObjectInI18nFormat && res && handleAsObject && noObject.indexOf(resType) < 0 && !(typeof joinArrays === 'string' && resType === '[object Array]')) {\n if (!options.returnObjects && !this.options.returnObjects) {\n if (!this.options.returnedObjectHandler) {\n this.logger.warn('accessing an object - but returnObjects options is not enabled!');\n }\n\n var r = this.options.returnedObjectHandler ? this.options.returnedObjectHandler(resUsedKey, res, _objectSpread$2(_objectSpread$2({}, options), {}, {\n ns: namespaces\n })) : \"key '\".concat(key, \" (\").concat(this.language, \")' returned an object instead of string.\");\n\n if (returnDetails) {\n resolved.res = r;\n return resolved;\n }\n\n return r;\n }\n\n if (keySeparator) {\n var resTypeIsArray = resType === '[object Array]';\n var copy = resTypeIsArray ? [] : {};\n var newKeyToUse = resTypeIsArray ? resExactUsedKey : resUsedKey;\n\n for (var m in res) {\n if (Object.prototype.hasOwnProperty.call(res, m)) {\n var deepKey = \"\".concat(newKeyToUse).concat(keySeparator).concat(m);\n copy[m] = this.translate(deepKey, _objectSpread$2(_objectSpread$2({}, options), {\n joinArrays: false,\n ns: namespaces\n }));\n if (copy[m] === deepKey) copy[m] = res[m];\n }\n }\n\n res = copy;\n }\n } else if (handleAsObjectInI18nFormat && typeof joinArrays === 'string' && resType === '[object Array]') {\n res = res.join(joinArrays);\n if (res) res = this.extendTranslation(res, keys, options, lastKey);\n } else {\n var usedDefault = false;\n var usedKey = false;\n var needsPluralHandling = options.count !== undefined && typeof options.count !== 'string';\n var hasDefaultValue = Translator.hasDefaultValue(options);\n var defaultValueSuffix = needsPluralHandling ? this.pluralResolver.getSuffix(lng, options.count, options) : '';\n var defaultValue = options[\"defaultValue\".concat(defaultValueSuffix)] || options.defaultValue;\n\n if (!this.isValidLookup(res) && hasDefaultValue) {\n usedDefault = true;\n res = defaultValue;\n }\n\n if (!this.isValidLookup(res)) {\n usedKey = true;\n res = key;\n }\n\n var missingKeyNoValueFallbackToKey = options.missingKeyNoValueFallbackToKey || this.options.missingKeyNoValueFallbackToKey;\n var resForMissing = missingKeyNoValueFallbackToKey && usedKey ? undefined : res;\n var updateMissing = hasDefaultValue && defaultValue !== res && this.options.updateMissing;\n\n if (usedKey || usedDefault || updateMissing) {\n this.logger.log(updateMissing ? 'updateKey' : 'missingKey', lng, namespace, key, updateMissing ? defaultValue : res);\n\n if (keySeparator) {\n var fk = this.resolve(key, _objectSpread$2(_objectSpread$2({}, options), {}, {\n keySeparator: false\n }));\n if (fk && fk.res) this.logger.warn('Seems the loaded translations were in flat JSON format instead of nested. Either set keySeparator: false on init or make sure your translations are published in nested format.');\n }\n\n var lngs = [];\n var fallbackLngs = this.languageUtils.getFallbackCodes(this.options.fallbackLng, options.lng || this.language);\n\n if (this.options.saveMissingTo === 'fallback' && fallbackLngs && fallbackLngs[0]) {\n for (var i = 0; i < fallbackLngs.length; i++) {\n lngs.push(fallbackLngs[i]);\n }\n } else if (this.options.saveMissingTo === 'all') {\n lngs = this.languageUtils.toResolveHierarchy(options.lng || this.language);\n } else {\n lngs.push(options.lng || this.language);\n }\n\n var send = function send(l, k, specificDefaultValue) {\n var defaultForMissing = hasDefaultValue && specificDefaultValue !== res ? specificDefaultValue : resForMissing;\n\n if (_this2.options.missingKeyHandler) {\n _this2.options.missingKeyHandler(l, namespace, k, defaultForMissing, updateMissing, options);\n } else if (_this2.backendConnector && _this2.backendConnector.saveMissing) {\n _this2.backendConnector.saveMissing(l, namespace, k, defaultForMissing, updateMissing, options);\n }\n\n _this2.emit('missingKey', l, namespace, k, res);\n };\n\n if (this.options.saveMissing) {\n if (this.options.saveMissingPlurals && needsPluralHandling) {\n lngs.forEach(function (language) {\n _this2.pluralResolver.getSuffixes(language, options).forEach(function (suffix) {\n send([language], key + suffix, options[\"defaultValue\".concat(suffix)] || defaultValue);\n });\n });\n } else {\n send(lngs, key, defaultValue);\n }\n }\n }\n\n res = this.extendTranslation(res, keys, options, resolved, lastKey);\n if (usedKey && res === key && this.options.appendNamespaceToMissingKey) res = \"\".concat(namespace, \":\").concat(key);\n\n if ((usedKey || usedDefault) && this.options.parseMissingKeyHandler) {\n if (this.options.compatibilityAPI !== 'v1') {\n res = this.options.parseMissingKeyHandler(this.options.appendNamespaceToMissingKey ? \"\".concat(namespace, \":\").concat(key) : key, usedDefault ? res : undefined);\n } else {\n res = this.options.parseMissingKeyHandler(res);\n }\n }\n }\n\n if (returnDetails) {\n resolved.res = res;\n return resolved;\n }\n\n return res;\n }\n }, {\n key: \"extendTranslation\",\n value: function extendTranslation(res, key, options, resolved, lastKey) {\n var _this3 = this;\n\n if (this.i18nFormat && this.i18nFormat.parse) {\n res = this.i18nFormat.parse(res, _objectSpread$2(_objectSpread$2({}, this.options.interpolation.defaultVariables), options), resolved.usedLng, resolved.usedNS, resolved.usedKey, {\n resolved: resolved\n });\n } else if (!options.skipInterpolation) {\n if (options.interpolation) this.interpolator.init(_objectSpread$2(_objectSpread$2({}, options), {\n interpolation: _objectSpread$2(_objectSpread$2({}, this.options.interpolation), options.interpolation)\n }));\n var skipOnVariables = typeof res === 'string' && (options && options.interpolation && options.interpolation.skipOnVariables !== undefined ? options.interpolation.skipOnVariables : this.options.interpolation.skipOnVariables);\n var nestBef;\n\n if (skipOnVariables) {\n var nb = res.match(this.interpolator.nestingRegexp);\n nestBef = nb && nb.length;\n }\n\n var data = options.replace && typeof options.replace !== 'string' ? options.replace : options;\n if (this.options.interpolation.defaultVariables) data = _objectSpread$2(_objectSpread$2({}, this.options.interpolation.defaultVariables), data);\n res = this.interpolator.interpolate(res, data, options.lng || this.language, options);\n\n if (skipOnVariables) {\n var na = res.match(this.interpolator.nestingRegexp);\n var nestAft = na && na.length;\n if (nestBef < nestAft) options.nest = false;\n }\n\n if (options.nest !== false) res = this.interpolator.nest(res, function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n if (lastKey && lastKey[0] === args[0] && !options.context) {\n _this3.logger.warn(\"It seems you are nesting recursively key: \".concat(args[0], \" in key: \").concat(key[0]));\n\n return null;\n }\n\n return _this3.translate.apply(_this3, args.concat([key]));\n }, options);\n if (options.interpolation) this.interpolator.reset();\n }\n\n var postProcess = options.postProcess || this.options.postProcess;\n var postProcessorNames = typeof postProcess === 'string' ? [postProcess] : postProcess;\n\n if (res !== undefined && res !== null && postProcessorNames && postProcessorNames.length && options.applyPostProcessor !== false) {\n res = postProcessor.handle(postProcessorNames, res, key, this.options && this.options.postProcessPassResolved ? _objectSpread$2({\n i18nResolved: resolved\n }, options) : options, this);\n }\n\n return res;\n }\n }, {\n key: \"resolve\",\n value: function resolve(keys) {\n var _this4 = this;\n\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var found;\n var usedKey;\n var exactUsedKey;\n var usedLng;\n var usedNS;\n if (typeof keys === 'string') keys = [keys];\n keys.forEach(function (k) {\n if (_this4.isValidLookup(found)) return;\n\n var extracted = _this4.extractFromKey(k, options);\n\n var key = extracted.key;\n usedKey = key;\n var namespaces = extracted.namespaces;\n if (_this4.options.fallbackNS) namespaces = namespaces.concat(_this4.options.fallbackNS);\n var needsPluralHandling = options.count !== undefined && typeof options.count !== 'string';\n\n var needsZeroSuffixLookup = needsPluralHandling && !options.ordinal && options.count === 0 && _this4.pluralResolver.shouldUseIntlApi();\n\n var needsContextHandling = options.context !== undefined && (typeof options.context === 'string' || typeof options.context === 'number') && options.context !== '';\n var codes = options.lngs ? options.lngs : _this4.languageUtils.toResolveHierarchy(options.lng || _this4.language, options.fallbackLng);\n namespaces.forEach(function (ns) {\n if (_this4.isValidLookup(found)) return;\n usedNS = ns;\n\n if (!checkedLoadedFor[\"\".concat(codes[0], \"-\").concat(ns)] && _this4.utils && _this4.utils.hasLoadedNamespace && !_this4.utils.hasLoadedNamespace(usedNS)) {\n checkedLoadedFor[\"\".concat(codes[0], \"-\").concat(ns)] = true;\n\n _this4.logger.warn(\"key \\\"\".concat(usedKey, \"\\\" for languages \\\"\").concat(codes.join(', '), \"\\\" won't get resolved as namespace \\\"\").concat(usedNS, \"\\\" was not yet loaded\"), 'This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!');\n }\n\n codes.forEach(function (code) {\n if (_this4.isValidLookup(found)) return;\n usedLng = code;\n var finalKeys = [key];\n\n if (_this4.i18nFormat && _this4.i18nFormat.addLookupKeys) {\n _this4.i18nFormat.addLookupKeys(finalKeys, key, code, ns, options);\n } else {\n var pluralSuffix;\n if (needsPluralHandling) pluralSuffix = _this4.pluralResolver.getSuffix(code, options.count, options);\n var zeroSuffix = \"\".concat(_this4.options.pluralSeparator, \"zero\");\n\n if (needsPluralHandling) {\n finalKeys.push(key + pluralSuffix);\n\n if (needsZeroSuffixLookup) {\n finalKeys.push(key + zeroSuffix);\n }\n }\n\n if (needsContextHandling) {\n var contextKey = \"\".concat(key).concat(_this4.options.contextSeparator).concat(options.context);\n finalKeys.push(contextKey);\n\n if (needsPluralHandling) {\n finalKeys.push(contextKey + pluralSuffix);\n\n if (needsZeroSuffixLookup) {\n finalKeys.push(contextKey + zeroSuffix);\n }\n }\n }\n }\n\n var possibleKey;\n\n while (possibleKey = finalKeys.pop()) {\n if (!_this4.isValidLookup(found)) {\n exactUsedKey = possibleKey;\n found = _this4.getResource(code, ns, possibleKey, options);\n }\n }\n });\n });\n });\n return {\n res: found,\n usedKey: usedKey,\n exactUsedKey: exactUsedKey,\n usedLng: usedLng,\n usedNS: usedNS\n };\n }\n }, {\n key: \"isValidLookup\",\n value: function isValidLookup(res) {\n return res !== undefined && !(!this.options.returnNull && res === null) && !(!this.options.returnEmptyString && res === '');\n }\n }, {\n key: \"getResource\",\n value: function getResource(code, ns, key) {\n var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n if (this.i18nFormat && this.i18nFormat.getResource) return this.i18nFormat.getResource(code, ns, key, options);\n return this.resourceStore.getResource(code, ns, key, options);\n }\n }], [{\n key: \"hasDefaultValue\",\n value: function hasDefaultValue(options) {\n var prefix = 'defaultValue';\n\n for (var option in options) {\n if (Object.prototype.hasOwnProperty.call(options, option) && prefix === option.substring(0, prefix.length) && undefined !== options[option]) {\n return true;\n }\n }\n\n return false;\n }\n }]);\n\n return Translator;\n}(EventEmitter);\n\nfunction capitalize(string) {\n return string.charAt(0).toUpperCase() + string.slice(1);\n}\n\nvar LanguageUtil = function () {\n function LanguageUtil(options) {\n _classCallCheck(this, LanguageUtil);\n\n this.options = options;\n this.supportedLngs = this.options.supportedLngs || false;\n this.logger = baseLogger.create('languageUtils');\n }\n\n _createClass(LanguageUtil, [{\n key: \"getScriptPartFromCode\",\n value: function getScriptPartFromCode(code) {\n if (!code || code.indexOf('-') < 0) return null;\n var p = code.split('-');\n if (p.length === 2) return null;\n p.pop();\n if (p[p.length - 1].toLowerCase() === 'x') return null;\n return this.formatLanguageCode(p.join('-'));\n }\n }, {\n key: \"getLanguagePartFromCode\",\n value: function getLanguagePartFromCode(code) {\n if (!code || code.indexOf('-') < 0) return code;\n var p = code.split('-');\n return this.formatLanguageCode(p[0]);\n }\n }, {\n key: \"formatLanguageCode\",\n value: function formatLanguageCode(code) {\n if (typeof code === 'string' && code.indexOf('-') > -1) {\n var specialCases = ['hans', 'hant', 'latn', 'cyrl', 'cans', 'mong', 'arab'];\n var p = code.split('-');\n\n if (this.options.lowerCaseLng) {\n p = p.map(function (part) {\n return part.toLowerCase();\n });\n } else if (p.length === 2) {\n p[0] = p[0].toLowerCase();\n p[1] = p[1].toUpperCase();\n if (specialCases.indexOf(p[1].toLowerCase()) > -1) p[1] = capitalize(p[1].toLowerCase());\n } else if (p.length === 3) {\n p[0] = p[0].toLowerCase();\n if (p[1].length === 2) p[1] = p[1].toUpperCase();\n if (p[0] !== 'sgn' && p[2].length === 2) p[2] = p[2].toUpperCase();\n if (specialCases.indexOf(p[1].toLowerCase()) > -1) p[1] = capitalize(p[1].toLowerCase());\n if (specialCases.indexOf(p[2].toLowerCase()) > -1) p[2] = capitalize(p[2].toLowerCase());\n }\n\n return p.join('-');\n }\n\n return this.options.cleanCode || this.options.lowerCaseLng ? code.toLowerCase() : code;\n }\n }, {\n key: \"isSupportedCode\",\n value: function isSupportedCode(code) {\n if (this.options.load === 'languageOnly' || this.options.nonExplicitSupportedLngs) {\n code = this.getLanguagePartFromCode(code);\n }\n\n return !this.supportedLngs || !this.supportedLngs.length || this.supportedLngs.indexOf(code) > -1;\n }\n }, {\n key: \"getBestMatchFromCodes\",\n value: function getBestMatchFromCodes(codes) {\n var _this = this;\n\n if (!codes) return null;\n var found;\n codes.forEach(function (code) {\n if (found) return;\n\n var cleanedLng = _this.formatLanguageCode(code);\n\n if (!_this.options.supportedLngs || _this.isSupportedCode(cleanedLng)) found = cleanedLng;\n });\n\n if (!found && this.options.supportedLngs) {\n codes.forEach(function (code) {\n if (found) return;\n\n var lngOnly = _this.getLanguagePartFromCode(code);\n\n if (_this.isSupportedCode(lngOnly)) return found = lngOnly;\n found = _this.options.supportedLngs.find(function (supportedLng) {\n if (supportedLng.indexOf(lngOnly) === 0) return supportedLng;\n });\n });\n }\n\n if (!found) found = this.getFallbackCodes(this.options.fallbackLng)[0];\n return found;\n }\n }, {\n key: \"getFallbackCodes\",\n value: function getFallbackCodes(fallbacks, code) {\n if (!fallbacks) return [];\n if (typeof fallbacks === 'function') fallbacks = fallbacks(code);\n if (typeof fallbacks === 'string') fallbacks = [fallbacks];\n if (Object.prototype.toString.apply(fallbacks) === '[object Array]') return fallbacks;\n if (!code) return fallbacks[\"default\"] || [];\n var found = fallbacks[code];\n if (!found) found = fallbacks[this.getScriptPartFromCode(code)];\n if (!found) found = fallbacks[this.formatLanguageCode(code)];\n if (!found) found = fallbacks[this.getLanguagePartFromCode(code)];\n if (!found) found = fallbacks[\"default\"];\n return found || [];\n }\n }, {\n key: \"toResolveHierarchy\",\n value: function toResolveHierarchy(code, fallbackCode) {\n var _this2 = this;\n\n var fallbackCodes = this.getFallbackCodes(fallbackCode || this.options.fallbackLng || [], code);\n var codes = [];\n\n var addCode = function addCode(c) {\n if (!c) return;\n\n if (_this2.isSupportedCode(c)) {\n codes.push(c);\n } else {\n _this2.logger.warn(\"rejecting language code not found in supportedLngs: \".concat(c));\n }\n };\n\n if (typeof code === 'string' && code.indexOf('-') > -1) {\n if (this.options.load !== 'languageOnly') addCode(this.formatLanguageCode(code));\n if (this.options.load !== 'languageOnly' && this.options.load !== 'currentOnly') addCode(this.getScriptPartFromCode(code));\n if (this.options.load !== 'currentOnly') addCode(this.getLanguagePartFromCode(code));\n } else if (typeof code === 'string') {\n addCode(this.formatLanguageCode(code));\n }\n\n fallbackCodes.forEach(function (fc) {\n if (codes.indexOf(fc) < 0) addCode(_this2.formatLanguageCode(fc));\n });\n return codes;\n }\n }]);\n\n return LanguageUtil;\n}();\n\nvar sets = [{\n lngs: ['ach', 'ak', 'am', 'arn', 'br', 'fil', 'gun', 'ln', 'mfe', 'mg', 'mi', 'oc', 'pt', 'pt-BR', 'tg', 'tl', 'ti', 'tr', 'uz', 'wa'],\n nr: [1, 2],\n fc: 1\n}, {\n lngs: ['af', 'an', 'ast', 'az', 'bg', 'bn', 'ca', 'da', 'de', 'dev', 'el', 'en', 'eo', 'es', 'et', 'eu', 'fi', 'fo', 'fur', 'fy', 'gl', 'gu', 'ha', 'hi', 'hu', 'hy', 'ia', 'it', 'kk', 'kn', 'ku', 'lb', 'mai', 'ml', 'mn', 'mr', 'nah', 'nap', 'nb', 'ne', 'nl', 'nn', 'no', 'nso', 'pa', 'pap', 'pms', 'ps', 'pt-PT', 'rm', 'sco', 'se', 'si', 'so', 'son', 'sq', 'sv', 'sw', 'ta', 'te', 'tk', 'ur', 'yo'],\n nr: [1, 2],\n fc: 2\n}, {\n lngs: ['ay', 'bo', 'cgg', 'fa', 'ht', 'id', 'ja', 'jbo', 'ka', 'km', 'ko', 'ky', 'lo', 'ms', 'sah', 'su', 'th', 'tt', 'ug', 'vi', 'wo', 'zh'],\n nr: [1],\n fc: 3\n}, {\n lngs: ['be', 'bs', 'cnr', 'dz', 'hr', 'ru', 'sr', 'uk'],\n nr: [1, 2, 5],\n fc: 4\n}, {\n lngs: ['ar'],\n nr: [0, 1, 2, 3, 11, 100],\n fc: 5\n}, {\n lngs: ['cs', 'sk'],\n nr: [1, 2, 5],\n fc: 6\n}, {\n lngs: ['csb', 'pl'],\n nr: [1, 2, 5],\n fc: 7\n}, {\n lngs: ['cy'],\n nr: [1, 2, 3, 8],\n fc: 8\n}, {\n lngs: ['fr'],\n nr: [1, 2],\n fc: 9\n}, {\n lngs: ['ga'],\n nr: [1, 2, 3, 7, 11],\n fc: 10\n}, {\n lngs: ['gd'],\n nr: [1, 2, 3, 20],\n fc: 11\n}, {\n lngs: ['is'],\n nr: [1, 2],\n fc: 12\n}, {\n lngs: ['jv'],\n nr: [0, 1],\n fc: 13\n}, {\n lngs: ['kw'],\n nr: [1, 2, 3, 4],\n fc: 14\n}, {\n lngs: ['lt'],\n nr: [1, 2, 10],\n fc: 15\n}, {\n lngs: ['lv'],\n nr: [1, 2, 0],\n fc: 16\n}, {\n lngs: ['mk'],\n nr: [1, 2],\n fc: 17\n}, {\n lngs: ['mnk'],\n nr: [0, 1, 2],\n fc: 18\n}, {\n lngs: ['mt'],\n nr: [1, 2, 11, 20],\n fc: 19\n}, {\n lngs: ['or'],\n nr: [2, 1],\n fc: 2\n}, {\n lngs: ['ro'],\n nr: [1, 2, 20],\n fc: 20\n}, {\n lngs: ['sl'],\n nr: [5, 1, 2, 3],\n fc: 21\n}, {\n lngs: ['he', 'iw'],\n nr: [1, 2, 20, 21],\n fc: 22\n}];\nvar _rulesPluralsTypes = {\n 1: function _(n) {\n return Number(n > 1);\n },\n 2: function _(n) {\n return Number(n != 1);\n },\n 3: function _(n) {\n return 0;\n },\n 4: function _(n) {\n return Number(n % 10 == 1 && n % 100 != 11 ? 0 : n % 10 >= 2 && n % 10 <= 4 && (n % 100 < 10 || n % 100 >= 20) ? 1 : 2);\n },\n 5: function _(n) {\n return Number(n == 0 ? 0 : n == 1 ? 1 : n == 2 ? 2 : n % 100 >= 3 && n % 100 <= 10 ? 3 : n % 100 >= 11 ? 4 : 5);\n },\n 6: function _(n) {\n return Number(n == 1 ? 0 : n >= 2 && n <= 4 ? 1 : 2);\n },\n 7: function _(n) {\n return Number(n == 1 ? 0 : n % 10 >= 2 && n % 10 <= 4 && (n % 100 < 10 || n % 100 >= 20) ? 1 : 2);\n },\n 8: function _(n) {\n return Number(n == 1 ? 0 : n == 2 ? 1 : n != 8 && n != 11 ? 2 : 3);\n },\n 9: function _(n) {\n return Number(n >= 2);\n },\n 10: function _(n) {\n return Number(n == 1 ? 0 : n == 2 ? 1 : n < 7 ? 2 : n < 11 ? 3 : 4);\n },\n 11: function _(n) {\n return Number(n == 1 || n == 11 ? 0 : n == 2 || n == 12 ? 1 : n > 2 && n < 20 ? 2 : 3);\n },\n 12: function _(n) {\n return Number(n % 10 != 1 || n % 100 == 11);\n },\n 13: function _(n) {\n return Number(n !== 0);\n },\n 14: function _(n) {\n return Number(n == 1 ? 0 : n == 2 ? 1 : n == 3 ? 2 : 3);\n },\n 15: function _(n) {\n return Number(n % 10 == 1 && n % 100 != 11 ? 0 : n % 10 >= 2 && (n % 100 < 10 || n % 100 >= 20) ? 1 : 2);\n },\n 16: function _(n) {\n return Number(n % 10 == 1 && n % 100 != 11 ? 0 : n !== 0 ? 1 : 2);\n },\n 17: function _(n) {\n return Number(n == 1 || n % 10 == 1 && n % 100 != 11 ? 0 : 1);\n },\n 18: function _(n) {\n return Number(n == 0 ? 0 : n == 1 ? 1 : 2);\n },\n 19: function _(n) {\n return Number(n == 1 ? 0 : n == 0 || n % 100 > 1 && n % 100 < 11 ? 1 : n % 100 > 10 && n % 100 < 20 ? 2 : 3);\n },\n 20: function _(n) {\n return Number(n == 1 ? 0 : n == 0 || n % 100 > 0 && n % 100 < 20 ? 1 : 2);\n },\n 21: function _(n) {\n return Number(n % 100 == 1 ? 1 : n % 100 == 2 ? 2 : n % 100 == 3 || n % 100 == 4 ? 3 : 0);\n },\n 22: function _(n) {\n return Number(n == 1 ? 0 : n == 2 ? 1 : (n < 0 || n > 10) && n % 10 == 0 ? 2 : 3);\n }\n};\nvar deprecatedJsonVersions = ['v1', 'v2', 'v3'];\nvar suffixesOrder = {\n zero: 0,\n one: 1,\n two: 2,\n few: 3,\n many: 4,\n other: 5\n};\n\nfunction createRules() {\n var rules = {};\n sets.forEach(function (set) {\n set.lngs.forEach(function (l) {\n rules[l] = {\n numbers: set.nr,\n plurals: _rulesPluralsTypes[set.fc]\n };\n });\n });\n return rules;\n}\n\nvar PluralResolver = function () {\n function PluralResolver(languageUtils) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, PluralResolver);\n\n this.languageUtils = languageUtils;\n this.options = options;\n this.logger = baseLogger.create('pluralResolver');\n\n if ((!this.options.compatibilityJSON || this.options.compatibilityJSON === 'v4') && (typeof Intl === 'undefined' || !Intl.PluralRules)) {\n this.options.compatibilityJSON = 'v3';\n this.logger.error('Your environment seems not to be Intl API compatible, use an Intl.PluralRules polyfill. Will fallback to the compatibilityJSON v3 format handling.');\n }\n\n this.rules = createRules();\n }\n\n _createClass(PluralResolver, [{\n key: \"addRule\",\n value: function addRule(lng, obj) {\n this.rules[lng] = obj;\n }\n }, {\n key: \"getRule\",\n value: function getRule(code) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (this.shouldUseIntlApi()) {\n try {\n return new Intl.PluralRules(code, {\n type: options.ordinal ? 'ordinal' : 'cardinal'\n });\n } catch (_unused) {\n return;\n }\n }\n\n return this.rules[code] || this.rules[this.languageUtils.getLanguagePartFromCode(code)];\n }\n }, {\n key: \"needsPlural\",\n value: function needsPlural(code) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var rule = this.getRule(code, options);\n\n if (this.shouldUseIntlApi()) {\n return rule && rule.resolvedOptions().pluralCategories.length > 1;\n }\n\n return rule && rule.numbers.length > 1;\n }\n }, {\n key: \"getPluralFormsOfKey\",\n value: function getPluralFormsOfKey(code, key) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n return this.getSuffixes(code, options).map(function (suffix) {\n return \"\".concat(key).concat(suffix);\n });\n }\n }, {\n key: \"getSuffixes\",\n value: function getSuffixes(code) {\n var _this = this;\n\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var rule = this.getRule(code, options);\n\n if (!rule) {\n return [];\n }\n\n if (this.shouldUseIntlApi()) {\n return rule.resolvedOptions().pluralCategories.sort(function (pluralCategory1, pluralCategory2) {\n return suffixesOrder[pluralCategory1] - suffixesOrder[pluralCategory2];\n }).map(function (pluralCategory) {\n return \"\".concat(_this.options.prepend).concat(pluralCategory);\n });\n }\n\n return rule.numbers.map(function (number) {\n return _this.getSuffix(code, number, options);\n });\n }\n }, {\n key: \"getSuffix\",\n value: function getSuffix(code, count) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var rule = this.getRule(code, options);\n\n if (rule) {\n if (this.shouldUseIntlApi()) {\n return \"\".concat(this.options.prepend).concat(rule.select(count));\n }\n\n return this.getSuffixRetroCompatible(rule, count);\n }\n\n this.logger.warn(\"no plural rule found for: \".concat(code));\n return '';\n }\n }, {\n key: \"getSuffixRetroCompatible\",\n value: function getSuffixRetroCompatible(rule, count) {\n var _this2 = this;\n\n var idx = rule.noAbs ? rule.plurals(count) : rule.plurals(Math.abs(count));\n var suffix = rule.numbers[idx];\n\n if (this.options.simplifyPluralSuffix && rule.numbers.length === 2 && rule.numbers[0] === 1) {\n if (suffix === 2) {\n suffix = 'plural';\n } else if (suffix === 1) {\n suffix = '';\n }\n }\n\n var returnSuffix = function returnSuffix() {\n return _this2.options.prepend && suffix.toString() ? _this2.options.prepend + suffix.toString() : suffix.toString();\n };\n\n if (this.options.compatibilityJSON === 'v1') {\n if (suffix === 1) return '';\n if (typeof suffix === 'number') return \"_plural_\".concat(suffix.toString());\n return returnSuffix();\n } else if (this.options.compatibilityJSON === 'v2') {\n return returnSuffix();\n } else if (this.options.simplifyPluralSuffix && rule.numbers.length === 2 && rule.numbers[0] === 1) {\n return returnSuffix();\n }\n\n return this.options.prepend && idx.toString() ? this.options.prepend + idx.toString() : idx.toString();\n }\n }, {\n key: \"shouldUseIntlApi\",\n value: function shouldUseIntlApi() {\n return !deprecatedJsonVersions.includes(this.options.compatibilityJSON);\n }\n }]);\n\n return PluralResolver;\n}();\n\nfunction ownKeys$3(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$3(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$3(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar Interpolator = function () {\n function Interpolator() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n _classCallCheck(this, Interpolator);\n\n this.logger = baseLogger.create('interpolator');\n this.options = options;\n\n this.format = options.interpolation && options.interpolation.format || function (value) {\n return value;\n };\n\n this.init(options);\n }\n\n _createClass(Interpolator, [{\n key: \"init\",\n value: function init() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n if (!options.interpolation) options.interpolation = {\n escapeValue: true\n };\n var iOpts = options.interpolation;\n this.escape = iOpts.escape !== undefined ? iOpts.escape : escape;\n this.escapeValue = iOpts.escapeValue !== undefined ? iOpts.escapeValue : true;\n this.useRawValueToEscape = iOpts.useRawValueToEscape !== undefined ? iOpts.useRawValueToEscape : false;\n this.prefix = iOpts.prefix ? regexEscape(iOpts.prefix) : iOpts.prefixEscaped || '{{';\n this.suffix = iOpts.suffix ? regexEscape(iOpts.suffix) : iOpts.suffixEscaped || '}}';\n this.formatSeparator = iOpts.formatSeparator ? iOpts.formatSeparator : iOpts.formatSeparator || ',';\n this.unescapePrefix = iOpts.unescapeSuffix ? '' : iOpts.unescapePrefix || '-';\n this.unescapeSuffix = this.unescapePrefix ? '' : iOpts.unescapeSuffix || '';\n this.nestingPrefix = iOpts.nestingPrefix ? regexEscape(iOpts.nestingPrefix) : iOpts.nestingPrefixEscaped || regexEscape('$t(');\n this.nestingSuffix = iOpts.nestingSuffix ? regexEscape(iOpts.nestingSuffix) : iOpts.nestingSuffixEscaped || regexEscape(')');\n this.nestingOptionsSeparator = iOpts.nestingOptionsSeparator ? iOpts.nestingOptionsSeparator : iOpts.nestingOptionsSeparator || ',';\n this.maxReplaces = iOpts.maxReplaces ? iOpts.maxReplaces : 1000;\n this.alwaysFormat = iOpts.alwaysFormat !== undefined ? iOpts.alwaysFormat : false;\n this.resetRegExp();\n }\n }, {\n key: \"reset\",\n value: function reset() {\n if (this.options) this.init(this.options);\n }\n }, {\n key: \"resetRegExp\",\n value: function resetRegExp() {\n var regexpStr = \"\".concat(this.prefix, \"(.+?)\").concat(this.suffix);\n this.regexp = new RegExp(regexpStr, 'g');\n var regexpUnescapeStr = \"\".concat(this.prefix).concat(this.unescapePrefix, \"(.+?)\").concat(this.unescapeSuffix).concat(this.suffix);\n this.regexpUnescape = new RegExp(regexpUnescapeStr, 'g');\n var nestingRegexpStr = \"\".concat(this.nestingPrefix, \"(.+?)\").concat(this.nestingSuffix);\n this.nestingRegexp = new RegExp(nestingRegexpStr, 'g');\n }\n }, {\n key: \"interpolate\",\n value: function interpolate(str, data, lng, options) {\n var _this = this;\n\n var match;\n var value;\n var replaces;\n var defaultData = this.options && this.options.interpolation && this.options.interpolation.defaultVariables || {};\n\n function regexSafe(val) {\n return val.replace(/\\$/g, '$$$$');\n }\n\n var handleFormat = function handleFormat(key) {\n if (key.indexOf(_this.formatSeparator) < 0) {\n var path = getPathWithDefaults(data, defaultData, key);\n return _this.alwaysFormat ? _this.format(path, undefined, lng, _objectSpread$3(_objectSpread$3(_objectSpread$3({}, options), data), {}, {\n interpolationkey: key\n })) : path;\n }\n\n var p = key.split(_this.formatSeparator);\n var k = p.shift().trim();\n var f = p.join(_this.formatSeparator).trim();\n return _this.format(getPathWithDefaults(data, defaultData, k), f, lng, _objectSpread$3(_objectSpread$3(_objectSpread$3({}, options), data), {}, {\n interpolationkey: k\n }));\n };\n\n this.resetRegExp();\n var missingInterpolationHandler = options && options.missingInterpolationHandler || this.options.missingInterpolationHandler;\n var skipOnVariables = options && options.interpolation && options.interpolation.skipOnVariables !== undefined ? options.interpolation.skipOnVariables : this.options.interpolation.skipOnVariables;\n var todos = [{\n regex: this.regexpUnescape,\n safeValue: function safeValue(val) {\n return regexSafe(val);\n }\n }, {\n regex: this.regexp,\n safeValue: function safeValue(val) {\n return _this.escapeValue ? regexSafe(_this.escape(val)) : regexSafe(val);\n }\n }];\n todos.forEach(function (todo) {\n replaces = 0;\n\n while (match = todo.regex.exec(str)) {\n var matchedVar = match[1].trim();\n value = handleFormat(matchedVar);\n\n if (value === undefined) {\n if (typeof missingInterpolationHandler === 'function') {\n var temp = missingInterpolationHandler(str, match, options);\n value = typeof temp === 'string' ? temp : '';\n } else if (options && options.hasOwnProperty(matchedVar)) {\n value = '';\n } else if (skipOnVariables) {\n value = match[0];\n continue;\n } else {\n _this.logger.warn(\"missed to pass in variable \".concat(matchedVar, \" for interpolating \").concat(str));\n\n value = '';\n }\n } else if (typeof value !== 'string' && !_this.useRawValueToEscape) {\n value = makeString(value);\n }\n\n var safeValue = todo.safeValue(value);\n str = str.replace(match[0], safeValue);\n\n if (skipOnVariables) {\n todo.regex.lastIndex += value.length;\n todo.regex.lastIndex -= match[0].length;\n } else {\n todo.regex.lastIndex = 0;\n }\n\n replaces++;\n\n if (replaces >= _this.maxReplaces) {\n break;\n }\n }\n });\n return str;\n }\n }, {\n key: \"nest\",\n value: function nest(str, fc) {\n var _this2 = this;\n\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var match;\n var value;\n\n var clonedOptions = _objectSpread$3({}, options);\n\n clonedOptions.applyPostProcessor = false;\n delete clonedOptions.defaultValue;\n\n function handleHasOptions(key, inheritedOptions) {\n var sep = this.nestingOptionsSeparator;\n if (key.indexOf(sep) < 0) return key;\n var c = key.split(new RegExp(\"\".concat(sep, \"[ ]*{\")));\n var optionsString = \"{\".concat(c[1]);\n key = c[0];\n optionsString = this.interpolate(optionsString, clonedOptions);\n optionsString = optionsString.replace(/'/g, '\"');\n\n try {\n clonedOptions = JSON.parse(optionsString);\n if (inheritedOptions) clonedOptions = _objectSpread$3(_objectSpread$3({}, inheritedOptions), clonedOptions);\n } catch (e) {\n this.logger.warn(\"failed parsing options string in nesting for key \".concat(key), e);\n return \"\".concat(key).concat(sep).concat(optionsString);\n }\n\n delete clonedOptions.defaultValue;\n return key;\n }\n\n while (match = this.nestingRegexp.exec(str)) {\n var formatters = [];\n var doReduce = false;\n\n if (match[0].indexOf(this.formatSeparator) !== -1 && !/{.*}/.test(match[1])) {\n var r = match[1].split(this.formatSeparator).map(function (elem) {\n return elem.trim();\n });\n match[1] = r.shift();\n formatters = r;\n doReduce = true;\n }\n\n value = fc(handleHasOptions.call(this, match[1].trim(), clonedOptions), clonedOptions);\n if (value && match[0] === str && typeof value !== 'string') return value;\n if (typeof value !== 'string') value = makeString(value);\n\n if (!value) {\n this.logger.warn(\"missed to resolve \".concat(match[1], \" for nesting \").concat(str));\n value = '';\n }\n\n if (doReduce) {\n value = formatters.reduce(function (v, f) {\n return _this2.format(v, f, options.lng, _objectSpread$3(_objectSpread$3({}, options), {}, {\n interpolationkey: match[1].trim()\n }));\n }, value.trim());\n }\n\n str = str.replace(match[0], value);\n this.regexp.lastIndex = 0;\n }\n\n return str;\n }\n }]);\n\n return Interpolator;\n}();\n\nfunction ownKeys$4(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread$4(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$4(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$4(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction parseFormatStr(formatStr) {\n var formatName = formatStr.toLowerCase().trim();\n var formatOptions = {};\n\n if (formatStr.indexOf('(') > -1) {\n var p = formatStr.split('(');\n formatName = p[0].toLowerCase().trim();\n var optStr = p[1].substring(0, p[1].length - 1);\n\n if (formatName === 'currency' && optStr.indexOf(':') < 0) {\n if (!formatOptions.currency) formatOptions.currency = optStr.trim();\n } else if (formatName === 'relativetime' && optStr.indexOf(':') < 0) {\n if (!formatOptions.range) formatOptions.range = optStr.trim();\n } else {\n var opts = optStr.split(';');\n opts.forEach(function (opt) {\n if (!opt) return;\n\n var _opt$split = opt.split(':'),\n _opt$split2 = _toArray(_opt$split),\n key = _opt$split2[0],\n rest = _opt$split2.slice(1);\n\n var val = rest.join(':').trim().replace(/^'+|'+$/g, '');\n if (!formatOptions[key.trim()]) formatOptions[key.trim()] = val;\n if (val === 'false') formatOptions[key.trim()] = false;\n if (val === 'true') formatOptions[key.trim()] = true;\n if (!isNaN(val)) formatOptions[key.trim()] = parseInt(val, 10);\n });\n }\n }\n\n return {\n formatName: formatName,\n formatOptions: formatOptions\n };\n}\n\nvar Formatter = function () {\n function Formatter() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n\n _classCallCheck(this, Formatter);\n\n this.logger = baseLogger.create('formatter');\n this.options = options;\n this.formats = {\n number: function number(val, lng, options) {\n return new Intl.NumberFormat(lng, options).format(val);\n },\n currency: function currency(val, lng, options) {\n return new Intl.NumberFormat(lng, _objectSpread$4(_objectSpread$4({}, options), {}, {\n style: 'currency'\n })).format(val);\n },\n datetime: function datetime(val, lng, options) {\n return new Intl.DateTimeFormat(lng, _objectSpread$4({}, options)).format(val);\n },\n relativetime: function relativetime(val, lng, options) {\n return new Intl.RelativeTimeFormat(lng, _objectSpread$4({}, options)).format(val, options.range || 'day');\n },\n list: function list(val, lng, options) {\n return new Intl.ListFormat(lng, _objectSpread$4({}, options)).format(val);\n }\n };\n this.init(options);\n }\n\n _createClass(Formatter, [{\n key: \"init\",\n value: function init(services) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n interpolation: {}\n };\n var iOpts = options.interpolation;\n this.formatSeparator = iOpts.formatSeparator ? iOpts.formatSeparator : iOpts.formatSeparator || ',';\n }\n }, {\n key: \"add\",\n value: function add(name, fc) {\n this.formats[name.toLowerCase().trim()] = fc;\n }\n }, {\n key: \"format\",\n value: function format(value, _format, lng, options) {\n var _this = this;\n\n var formats = _format.split(this.formatSeparator);\n\n var result = formats.reduce(function (mem, f) {\n var _parseFormatStr = parseFormatStr(f),\n formatName = _parseFormatStr.formatName,\n formatOptions = _parseFormatStr.formatOptions;\n\n if (_this.formats[formatName]) {\n var formatted = mem;\n\n try {\n var valOptions = options && options.formatParams && options.formatParams[options.interpolationkey] || {};\n var l = valOptions.locale || valOptions.lng || options.locale || options.lng || lng;\n formatted = _this.formats[formatName](mem, l, _objectSpread$4(_objectSpread$4(_objectSpread$4({}, formatOptions), options), valOptions));\n } catch (error) {\n _this.logger.warn(error);\n }\n\n return formatted;\n } else {\n _this.logger.warn(\"there was no format function for \".concat(formatName));\n }\n\n return mem;\n }, value);\n return result;\n }\n }]);\n\n return Formatter;\n}();\n\nfunction ownKeys$5(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread$5(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$5(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$5(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _createSuper$2(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$2(); 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 _isNativeReflectConstruct$2() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction removePending(q, name) {\n if (q.pending[name] !== undefined) {\n delete q.pending[name];\n q.pendingCount--;\n }\n}\n\nvar Connector = function (_EventEmitter) {\n _inherits(Connector, _EventEmitter);\n\n var _super = _createSuper$2(Connector);\n\n function Connector(backend, store, services) {\n var _this;\n\n var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n\n _classCallCheck(this, Connector);\n\n _this = _super.call(this);\n\n if (isIE10) {\n EventEmitter.call(_assertThisInitialized(_this));\n }\n\n _this.backend = backend;\n _this.store = store;\n _this.services = services;\n _this.languageUtils = services.languageUtils;\n _this.options = options;\n _this.logger = baseLogger.create('backendConnector');\n _this.waitingReads = [];\n _this.maxParallelReads = options.maxParallelReads || 10;\n _this.readingCalls = 0;\n _this.state = {};\n _this.queue = [];\n\n if (_this.backend && _this.backend.init) {\n _this.backend.init(services, options.backend, options);\n }\n\n return _this;\n }\n\n _createClass(Connector, [{\n key: \"queueLoad\",\n value: function queueLoad(languages, namespaces, options, callback) {\n var _this2 = this;\n\n var toLoad = {};\n var pending = {};\n var toLoadLanguages = {};\n var toLoadNamespaces = {};\n languages.forEach(function (lng) {\n var hasAllNamespaces = true;\n namespaces.forEach(function (ns) {\n var name = \"\".concat(lng, \"|\").concat(ns);\n\n if (!options.reload && _this2.store.hasResourceBundle(lng, ns)) {\n _this2.state[name] = 2;\n } else if (_this2.state[name] < 0) ; else if (_this2.state[name] === 1) {\n if (pending[name] === undefined) pending[name] = true;\n } else {\n _this2.state[name] = 1;\n hasAllNamespaces = false;\n if (pending[name] === undefined) pending[name] = true;\n if (toLoad[name] === undefined) toLoad[name] = true;\n if (toLoadNamespaces[ns] === undefined) toLoadNamespaces[ns] = true;\n }\n });\n if (!hasAllNamespaces) toLoadLanguages[lng] = true;\n });\n\n if (Object.keys(toLoad).length || Object.keys(pending).length) {\n this.queue.push({\n pending: pending,\n pendingCount: Object.keys(pending).length,\n loaded: {},\n errors: [],\n callback: callback\n });\n }\n\n return {\n toLoad: Object.keys(toLoad),\n pending: Object.keys(pending),\n toLoadLanguages: Object.keys(toLoadLanguages),\n toLoadNamespaces: Object.keys(toLoadNamespaces)\n };\n }\n }, {\n key: \"loaded\",\n value: function loaded(name, err, data) {\n var s = name.split('|');\n var lng = s[0];\n var ns = s[1];\n if (err) this.emit('failedLoading', lng, ns, err);\n\n if (data) {\n this.store.addResourceBundle(lng, ns, data);\n }\n\n this.state[name] = err ? -1 : 2;\n var loaded = {};\n this.queue.forEach(function (q) {\n pushPath(q.loaded, [lng], ns);\n removePending(q, name);\n if (err) q.errors.push(err);\n\n if (q.pendingCount === 0 && !q.done) {\n Object.keys(q.loaded).forEach(function (l) {\n if (!loaded[l]) loaded[l] = {};\n var loadedKeys = q.loaded[l];\n\n if (loadedKeys.length) {\n loadedKeys.forEach(function (ns) {\n if (loaded[l][ns] === undefined) loaded[l][ns] = true;\n });\n }\n });\n q.done = true;\n\n if (q.errors.length) {\n q.callback(q.errors);\n } else {\n q.callback();\n }\n }\n });\n this.emit('loaded', loaded);\n this.queue = this.queue.filter(function (q) {\n return !q.done;\n });\n }\n }, {\n key: \"read\",\n value: function read(lng, ns, fcName) {\n var _this3 = this;\n\n var tried = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;\n var wait = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 350;\n var callback = arguments.length > 5 ? arguments[5] : undefined;\n if (!lng.length) return callback(null, {});\n\n if (this.readingCalls >= this.maxParallelReads) {\n this.waitingReads.push({\n lng: lng,\n ns: ns,\n fcName: fcName,\n tried: tried,\n wait: wait,\n callback: callback\n });\n return;\n }\n\n this.readingCalls++;\n return this.backend[fcName](lng, ns, function (err, data) {\n if (err && data && tried < 5) {\n setTimeout(function () {\n _this3.read.call(_this3, lng, ns, fcName, tried + 1, wait * 2, callback);\n }, wait);\n return;\n }\n\n _this3.readingCalls--;\n\n if (_this3.waitingReads.length > 0) {\n var next = _this3.waitingReads.shift();\n\n _this3.read(next.lng, next.ns, next.fcName, next.tried, next.wait, next.callback);\n }\n\n callback(err, data);\n });\n }\n }, {\n key: \"prepareLoading\",\n value: function prepareLoading(languages, namespaces) {\n var _this4 = this;\n\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var callback = arguments.length > 3 ? arguments[3] : undefined;\n\n if (!this.backend) {\n this.logger.warn('No backend was added via i18next.use. Will not load resources.');\n return callback && callback();\n }\n\n if (typeof languages === 'string') languages = this.languageUtils.toResolveHierarchy(languages);\n if (typeof namespaces === 'string') namespaces = [namespaces];\n var toLoad = this.queueLoad(languages, namespaces, options, callback);\n\n if (!toLoad.toLoad.length) {\n if (!toLoad.pending.length) callback();\n return null;\n }\n\n toLoad.toLoad.forEach(function (name) {\n _this4.loadOne(name);\n });\n }\n }, {\n key: \"load\",\n value: function load(languages, namespaces, callback) {\n this.prepareLoading(languages, namespaces, {}, callback);\n }\n }, {\n key: \"reload\",\n value: function reload(languages, namespaces, callback) {\n this.prepareLoading(languages, namespaces, {\n reload: true\n }, callback);\n }\n }, {\n key: \"loadOne\",\n value: function loadOne(name) {\n var _this5 = this;\n\n var prefix = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n var s = name.split('|');\n var lng = s[0];\n var ns = s[1];\n this.read(lng, ns, 'read', undefined, undefined, function (err, data) {\n if (err) _this5.logger.warn(\"\".concat(prefix, \"loading namespace \").concat(ns, \" for language \").concat(lng, \" failed\"), err);\n if (!err && data) _this5.logger.log(\"\".concat(prefix, \"loaded namespace \").concat(ns, \" for language \").concat(lng), data);\n\n _this5.loaded(name, err, data);\n });\n }\n }, {\n key: \"saveMissing\",\n value: function saveMissing(languages, namespace, key, fallbackValue, isUpdate) {\n var options = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : {};\n\n if (this.services.utils && this.services.utils.hasLoadedNamespace && !this.services.utils.hasLoadedNamespace(namespace)) {\n this.logger.warn(\"did not save key \\\"\".concat(key, \"\\\" as the namespace \\\"\").concat(namespace, \"\\\" was not yet loaded\"), 'This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!');\n return;\n }\n\n if (key === undefined || key === null || key === '') return;\n\n if (this.backend && this.backend.create) {\n this.backend.create(languages, namespace, key, fallbackValue, null, _objectSpread$5(_objectSpread$5({}, options), {}, {\n isUpdate: isUpdate\n }));\n }\n\n if (!languages || !languages[0]) return;\n this.store.addResource(languages[0], namespace, key, fallbackValue);\n }\n }]);\n\n return Connector;\n}(EventEmitter);\n\nfunction get() {\n return {\n debug: false,\n initImmediate: true,\n ns: ['translation'],\n defaultNS: ['translation'],\n fallbackLng: ['dev'],\n fallbackNS: false,\n supportedLngs: false,\n nonExplicitSupportedLngs: false,\n load: 'all',\n preload: false,\n simplifyPluralSuffix: true,\n keySeparator: '.',\n nsSeparator: ':',\n pluralSeparator: '_',\n contextSeparator: '_',\n partialBundledLanguages: false,\n saveMissing: false,\n updateMissing: false,\n saveMissingTo: 'fallback',\n saveMissingPlurals: true,\n missingKeyHandler: false,\n missingInterpolationHandler: false,\n postProcess: false,\n postProcessPassResolved: false,\n returnNull: true,\n returnEmptyString: true,\n returnObjects: false,\n joinArrays: false,\n returnedObjectHandler: false,\n parseMissingKeyHandler: false,\n appendNamespaceToMissingKey: false,\n appendNamespaceToCIMode: false,\n overloadTranslationOptionHandler: function handle(args) {\n var ret = {};\n if (_typeof(args[1]) === 'object') ret = args[1];\n if (typeof args[1] === 'string') ret.defaultValue = args[1];\n if (typeof args[2] === 'string') ret.tDescription = args[2];\n\n if (_typeof(args[2]) === 'object' || _typeof(args[3]) === 'object') {\n var options = args[3] || args[2];\n Object.keys(options).forEach(function (key) {\n ret[key] = options[key];\n });\n }\n\n return ret;\n },\n interpolation: {\n escapeValue: true,\n format: function format(value, _format, lng, options) {\n return value;\n },\n prefix: '{{',\n suffix: '}}',\n formatSeparator: ',',\n unescapePrefix: '-',\n nestingPrefix: '$t(',\n nestingSuffix: ')',\n nestingOptionsSeparator: ',',\n maxReplaces: 1000,\n skipOnVariables: true\n }\n };\n}\nfunction transformOptions(options) {\n if (typeof options.ns === 'string') options.ns = [options.ns];\n if (typeof options.fallbackLng === 'string') options.fallbackLng = [options.fallbackLng];\n if (typeof options.fallbackNS === 'string') options.fallbackNS = [options.fallbackNS];\n\n if (options.supportedLngs && options.supportedLngs.indexOf('cimode') < 0) {\n options.supportedLngs = options.supportedLngs.concat(['cimode']);\n }\n\n return options;\n}\n\nfunction ownKeys$6(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread$6(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$6(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$6(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _createSuper$3(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$3(); 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 _isNativeReflectConstruct$3() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction noop() {}\n\nfunction bindMemberFunctions(inst) {\n var mems = Object.getOwnPropertyNames(Object.getPrototypeOf(inst));\n mems.forEach(function (mem) {\n if (typeof inst[mem] === 'function') {\n inst[mem] = inst[mem].bind(inst);\n }\n });\n}\n\nvar I18n = function (_EventEmitter) {\n _inherits(I18n, _EventEmitter);\n\n var _super = _createSuper$3(I18n);\n\n function I18n() {\n var _this;\n\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var callback = arguments.length > 1 ? arguments[1] : undefined;\n\n _classCallCheck(this, I18n);\n\n _this = _super.call(this);\n\n if (isIE10) {\n EventEmitter.call(_assertThisInitialized(_this));\n }\n\n _this.options = transformOptions(options);\n _this.services = {};\n _this.logger = baseLogger;\n _this.modules = {\n external: []\n };\n bindMemberFunctions(_assertThisInitialized(_this));\n\n if (callback && !_this.isInitialized && !options.isClone) {\n if (!_this.options.initImmediate) {\n _this.init(options, callback);\n\n return _possibleConstructorReturn(_this, _assertThisInitialized(_this));\n }\n\n setTimeout(function () {\n _this.init(options, callback);\n }, 0);\n }\n\n return _this;\n }\n\n _createClass(I18n, [{\n key: \"init\",\n value: function init() {\n var _this2 = this;\n\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var callback = arguments.length > 1 ? arguments[1] : undefined;\n\n if (typeof options === 'function') {\n callback = options;\n options = {};\n }\n\n if (!options.defaultNS && options.ns) {\n if (typeof options.ns === 'string') {\n options.defaultNS = options.ns;\n } else if (options.ns.indexOf('translation') < 0) {\n options.defaultNS = options.ns[0];\n }\n }\n\n var defOpts = get();\n this.options = _objectSpread$6(_objectSpread$6(_objectSpread$6({}, defOpts), this.options), transformOptions(options));\n\n if (this.options.compatibilityAPI !== 'v1') {\n this.options.interpolation = _objectSpread$6(_objectSpread$6({}, defOpts.interpolation), this.options.interpolation);\n }\n\n if (options.keySeparator !== undefined) {\n this.options.userDefinedKeySeparator = options.keySeparator;\n }\n\n if (options.nsSeparator !== undefined) {\n this.options.userDefinedNsSeparator = options.nsSeparator;\n }\n\n function createClassOnDemand(ClassOrObject) {\n if (!ClassOrObject) return null;\n if (typeof ClassOrObject === 'function') return new ClassOrObject();\n return ClassOrObject;\n }\n\n if (!this.options.isClone) {\n if (this.modules.logger) {\n baseLogger.init(createClassOnDemand(this.modules.logger), this.options);\n } else {\n baseLogger.init(null, this.options);\n }\n\n var formatter;\n\n if (this.modules.formatter) {\n formatter = this.modules.formatter;\n } else if (typeof Intl !== 'undefined') {\n formatter = Formatter;\n }\n\n var lu = new LanguageUtil(this.options);\n this.store = new ResourceStore(this.options.resources, this.options);\n var s = this.services;\n s.logger = baseLogger;\n s.resourceStore = this.store;\n s.languageUtils = lu;\n s.pluralResolver = new PluralResolver(lu, {\n prepend: this.options.pluralSeparator,\n compatibilityJSON: this.options.compatibilityJSON,\n simplifyPluralSuffix: this.options.simplifyPluralSuffix\n });\n\n if (formatter && (!this.options.interpolation.format || this.options.interpolation.format === defOpts.interpolation.format)) {\n s.formatter = createClassOnDemand(formatter);\n s.formatter.init(s, this.options);\n this.options.interpolation.format = s.formatter.format.bind(s.formatter);\n }\n\n s.interpolator = new Interpolator(this.options);\n s.utils = {\n hasLoadedNamespace: this.hasLoadedNamespace.bind(this)\n };\n s.backendConnector = new Connector(createClassOnDemand(this.modules.backend), s.resourceStore, s, this.options);\n s.backendConnector.on('*', function (event) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n _this2.emit.apply(_this2, [event].concat(args));\n });\n\n if (this.modules.languageDetector) {\n s.languageDetector = createClassOnDemand(this.modules.languageDetector);\n s.languageDetector.init(s, this.options.detection, this.options);\n }\n\n if (this.modules.i18nFormat) {\n s.i18nFormat = createClassOnDemand(this.modules.i18nFormat);\n if (s.i18nFormat.init) s.i18nFormat.init(this);\n }\n\n this.translator = new Translator(this.services, this.options);\n this.translator.on('*', function (event) {\n for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n args[_key2 - 1] = arguments[_key2];\n }\n\n _this2.emit.apply(_this2, [event].concat(args));\n });\n this.modules.external.forEach(function (m) {\n if (m.init) m.init(_this2);\n });\n }\n\n this.format = this.options.interpolation.format;\n if (!callback) callback = noop;\n\n if (this.options.fallbackLng && !this.services.languageDetector && !this.options.lng) {\n var codes = this.services.languageUtils.getFallbackCodes(this.options.fallbackLng);\n if (codes.length > 0 && codes[0] !== 'dev') this.options.lng = codes[0];\n }\n\n if (!this.services.languageDetector && !this.options.lng) {\n this.logger.warn('init: no languageDetector is used and no lng is defined');\n }\n\n var storeApi = ['getResource', 'hasResourceBundle', 'getResourceBundle', 'getDataByLanguage'];\n storeApi.forEach(function (fcName) {\n _this2[fcName] = function () {\n var _this2$store;\n\n return (_this2$store = _this2.store)[fcName].apply(_this2$store, arguments);\n };\n });\n var storeApiChained = ['addResource', 'addResources', 'addResourceBundle', 'removeResourceBundle'];\n storeApiChained.forEach(function (fcName) {\n _this2[fcName] = function () {\n var _this2$store2;\n\n (_this2$store2 = _this2.store)[fcName].apply(_this2$store2, arguments);\n\n return _this2;\n };\n });\n var deferred = defer();\n\n var load = function load() {\n var finish = function finish(err, t) {\n if (_this2.isInitialized && !_this2.initializedStoreOnce) _this2.logger.warn('init: i18next is already initialized. You should call init just once!');\n _this2.isInitialized = true;\n if (!_this2.options.isClone) _this2.logger.log('initialized', _this2.options);\n\n _this2.emit('initialized', _this2.options);\n\n deferred.resolve(t);\n callback(err, t);\n };\n\n if (_this2.languages && _this2.options.compatibilityAPI !== 'v1' && !_this2.isInitialized) return finish(null, _this2.t.bind(_this2));\n\n _this2.changeLanguage(_this2.options.lng, finish);\n };\n\n if (this.options.resources || !this.options.initImmediate) {\n load();\n } else {\n setTimeout(load, 0);\n }\n\n return deferred;\n }\n }, {\n key: \"loadResources\",\n value: function loadResources(language) {\n var _this3 = this;\n\n var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : noop;\n var usedCallback = callback;\n var usedLng = typeof language === 'string' ? language : this.language;\n if (typeof language === 'function') usedCallback = language;\n\n if (!this.options.resources || this.options.partialBundledLanguages) {\n if (usedLng && usedLng.toLowerCase() === 'cimode') return usedCallback();\n var toLoad = [];\n\n var append = function append(lng) {\n if (!lng) return;\n\n var lngs = _this3.services.languageUtils.toResolveHierarchy(lng);\n\n lngs.forEach(function (l) {\n if (toLoad.indexOf(l) < 0) toLoad.push(l);\n });\n };\n\n if (!usedLng) {\n var fallbacks = this.services.languageUtils.getFallbackCodes(this.options.fallbackLng);\n fallbacks.forEach(function (l) {\n return append(l);\n });\n } else {\n append(usedLng);\n }\n\n if (this.options.preload) {\n this.options.preload.forEach(function (l) {\n return append(l);\n });\n }\n\n this.services.backendConnector.load(toLoad, this.options.ns, function (e) {\n if (!e && !_this3.resolvedLanguage && _this3.language) _this3.setResolvedLanguage(_this3.language);\n usedCallback(e);\n });\n } else {\n usedCallback(null);\n }\n }\n }, {\n key: \"reloadResources\",\n value: function reloadResources(lngs, ns, callback) {\n var deferred = defer();\n if (!lngs) lngs = this.languages;\n if (!ns) ns = this.options.ns;\n if (!callback) callback = noop;\n this.services.backendConnector.reload(lngs, ns, function (err) {\n deferred.resolve();\n callback(err);\n });\n return deferred;\n }\n }, {\n key: \"use\",\n value: function use(module) {\n if (!module) throw new Error('You are passing an undefined module! Please check the object you are passing to i18next.use()');\n if (!module.type) throw new Error('You are passing a wrong module! Please check the object you are passing to i18next.use()');\n\n if (module.type === 'backend') {\n this.modules.backend = module;\n }\n\n if (module.type === 'logger' || module.log && module.warn && module.error) {\n this.modules.logger = module;\n }\n\n if (module.type === 'languageDetector') {\n this.modules.languageDetector = module;\n }\n\n if (module.type === 'i18nFormat') {\n this.modules.i18nFormat = module;\n }\n\n if (module.type === 'postProcessor') {\n postProcessor.addPostProcessor(module);\n }\n\n if (module.type === 'formatter') {\n this.modules.formatter = module;\n }\n\n if (module.type === '3rdParty') {\n this.modules.external.push(module);\n }\n\n return this;\n }\n }, {\n key: \"setResolvedLanguage\",\n value: function setResolvedLanguage(l) {\n if (!l || !this.languages) return;\n if (['cimode', 'dev'].indexOf(l) > -1) return;\n\n for (var li = 0; li < this.languages.length; li++) {\n var lngInLngs = this.languages[li];\n if (['cimode', 'dev'].indexOf(lngInLngs) > -1) continue;\n\n if (this.store.hasLanguageSomeTranslations(lngInLngs)) {\n this.resolvedLanguage = lngInLngs;\n break;\n }\n }\n }\n }, {\n key: \"changeLanguage\",\n value: function changeLanguage(lng, callback) {\n var _this4 = this;\n\n this.isLanguageChangingTo = lng;\n var deferred = defer();\n this.emit('languageChanging', lng);\n\n var setLngProps = function setLngProps(l) {\n _this4.language = l;\n _this4.languages = _this4.services.languageUtils.toResolveHierarchy(l);\n _this4.resolvedLanguage = undefined;\n\n _this4.setResolvedLanguage(l);\n };\n\n var done = function done(err, l) {\n if (l) {\n setLngProps(l);\n\n _this4.translator.changeLanguage(l);\n\n _this4.isLanguageChangingTo = undefined;\n\n _this4.emit('languageChanged', l);\n\n _this4.logger.log('languageChanged', l);\n } else {\n _this4.isLanguageChangingTo = undefined;\n }\n\n deferred.resolve(function () {\n return _this4.t.apply(_this4, arguments);\n });\n if (callback) callback(err, function () {\n return _this4.t.apply(_this4, arguments);\n });\n };\n\n var setLng = function setLng(lngs) {\n if (!lng && !lngs && _this4.services.languageDetector) lngs = [];\n var l = typeof lngs === 'string' ? lngs : _this4.services.languageUtils.getBestMatchFromCodes(lngs);\n\n if (l) {\n if (!_this4.language) {\n setLngProps(l);\n }\n\n if (!_this4.translator.language) _this4.translator.changeLanguage(l);\n if (_this4.services.languageDetector) _this4.services.languageDetector.cacheUserLanguage(l);\n }\n\n _this4.loadResources(l, function (err) {\n done(err, l);\n });\n };\n\n if (!lng && this.services.languageDetector && !this.services.languageDetector.async) {\n setLng(this.services.languageDetector.detect());\n } else if (!lng && this.services.languageDetector && this.services.languageDetector.async) {\n this.services.languageDetector.detect(setLng);\n } else {\n setLng(lng);\n }\n\n return deferred;\n }\n }, {\n key: \"getFixedT\",\n value: function getFixedT(lng, ns, keyPrefix) {\n var _this5 = this;\n\n var fixedT = function fixedT(key, opts) {\n var options;\n\n if (_typeof(opts) !== 'object') {\n for (var _len3 = arguments.length, rest = new Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) {\n rest[_key3 - 2] = arguments[_key3];\n }\n\n options = _this5.options.overloadTranslationOptionHandler([key, opts].concat(rest));\n } else {\n options = _objectSpread$6({}, opts);\n }\n\n options.lng = options.lng || fixedT.lng;\n options.lngs = options.lngs || fixedT.lngs;\n options.ns = options.ns || fixedT.ns;\n options.keyPrefix = options.keyPrefix || keyPrefix || fixedT.keyPrefix;\n var keySeparator = _this5.options.keySeparator || '.';\n var resultKey = options.keyPrefix ? \"\".concat(options.keyPrefix).concat(keySeparator).concat(key) : key;\n return _this5.t(resultKey, options);\n };\n\n if (typeof lng === 'string') {\n fixedT.lng = lng;\n } else {\n fixedT.lngs = lng;\n }\n\n fixedT.ns = ns;\n fixedT.keyPrefix = keyPrefix;\n return fixedT;\n }\n }, {\n key: \"t\",\n value: function t() {\n var _this$translator;\n\n return this.translator && (_this$translator = this.translator).translate.apply(_this$translator, arguments);\n }\n }, {\n key: \"exists\",\n value: function exists() {\n var _this$translator2;\n\n return this.translator && (_this$translator2 = this.translator).exists.apply(_this$translator2, arguments);\n }\n }, {\n key: \"setDefaultNamespace\",\n value: function setDefaultNamespace(ns) {\n this.options.defaultNS = ns;\n }\n }, {\n key: \"hasLoadedNamespace\",\n value: function hasLoadedNamespace(ns) {\n var _this6 = this;\n\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n if (!this.isInitialized) {\n this.logger.warn('hasLoadedNamespace: i18next was not initialized', this.languages);\n return false;\n }\n\n if (!this.languages || !this.languages.length) {\n this.logger.warn('hasLoadedNamespace: i18n.languages were undefined or empty', this.languages);\n return false;\n }\n\n var lng = this.resolvedLanguage || this.languages[0];\n var fallbackLng = this.options ? this.options.fallbackLng : false;\n var lastLng = this.languages[this.languages.length - 1];\n if (lng.toLowerCase() === 'cimode') return true;\n\n var loadNotPending = function loadNotPending(l, n) {\n var loadState = _this6.services.backendConnector.state[\"\".concat(l, \"|\").concat(n)];\n\n return loadState === -1 || loadState === 2;\n };\n\n if (options.precheck) {\n var preResult = options.precheck(this, loadNotPending);\n if (preResult !== undefined) return preResult;\n }\n\n if (this.hasResourceBundle(lng, ns)) return true;\n if (!this.services.backendConnector.backend || this.options.resources && !this.options.partialBundledLanguages) return true;\n if (loadNotPending(lng, ns) && (!fallbackLng || loadNotPending(lastLng, ns))) return true;\n return false;\n }\n }, {\n key: \"loadNamespaces\",\n value: function loadNamespaces(ns, callback) {\n var _this7 = this;\n\n var deferred = defer();\n\n if (!this.options.ns) {\n callback && callback();\n return Promise.resolve();\n }\n\n if (typeof ns === 'string') ns = [ns];\n ns.forEach(function (n) {\n if (_this7.options.ns.indexOf(n) < 0) _this7.options.ns.push(n);\n });\n this.loadResources(function (err) {\n deferred.resolve();\n if (callback) callback(err);\n });\n return deferred;\n }\n }, {\n key: \"loadLanguages\",\n value: function loadLanguages(lngs, callback) {\n var deferred = defer();\n if (typeof lngs === 'string') lngs = [lngs];\n var preloaded = this.options.preload || [];\n var newLngs = lngs.filter(function (lng) {\n return preloaded.indexOf(lng) < 0;\n });\n\n if (!newLngs.length) {\n if (callback) callback();\n return Promise.resolve();\n }\n\n this.options.preload = preloaded.concat(newLngs);\n this.loadResources(function (err) {\n deferred.resolve();\n if (callback) callback(err);\n });\n return deferred;\n }\n }, {\n key: \"dir\",\n value: function dir(lng) {\n if (!lng) lng = this.resolvedLanguage || (this.languages && this.languages.length > 0 ? this.languages[0] : this.language);\n if (!lng) return 'rtl';\n var rtlLngs = ['ar', 'shu', 'sqr', 'ssh', 'xaa', 'yhd', 'yud', 'aao', 'abh', 'abv', 'acm', 'acq', 'acw', 'acx', 'acy', 'adf', 'ads', 'aeb', 'aec', 'afb', 'ajp', 'apc', 'apd', 'arb', 'arq', 'ars', 'ary', 'arz', 'auz', 'avl', 'ayh', 'ayl', 'ayn', 'ayp', 'bbz', 'pga', 'he', 'iw', 'ps', 'pbt', 'pbu', 'pst', 'prp', 'prd', 'ug', 'ur', 'ydd', 'yds', 'yih', 'ji', 'yi', 'hbo', 'men', 'xmn', 'fa', 'jpr', 'peo', 'pes', 'prs', 'dv', 'sam', 'ckb'];\n return rtlLngs.indexOf(this.services.languageUtils.getLanguagePartFromCode(lng)) > -1 || lng.toLowerCase().indexOf('-arab') > 1 ? 'rtl' : 'ltr';\n }\n }, {\n key: \"cloneInstance\",\n value: function cloneInstance() {\n var _this8 = this;\n\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : noop;\n\n var mergedOptions = _objectSpread$6(_objectSpread$6(_objectSpread$6({}, this.options), options), {\n isClone: true\n });\n\n var clone = new I18n(mergedOptions);\n var membersToCopy = ['store', 'services', 'language'];\n membersToCopy.forEach(function (m) {\n clone[m] = _this8[m];\n });\n clone.services = _objectSpread$6({}, this.services);\n clone.services.utils = {\n hasLoadedNamespace: clone.hasLoadedNamespace.bind(clone)\n };\n clone.translator = new Translator(clone.services, clone.options);\n clone.translator.on('*', function (event) {\n for (var _len4 = arguments.length, args = new Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) {\n args[_key4 - 1] = arguments[_key4];\n }\n\n clone.emit.apply(clone, [event].concat(args));\n });\n clone.init(mergedOptions, callback);\n clone.translator.options = clone.options;\n clone.translator.backendConnector.services.utils = {\n hasLoadedNamespace: clone.hasLoadedNamespace.bind(clone)\n };\n return clone;\n }\n }, {\n key: \"toJSON\",\n value: function toJSON() {\n return {\n options: this.options,\n store: this.store,\n language: this.language,\n languages: this.languages,\n resolvedLanguage: this.resolvedLanguage\n };\n }\n }]);\n\n return I18n;\n}(EventEmitter);\n\n_defineProperty(I18n, \"createInstance\", function () {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var callback = arguments.length > 1 ? arguments[1] : undefined;\n return new I18n(options, callback);\n});\n\nvar instance = I18n.createInstance();\ninstance.createInstance = I18n.createInstance;\n\nvar createInstance = instance.createInstance;\nvar init = instance.init;\nvar loadResources = instance.loadResources;\nvar reloadResources = instance.reloadResources;\nvar use = instance.use;\nvar changeLanguage = instance.changeLanguage;\nvar getFixedT = instance.getFixedT;\nvar t = instance.t;\nvar exists = instance.exists;\nvar setDefaultNamespace = instance.setDefaultNamespace;\nvar hasLoadedNamespace = instance.hasLoadedNamespace;\nvar loadNamespaces = instance.loadNamespaces;\nvar loadLanguages = instance.loadLanguages;\n\nexport default instance;\nexport { changeLanguage, createInstance, exists, getFixedT, hasLoadedNamespace, init, loadLanguages, loadNamespaces, loadResources, reloadResources, setDefaultNamespace, t, use };\n","import _classCallCheck from '@babel/runtime/helpers/esm/classCallCheck';\nimport _createClass from '@babel/runtime/helpers/esm/createClass';\n\nvar arr = [];\nvar each = arr.forEach;\nvar slice = arr.slice;\nfunction defaults(obj) {\n each.call(slice.call(arguments, 1), function (source) {\n if (source) {\n for (var prop in source) {\n if (obj[prop] === undefined) obj[prop] = source[prop];\n }\n }\n });\n return obj;\n}\n\n// eslint-disable-next-line no-control-regex\nvar fieldContentRegExp = /^[\\u0009\\u0020-\\u007e\\u0080-\\u00ff]+$/;\n\nvar serializeCookie = function serializeCookie(name, val, options) {\n var opt = options || {};\n opt.path = opt.path || '/';\n var value = encodeURIComponent(val);\n var str = name + '=' + value;\n\n if (opt.maxAge > 0) {\n var maxAge = opt.maxAge - 0;\n if (isNaN(maxAge)) throw new Error('maxAge should be a Number');\n str += '; Max-Age=' + Math.floor(maxAge);\n }\n\n if (opt.domain) {\n if (!fieldContentRegExp.test(opt.domain)) {\n throw new TypeError('option domain is invalid');\n }\n\n str += '; Domain=' + opt.domain;\n }\n\n if (opt.path) {\n if (!fieldContentRegExp.test(opt.path)) {\n throw new TypeError('option path is invalid');\n }\n\n str += '; Path=' + opt.path;\n }\n\n if (opt.expires) {\n if (typeof opt.expires.toUTCString !== 'function') {\n throw new TypeError('option expires is invalid');\n }\n\n str += '; Expires=' + opt.expires.toUTCString();\n }\n\n if (opt.httpOnly) str += '; HttpOnly';\n if (opt.secure) str += '; Secure';\n\n if (opt.sameSite) {\n var sameSite = typeof opt.sameSite === 'string' ? opt.sameSite.toLowerCase() : opt.sameSite;\n\n switch (sameSite) {\n case true:\n str += '; SameSite=Strict';\n break;\n\n case 'lax':\n str += '; SameSite=Lax';\n break;\n\n case 'strict':\n str += '; SameSite=Strict';\n break;\n\n case 'none':\n str += '; SameSite=None';\n break;\n\n default:\n throw new TypeError('option sameSite is invalid');\n }\n }\n\n return str;\n};\n\nvar cookie = {\n create: function create(name, value, minutes, domain) {\n var cookieOptions = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {\n path: '/',\n sameSite: 'strict'\n };\n\n if (minutes) {\n cookieOptions.expires = new Date();\n cookieOptions.expires.setTime(cookieOptions.expires.getTime() + minutes * 60 * 1000);\n }\n\n if (domain) cookieOptions.domain = domain;\n document.cookie = serializeCookie(name, encodeURIComponent(value), cookieOptions);\n },\n read: function read(name) {\n var nameEQ = name + '=';\n var ca = document.cookie.split(';');\n\n for (var i = 0; i < ca.length; i++) {\n var c = ca[i];\n\n while (c.charAt(0) === ' ') {\n c = c.substring(1, c.length);\n }\n\n if (c.indexOf(nameEQ) === 0) return c.substring(nameEQ.length, c.length);\n }\n\n return null;\n },\n remove: function remove(name) {\n this.create(name, '', -1);\n }\n};\nvar cookie$1 = {\n name: 'cookie',\n lookup: function lookup(options) {\n var found;\n\n if (options.lookupCookie && typeof document !== 'undefined') {\n var c = cookie.read(options.lookupCookie);\n if (c) found = c;\n }\n\n return found;\n },\n cacheUserLanguage: function cacheUserLanguage(lng, options) {\n if (options.lookupCookie && typeof document !== 'undefined') {\n cookie.create(options.lookupCookie, lng, options.cookieMinutes, options.cookieDomain, options.cookieOptions);\n }\n }\n};\n\nvar querystring = {\n name: 'querystring',\n lookup: function lookup(options) {\n var found;\n\n if (typeof window !== 'undefined') {\n var search = window.location.search;\n\n if (!window.location.search && window.location.hash && window.location.hash.indexOf('?') > -1) {\n search = window.location.hash.substring(window.location.hash.indexOf('?'));\n }\n\n var query = search.substring(1);\n var params = query.split('&');\n\n for (var i = 0; i < params.length; i++) {\n var pos = params[i].indexOf('=');\n\n if (pos > 0) {\n var key = params[i].substring(0, pos);\n\n if (key === options.lookupQuerystring) {\n found = params[i].substring(pos + 1);\n }\n }\n }\n }\n\n return found;\n }\n};\n\nvar hasLocalStorageSupport = null;\n\nvar localStorageAvailable = function localStorageAvailable() {\n if (hasLocalStorageSupport !== null) return hasLocalStorageSupport;\n\n try {\n hasLocalStorageSupport = window !== 'undefined' && window.localStorage !== null;\n var testKey = 'i18next.translate.boo';\n window.localStorage.setItem(testKey, 'foo');\n window.localStorage.removeItem(testKey);\n } catch (e) {\n hasLocalStorageSupport = false;\n }\n\n return hasLocalStorageSupport;\n};\n\nvar localStorage = {\n name: 'localStorage',\n lookup: function lookup(options) {\n var found;\n\n if (options.lookupLocalStorage && localStorageAvailable()) {\n var lng = window.localStorage.getItem(options.lookupLocalStorage);\n if (lng) found = lng;\n }\n\n return found;\n },\n cacheUserLanguage: function cacheUserLanguage(lng, options) {\n if (options.lookupLocalStorage && localStorageAvailable()) {\n window.localStorage.setItem(options.lookupLocalStorage, lng);\n }\n }\n};\n\nvar hasSessionStorageSupport = null;\n\nvar sessionStorageAvailable = function sessionStorageAvailable() {\n if (hasSessionStorageSupport !== null) return hasSessionStorageSupport;\n\n try {\n hasSessionStorageSupport = window !== 'undefined' && window.sessionStorage !== null;\n var testKey = 'i18next.translate.boo';\n window.sessionStorage.setItem(testKey, 'foo');\n window.sessionStorage.removeItem(testKey);\n } catch (e) {\n hasSessionStorageSupport = false;\n }\n\n return hasSessionStorageSupport;\n};\n\nvar sessionStorage = {\n name: 'sessionStorage',\n lookup: function lookup(options) {\n var found;\n\n if (options.lookupSessionStorage && sessionStorageAvailable()) {\n var lng = window.sessionStorage.getItem(options.lookupSessionStorage);\n if (lng) found = lng;\n }\n\n return found;\n },\n cacheUserLanguage: function cacheUserLanguage(lng, options) {\n if (options.lookupSessionStorage && sessionStorageAvailable()) {\n window.sessionStorage.setItem(options.lookupSessionStorage, lng);\n }\n }\n};\n\nvar navigator$1 = {\n name: 'navigator',\n lookup: function lookup(options) {\n var found = [];\n\n if (typeof navigator !== 'undefined') {\n if (navigator.languages) {\n // chrome only; not an array, so can't use .push.apply instead of iterating\n for (var i = 0; i < navigator.languages.length; i++) {\n found.push(navigator.languages[i]);\n }\n }\n\n if (navigator.userLanguage) {\n found.push(navigator.userLanguage);\n }\n\n if (navigator.language) {\n found.push(navigator.language);\n }\n }\n\n return found.length > 0 ? found : undefined;\n }\n};\n\nvar htmlTag = {\n name: 'htmlTag',\n lookup: function lookup(options) {\n var found;\n var htmlTag = options.htmlTag || (typeof document !== 'undefined' ? document.documentElement : null);\n\n if (htmlTag && typeof htmlTag.getAttribute === 'function') {\n found = htmlTag.getAttribute('lang');\n }\n\n return found;\n }\n};\n\nvar path = {\n name: 'path',\n lookup: function lookup(options) {\n var found;\n\n if (typeof window !== 'undefined') {\n var language = window.location.pathname.match(/\\/([a-zA-Z-]*)/g);\n\n if (language instanceof Array) {\n if (typeof options.lookupFromPathIndex === 'number') {\n if (typeof language[options.lookupFromPathIndex] !== 'string') {\n return undefined;\n }\n\n found = language[options.lookupFromPathIndex].replace('/', '');\n } else {\n found = language[0].replace('/', '');\n }\n }\n }\n\n return found;\n }\n};\n\nvar subdomain = {\n name: 'subdomain',\n lookup: function lookup(options) {\n var found;\n\n if (typeof window !== 'undefined') {\n var language = window.location.href.match(/(?:http[s]*\\:\\/\\/)*(.*?)\\.(?=[^\\/]*\\..{2,5})/gi);\n\n if (language instanceof Array) {\n if (typeof options.lookupFromSubdomainIndex === 'number') {\n found = language[options.lookupFromSubdomainIndex].replace('http://', '').replace('https://', '').replace('.', '');\n } else {\n found = language[0].replace('http://', '').replace('https://', '').replace('.', '');\n }\n }\n }\n\n return found;\n }\n};\n\nfunction getDefaults() {\n return {\n order: ['querystring', 'cookie', 'localStorage', 'sessionStorage', 'navigator', 'htmlTag'],\n lookupQuerystring: 'lng',\n lookupCookie: 'i18next',\n lookupLocalStorage: 'i18nextLng',\n lookupSessionStorage: 'i18nextLng',\n // cache user language\n caches: ['localStorage'],\n excludeCacheFor: ['cimode'] //cookieMinutes: 10,\n //cookieDomain: 'myDomain'\n\n };\n}\n\nvar Browser = /*#__PURE__*/function () {\n function Browser(services) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n _classCallCheck(this, Browser);\n\n this.type = 'languageDetector';\n this.detectors = {};\n this.init(services, options);\n }\n\n _createClass(Browser, [{\n key: \"init\",\n value: function init(services) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var i18nOptions = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n this.services = services;\n this.options = defaults(options, this.options || {}, getDefaults()); // backwards compatibility\n\n if (this.options.lookupFromUrlIndex) this.options.lookupFromPathIndex = this.options.lookupFromUrlIndex;\n this.i18nOptions = i18nOptions;\n this.addDetector(cookie$1);\n this.addDetector(querystring);\n this.addDetector(localStorage);\n this.addDetector(sessionStorage);\n this.addDetector(navigator$1);\n this.addDetector(htmlTag);\n this.addDetector(path);\n this.addDetector(subdomain);\n }\n }, {\n key: \"addDetector\",\n value: function addDetector(detector) {\n this.detectors[detector.name] = detector;\n }\n }, {\n key: \"detect\",\n value: function detect(detectionOrder) {\n var _this = this;\n\n if (!detectionOrder) detectionOrder = this.options.order;\n var detected = [];\n detectionOrder.forEach(function (detectorName) {\n if (_this.detectors[detectorName]) {\n var lookup = _this.detectors[detectorName].lookup(_this.options);\n\n if (lookup && typeof lookup === 'string') lookup = [lookup];\n if (lookup) detected = detected.concat(lookup);\n }\n });\n if (this.services.languageUtils.getBestMatchFromCodes) return detected; // new i18next v19.5.0\n\n return detected.length > 0 ? detected[0] : null; // a little backward compatibility\n }\n }, {\n key: \"cacheUserLanguage\",\n value: function cacheUserLanguage(lng, caches) {\n var _this2 = this;\n\n if (!caches) caches = this.options.caches;\n if (!caches) return;\n if (this.options.excludeCacheFor && this.options.excludeCacheFor.indexOf(lng) > -1) return;\n caches.forEach(function (cacheName) {\n if (_this2.detectors[cacheName]) _this2.detectors[cacheName].cacheUserLanguage(lng, _this2.options);\n });\n }\n }]);\n\n return Browser;\n}();\n\nBrowser.type = 'languageDetector';\n\nexport { Browser as default };\n","import i18n from 'i18next'\nimport LanguageDetector from 'i18next-browser-languagedetector'\nimport { initReactI18next } from 'react-i18next'\nimport enLocale from './locale/en.json'\nimport itLocale from './locale/it.json'\n\nconst customLangDetector = {\n name: 'dw-lang-detector',\n lookup() {\n const lang = 'en'\n return lang\n },\n}\nconst lngDetector = new LanguageDetector()\nlngDetector.addDetector(customLangDetector)\n\n\nconst languages = {\n en: {\n translation: enLocale,\n },\n it: {\n translation: itLocale,\n },\n}\n\nexport default i18n\n .use(lngDetector)\n .use(initReactI18next)\n .init({\n resources: languages,\n fallbackLng: 'en',\n debug: true,\n keySeparator: '.',\n interpolation: {\n escapeValue: false,\n format: function (value, format) {\n if (format === 'highlight')\n return `<span class='highlighted'>${value}</span>`\n return value\n },\n },\n })\n","import React from 'react'\nimport ReactDOM from 'react-dom'\nimport App from './App'\nimport './i18n'\n\nReactDOM.render(\n <React.StrictMode>\n <App />\n </React.StrictMode>,\n document.getElementById('root')\n)\n\n"],"names":["LeftArrow","size","theme","useContext","ThemeContext","width","height","viewBox","fill","colors","icons","xmlns","fillRule","clipRule","d","Eye","stroke","strokeWidth","strokeLinecap","strokeLinejoin","Github","transform","opacity","Linkedin","Logo","id","clipPathUnits","strokeMiterlimit","Message","RightArrow","clipPath","BaseContainerStyled","styled","pxToRem","pageBorder","clampValues","parseInt","PAGE_PADDING_REM","BaseContainer","children","FlexContainerStyled","props","align","phone","FlexContainer","StyledButton","primary","buttonText","CustomButton","StyledLink","Link","CustomLink","useClickOutside","ref","cb","addListener","useEffect","handleAwayClick","event","current","contains","target","document","addEventListener","removeEventListener","LanguageSelectorDropdown","projectCardBackground","LanguageSelector","isVisible","setLanguageDropdownState","innerRef","useRef","Burger","color","direction","distance","duration","easing","hideOutline","label","lines","onToggle","render","rounded","toggle","toggled","toggledInternal","toggleInternal","useState","Math","max","min","room","round","barHeightRaw","barHeight","marginRaw","margin","topOffset","move","parseFloat","toFixed","time","burgerStyles","cursor","position","transition","userSelect","barStyles","background","left","toggleFunction","isToggled","undefined","handler","isLeft","_extends","Object","assign","i","arguments","length","source","key","prototype","hasOwnProperty","call","apply","this","Turn","React","o","className","onClick","onKeyUp","e","role","style","tabIndex","top","ThemeSwtich","ThemeSwitchLabel","ThemeSwitchHandle","Crater","StarCloud","ThemeSwitchInput","ThemeToggle","onChange","useDarkMode","darkMode","setDarkMode","type","checked","name","evt","handleChange","htmlFor","Array","from","_","index","HeaderContainer","Navigation","tablet","MenuContainer","SocialContainer","SocialContainerMobile","UtilsContainer","HamburgerWrapper","StyledNavLink","NavLink","text","MobileNavigation","MobileMenuDropdown","ThemeToggleWrapper","LogoLink","Header","toggleTheme","t","useTranslation","open","useGlobalModal","mobileMenuref","mobileMenu","setMobileMenu","showLanguageList","setShowLanguageList","to","href","rel","isDark","currentTarget","Animation","keyframes","LoaderContainer","body","LoaderSpinner","First","Second","Loading","setTheme","userTheme","window","matchMedia","matches","localTheme","localStorage","getItem","setMode","mode","setItem","element","value","Date","isObjectType","isNullOrUndefined","isArray","isDateObject","isObject","isCheckBoxInput","names","has","substring","search","getNodeParentName","filter","Boolean","val","obj","path","defaultValue","result","compact","split","reduce","isUndefined","EVENTS","VALIDATION_MODE","INPUT_VALIDATION_RULES","formState","control","localProxyFormState","isRoot","defaultValues","_defaultValues","defineProperty","get","_key","_proxyFormState","keys","formStateData","isEmptyObject","find","useSubscribe","_props","subscription","disabled","subject","subscribe","next","unsubscribe","_names","formValues","isGlobal","isString","watch","add","map","fieldName","watchAll","HTMLElement","cloneObject","data","copy","Set","isWeb","Blob","FileList","tempObject","prototypeCopy","constructor","isPlainObject","validateAllFieldCriteria","errors","message","types","test","input","replace","set","object","tempPath","isKey","stringToPath","lastIndex","newValue","objValue","isNaN","focusFieldBy","fields","callback","fieldsNames","field","_f","currentField","focus","refs","isOnSubmit","isOnBlur","isOnChange","isOnAll","isOnTouch","isBlurEvent","some","watchName","startsWith","slice","error","fieldArrayErrors","owner","ownerDocument","defaultView","RegExp","defaultResult","isValid","validResult","options","values","option","attributes","defaultReturn","previous","getValidateError","isMessage","every","isBoolean","validationData","isRegex","async","inputValue","shouldUseNativeValidation","isFieldArray","required","maxLength","minLength","pattern","validate","valueAsNumber","mount","inputRef","setCustomValidity","reportValidity","isRadio","isRadioInput","isCheckBox","isRadioOrCheckbox","isEmpty","isFileInput","isHTMLElement","appendErrorsCurry","appendErrors","bind","getMinMaxMessage","exceedMax","maxLengthMessage","minLengthMessage","maxType","minType","getCheckboxValue","getRadioValue","getValueAndMessage","exceedMin","maxOutput","minOutput","valueDate","valueAsDate","convertTimeToDate","toDateString","isTime","isWeek","valueNumber","maxLengthOutput","minLengthOutput","patternValue","match","isFunction","validateError","validationResult","isEmptyArray","unset","updatePath","childObject","baseGet","previousObjRef","k","objectRef","currentPaths","currentPathsLength","item","createSubject","_observers","observers","observer","push","deepEqual","object1","object2","isPrimitive","getTime","keys1","keys2","val1","includes","val2","isConnected","markFieldsDirty","isParentNodeArray","objectHasFunction","getDirtyFieldsFromDefaultValues","dirtyFieldsFromValues","setValueAs","NaN","getFieldValue","files","isMultipleSelect","selectedOptions","getFieldValueAs","_fields","criteriaMode","rule","schemaErrorLookup","join","foundError","pop","isTouched","isSubmitted","reValidateMode","defaultOptions","shouldFocusError","createFormControl","flushRootRender","_options","shouldCaptureDirtyFields","resetOptions","keepDirtyValues","delayErrorCallback","_formState","submitCount","isDirty","isLoading","isValidating","isSubmitting","isSubmitSuccessful","touchedFields","dirtyFields","_formValues","shouldUnregister","_stateFlags","action","unMount","array","timer","_subjects","state","validationModeBeforeSubmit","getValidationModes","validationModeAfterSubmit","shouldDisplayAllAssociatedErrors","debounce","wait","clearTimeout","setTimeout","_updateValid","resolver","_executeSchema","executeBuiltInValidation","_updateIsValidating","_updateFieldArray","method","args","shouldSetValues","shouldUpdateFieldsAndState","fieldValues","argA","argB","unsetEmptyArray","getDirtyFields","_getDirty","updateErrors","updateValidAndValue","shouldSkipSetValueAs","defaultChecked","setFieldValue","updateTouchAndDirty","fieldValue","shouldDirty","shouldRender","shouldUpdateField","isPreviousDirty","output","isCurrentFieldPristine","isPreviousFieldTouched","shouldRenderByError","fieldState","previousFieldError","shouldUpdateValid","delayError","updatedFormState","context","getResolverOptions","executeSchemaAndUpdateState","shouldOnlyCheckValid","valid","isFieldArrayRoot","fieldError","validateField","updateFieldArrayRootError","_removeUnmounted","live","unregister","getValues","_getWatch","generateWatchOutput","_getFieldArray","fieldReference","forEach","optionRef","selected","checkboxRef","radioRef","shouldTouch","shouldValidate","trigger","setValues","fieldKey","setValue","cloneValue","isWatched","getEventValue","shouldSkipValidation","hasValidation","deps","skipValidation","watched","onBlur","previousErrorLookupResult","errorLookupResult","fieldNames","convertToArrayPayload","Promise","all","shouldFocus","getFieldState","invalid","clearErrors","inputName","setError","payload","delete","keepValue","keepError","keepDirty","keepTouched","keepDefaultValue","keepIsValid","register","disabledIsDefined","getRuleValue","fieldRef","querySelectorAll","radioOrCheckbox","isNameInFieldArray","_focusError","handleSubmit","onValid","onInvalid","preventDefault","persist","hasNoPromiseError","err","resetField","_reset","keepStateOptions","updatedValues","cloneUpdatedValues","keepDefaultValues","keepValues","form","closest","reset","keepSubmitCount","keepIsSubmitted","keepErrors","setFocus","shouldSelect","select","then","ContactModal","commonInputStyles","css","badgeBackground","CustomInput","CustomTextArea","CustomCheckbox","CustomBlock","shouldSpan","CustomLabel","FormFooter","ErrorLabel","ContactForm","PrivacyPolicyBlock","FormFeedback","status","Modal","fetch","headers","setFormState","close","_formControl","updateFormState","shouldRenderFormState","getProxyFormState","useForm","handleValidationErrors","onSubmit","JSON","stringify","catch","GlobalModal","component","modalSize","hideHeader","hideCloseIcon","FONT_SIZE","PAGE_PADDING","AVAILABLE_FOR_HIRE","pxValue","ratio","config","useMediaQuery","query","queryMatch","setQueryMatch","handleQueryListener","updatedMatches","uniqueArray","a","useWindowResizeListener","windowDimensions","setWindowDimensions","handleWindowResize","innerWidth","innerHeight","clampBuilder","minWidthPx","maxWidthPx","minPxSize","maxPxSize","minWidth","minRemWidth","maxRemWidth","slope","calculatedPreferredValue","Device","DeviceMap","fullhd","tabletMini","cssOrDevice","mediaQuery","cssProperties","scrollbar","Title","SecondaryTitle","modalStyle","commonTheme","fontSize","secondary","lightMode","GlobalStyles","createGlobalStyle","toString","fnToStr","Function","previousComparisons","Map","equal","b","check","clear","aTag","previouslyCompared","aKeys","definedKeys","bKeys","keyCount","aIterator","entries","isMap","info","done","aKey","aValue","Uint8Array","len","byteLength","aCode","full","suffix","fromIndex","indexOf","endsWith","nativeCodeSuffix","isDefinedKey","bSet","isAbsolute","pathname","charAt","spliceOne","list","n","hasTrailingSlash","toParts","fromParts","isToAbs","isFromAbs","mustEndAbs","concat","last","up","part","unshift","substr","valueOf","valueEqual","bValue","addLeadingSlash","stripLeadingSlash","stripBasename","prefix","toLowerCase","hasBasename","stripTrailingSlash","createPath","location","hash","createLocation","currentLocation","hashIndex","searchIndex","parsePath","decodeURI","URIError","resolvePathname","locationsAreEqual","createTransitionManager","prompt","listeners","setPrompt","nextPrompt","confirmTransitionTo","getUserConfirmation","appendListener","fn","isActive","listener","notifyListeners","_len","canUseDOM","createElement","getConfirmation","confirm","PopStateEvent","HashChangeEvent","getHistoryState","history","createBrowserHistory","invariant","globalHistory","canUseHistory","ua","navigator","userAgent","supportsHistory","needsHashChangeListener","_props$forceRefresh","forceRefresh","_props$getUserConfirm","_props$keyLength","keyLength","basename","getDOMLocation","historyState","_ref","_window$location","createKey","random","transitionManager","setState","nextState","handlePopState","isExtraneousPopstateEvent","handlePop","handleHashChange","forceNextPop","ok","fromLocation","toLocation","toIndex","allKeys","delta","go","revertPop","initialLocation","createHref","listenerCount","checkDOMListeners","isBlocked","pushState","prevIndex","nextKeys","replaceState","goBack","goForward","block","unblock","listen","unlisten","HashChangeEvent$1","HashPathCoders","hashbang","encodePath","decodePath","noslash","slash","stripHash","url","getHashPath","replaceHashPath","createHashHistory","_props$hashType","hashType","_HashPathCoders$hashT","ignorePath","encodedPath","prevLocation","allPaths","lastIndexOf","baseTag","querySelector","getAttribute","pushHashPath","nextPaths","clamp","lowerBound","upperBound","createMemoryHistory","_props$initialEntries","initialEntries","_props$initialIndex","initialIndex","entry","nextIndex","nextEntries","splice","canGo","reactIs","require","REACT_STATICS","childContextTypes","contextType","contextTypes","defaultProps","displayName","getDefaultProps","getDerivedStateFromError","getDerivedStateFromProps","mixins","propTypes","KNOWN_STATICS","caller","callee","arity","MEMO_STATICS","compare","TYPE_STATICS","getStatics","isMemo","ForwardRef","Memo","getOwnPropertyNames","getOwnPropertySymbols","getOwnPropertyDescriptor","getPrototypeOf","objectPrototype","module","exports","hoistNonReactStatics","targetComponent","sourceComponent","blacklist","inheritedComponent","targetStatics","sourceStatics","descriptor","arr","FUNC_ERROR_TEXT","HASH_UNDEFINED","PLACEHOLDER","WRAP_CURRY_RIGHT_FLAG","WRAP_PARTIAL_FLAG","WRAP_PARTIAL_RIGHT_FLAG","WRAP_ARY_FLAG","WRAP_REARG_FLAG","INFINITY","MAX_SAFE_INTEGER","NAN","MAX_ARRAY_LENGTH","wrapFlags","argsTag","arrayTag","boolTag","dateTag","errorTag","funcTag","genTag","mapTag","numberTag","objectTag","promiseTag","regexpTag","setTag","stringTag","symbolTag","weakMapTag","arrayBufferTag","dataViewTag","float32Tag","float64Tag","int8Tag","int16Tag","int32Tag","uint8Tag","uint8ClampedTag","uint16Tag","uint32Tag","reEmptyStringLeading","reEmptyStringMiddle","reEmptyStringTrailing","reEscapedHtml","reUnescapedHtml","reHasEscapedHtml","reHasUnescapedHtml","reEscape","reEvaluate","reInterpolate","reIsDeepProp","reIsPlainProp","rePropName","reRegExpChar","reHasRegExpChar","reTrimStart","reWhitespace","reWrapComment","reWrapDetails","reSplitDetails","reAsciiWord","reForbiddenIdentifierChars","reEscapeChar","reEsTemplate","reFlags","reIsBadHex","reIsBinary","reIsHostCtor","reIsOctal","reIsUint","reLatin","reNoMatch","reUnescapedString","rsComboRange","rsComboMarksRange","rsDingbatRange","rsLowerRange","rsUpperRange","rsVarRange","rsBreakRange","rsMathOpRange","rsApos","rsAstral","rsBreak","rsCombo","rsDigits","rsDingbat","rsLower","rsMisc","rsFitz","rsNonAstral","rsRegional","rsSurrPair","rsUpper","rsMiscLower","rsMiscUpper","rsOptContrLower","rsOptContrUpper","reOptMod","rsOptVar","rsSeq","rsEmoji","rsSymbol","reApos","reComboMark","reUnicode","reUnicodeWord","reHasUnicode","reHasUnicodeWord","contextProps","templateCounter","typedArrayTags","cloneableTags","stringEscapes","freeParseFloat","freeParseInt","freeGlobal","global","freeSelf","self","root","freeExports","nodeType","freeModule","moduleExports","freeProcess","process","nodeUtil","binding","nodeIsArrayBuffer","isArrayBuffer","nodeIsDate","isDate","nodeIsMap","nodeIsRegExp","isRegExp","nodeIsSet","isSet","nodeIsTypedArray","isTypedArray","func","thisArg","arrayAggregator","setter","iteratee","accumulator","arrayEach","arrayEachRight","arrayEvery","predicate","arrayFilter","resIndex","arrayIncludes","baseIndexOf","arrayIncludesWith","comparator","arrayMap","arrayPush","offset","arrayReduce","initAccum","arrayReduceRight","arraySome","asciiSize","baseProperty","baseFindKey","collection","eachFunc","baseFindIndex","fromRight","strictIndexOf","baseIsNaN","baseIndexOfWith","baseMean","baseSum","basePropertyOf","baseReduce","baseTimes","baseTrim","string","trimmedEndIndex","baseUnary","baseValues","cacheHas","cache","charsStartIndex","strSymbols","chrSymbols","charsEndIndex","countHolders","placeholder","deburrLetter","escapeHtmlChar","escapeStringChar","chr","hasUnicode","mapToArray","overArg","arg","replaceHolders","setToArray","setToPairs","stringSize","unicodeSize","stringToArray","unicodeToArray","asciiToArray","unescapeHtmlChar","runInContext","defaults","pick","Error","String","TypeError","arrayProto","funcProto","objectProto","coreJsData","funcToString","idCounter","maskSrcKey","uid","exec","IE_PROTO","nativeObjectToString","objectCtorString","oldDash","reIsNative","Buffer","Symbol","allocUnsafe","getPrototype","objectCreate","create","propertyIsEnumerable","spreadableSymbol","isConcatSpreadable","symIterator","iterator","symToStringTag","toStringTag","getNative","ctxClearTimeout","ctxNow","now","ctxSetTimeout","nativeCeil","ceil","nativeFloor","floor","nativeGetSymbols","nativeIsBuffer","isBuffer","nativeIsFinite","isFinite","nativeJoin","nativeKeys","nativeMax","nativeMin","nativeNow","nativeParseInt","nativeRandom","nativeReverse","reverse","DataView","WeakMap","nativeCreate","metaMap","realNames","dataViewCtorString","toSource","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","symbolProto","symbolValueOf","symbolToString","lodash","isObjectLike","LazyWrapper","LodashWrapper","wrapperClone","baseCreate","proto","baseLodash","chainAll","__wrapped__","__actions__","__chain__","__index__","__values__","__dir__","__filtered__","__iteratees__","__takeCount__","__views__","Hash","ListCache","MapCache","SetCache","__data__","Stack","arrayLikeKeys","inherited","isArr","isArg","isArguments","isBuff","isType","skipIndexes","isIndex","arraySample","baseRandom","arraySampleSize","shuffleSelf","copyArray","baseClamp","arrayShuffle","assignMergeValue","eq","baseAssignValue","assignValue","assocIndexOf","baseAggregator","baseEach","baseAssign","copyObject","baseAt","paths","skip","number","lower","upper","baseClone","bitmask","customizer","stack","isDeep","isFlat","isFull","initCloneArray","tag","getTag","isFunc","cloneBuffer","initCloneObject","getSymbolsIn","copySymbolsIn","keysIn","baseAssignIn","getSymbols","copySymbols","Ctor","cloneArrayBuffer","dataView","buffer","byteOffset","cloneDataView","cloneTypedArray","regexp","cloneRegExp","symbol","initCloneByTag","stacked","subValue","getAllKeysIn","getAllKeys","baseConformsTo","baseDelay","baseDifference","isCommon","valuesLength","outer","computed","valuesIndex","templateSettings","getMapData","pairs","LARGE_ARRAY_SIZE","createBaseEach","baseForOwn","baseEachRight","baseForOwnRight","baseEvery","baseExtremum","isSymbol","baseFilter","baseFlatten","depth","isStrict","isFlattenable","baseFor","createBaseFor","baseForRight","baseFunctions","castPath","toKey","baseGetAllKeys","keysFunc","symbolsFunc","baseGetTag","isOwn","unmasked","getRawTag","objectToString","baseGt","other","baseHas","baseHasIn","baseIntersection","arrays","othLength","othIndex","caches","Infinity","seen","baseInvoke","parent","baseIsArguments","baseIsEqual","equalFunc","objIsArr","othIsArr","objTag","othTag","objIsObj","othIsObj","isSameTag","equalArrays","convert","isPartial","equalByTag","objIsWrapped","othIsWrapped","objUnwrapped","othUnwrapped","objProps","objLength","objStacked","othStacked","skipCtor","othValue","compared","objCtor","othCtor","equalObjects","baseIsEqualDeep","baseIsMatch","matchData","noCustomizer","srcValue","COMPARE_PARTIAL_FLAG","baseIsNative","baseIteratee","identity","baseMatchesProperty","baseMatches","property","baseKeys","isPrototype","baseKeysIn","nativeKeysIn","isProto","baseLt","baseMap","isArrayLike","getMatchData","matchesStrictComparable","isStrictComparable","hasIn","baseMerge","srcIndex","mergeFunc","safeGet","isTyped","isArrayLikeObject","toPlainObject","baseMergeDeep","baseNth","baseOrderBy","iteratees","orders","getIteratee","criteria","comparer","sort","baseSortBy","objCriteria","othCriteria","ordersLength","compareAscending","compareMultiple","basePickBy","baseSet","basePullAll","basePullAt","indexes","baseUnset","baseRepeat","baseRest","start","setToString","overRest","baseSample","baseSampleSize","nested","baseSetData","baseSetToString","constant","baseShuffle","baseSlice","end","baseSome","baseSortedIndex","retHighest","low","high","mid","baseSortedIndexBy","valIsNaN","valIsNull","valIsSymbol","valIsUndefined","othIsDefined","othIsNull","othIsReflexive","othIsSymbol","setLow","baseSortedUniq","baseToNumber","baseToString","baseUniq","createSet","seenIndex","baseUpdate","updater","baseWhile","isDrop","baseWrapperValue","actions","baseXor","baseZipObject","assignFunc","valsLength","castArrayLikeObject","castFunction","castRest","castSlice","arrayBuffer","typedArray","valIsDefined","valIsReflexive","composeArgs","partials","holders","isCurried","argsIndex","argsLength","holdersLength","leftIndex","leftLength","rangeLength","isUncurried","composeArgsRight","holdersIndex","rightIndex","rightLength","isNew","createAggregator","initializer","createAssigner","assigner","sources","guard","isIterateeCall","iterable","createCaseFirst","methodName","trailing","createCompounder","words","deburr","createCtor","thisBinding","createFind","findIndexFunc","createFlow","flatRest","funcs","prereq","thru","wrapper","getFuncName","funcName","getData","isLaziable","plant","createHybrid","partialsRight","holdersRight","argPos","ary","isAry","isBind","isBindKey","isFlip","getHolder","holdersCount","newHolders","createRecurry","reorder","createInverter","toIteratee","baseInverter","createMathOperation","operator","createOver","arrayFunc","createPadding","chars","charsLength","createRange","step","toFinite","baseRange","createRelationalOperation","toNumber","wrapFunc","isCurry","newData","setData","setWrapToString","createRound","precision","toInteger","pair","noop","createToPairs","baseToPairs","createWrap","srcBitmask","newBitmask","isCombo","mergeData","createCurry","createPartial","createBind","customDefaultsAssignIn","customDefaultsMerge","customOmitClone","arrLength","arrStacked","arrValue","flatten","otherFunc","isKeyable","getValue","stubArray","hasPath","hasFunc","isLength","ArrayBuffer","resolve","ctorString","isMaskable","stubFalse","otherArgs","oldArray","shortOut","reference","details","insertWrapDetails","updateWrapDetails","getWrapDetails","count","lastCalled","stamp","remaining","rand","memoize","memoizeCapped","charCodeAt","quote","subString","clone","difference","differenceBy","differenceWith","findIndex","findLastIndex","head","intersection","mapped","intersectionBy","intersectionWith","pull","pullAll","pullAt","union","unionBy","unionWith","unzip","group","unzipWith","without","xor","xorBy","xorWith","zip","zipWith","chain","interceptor","wrapperAt","countBy","findLast","forEachRight","groupBy","invokeMap","keyBy","partition","sortBy","before","bindKey","WRAP_BIND_FLAG","lastArgs","lastThis","maxWait","timerId","lastCallTime","lastInvokeTime","leading","maxing","invokeFunc","leadingEdge","timerExpired","shouldInvoke","timeSinceLastCall","trailingEdge","timeWaiting","remainingWait","debounced","isInvoking","cancel","flush","defer","delay","memoized","Cache","negate","overArgs","transforms","funcsLength","partial","partialRight","rearg","gt","gte","isError","isInteger","isNumber","lt","lte","toArray","iteratorToArray","remainder","toLength","isBinary","assignIn","assignInWith","assignWith","at","propsIndex","propsLength","defaultsDeep","mergeWith","invert","invertBy","invoke","merge","omit","CLONE_DEEP_FLAG","basePick","pickBy","prop","toPairs","toPairsIn","camelCase","word","capitalize","upperFirst","kebabCase","lowerCase","lowerFirst","snakeCase","startCase","upperCase","toUpperCase","hasUnicodeWord","unicodeWords","asciiWords","attempt","bindAll","methodNames","flow","flowRight","methodOf","mixin","over","overEvery","overSome","basePropertyDeep","range","rangeRight","augend","addend","divide","dividend","divisor","multiply","multiplier","multiplicand","subtract","minuend","subtrahend","after","castArray","chunk","cond","conforms","baseConforms","properties","curry","curryRight","drop","dropRight","dropRightWhile","dropWhile","baseFill","flatMap","flatMapDeep","flatMapDepth","flattenDeep","flattenDepth","flip","fromPairs","functions","functionsIn","initial","mapKeys","mapValues","matchesProperty","nthArg","omitBy","once","orderBy","propertyOf","pullAllBy","pullAllWith","reject","remove","rest","sampleSize","setWith","shuffle","sortedUniq","sortedUniqBy","separator","limit","spread","tail","take","takeRight","takeRightWhile","takeWhile","tap","throttle","toPath","isArrLike","unary","uniq","uniqBy","uniqWith","update","updateWith","valuesIn","wrap","zipObject","zipObjectDeep","entriesIn","extend","extendWith","cloneDeep","cloneDeepWith","cloneWith","conformsTo","defaultTo","escape","escapeRegExp","findKey","findLastKey","forIn","forInRight","forOwn","forOwnRight","inRange","baseInRange","isElement","isEqual","isEqualWith","isMatch","isMatchWith","isNative","isNil","isNull","isSafeInteger","isWeakMap","isWeakSet","strictLastIndexOf","maxBy","mean","meanBy","minBy","stubObject","stubString","stubTrue","nth","noConflict","pad","strLength","padEnd","padStart","radix","floating","temp","reduceRight","repeat","sample","sortedIndex","sortedIndexBy","sortedIndexOf","sortedLastIndex","sortedLastIndexBy","sortedLastIndexOf","sum","sumBy","template","settings","isEscaping","isEvaluating","imports","importsKeys","importsValues","interpolate","reDelimiters","evaluate","sourceURL","escapeValue","interpolateValue","esTemplateValue","evaluateValue","variable","times","toLower","toSafeInteger","toUpper","trim","trimEnd","trimStart","truncate","omission","newEnd","unescape","uniqueId","each","eachRight","first","VERSION","isFilter","takeName","dropName","checkIteratee","isTaker","lodashFunc","retUnwrapped","isLazy","useLazy","isHybrid","isUnwrapped","onlyLazy","chainName","dir","isRight","view","getView","iterLength","takeCount","iterIndex","commit","wrapped","toJSON","define","propIsEnumerable","toObject","test1","test2","fromCharCode","test3","letter","shouldUseNative","symbols","s","isarray","pathToRegexp","parse","compile","str","tokensToFunction","tokensToRegExp","PATH_REGEXP","res","tokens","defaultDelimiter","delimiter","m","escaped","capture","modifier","asterisk","optional","escapeGroup","escapeString","encodeURIComponentPretty","encodeURI","c","flags","opts","encode","pretty","encodeURIComponent","token","segment","j","attachKeys","re","sensitive","strict","route","endsWithDelimiter","groups","regexpToRegexp","parts","arrayToRegexp","stringToRegexp","ReactPropTypesSecret","emptyFunction","emptyFunctionWithReset","resetWarningCache","shim","propName","componentName","propFullName","secret","getShim","isRequired","ReactPropTypes","bigint","bool","any","arrayOf","elementType","instanceOf","node","objectOf","oneOf","oneOfType","shape","exact","checkPropTypes","PropTypes","aa","r","y","ba","ca","da","ea","fa","ha","ia","ja","ka","B","f","g","acceptsBooleans","attributeName","attributeNamespace","mustUseProperty","propertyName","sanitizeURL","removeEmptyString","D","oa","pa","qa","ma","na","la","removeAttribute","setAttribute","setAttributeNS","xlinkHref","ra","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","sa","ta","wa","xa","ya","za","Aa","Ba","Ca","Da","Ea","Fa","Ga","Ha","Ia","Ja","for","E","Ma","Ka","La","Na","Oa","Pa","prepareStackTrace","Reflect","construct","h","Qa","_render","Ra","$$typeof","_context","_payload","_init","Sa","Ta","nodeName","Va","_valueTracker","configurable","enumerable","stopTracking","Ua","Wa","Xa","activeElement","Ya","_wrapperState","initialChecked","Za","initialValue","controlled","$a","ab","bb","eb","Children","db","fb","defaultSelected","gb","dangerouslySetInnerHTML","hb","ib","jb","textContent","kb","lb","mb","nb","ob","namespaceURI","innerHTML","firstChild","removeChild","appendChild","MSApp","execUnsafeLocalFunction","pb","lastChild","nodeValue","qb","animationIterationCount","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","columns","flex","flexGrow","flexPositive","flexShrink","flexNegative","flexOrder","gridArea","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","fontWeight","lineClamp","lineHeight","order","orphans","tabSize","widows","zIndex","zoom","fillOpacity","floodOpacity","stopOpacity","strokeDasharray","strokeDashoffset","strokeOpacity","rb","sb","tb","setProperty","ub","menuitem","area","base","br","col","embed","hr","img","keygen","link","meta","param","track","wbr","vb","wb","is","xb","srcElement","correspondingUseElement","parentNode","yb","zb","Ab","Bb","Cb","stateNode","Db","Eb","Fb","Gb","Hb","Ib","Jb","Kb","Lb","Mb","Ob","Pb","Qb","Rb","l","onError","Sb","Tb","Ub","Vb","Wb","Xb","Zb","alternate","return","$b","memoizedState","dehydrated","ac","cc","child","sibling","bc","dc","ec","fc","gc","hc","ic","jc","kc","lc","mc","nc","oc","pc","qc","rc","blockedOn","domEventName","eventSystemFlags","nativeEvent","targetContainers","sc","pointerId","tc","vc","wc","lanePriority","unstable_runWithPriority","priority","hydrate","containerInfo","xc","yc","shift","zc","Ac","Bc","unstable_scheduleCallback","unstable_NormalPriority","Cc","Dc","Ec","animationend","animationiteration","animationstart","transitionend","Fc","Gc","Hc","animation","Ic","Jc","Kc","Lc","Mc","Nc","Oc","Pc","Qc","unstable_now","F","Rc","Uc","pendingLanes","expiredLanes","suspendedLanes","pingedLanes","Vc","entangledLanes","entanglements","Wc","Xc","Yc","Zc","$c","eventTimes","clz32","bd","cd","log","LN2","dd","unstable_UserBlockingPriority","ed","fd","gd","hd","uc","jd","kd","ld","md","nd","od","keyCode","charCode","pd","qd","rd","_reactName","_targetInst","isDefaultPrevented","defaultPrevented","returnValue","isPropagationStopped","stopPropagation","cancelBubble","isPersistent","wd","xd","yd","sd","eventPhase","bubbles","cancelable","timeStamp","isTrusted","td","ud","detail","vd","Ad","screenX","screenY","clientX","clientY","pageX","pageY","ctrlKey","shiftKey","altKey","metaKey","getModifierState","zd","button","buttons","relatedTarget","fromElement","toElement","movementX","movementY","Bd","Dd","dataTransfer","Fd","Hd","animationName","elapsedTime","pseudoElement","Id","clipboardData","Jd","Ld","Md","Esc","Spacebar","Left","Up","Right","Down","Del","Win","Menu","Apps","Scroll","MozPrintableKey","Nd","Od","Alt","Control","Meta","Shift","Pd","Qd","code","locale","which","Rd","Td","pressure","tangentialPressure","tiltX","tiltY","twist","pointerType","isPrimary","Vd","touches","targetTouches","changedTouches","Xd","Yd","deltaX","wheelDeltaX","deltaY","wheelDeltaY","wheelDelta","deltaZ","deltaMode","Zd","$d","ae","be","documentMode","ce","de","ee","fe","ge","he","ie","le","date","datetime","email","month","password","tel","week","me","ne","oe","pe","qe","se","te","ue","ve","we","xe","ye","ze","oninput","Ae","detachEvent","Be","Ce","attachEvent","De","Ee","Fe","He","Ie","Je","Ke","Le","nextSibling","Me","compareDocumentPosition","Ne","HTMLIFrameElement","contentWindow","Oe","contentEditable","Pe","Qe","Re","Se","Te","Ue","selectionStart","selectionEnd","anchorNode","getSelection","anchorOffset","focusNode","focusOffset","Ve","We","Xe","Ye","Ze","Yb","instance","G","$e","af","bf","cf","df","passive","Nb","x","w","z","u","q","v","ef","ff","parentWindow","gf","hf","J","K","Q","L","je","char","ke","jf","kf","lf","mf","autoFocus","nf","__html","of","pf","qf","rf","sf","previousSibling","tf","vf","wf","xf","yf","zf","Af","Bf","H","I","Cf","M","N","Df","Ef","__reactInternalMemoizedUnmaskedChildContext","__reactInternalMemoizedMaskedChildContext","Ff","Gf","Hf","If","getChildContext","Jf","__reactInternalMemoizedMergedChildContext","Kf","Lf","Mf","Nf","Of","Pf","unstable_cancelCallback","Qf","unstable_shouldYield","Rf","unstable_requestPaint","Sf","Tf","unstable_getCurrentPriorityLevel","Uf","unstable_ImmediatePriority","Vf","Wf","Xf","unstable_LowPriority","Yf","unstable_IdlePriority","Zf","$f","ag","bg","cg","dg","O","eg","fg","gg","hg","ig","jg","kg","ReactCurrentBatchConfig","lg","mg","ng","og","pg","qg","rg","_currentValue","sg","childLanes","tg","dependencies","firstContext","lanes","ug","vg","observedBits","responders","wg","xg","updateQueue","baseState","firstBaseUpdate","lastBaseUpdate","shared","pending","effects","yg","zg","eventTime","lane","Ag","Bg","Cg","A","p","C","Dg","Eg","Fg","Component","Gg","Kg","isMounted","_reactInternals","enqueueSetState","Hg","Ig","Jg","enqueueReplaceState","enqueueForceUpdate","Lg","shouldComponentUpdate","isPureReactComponent","Mg","Ng","componentWillReceiveProps","UNSAFE_componentWillReceiveProps","Og","getSnapshotBeforeUpdate","UNSAFE_componentWillMount","componentWillMount","componentDidMount","Pg","Qg","_owner","_stringRef","Rg","Sg","lastEffect","nextEffect","firstEffect","Tg","Ug","Vg","implementation","Wg","Xg","Yg","Zg","$g","ah","bh","ch","dh","eh","documentElement","tagName","fh","gh","hh","P","ih","memoizedProps","revealOrder","jh","kh","lh","mh","nh","oh","pendingProps","ph","qh","rh","sh","th","uh","_workInProgressVersionPrimary","vh","ReactCurrentDispatcher","wh","xh","R","S","T","yh","zh","Ah","Bh","Ch","Dh","Eh","Fh","Gh","Hh","baseQueue","queue","Ih","Jh","Kh","lastRenderedReducer","eagerReducer","eagerState","lastRenderedState","dispatch","Lh","Mh","_getVersion","_source","mutableReadLanes","Nh","U","getSnapshot","setSnapshot","Oh","Ph","Qh","Rh","destroy","Sh","Th","Uh","Vh","Wh","Xh","Yh","Zh","$h","ai","bi","ci","di","readContext","useCallback","useImperativeHandle","useLayoutEffect","useMemo","useReducer","useDebugValue","useDeferredValue","useTransition","useMutableSource","useOpaqueIdentifier","unstable_isNewReconciler","uf","ei","ReactCurrentOwner","fi","gi","hi","ii","ji","ki","li","mi","baseLanes","ni","oi","pi","UNSAFE_componentWillUpdate","componentWillUpdate","componentDidUpdate","qi","ri","pendingContext","Bi","Di","Ei","si","retryLane","ti","fallback","unstable_avoidThisFallback","ui","unstable_expectedLoadTime","vi","wi","xi","yi","zi","isBackwards","rendering","renderingStartTime","tailMode","Ai","Fi","Gi","wasMultiple","multiple","onclick","createElementNS","createTextNode","V","Hi","Ii","W","Ji","Ki","Li","Mi","Ni","console","Oi","Pi","Qi","Ri","Si","componentDidCatch","Ti","componentStack","Ui","WeakSet","Vi","Wi","Xi","__reactInternalSnapshotBeforeUpdate","Yi","Zi","$i","aj","display","bj","onCommitFiberUnmount","componentWillUnmount","cj","dj","ej","fj","gj","hj","insertBefore","_reactRootContainer","ij","jj","kj","lj","mj","nj","oj","pj","X","Y","qj","rj","sj","tj","uj","vj","wj","ck","Z","xj","yj","zj","Aj","Bj","Cj","Dj","Ej","Fj","Gj","Hj","Ij","Jj","Sc","Kj","Lj","Mj","callbackNode","expirationTimes","callbackPriority","Tc","Nj","Oj","Pj","Qj","Rj","Sj","Tj","finishedWork","finishedLanes","Uj","timeoutHandle","Wj","Xj","pingCache","Yj","Zj","va","ak","bk","dk","rangeCount","focusedElem","selectionRange","ek","setStart","removeAllRanges","addRange","setEnd","scrollLeft","scrollTop","onCommitFiberRoot","fk","gk","ik","isReactComponent","pendingChildren","jk","mutableSourceEagerHydrationData","kk","lk","mk","nk","qk","hydrationOptions","mutableSources","_internalRoot","rk","tk","hasAttribute","sk","uk","hk","_calculateChangedBits","unstable_observedBits","unmount","Vj","vk","Events","wk","findFiberByHostInstance","bundleType","version","rendererPackageName","xk","rendererConfig","overrideHookState","overrideHookStateDeletePath","overrideHookStateRenamePath","overrideProps","overridePropsDeletePath","overridePropsRenamePath","setSuspenseHandler","scheduleUpdate","currentDispatcherRef","findHostInstanceByFiber","findHostInstancesForRefresh","scheduleRefresh","scheduleRoot","setRefreshHandler","getCurrentFiber","__REACT_DEVTOOLS_GLOBAL_HOOK__","yk","isDisabled","supportsFiber","inject","createPortal","findDOMNode","flushSync","unmountComponentAtNode","unstable_batchedUpdates","unstable_createPortal","unstable_renderSubtreeIntoContainer","checkDCE","__defProp","__publicField","writable","__defNormalProp","f2","n2","clsx","jsxRuntime","reactJsxRuntime_production_min","require$$0","__self","__source","Fragment","jsx","jsxs","ModalActions","el","title","ModalHeader","onBackdropClick","closeIconComponent","ModalComponent","forwardRef","isCloseable","headerComponent","HeaderComponent","headerClassName","actionClassName","contentClassName","onModalClose","isSlidePane","disableTheme","footer","attri","getAttributeNames","classes","dark","modalWrapper","right","modalBody","modalContent","GlobalModalComponent","isOpen","MainComponent","onClose","closeModal","customModal","CustomModal","isInModal","GlobalModalWrapper","super","modals","sheet","totalIndex","_a","_b","modalRef","_globalModalRef","modalIndex","updateModalProps","closeAll","matchHtmlEntity","htmlEntities","unescapeHtmlEntity","ownKeys","enumerableOnly","sym","_objectSpread","_defineProperty","getOwnPropertyDescriptors","defineProperties","i18nInstance","bindI18n","bindI18nStore","transEmptyNodeValue","transSupportBasicHtmlNodes","transWrapTextNodes","transKeepBasicHtmlNodesFor","useSuspense","I18nContext","createContext","getDefaults","ReportNamespaces","_classCallCheck","usedNamespaces","_createClass","namespaces","_this","ns","getI18n","initReactI18next","init","setDefaults","react","setI18n","_slicedToArray","arrayWithHoles","_i","_s","_e","_arr","_n","_d","unsupportedIterableToArray","nonIterableRest","warn","_console","alreadyWarned","warnOnce","_len2","_key2","loadNamespaces","i18n","isInitialized","on","initialized","off","oldI18nextHasLoadedNamespace","lng","languages","fallbackLng","lastLng","loadNotPending","loadState","services","backendConnector","backend","isLanguageChangingTo","hasResourceBundle","resources","partialBundledLanguages","hasLoadedNamespace","isNewerI18next","ignoreJSONStructure","precheck","usePrevious","ignore","i18nFromProps","i18nFromContext","defaultNSFromContext","defaultNS","reportNamespaces","notReadyT","retNotReady","ready","i18nOptions","keyPrefix","addUsedNamespaces","initializedStoreOnce","getT","getFixedT","nsMode","_useState","_useState2","setT","joinedNS","previousJoinedNS","boundReset","store","isInitial","ret","AsyncMode","ConcurrentMode","ContextConsumer","ContextProvider","Element","Lazy","Portal","Profiler","StrictMode","Suspense","isAsyncMode","isConcurrentMode","isContextConsumer","isContextProvider","isForwardRef","isFragment","isPortal","isProfiler","isStrictMode","isSuspense","isValidElementType","typeOf","BrowserRouter","createHistory","Router","resolveToLocation","normalizeToLocation","forwardRefShim","LinkAnchor","forwardedRef","navigate","ex","isModifiedEvent","RouterContext","isDuplicateNavigation","ariaCurrent","activeClassName","activeStyle","classNameProp","isActiveProp","locationProp","styleProp","escapedPath","matchPath","classnames","joinClassnames","MAX_SIGNED_31_BIT_INT","commonjsGlobal","globalThis","createEventEmitter","handlers","changedBits","calculateChangedBits","_Provider$childContex","_Consumer$contextType","contextProp","getUniqueId","Provider","_Component","emitter","_inheritsLoose","_proto","nextProps","oldValue","Consumer","_Component2","_this2","onUpdate","_proto2","createNamedContext","historyContext","_isMounted","_pendingLocation","staticContext","computeRootMatch","params","isExact","HistoryContext","Lifecycle","onMount","prevProps","onUnmount","cacheCount","generatePath","generator","compilePath","Redirect","computedMatch","matched","cacheKey","pathCache","memo","Route","isEmptyChildren","createURL","staticHandler","Switch","useHistory","useRouteMatch","forceUpdate","_status","_result","default","IsSomeRendererActing","only","PureComponent","cloneElement","_currentValue2","_threadCount","createFactory","createRef","isValidElement","lazy","performance","MessageChannel","unstable_forceFrameRate","cancelAnimationFrame","requestAnimationFrame","port2","port1","onmessage","postMessage","sortIndex","startTime","expirationTime","priorityLevel","unstable_Profiling","unstable_continueExecution","unstable_getFirstCallbackNode","unstable_next","unstable_pauseExecution","unstable_wrapCallback","msGridRow","msGridRowSpan","msGridColumn","msGridColumnSpan","WebkitLineClamp","safeIsNaN","Number","areInputsEqual","newInputs","lastInputs","second","resultFn","lastResult","calledOnce","newArgs","reactPropsRegex","getType","__spreadArrays","il","jl","assignProp","carry","newVal","originalObject","propType","mergeRecursively","origin","newComer","extensions","newObject","targetVal","newComers","componentId","insertRule","needle","toSheet","content","selectors","parents","line","column","factory","nullptn","formatptn","colonptn","cursorptn","transformptn","animationptn","propertiesptn","elementptn","selectorptn","andptn","escapeptn","invalidptn","keyframeptn","plcholdrptn","readonlyptn","beforeptn","afterptn","tailptn","whiteptn","pseudoptn","writingptn","supportsptn","propertyptn","selfptn","pseudofmt","dimensionptn","imgsrcptn","webkit","moz","ms","SEMICOLON","CLOSEBRACES","OPENBRACES","OPENPARENTHESES","CLOSEPARENTHESES","OPENBRACKET","CLOSEBRACKET","NEWLINE","CARRIAGE","TAB","AT","SPACE","AND","DASH","UNDERSCORE","STAR","COMMA","COLON","SINGLEQUOTE","DOUBLEQUOTE","FOWARDSLASH","GREATERTHAN","PLUS","TILDE","NULL","FORMFEED","VERTICALTAB","KEYFRAME","MEDIA","SUPPORTS","READONLY","IMPORT","CHARSET","DOCUMENT","PAGE","cascade","compress","semicolon","preserve","plugins","plugged","should","POSTS","PREPS","UNKWN","PROPS","BLCKS","ATRUL","unkwn","keyed","nscopealt","nscope","selector","bracket","comment","parentheses","trail","peak","counter","atrule","pseudo","caret","format","insert","eof","eol","out","flat","delimited","proxy","supports","vendor","padding","elements","isolate","scope","level","third","declare","items","stylis","use","plugin","condition","extendStatics","setPrototypeOf","__proto__","__extends","__","__assign","__rest","__awaiter","_arguments","fulfilled","rejected","__generator","sent","trys","ops","verb","op","__spreadArray","pack","ar","_arrayWithHoles","Constructor","_defineProperties","protoProps","staticProps","subClass","superClass","_nonIterableRest","_objectWithoutPropertiesLoose","excluded","sourceKeys","_setPrototypeOf","_arrayLikeToArray","arr2","_unsupportedIterableToArray","minLen","NetworkStatus","isNetworkRequestInFlight","networkStatus","isApolloError","graphQLErrors","clientErrors","networkError","errorMessage","extraInfo","_super","isNonEmptyArray","generateErrorMessage","ApolloError","contextKey","canUseSymbol","getApolloContext","canUseWeakMap","maybe","product","canUseWeakSet","usingJSDOM","canUseLayoutEffect","objects","deepFreeze","workSet","isNonNullObject","__DEV__","isFrozen","freeze","shallowFreeze","maybeDeepFreeze","mergeOptions","variables","genericMessage","InvariantError","verbosityLevels","verbosityLevel","wrapConsoleMethod","thunk","GLOBAL_KEY","safeGlobal","needToRemove","env","NODE_ENV","asyncIterator","DEV","_typeof","inspect","formatValue","seenValues","previouslySeenValues","customInspectFn","nodejsCustomInspectSymbol","getCustomFn","customValue","formatArray","getObjectTag","formatObject","formatObjectValue","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","loaded","__webpack_modules__","getter","__esModule","leafPrototypes","getProto","def","definition","chunkId","promises","miniCssF","inProgress","dataWebpackPrefix","script","needAttach","scripts","getElementsByTagName","charset","timeout","src","onScriptComplete","prev","onerror","onload","doneFns","nmd","installedChunks","installedChunkData","promise","errorType","realSrc","request","webpackJsonpCallback","parentChunkLoadingFunction","chunkIds","moreModules","runtime","chunkLoadingGlobal","ApolloProvider","client","ApolloContext","defineInspect","classObject","isNode","maybeNode","kind","Location","startToken","endToken","Token","QueryDocumentKeys","Name","Document","OperationDefinition","VariableDefinition","Variable","SelectionSet","Field","Argument","FragmentSpread","InlineFragment","FragmentDefinition","IntValue","FloatValue","StringValue","BooleanValue","NullValue","EnumValue","ListValue","ObjectValue","ObjectField","Directive","NamedType","ListType","NonNullType","SchemaDefinition","OperationTypeDefinition","ScalarTypeDefinition","ObjectTypeDefinition","FieldDefinition","InputValueDefinition","InterfaceTypeDefinition","UnionTypeDefinition","EnumTypeDefinition","EnumValueDefinition","InputObjectTypeDefinition","DirectiveDefinition","SchemaExtension","ScalarTypeExtension","ObjectTypeExtension","InterfaceTypeExtension","UnionTypeExtension","EnumTypeExtension","InputObjectTypeExtension","BREAK","visit","visitor","visitorKeys","inArray","edits","ancestors","newRoot","isLeaving","isEdited","_i2","_Object$keys2","editOffset","editKey","editValue","_visitorKeys$node$kin","visitFn","getVisitFn","kindVisitor","kindSpecificVisitor","leave","enter","specificVisitor","specificKindVisitor","_createForOfIteratorHelperLoose","allowArrayLike","it","hasSymbols","hasSymbol","getSymbol","observable","SymbolIterator","SymbolObservable","SymbolSpecies","getMethod","getSpecies","ctor","Observable","isObservable","hostReportError","enqueue","cleanupSubscription","cleanup","_cleanup","closeSubscription","_observer","_queue","_state","notifySubscription","onNotify","flushSubscription","Subscription","subscriber","subscriptionObserver","SubscriptionObserver","_subscription","complete","_subscriber","_proto3","_this3","_this4","hasSeed","hasValue","seed","acc","_this5","startNext","_this6","subscriptions","inner","completeIfDone","closed","_step","_iterator","getFragmentQueryDocument","fragmentName","actualFragmentName","fragments","definitions","operation","selectionSet","selections","createFragmentMap","symTable","fragment","getFragmentFromSelection","selection","fragmentMap","makeReference","__ref","isReference","valueToObjectRepresentation","argObj","isIntValue","isFloatValue","isBooleanValue","isStringValue","isObjectValue","nestedArgObj_1","isVariable","variableValue","isListValue","listValue","nestedArgArrayObj","isEnumValue","isNullValue","KNOWN_DIRECTIVES","getStoreKeyName","directives","filterKeys","filteredArgs_1","completeFieldName","stringifiedArgs","setStringify","stringifyReplacer","argumentsObjectFromField","argObj_1","resultKeyNameFromField","alias","getTypenameFromResult","__typename","isField","typename","isInlineFragment","checkDocument","doc","operations","getOperationDefinition","getOperationName","getFragmentDefinitions","getQueryDefinition","queryDef","getMainDefinition","queryDoc","fragmentDefinition","getDefaultValues","defs","variableDefinitions","passthrough","forward","toLink","ApolloLink","isTerminating","links","empty","leftLink","rightLink","starting","createOperation","transformedOperation","operationName","transformOperation","OPERATION_FIELDS","validateOperation","firstLink","LinkError","nextLink","serializeFetchParameter","serialized","parseError","throwServerError","response","statusCode","print","ast","printDocASTReducer","varDefs","_ref2","_ref3","argsLine","indent","_ref4","_ref5","_ref6","typeCondition","_ref7","_ref8","_ref9","_ref10","indentation","preferMultipleLines","isSingleLine","hasLeadingSpace","hasTrailingQuote","printAsMultipleLines","printBlockString","_ref11","_ref12","_ref13","_ref14","_ref15","_ref16","_ref17","_ref18","_ref19","addDescription","_ref20","operationTypes","_ref21","_ref22","_ref23","interfaces","_ref24","hasMultilineItems","_ref25","_ref26","_ref27","_ref28","_ref29","_ref30","_ref31","repeatable","locations","_ref32","_ref33","_ref34","_ref35","_ref36","_ref37","_ref38","description","maybeArray","_maybeArray$filter$jo","maybeString","isMultiline","fallbackHttpConfig","http","includeQuery","includeExtensions","accept","defaultPrinter","printer","selectHttpOptionsAndBodyInternal","configs","headersToLowerCase","credentials","normalized_1","fromError","errorValue","backupFetch","createHttpLink","linkOptions","uri","preferredFetch","useGETForQueries","_c","includeUnusedVariables","requestOptions","fetcher","checkFetcher","linkConfig","fetchOptions","chosenURI","fallbackURI","getContext","selectURI","clientAwarenessHeaders","clientAwareness","name_1","controller","contextHeaders","contextConfig","unusedNames_1","signal","AbortController","createSignalIfSupported","_controller","queryParams","addQueryParam","serializedVariables","serializedExtensions","preFragment","fragmentStart","queryParamsPrefix","newURI","rewriteURIForGET","setContext","bodyText","abort","execute","defaultMakeData","weakness","makeData","Trie","lookupArray","getChildTrie","isObjRef","weak","strong","shouldInclude","directive","isInclusionDirective","directiveArguments","directiveName","ifArgument","ifValue","getInclusionDirectives","evaledValue","hasDirectives","getDirectiveNames","hasClientExports","mergeDeep","mergeDeepArray","merger","DeepMerger","defaultReconciler","reconciler","pastCopies","sourceKey","targetValue","shallowCopyForMerge","hasOwn","defaultDataIdFromObject","_id","keyObject","defaultConfig","dataIdFromObject","addTypename","resultCaching","canonizeResults","shouldCanonizeResults","TypeOrFieldNameRegExp","fieldNameFromStoreName","storeFieldName","selectionSetMatchesResult","storeValueIsStoreObject","stringifyCanon","stringifyCache","known","pool","passes","keysByJSON","admit","ObjectCanon","isObjectOrArray","shallowCopy","original","proto_1","array_1","sortedKeys","json","firstValueIndex_1","sorted","obj_1","canonicalStringify","resetCanonicalStringify","canonical","asyncMap","mapFn","catchFn","activeCallbackCount","completed","promiseQueue","makeCallback","examiner","delegate","both","caught","sub","graphQLResultHasError","filterInPlace","elem","TYPENAME_FIELD","nullIfDocIsEmpty","fragmentDef","getFragmentDefinition","getDirectiveMatcher","removeDirectivesFromDocument","variablesInUse","variablesToRemove","fragmentSpreadsInUse","fragmentSpreadsToRemove","modifiedDoc","getAllFragmentSpreadsFromSelectionSet","frag","argMatcher","argument","aConfig","getArgumentMatcher","varDef","argConfig","argMatchCount_1","removeArgumentsFromDocument","fs","removeFragmentSpreadFromDocument","addTypenameToDocument","added","connectionRemoveConfig","willRemove","allFragments","buildQueryFromSelectionSet","prefixCounts","makeUniqueId","iterateObserversSafely","observersWithMethod","obs","fixObservableSubclass","subclass","species","isPromiseLike","addObserver","removeObserver","latest","reason","Concast","nextOrError","deliverLastMessage","addCount","quietly","called","cloneDeepHelper","copy_1","copy_2","queryManager","queryInfo","subObserver","defaultSubscriptionObserverErrorCallback","reobserve","tearDownQuery","isTornDown","watchQuery","defaultFetchPolicy","fetchPolicy","initialFetchPolicy","queryId","generateQueryId","opDef","queryName","ObservableQuery","removeQuery","saveAsLastResult","getLastResult","loading","hasForcedResolvers","diff","getDiff","returnPartialData","partialRefetch","logMissingFieldErrors","missing","updateLastResult","newResult","variablesMustMatch","getLast","resetErrors","reobserveOptions","pollInterval","vars","resetLastWrite","fetchMoreOptions","combinedOptions","qid","originalNetworkStatus","notifyOnNetworkStatusChange","observe","updatedQuerySet","fetchQuery","fetchMoreResult","batch","updateQuery","optimistic","writeQuery","onWatchUpdated","finally","reobserveCacheFirst","startGraphQLSubscription","subscriptionData","newOptions","broadcastQueries","updatePolling","nextFetchPolicy","newNetworkStatus","setObservableQuery","fetchQueryObservable","ssrMode","pollingInfo","interval","maybeFetch","poll","assumeImmutableResults","useDisposableConcast","oldVariables","oldFetchPolicy","mergedOptions","applyNextFetchPolicy","concast","reportResult","reportError","getCurrentResult","lastError","getLastError","isDifferentFromLastResult","errorResult","stopPolling","stopQuery","obsQuery","currentContext","MISSING_VALUE","globalKey","host","Slot","context_1","slots","saved","defaultDispose","dispose","newest","oldest","getNode","older","newer","parentEntrySlot","maybeUnsubscribe","entryOrDep","emptySetPool","assert","optionalMessage","valueGet","childValues","dirtyChildren","dirty","recomputing","Entry","mightBeDirty","rememberParent","forgetChildren","withValue","recomputeNewValue","setDirty","maybeSubscribe","reportClean","setClean","reallyRecompute","reportDirty","eachParent","forgetChild","dep","reportDirtyChild","reportCleanChild","parentCount","parentWasClean","childValue","valueIs","removeDirtyChild","_value","forgetDeps","EntryMethods","forget","depsByKey","depend","dep_1","dependOn","entryMethodName","m_1","makeDefaultMakeCacheKeyFunction","keyTrie","originalFunction","pow","keyArgs","makeCacheKey","recompute","clean","dirtyKey","peekKey","peek","forgetKey","getKey","cacheSlot","cacheInfoMap","getCacheInfo","forgetCache","rv","makeVar","broadcast","oldListeners","attach","onNextChange","attachCache","broadcastWatches","resolvers","fragmentMatcher","addResolvers","setFragmentMatcher","LocalState","resolverGroup","remoteResult","onlyRunForcedResolvers","resolveDocument","localResult","removeClientSetsFromDocument","getCacheKey","identify","buildRootValueFromCache","prepareContext","exportedVariables","forceResolvers","rootValue","mainDefinition","definitionOperation","defaultOperationType","execContext","resolveSelectionSet","resultsToMerge","resolveField","fieldResult","fragmentResult","aliasedFieldName","aliasUsed","resultPromise","shouldForceResolvers","resolverType","resolverMap","resolveSubSelectedArray","destructiveMethodCounts","wrapDestructiveCacheMethod","cancelNotifyTimeout","lastRequestId","stopped","observableQuery","QueryInfo","lastDiff","getDiffOptions","updateWatch","oq","updateLastDiff","oldDiff","notifyTimeout","notify","oqListener","fromOptimisticTransaction","shouldNotify","watchOptions","watcher","setDiff","lastWatch","lastWrite","dmCount","cacheWriteBehavior","shouldWriteResult","errorPolicy","performTransaction","shouldWrite","overwrite","diffOptions","ignoreErrors","writeWithErrors","queryDeduplication","onBroadcast","localState","queries","fetchCancelFns","transformCache","queryIdCounter","requestIdCounter","mutationIdCounter","inFlightLinkObservables","mutationStore","QueryManager","_info","stopQueryNoBroadcast","cancelPendingFetches","mutation","optimisticResponse","updateQueries","refetchQueries","awaitRefetchQueries","updateWithProxyFn","onQueryUpdated","mutate","_g","keepRootFields","mutationId","generateMutationId","markMutationOptimistic","mutationStoreValue","storeResult","removeOptimistic","markMutationResult","cacheWrites","skipCache","dataId","updateQueries_1","currentQueryResult","nextQueryResult","mutationResult","queryVariables","results_1","asQuery","modify","DELETE","include","recordOptimisticTransaction","getQueryStore","transformed","forLink","transformForLink","clientQuery","serverQuery","cacheEntry_1","defaultVars","generateRequestId","stopQueryInStore","stopQueryInStoreNoBroadcast","discardWatches","getObservableQueries","queryNamesAndDocs","legacyQueryOptions","desc","getQuery","reFetchObservableQueries","includeStandby","observableQueryPromises","makeObservable","write","addExportedVariables","observablePromise_1","stop","getLocalState","getObservableFromLink","deduplication","inFlightLinkObservables_1","forceFetch","byVariables_1","varJson_1","runResolvers","getResultsFromLink","hasErrors","requestId","markResult","aqr","getVariables","normalized","fromVariables","concastSources","cleanupCancelFn","updateCache","includedQueriesById","results","fetchQueryByPolicy","refetchWritePolicy","readCache","resultsFromCache","fromData","refetch","resultsFromLink","oldNetworkStatus","hasSuggestedDevtools","resetStoreCallbacks","clearStoreCallbacks","ssrForceFetchDelay","connectToDevTools","__APOLLO_CLIENT__","typeDefs","clientAwarenessName","clientAwarenessVersion","HttpLink","disableNetworkFetches","resetStore","__APOLLO_DEVTOOLS_GLOBAL_HOOK__","nav","devToolsHookCb","mutations","dataWithOptimisticResults","extract","ApolloClient","readQuery","readFragment","writeFragment","clearStore","serializedState","restore","setResolvers","getResolvers","newLink","getFragmentDoc","ApolloCache","updateResult","optimisticId","transaction","read","rootId","delModifier","INVALIDATE","policies","rootIds","objectOrReference","canRead","objOrRef","toReference","objOrIdOrRef","mergeIntoStore","EntityStore","lookup","storeObject","rootTypenamesById","Layer","dependOnExistence","existing","incoming","merged","storeObjectReconciler","caching","fieldsToDirty_1","__exists","hasKeyArgs","changedFields_1","needToMerge_1","allDeleted_1","sharedDetails_1","readField","fieldNameOrOptions","storage","getStorage","getStoreFieldName","evicted","evict","extraRootIds","getRootIdSet","__META","rest_1","retain","ids","snapshot","findChildRefIds","idsToRemove","root_1","found_1","workSet_1","keyMaker","resetCaching","CacheGroup","makeDepKey","maybeDependOnExistenceOfEntity","entityId","supportsResultCaching","Stump","Root","layerId","replay","stump","addLayer","storageTrie","removeLayer","ownStoreObject","parentStoreObject","fromParent","existingObject","incomingObject","existingValue","incomingValue","execSelectionSetKeyArgs","knownResults","canon","executeSelectionSet","peekArgs","enclosingRef","execSelectionSetImpl","resultCacheMaxSize","varString","executeSubSelectedArray","execSubSelectedArrayImpl","StoreReader","rootRef","execResult","MissingFieldError","firstMissing","isKnown","objectsToMerge","missingMerger","handleMissing","resultName","rootIdsByTypename","pass","fragmentMatches","finalResult","frozen","childResult","getTypenameFromStoreObject","assertSelectionSetForIdValue","tree","specifierInfoCache","lookupSpecifierInfo","spec","keyFieldsFnFromSpecifier","specifier","keyFieldsFn","collectSpecifierPaths","schemaKeyPath","extracted","extractKeyPath","extractKey","keyArgsFnFromSpecifier","keyArgsFn","collected","keyPath","firstKey","firstChar","variableName","varKeyPath","directiveName_1","directiveArgs","extractor","getSpecifierPaths","toMerge","paths_1","currentPath_1","normalize","reducer","argsFromFieldSpecifier","nullKeyFieldsFn","simpleKeyArgsFn","_args","mergeTrueFn","mergeObjects","mergeFalseFn","typePolicies","toBeAdded","supertypeMap","fuzzySubtypes","usingPossibleTypes","setRootTypename","possibleTypes","addPossibleTypes","addTypePolicies","Policies","partialContext","ROOT_QUERY","normalizeReadFieldOptions","policy","getTypePolicy","keyFn","specifierOrId","queryType","mutationType","subscriptionType","keyFields","setMerge","getFieldPolicy","old","supertype","getSupertypeSet","subtype","policy_1","supertypes","inbox","updateTypePolicy","createIfMissing","fieldPolicies","supertypeSet","typenameSupertypeSet","workQueue_1","maybeEnqueue_1","needToCheckFuzzySubtypes","checkingFuzzySubtypes","regExp","fuzzyString","fieldSpec","specifierOrString","directivesObj","storeKeyNameFromField","readOptions","makeFieldFunctionOptions","parentTypename","childTypename","makeMergeObjectsFunction","readFieldArgs","argc","undefId","stringifyForDisplay","eType","iType","getContextFlavor","clientOnly","deferred","flavored","flavors","reader","StoreWriter","operationDefinition","written","incomingById","processSelectionSet","mergeTree","fieldNodeSet","entityRef","applied","applyMerges","fieldsWithSelectionSets_1","hasSelectionSet_1","childTree","hasMergeFunction_1","existingRef","incomingObj","getChild","parentType","typeDotName","warnings","childTypenames","warnAboutDataLoss","result_1","flattenFields","resultFieldKey","getChildMergeTree","processFieldValue","getMergeFunction","maybeRecycleChildMergeTree","getReadFunction","dataRef","sets","isFresh","previous_1","mergeMergeTrees","mergeTreeIsEmpty","fieldMap","limitingTrie","inheritedContext","visitedNode","visited","if","getStorageArgs","e_1","i_1","getValue_1","eVal","iVal","aVal","runMergeFunction","emptyMergeTreePool","needToMergeMaps","remainingRightKeys_1","leftTree","normalizeConfig","InMemoryCache","rootStore","optimisticData","resetResultCache","resetResultIdentities","previousReader","storeReader","storeWriter","maybeBroadcastWatch","broadcastWatch","diffQueryAgainstStore","txCount","writeToStore","watches","immediate","resetCanon","release","idToRemove","newOptimisticData","perform","layer","alreadyDirty","typenameDocumentCache","httplink","handle","req","NavigationContext","landscapeNavigation","isContactModalVisible","triggerContactModal","NavigationProvider","isLandscape","setIsContactModalVisible","classList","HomeContent","ProjectsContent","AboutContent","ProjectDetails","NotFound","Routes","BaseWrapper","themeMode","globalModalRef","changeTheme","_assertThisInitialized","ReferenceError","_inherits","_possibleConstructorReturn","_getPrototypeOf","_toArray","iter","consoleLogger","baseLogger","Logger","concreteLogger","logger","debug","_len3","_key3","_len4","_key4","lvl","debugOnly","moduleName","EventEmitter","events","cloned","_cloned","rej","makeString","getLastOfPath","Empty","cleanKey","canNotTraverseDeeper","setPath","_getLastOfPath","getPath","_getLastOfPath3","getPathWithDefaults","defaultData","deepExtend","regexEscape","_entityMap","isIE10","userAgentData","ownKeys$1","_objectSpread$1","_createSuper","Derived","hasNativeReflectConstruct","sham","Proxy","_isNativeReflectConstruct","Super","NewTarget","deepFind","keySeparator","mix","joinedPath","ResourceStore","_EventEmitter","silent","addNamespaces","emit","addResource","deep","removeNamespaces","getResource","compatibilityAPI","getDataByLanguage","postProcessor","processors","addPostProcessor","translator","processor","ownKeys$2","_objectSpread$2","_createSuper$1","_isNativeReflectConstruct$1","checkedLoadedFor","Translator","language","interpolation","resolved","nsSeparator","wouldCheckForNsInKey","seemsNaturalLanguage","userDefinedKeySeparator","userDefinedNsSeparator","possibleChars","looksLikeObjectPath","interpolator","nestingRegexp","lastKey","overloadTranslationOptionHandler","returnDetails","_this$extractFromKey","extractFromKey","namespace","appendNamespaceToCIMode","resUsedKey","usedKey","resExactUsedKey","exactUsedKey","resType","noObject","joinArrays","handleAsObjectInI18nFormat","i18nFormat","handleAsObject","returnObjects","returnedObjectHandler","resTypeIsArray","newKeyToUse","deepKey","translate","extendTranslation","usedDefault","needsPluralHandling","hasDefaultValue","defaultValueSuffix","pluralResolver","getSuffix","isValidLookup","missingKeyNoValueFallbackToKey","resForMissing","updateMissing","lngs","fallbackLngs","languageUtils","getFallbackCodes","saveMissingTo","toResolveHierarchy","send","specificDefaultValue","defaultForMissing","missingKeyHandler","saveMissing","saveMissingPlurals","getSuffixes","appendNamespaceToMissingKey","parseMissingKeyHandler","defaultVariables","usedLng","usedNS","skipInterpolation","nestBef","skipOnVariables","nest","postProcess","postProcessorNames","applyPostProcessor","postProcessPassResolved","i18nResolved","found","fallbackNS","needsZeroSuffixLookup","ordinal","shouldUseIntlApi","needsContextHandling","codes","utils","possibleKey","finalKeys","addLookupKeys","pluralSuffix","zeroSuffix","pluralSeparator","contextSeparator","returnNull","returnEmptyString","resourceStore","LanguageUtil","supportedLngs","formatLanguageCode","specialCases","lowerCaseLng","cleanCode","load","nonExplicitSupportedLngs","getLanguagePartFromCode","cleanedLng","isSupportedCode","lngOnly","supportedLng","fallbacks","getScriptPartFromCode","fallbackCode","fallbackCodes","addCode","nr","_rulesPluralsTypes","deprecatedJsonVersions","suffixesOrder","zero","one","two","few","many","createRules","rules","numbers","plurals","PluralResolver","compatibilityJSON","Intl","PluralRules","_unused","getRule","resolvedOptions","pluralCategories","pluralCategory1","pluralCategory2","pluralCategory","prepend","getSuffixRetroCompatible","idx","noAbs","abs","simplifyPluralSuffix","returnSuffix","ownKeys$3","_objectSpread$3","Interpolator","iOpts","useRawValueToEscape","prefixEscaped","suffixEscaped","formatSeparator","unescapePrefix","unescapeSuffix","nestingPrefix","nestingPrefixEscaped","nestingSuffix","nestingSuffixEscaped","nestingOptionsSeparator","maxReplaces","alwaysFormat","resetRegExp","regexpStr","regexpUnescapeStr","regexpUnescape","nestingRegexpStr","replaces","regexSafe","handleFormat","interpolationkey","missingInterpolationHandler","regex","safeValue","todo","matchedVar","clonedOptions","handleHasOptions","inheritedOptions","sep","optionsString","formatters","doReduce","ownKeys$4","_objectSpread$4","Formatter","formats","NumberFormat","currency","DateTimeFormat","relativetime","RelativeTimeFormat","ListFormat","_format","mem","_parseFormatStr","formatStr","formatName","formatOptions","optStr","opt","_opt$split2","parseFormatStr","formatted","valOptions","formatParams","ownKeys$5","_objectSpread$5","_createSuper$2","_isNativeReflectConstruct$2","Connector","waitingReads","maxParallelReads","readingCalls","toLoad","toLoadLanguages","toLoadNamespaces","hasAllNamespaces","reload","pendingCount","addResourceBundle","_getLastOfPath2","pushPath","removePending","loadedKeys","fcName","tried","queueLoad","loadOne","prepareLoading","fallbackValue","isUpdate","initImmediate","preload","tDescription","transformOptions","ownKeys$6","_objectSpread$6","_createSuper$3","_isNativeReflectConstruct$3","bindMemberFunctions","inst","I18n","modules","external","isClone","defOpts","createClassOnDemand","ClassOrObject","formatter","lu","languageDetector","detection","storeApi","_this2$store","storeApiChained","_this2$store2","finish","changeLanguage","usedCallback","append","resolvedLanguage","setResolvedLanguage","lngInLngs","hasLanguageSomeTranslations","setLngProps","setLng","getBestMatchFromCodes","cacheUserLanguage","loadResources","detect","fixedT","resultKey","_this$translator","_this$translator2","exists","preResult","_this7","preloaded","newLngs","_this8","membersToCopy","createInstance","reloadResources","setDefaultNamespace","loadLanguages","fieldContentRegExp","serializeCookie","maxAge","domain","expires","toUTCString","httpOnly","secure","sameSite","cookie","minutes","cookieOptions","setTime","nameEQ","cookie$1","lookupCookie","cookieMinutes","cookieDomain","querystring","pos","lookupQuerystring","hasLocalStorageSupport","localStorageAvailable","testKey","removeItem","lookupLocalStorage","hasSessionStorageSupport","sessionStorageAvailable","sessionStorage","lookupSessionStorage","navigator$1","userLanguage","htmlTag","lookupFromPathIndex","subdomain","lookupFromSubdomainIndex","Browser","detectors","excludeCacheFor","lookupFromUrlIndex","addDetector","detector","detectionOrder","detected","detectorName","cacheName","customLangDetector","lngDetector","LanguageDetector","en","translation","enLocale","itLocale","ReactDOM","getElementById"],"sourceRoot":""}