{"version":3,"sources":["../node_modules/react/jsx-runtime.js","../node_modules/tslib/tslib.es6.js","../../src/constants.ts","../../src/assert.ts","../../src/crypt.ts","../../src/deepCopy.ts","../../src/deferred.ts","../../src/environment.ts","../../src/errors.ts","../../src/json.ts","../../src/jwt.ts","../../src/obj.ts","../../src/query.ts","../../src/sha1.ts","../../src/subscribe.ts","../../src/validation.ts","../../src/utf8.ts","../../src/exponential_backoff.ts","../node_modules/react/index.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/regenerator/index.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/defineProperty.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/objectSpread2.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js","../../src/logger.ts","../../src/firebaseApp.ts","../../src/firebaseNamespace.ts","../../src/firebaseNamespaceCore.ts","../../src/platformLoggerService.ts","../../index.ts","../../src/registerCoreComponents.ts","../../src/component.ts","../../src/provider.ts","../../src/component_container.ts","../node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","../../modules/BrowserRouter.js","../../modules/HashRouter.js","../../modules/utils/locationUtils.js","../../modules/Link.js","../../modules/NavLink.js","../node_modules/@firebase/firestore/dist/esm5/prebuilt-e065c69d-7a321be7.js","../node_modules/@babel/runtime/helpers/esm/extends.js","../../modules/HistoryContext.js","../../modules/createNameContext.js","../../modules/RouterContext.js","../../modules/Router.js","../../modules/MemoryRouter.js","../../modules/Lifecycle.js","../../modules/generatePath.js","../../modules/Redirect.js","../../modules/matchPath.js","../../modules/Route.js","../../modules/StaticRouter.js","../../modules/Switch.js","../../modules/withRouter.js","../../modules/hooks.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/slicedToArray.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/nonIterableRest.js","../node_modules/@firebase/webchannel-wrapper/dist/index.esm.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/axios/index.js","../node_modules/axios/lib/utils.js","../node_modules/react-dom/index.js","../node_modules/tiny-invariant/dist/tiny-invariant.esm.js","../node_modules/prop-types/index.js","../node_modules/react-toast-notifications/dist/index.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/taggedTemplateLiteral.js","../node_modules/resolve-pathname/esm/resolve-pathname.js","../node_modules/value-equal/esm/value-equal.js","../node_modules/history/esm/history.js","../node_modules/idb/build/idb.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/toConsumableArray.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/iterableToArray.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js","../../src/clonePseudoElements.ts","../../src/util.ts","../../src/cloneNode.ts","../../src/getBlobFromURL.ts","../../src/embedResources.ts","../../src/embedImages.ts","../../src/embedWebFonts.ts","../../src/createSvgDataURL.ts","../../src/applyStyleWithOptions.ts","../../src/index.ts","../node_modules/webpack/buildin/global.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js","../node_modules/lodash/lodash.js","../node_modules/object-assign/index.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js","../../src/shared/uid.ts","../../src/web/Svg.tsx","../../src/web/ContentLoader.tsx","../../src/web/presets/FacebookStyle.tsx","../../../index.ts","../../../index.bundle.ts","../../../src/config.ts","../../src/api/error.ts","../../src/context.ts","../../src/serializer.ts","../../src/api/service.ts","../../src/config.ts","../../src/util/constants.ts","../../src/util/errors.ts","../../src/api/common.ts","../../src/api/create-installation-request.ts","../../src/util/sleep.ts","../../src/helpers/generate-fid.ts","../../src/helpers/buffer-to-base64-url-safe.ts","../../src/util/get-key.ts","../../src/helpers/fid-changed.ts","../../src/helpers/idb-manager.ts","../../src/helpers/get-installation-entry.ts","../../src/api/generate-auth-token-request.ts","../../src/helpers/refresh-auth-token.ts","../../src/functions/get-token.ts","../../src/api/delete-installation-request.ts","../../src/functions/on-id-change.ts","../../src/helpers/extract-app-config.ts","../../src/functions/get-id.ts","../../src/functions/delete-installation.ts","../../src/interfaces/internal-message-payload.ts","../../src/helpers/array-base64-translator.ts","../../src/helpers/migrate-old-database.ts","../../src/core/api.ts","../../src/core/token-management.ts","../../src/helpers/is-console-message.ts","../../src/helpers/sleep.ts","../../src/controllers/sw-controller.ts","../../src/helpers/externalizePayload.ts","../../src/controllers/window-controller.ts","../../src/implementation/constants.ts","../../src/implementation/error.ts","../../src/implementation/string.ts","../../src/implementation/taskenums.ts","../../src/implementation/xhrio.ts","../../src/implementation/xhrio_network.ts","../../src/implementation/xhriopool.ts","../../src/implementation/type.ts","../../src/implementation/fs.ts","../../src/implementation/blob.ts","../../src/implementation/location.ts","../../src/implementation/json.ts","../../src/implementation/path.ts","../../src/implementation/url.ts","../../src/implementation/metadata.ts","../../src/implementation/list.ts","../../src/implementation/requestinfo.ts","../../src/implementation/requests.ts","../../src/implementation/observer.ts","../../src/implementation/async.ts","../../src/task.ts","../../src/reference.ts","../../compat/tasksnapshot.ts","../../compat/task.ts","../../compat/list.ts","../../compat/reference.ts","../../src/implementation/failrequest.ts","../../src/implementation/request.ts","../../src/implementation/backoff.ts","../../src/service.ts","../../compat/service.ts","../../compat/index.ts","../../src/services/api_service.ts","../../src/utils/errors.ts","../../src/utils/console_logger.ts","../../src/services/settings_service.ts","../../src/utils/string_merger.ts","../../src/services/iid_service.ts","../../src/utils/attributes_utils.ts","../../src/services/remote_config_service.ts","../../src/services/initialization_service.ts","../../src/services/transport_service.ts","../../src/services/perf_logger.ts","../../src/utils/metric_utils.ts","../../src/resources/trace.ts","../../src/resources/network_request.ts","../../src/services/oob_resources_service.ts","../../src/controllers/perf.ts","../../src/helpers.ts","../../src/get-config.ts","../../src/initialize-ids.ts","../../src/factory.ts","../../src/functions.ts","../../src/client/caching_client.ts","../../src/client/rest_client.ts","../../src/language.ts","../../src/client/remote_config_fetch_client.ts","../../src/value.ts","../../src/remote_config.ts","../../src/storage/storage.ts","../../src/storage/storage_cache.ts","../../src/client/retrying_client.ts","../../app/index.ts","../node_modules/react-toast-notifications/dist/ToastElement.js","../node_modules/react-toast-notifications/dist/utils.js","../node_modules/process/browser.js","../node_modules/dom-helpers/esm/removeClass.js","../node_modules/react-transition-group/esm/config.js","../node_modules/react-transition-group/esm/TransitionGroupContext.js","../node_modules/react-transition-group/esm/Transition.js","../node_modules/react-transition-group/esm/CSSTransition.js","../node_modules/dom-helpers/esm/addClass.js","../node_modules/dom-helpers/esm/hasClass.js","../node_modules/react-transition-group/esm/utils/ChildMapping.js","../node_modules/react-transition-group/esm/TransitionGroup.js","../node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../node_modules/react-transition-group/esm/ReplaceTransition.js","../node_modules/react-transition-group/esm/SwitchTransition.js","../node_modules/mini-create-react-context/dist/esm/index.js","../node_modules/react-router/node_modules/path-to-regexp/index.js","../node_modules/react-toast-notifications/dist/ToastContainer.js","../node_modules/axios/lib/helpers/bind.js","../node_modules/axios/lib/helpers/buildURL.js","../node_modules/axios/lib/cancel/isCancel.js","../node_modules/axios/lib/defaults.js","../node_modules/axios/lib/adapters/xhr.js","../node_modules/axios/lib/core/createError.js","../node_modules/axios/lib/core/mergeConfig.js","../node_modules/axios/lib/cancel/Cancel.js","../node_modules/react-is/index.js","../node_modules/@emotion/sheet/dist/sheet.browser.esm.js","../node_modules/@emotion/stylis/dist/stylis.browser.esm.js","../node_modules/@emotion/cache/dist/cache.browser.esm.js","../node_modules/@emotion/utils/dist/utils.browser.esm.js","../node_modules/@emotion/hash/dist/hash.browser.esm.js","../node_modules/@emotion/unitless/dist/unitless.browser.esm.js","../node_modules/@emotion/memoize/dist/memoize.browser.esm.js","../node_modules/@emotion/serialize/dist/serialize.browser.esm.js","../node_modules/@emotion/core/dist/emotion-element-57a3a7a3.browser.esm.js","../node_modules/@emotion/css/dist/css.browser.esm.js","../node_modules/@emotion/core/dist/core.browser.esm.js","../node_modules/querystring-es3/index.js","../node_modules/axios-auth-refresh/dist/index.min.js","../node_modules/announcekit-react/dist/index.js","../node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../node_modules/query-string/index.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js","../node_modules/babel-preset-react-app/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/react/cjs/react-jsx-runtime.production.min.js","../node_modules/react/cjs/react.production.min.js","../node_modules/@babel/runtime/helpers/inheritsLoose.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/react-dom/cjs/react-dom.production.min.js","../node_modules/scheduler/index.js","../node_modules/scheduler/cjs/scheduler.production.min.js","../node_modules/react-toast-notifications/dist/icons.js","../node_modules/react-toast-notifications/dist/colors.js","../node_modules/react-toast-notifications/dist/ToastProvider.js","../node_modules/react-toast-notifications/dist/ToastController.js","../node_modules/regenerator-runtime/runtime.js","../node_modules/webpack/buildin/module.js","../node_modules/querystring-es3/decode.js","../node_modules/querystring-es3/encode.js","../node_modules/axios/lib/axios.js","../node_modules/axios/lib/core/Axios.js","../node_modules/axios/lib/core/InterceptorManager.js","../node_modules/axios/lib/core/dispatchRequest.js","../node_modules/axios/lib/core/transformData.js","../node_modules/axios/lib/helpers/normalizeHeaderName.js","../node_modules/axios/lib/core/settle.js","../node_modules/axios/lib/core/enhanceError.js","../node_modules/axios/lib/helpers/cookies.js","../node_modules/axios/lib/core/buildFullPath.js","../node_modules/axios/lib/helpers/isAbsoluteURL.js","../node_modules/axios/lib/helpers/combineURLs.js","../node_modules/axios/lib/helpers/parseHeaders.js","../node_modules/axios/lib/helpers/isURLSameOrigin.js","../node_modules/axios/lib/cancel/CancelToken.js","../node_modules/axios/lib/helpers/spread.js","../node_modules/axios/lib/helpers/isAxiosError.js","../node_modules/@firebase/auth/dist/auth.esm.js","../../src/core/storage/DOMStorageWrapper.ts","../../src/core/storage/MemoryStorage.ts","../../src/core/storage/storage.ts","../../src/core/util/util.ts","../../src/core/util/Path.ts","../../src/realtime/Constants.ts","../../src/core/RepoInfo.ts","../../src/core/util/libs/parser.ts","../../src/core/snap/snap.ts","../../src/core/util/validation.ts","../../src/core/snap/LeafNode.ts","../../src/core/snap/indexes/PriorityIndex.ts","../../src/core/util/SortedMap.ts","../../src/core/snap/Node.ts","../../src/core/snap/indexes/Index.ts","../../src/core/snap/indexes/KeyIndex.ts","../../src/core/snap/IndexMap.ts","../../src/core/snap/ChildrenNode.ts","../../src/core/snap/childSet.ts","../../src/core/snap/comparators.ts","../../src/core/snap/nodeFromJSON.ts","../../src/core/operation/Operation.ts","../../src/core/operation/AckUserWrite.ts","../../src/core/util/ImmutableTree.ts","../../src/core/operation/ListenComplete.ts","../../src/core/operation/Overwrite.ts","../../src/core/operation/Merge.ts","../../src/core/view/CacheNode.ts","../../src/core/view/ViewCache.ts","../../src/core/view/Change.ts","../../src/core/view/filter/IndexedFilter.ts","../../src/core/view/ChildChangeAccumulator.ts","../../src/core/view/CompleteChildSource.ts","../../src/core/view/ViewProcessor.ts","../../src/core/view/EventGenerator.ts","../../src/core/util/NextPushId.ts","../../src/core/snap/indexes/ValueIndex.ts","../../src/core/snap/indexes/PathIndex.ts","../../src/core/view/filter/RangedFilter.ts","../../src/core/view/filter/LimitedFilter.ts","../../src/core/view/QueryParams.ts","../../src/core/view/View.ts","../../src/core/SyncPoint.ts","../../src/core/CompoundWrite.ts","../../src/core/WriteTree.ts","../../src/core/SyncTree.ts","../../src/core/util/ServerValues.ts","../../src/core/SparseSnapshotTree.ts","../../src/core/SnapshotHolder.ts","../../src/core/stats/StatsCollection.ts","../../src/core/stats/StatsManager.ts","../../src/core/stats/StatsListener.ts","../../src/core/stats/StatsReporter.ts","../../src/core/view/EventQueue.ts","../../src/core/util/EventEmitter.ts","../../src/core/util/VisibilityMonitor.ts","../../src/core/util/OnlineMonitor.ts","../../src/realtime/polling/PacketReceiver.ts","../../src/realtime/BrowserPollConnection.ts","../../src/core/version.ts","../../src/realtime/WebSocketConnection.ts","../../src/realtime/TransportManager.ts","../../src/realtime/Connection.ts","../../src/core/ServerActions.ts","../../src/core/PersistentConnection.ts","../../src/core/ReadonlyRestClient.ts","../../src/api/DataSnapshot.ts","../../src/core/util/Tree.ts","../../src/core/Repo.ts","../../src/api/Query.ts","../../src/api/onDisconnect.ts","../../src/api/TransactionResult.ts","../../src/core/view/Event.ts","../../src/core/view/EventRegistration.ts","../../src/api/Reference.ts","../../src/core/AuthTokenProvider.ts","../../src/core/RepoManager.ts","../../src/api/Database.ts","../../src/api/internal.ts","../../src/api/test_access.ts","../node_modules/webpack/buildin/harmony-module.js","../node_modules/react-fast-compare/index.js","../node_modules/react-router/node_modules/isarray/index.js","../node_modules/react-is/cjs/react-is.production.min.js","../node_modules/strict-uri-encode/index.js"],"names":["module","exports","require","extendStatics","d","b","Object","setPrototypeOf","__proto__","Array","p","prototype","hasOwnProperty","call","__extends","TypeError","String","__","this","constructor","create","__assign","assign","t","s","i","n","arguments","length","apply","__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","__generator","body","f","y","g","_","label","sent","trys","ops","verb","Symbol","iterator","v","op","pop","push","__values","o","m","__read","r","ar","error","__spreadArray","to","from","il","j","assert","assertion","message","assertionError","Error","CONSTANTS","stringToByteArray","str","out","c","charCodeAt","base64","byteToCharMap_","charToByteMap_","byteToCharMapWebSafe_","charToByteMapWebSafe_","ENCODED_VALS_BASE","HAS_NATIVE_SUPPORT","atob","encodeByteArray","input","webSafe","isArray","init_","byteToCharMap","output","byte1","haveByte2","byte2","haveByte3","byte3","outByte1","outByte2","outByte3","outByte4","join","encodeString","btoa","decodeString","bytes","pos","c1","fromCharCode","c2","u","c3","byteArrayToString","decodeStringToByteArray","charToByteMap","charAt","byte4","ENCODED_VALS","ENCODED_VALS_WEBSAFE","base64Encode","utf8Bytes","base64Decode","console","deepCopy","deepExtend","undefined","target","source","Date","getTime","prop","promise","wrapCallback","callback","catch","getUA","navigator","isMobileCordova","window","test","isNode","toString","global","process","isBrowser","self","isBrowserExtension","runtime","chrome","browser","id","isReactNative","isElectron","indexOf","isIE","ua","isUWP","isNodeSdk","isIndexedDBAvailable","indexedDB","validateIndexedDBOpenable","open","onsuccess","close","deleteDatabase","onupgradeneeded","onerror","areCookiesEnabled","cookieEnabled","jsonEval","JSON","parse","stringify","data","decode","token","header","claims","signature","parts","split","isValidFormat","isAdmin","contains","obj","key","safeGet","isEmpty","map","fn","contextObj","res","querystring","querystringParams","params","forEach","arrayVal","encodeURIComponent","entries","chain_","buf_","W_","pad_","inbuf_","total_","blockSize","reset","compress_","buf","offset","W","k","a","update","lengthMinusBlock","inbuf","digest","totalBits","createSubscribe","executor","onNoObservers","proxy","ObserverProxy","subscribe","bind","observers","unsubscribes","observerCount","task","finalized","forEachObserver","observer","complete","nextOrObserver","methods","method","implementsAnyMethods","noop","unsub","unsubscribeOne","finalError","sendOne","err","validateArgCount","fnName","minCount","maxCount","argCount","argError","errorPrefix","argumentNumber","optional","argName","validateCallback","validateContextObject","context","high","stringLength","calculateBackoffMillis","backoffCount","intervalMillis","backoffFactor","currBaseValue","Math","pow","randomWait","round","random","min","_defineProperty","defineProperty","enumerable","configurable","writable","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","_objectSpread2","getOwnPropertyDescriptors","defineProperties","asyncGeneratorStep","gen","_next","_throw","arg","info","_asyncToGenerator","args","_a","appName","logger","options","config","firebase_","isDeleted_","name_","name","automaticDataCollectionEnabled_","automaticDataCollectionEnabled","options_","container","_addComponent","INTERNAL","components","component","checkDestroyed_","val","delete","removeApp","all","getProviders","provider","_getService","instanceIdentifier","getProvider","getImmediate","identifier","_removeServiceInstance","clearInstance","addComponent","debug","_addOrOverwriteComponent","addOrOverwriteComponent","toJSON","ERROR_FACTORY","FirebaseAppImpl","log","firebase","createFirebaseNamespace","namespace","firebaseAppImpl","apps","Map","__esModule","initializeApp","rawConfig","DEFAULT_ENTRY_NAME","app","registerVersion","libraryKeyOrName","version","variant","library","PLATFORM_LOG_STRING","libraryMismatch","match","versionMismatch","warning","warn","registerComponent","setLogLevel","onLog","logCallback","SDK_VERSION","useAsService","componentName","has","type","set","serviceNamespace","appArg","serviceProps","multipleInstances","get","createFirebaseNamespaceCore","extendNamespace","props","ErrorFactory","getPlatformInfoString","getComponent","isVersionServiceProvider","service","logString","firebaseNamespace","PlatformLoggerService","instanceFactory","instantiationMode","setInstantiationMode","mode","setMultipleInstances","setServiceProps","instances","instancesDeferred","normalizedIdentifier","normalizeInstanceIdentifier","deferred","instance","getOrInitializeService","setComponent","isComponentEager","instanceDeferred","services","values","_delete","isComponentSet","isInitialized","normalizeIdentifierForFactory","providers","Provider","_inheritsLoose","subClass","superClass","BrowserRouter","history","createHistory","render","children","React","Component","resolveToLocation","currentLocation","normalizeToLocation","createLocation","forwardRefShim","C","forwardRef","LinkAnchor","innerRef","navigate","onClick","rest","event","ex","isModifiedEvent","forwardedRef","Link","replace","RouterContext","location","href","NavLink","ariaCurrent","activeClassName","activeStyle","classNameProp","className","exact","isActiveProp","isActive","locationProp","sensitive","strict","styleProp","style","toLocation","path","escapedPath","matchPath","classnames","joinClassnames","persistenceKey","host","ssl","forceLongPolling","I","projectId","database","isEqual","E","T","logLevel","N","DEBUG","S","A","ERROR","D","WARN","x","O","crypto","msCrypto","Uint8Array","getRandomValues","floor","V","L","every","R","U","h","fromBase64String","fromUint8Array","toBase64","toUint8Array","l","M","OK","CANCELLED","UNKNOWN","INVALID_ARGUMENT","DEADLINE_EXCEEDED","NOT_FOUND","ALREADY_EXISTS","PERMISSION_DENIED","UNAUTHENTICATED","RESOURCE_EXHAUSTED","FAILED_PRECONDITION","ABORTED","OUT_OF_RANGE","UNIMPLEMENTED","UNAVAILABLE","DATA_LOSS","q","code","F","uid","z","user","Authorization","G","getToken","B","currentUser","forceRefresh","$","auth","addAuthTokenListener","accessToken","removeAuthTokenListener","getUid","Q","getAuthHeaderValueForFirstParty","Y","H","previousValue","max","K","seconds","nanoseconds","now","fromMillis","fromDate","toDate","toMillis","valueOf","padStart","X","timestamp","segments","child","slice","limit","J","Z","tt","et","nt","st","it","rt","ot","ct","at","ut","ht","lt","_t","ft","dt","wt","Et","fields","sort","Tt","RegExp","exec","substr","Number","nanos","mapValue","__type__","stringValue","__previous_value__","__local_write_time__","timestampValue","pt","isInteger","MAX_SAFE_INTEGER","MIN_SAFE_INTEGER","vt","yt","booleanValue","bytesValue","referenceValue","geoPointValue","latitude","longitude","integerValue","doubleValue","isNaN","arrayValue","mt","find","gt","bt","It","Nt","At","Dt","St","proto","empty","field","xt","Rt","Pt","kt","Ot","Vt","hasCommittedMutations","Ct","Lt","collectionGroup","orderBy","filters","startAt","endAt","Ut","dir","Wt","Mt","Jt","te","qt","Ft","jt","Qt","Yt","Ht","Kt","zt","Gt","matches","Bt","some","nullValue","Xt","position","before","Zt","$t","ee","limitType","ne","re","ie","oe","ue","se","ae","ce","he","fe","le","pe","de","ve","ye","me","ge","targetId","sequenceNumber","lastLimboFreeSnapshotVersion","resumeToken","we","be","_e","Ie","Ee","Ae","De","Se","xe","ke","Ne","Pe","Te","Oe","elements","Ve","Ce","transform","Le","transformResults","Re","updateTime","exists","Ue","Me","qe","Be","He","fieldTransforms","Xe","Qe","Ye","Fe","Ke","Ge","je","ze","We","Ze","Je","$e","tn","count","en","nn","rn","root","un","EMPTY","copy","remove","left","right","size","on","color","RED","sn","first","last","an","add","cn","hn","ln","pn","dn","vn","yn","mn","gn","wn","bn","_n","track","doc","In","query","docs","docChanges","fromCache","En","Tn","Nn","removedTargetIds","An","Dn","state","targetIds","cause","Sn","On","xn","kn","removeTarget","Rn","Pn","Vn","asc","desc","in","Cn","Ln","toISOString","Un","Mn","qn","Fn","hr","jn","zn","Yn","Gn","Bn","Qn","Hn","Kn","Xn","updateMask","cr","verify","updateTransforms","fieldPath","setToServerValue","appendMissingElements","removeAllFromArray","increment","currentDocument","Wn","fieldPaths","Zn","documents","Jn","structuredQuery","parent","collectionId","allDescendants","unaryFilter","or","fieldFilter","ir","compositeFilter","where","direction","rr","er","$n","tr","ur","nr","sr","reduce","concat","NaN","fr","lr","pr","action","transaction","aborted","oncomplete","onabort","yr","_r","abort","store","objectStore","gr","dr","wr","w","db","onblocked","oldVersion","onversionchange","runTransaction","vr","ts","es","ss","mr","put","rs","cursor","os","cs","us","hs","ls","primaryKey","continue","ns","index","range","reverse","openKeyCursor","openCursor","br","setTimeout","Ir","_s","fs","ds","ws","Es","Ts","start","Is","As","Rs","cancel","clearTimeout","Ps","Er","Tr","Nr","ys","gs","Vs","Ar","Sr","Dr","xr","substring","kr","Or","ownerId","allowTabSynchronization","leaseTimestampMs","Pr","userId","lastAcknowledgedBatchId","lastStreamToken","keyPath","Vr","batchId","localWriteTimeMs","baseMutations","mutations","userMutationsIndex","userMutationsKeyPath","Cr","prefixForUser","prefixForPath","PLACEHOLDER","Lr","readTime","Rr","Ur","unknownDocument","noDocument","document","parentPath","readTimeIndex","readTimeIndexPath","collectionReadTimeIndex","collectionReadTimeIndexPath","Mr","byteSize","qr","canonicalId","lastListenSequenceNumber","queryTargetsIndexName","queryTargetsKeyPath","Fr","documentTargetsIndex","documentTargetsKeyPath","jr","highestTargetId","highestListenSequenceNumber","lastRemoteSnapshotVersion","targetCount","zr","Gr","clientId","updateTimeMs","networkEnabled","inForeground","Br","bundleId","createTime","Qr","bundledQuery","Yr","Hr","ps","bs","Kr","Xr","vs","Ss","Ds","Cs","xs","Wr","batch","Ns","$s","Zr","Fs","Jr","ri","$r","ti","ni","ei","ii","splice","oi","ui","si","ai","Os","ci","ks","Ms","hi","Ls","fi","Bs","li","qs","Us","getEntries","pi","Qs","di","IDBKeyRange","bound","vi","Ks","Ws","js","Gs","yi","zs","Hs","Js","Ys","Xs","Zs","mi","gi","wi","_i","bi","only","Ii","Ei","Ti","Ai","NEGATIVE_INFINITY","POSITIVE_INFINITY","Ri","Ni","Pi","lowerBound","Vi","upperBound","Si","Di","Ci","xi","$i","Fi","Oi","ki","Mi","Li","Bi","qi","Ui","Qi","Ki","Wi","ji","Gi","zi","Hi","Ji","Yi","Xi","Zi","buffer","stop","maxValue","updateMetadata","getMetadata","createObjectStore","autoIncrement","createIndex","unique","deleteObjectStore","objectStoreNames","eo","no","so","io","isPrimary","ro","oo","co","ao","uo","ho","lo","_o","fo","wo","localStorage","Eo","To","Io","mo","Ao","Ro","Po","newVersion","yo","Vo","po","bo","vo","So","Do","Co","xo","No","$o","removeItem","Fo","Oo","ko","Mo","Lo","Bo","qo","Uo","Qo","Ko","Wo","jo","addEventListener","visibilityState","removeEventListener","getItem","setItem","progress","Go","zo","Ho","Jo","Yo","Xo","Zo","tc","ec","nc","sc","ic","rc","oc","cc","ac","uc","hc","lc","hasPendingWrites","persistence","_c","fc","dc","wc","Ec","Tc","Ic","mc","Ac","Rc","Pc","metadata","yc","gc","Vc","bc","go","vc","Sc","Dc","Cc","xc","Nc","$c","Fc","Oc","kc","Mc","Lc","Bc","qc","Uc","Qc","Kc","shift","Wc","jc","Gc","zc","Hc","Jc","Yc","Xc","Zc","ta","ea","na","sa","ia","ra","Set","oa","ca","aa","activeTargetIds","onlineState","ha","la","fa","da","wa","Ea","Ta","storage","Ia","ma","Aa","Ra","Pa","ya","ga","Va","pa","ba","va","Sa","Da","Ca","xa","Na","$a","Fa","Oa","ka","Ma","La","Ba","qa","Ua","Qa","Ka","Wa","ja","storageArea","newValue","Ga","za","Ha","Ja","Ya","Xa","Za","tu","eu","nu","su","iu","ru","ou","cu","au","uu","hu","lu","_u","BatchGetDocuments","Commit","RunQuery","fu","du","wu","Eu","Tu","Iu","onMessage","mu","send","Au","Ru","Pu","Su","listenOnce","COMPLETE","getLastErrorCode","NO_ERROR","getResponseJson","TIMEOUT","HTTP_ERROR","getStatus","getResponseText","status","toLowerCase","Cu","gu","httpSessionIdParam","initMessageHeaders","messageUrlParams","sendRawJson","supportsCrossDomainXhr","internalChannelParams","forwardChannelRequestTimeoutMs","detectBufferingProxy","vu","httpHeadersOverwriteParam","createWebChannel","listen","EventType","OPEN","CLOSE","MESSAGE","STAT_EVENT","stat","PROXY","NOPROXY","yu","Vu","pu","bu","Du","xu","Nu","$u","Fu","Ou","ku","Mu","Lu","Bu","qu","Uu","Qu","Ku","listener","Wu","ju","stream","Gu","zu","Hu","Ju","Yu","Xu","Zu","th","eh","nh","sh","ih","rh","oh","targetChange","targetChangeType","documentChange","documentDelete","documentRemove","ah","uh","addTarget","labels","hh","lh","fh","streamToken","writeResults","commitTime","dh","wh","Eh","writes","credentials","Th","Ih","terminate","mh","Ah","Rh","Ph","yh","gh","Vh","ph","bh","Sh","Dh","Ch","xh","Nh","$h","Fh","Oh","kh","Mh","Lh","_h","Bh","qh","Uh","Qh","Kh","listeners","queries","Wh","jh","onError","Gh","zh","Hh","Jh","Yh","Xh","includeMetadataChanges","Zh","tl","el","nl","payload","byteLength","sl","rl","bytesLoaded","documentsLoaded","namedQuery","documentMetadata","ol","taskState","totalDocuments","totalBytes","cl","al","ul","hl","ll","fl","dl","wl","El","Tl","snapshot","Il","ml","Al","Rl","view","Pl","yl","gl","Vl","pl","bl","vl","Sl","Dl","Cl","xl","Nl","$l","Fl","Ol","kl","Ml","Ll","ms","is","Bl","clear","_l","as","ql","Ul","Ql","Kl","synchronizeTabs","initialize","Wl","jl","Gl","zl","Hl","Jl","Yl","cacheSizeBytes","forceOwnership","Xl","Zl","t_","e_","n_","read","releaseLock","closed","muted","s_","i_","r_","o_","TextDecoder","c_","a_","u_","h_","l_","findIndex","f_","_methodName","d_","merge","mergeFields","ignoreUndefinedProperties","experimentalForceLongPolling","experimentalAutoDetectLongPolling","w_","E_","T_","I_","m_","A_","y_","g_","client","sessionIndex","V_","p_","b_","settings","v_","S_","firestore","withConverter","C_","D_","isFinite","x_","N_","F_","O_","k_","M_","L_","B_","q_","U_","Q_","K_","methodName","j_","G_","z_","H_","J_","getPrototypeOf","search","Y_","X_","Z_","tf","ef","nf","found","missing","sf","write","rf","commit","updateFunction","cf","run","af","uf","hf","lf","_f","getConfiguration","ff","df","wf","Ef","Tf","If","mf","Af","Rf","Pf","yf","gf","Vf","pf","bf","vf","enqueue","Sf","Df","Cf","stack","includes","xf","Nf","$f","Ff","Of","kf","Mf","Lf","onProgress","Bf","qf","DOMException","R_","P_","Uf","Qf","Kf","Wf","jf","Gf","zf","Hf","Jf","Yf","Xf","Zf","fromFirestore","td","ed","nd","sd","rd","od","ad","ud","hd","toFirestore","ld","serverTimestamps","_d","fd","dd","oldIndex","newIndex","pc","wd","Ed","Td","Id","md","Ad","enableIndexedDbPersistence","enableMultiTabIndexedDbPersistence","clearIndexedDbPersistence","Rd","Pd","useEmulator","enableNetwork","disableNetwork","enablePersistence","experimentalForceOwningTab","clearPersistence","waitForPendingWrites","onSnapshotsInSync","collection","loadBundle","yd","gd","Vd","WeakMap","pd","onSnapshot","ref","limitToLast","startAfter","endBefore","documentId","serverTimestamp","arrayUnion","arrayRemove","ArrayBuffer","ReadableStream","getReader","TextEncoder","encode","_extends","historyContext","createContext","createNamedContext","Router","computeRootMatch","url","isExact","pathname","componentDidMount","_pendingLocation","componentWillUnmount","unlisten","staticContext","HistoryContext","Lifecycle","onMount","componentDidUpdate","onUpdate","prevProps","onUnmount","cache","cacheCount","generatePath","pathToRegexp","compilePath","pretty","Redirect","computedMatch","prevLocation","locationsAreEqual","matched","cacheKey","pathCache","regexp","end","memo","Route","addLeadingSlash","stripBasename","basename","base","createURL","createPath","staticHandler","invariant","Switch","element","withRouter","displayName","wrappedComponentRef","remainingProps","hoistStatics","useContext","useHistory","useLocation","_slicedToArray","arr","_arr","unsupportedIterableToArray","commonjsGlobal","globalThis","goog","unshift","Function","Kb","trim","userAgent","documentMode","parseFloat","parseInt","defaultPrevented","relatedTarget","button","screenY","screenX","clientY","clientX","metaKey","shiftKey","altKey","ctrlKey","pointerId","pointerType","changedTouches","srcElement","nodeName","fromElement","toElement","pageX","pageY","2","3","4","preventDefault","returnValue","keyCode","src","capture","ab","cb","bb","eb","gb","once","hb","ib","jb","kb","nb","lb","attachEvent","mb","addListener","removeListener","ob","pb","detachEvent","qb","sb","handleEvent","tb","ub","vb","Cb","xb","class_1","wb","yb","zb","Ab","Bb","Fb","Db","Eb","Gb","Hb","Ib","Jb","_super","_this","Lb","Mb","Nb","Ob","Rb","Tb","Ub","Vb","Wb","Xb","Yb","rb","Zb","fb","$b","Pb","getResponseHeader","Qb","Sb","abs","decodeURI","decodeURIComponent","encodeURI","PerformanceNavigationTiming","performance","getEntriesByType","nextHopProtocol","jd","kd","e_2","_b","e_2_1","return","onload","ontimeout","e_1","e_1_1","qd","headers","xd","zd","protocol","statusText","vd","onreadystatechange","readyState","Bd","Cd","Dd","concurrentRequestLimit","fastHandshake","Fd","sendBeacon","Image","Gd","Hd","Ld","Kd","Jd","Md","bd","cd","hostname","port","Nd","Od","messageHeaders","clientProtocolHeaderRequired","messageContentType","__sm__","Qd","toUpperCase","XMLHttpRequest","FormData","setRequestHeader","responseType","withCredentials","timeout","responseText","__data__","getLastError","createWebChannelTransport","getStatEventTarget","ErrorCode","Event","Stat","WebChannel","XhrIo","_objectWithoutPropertiesLoose","excluded","sourceKeys","isUndefined","isObject","isPlainObject","isFunction","isArrayBuffer","isBuffer","isFormData","isArrayBufferView","isView","isString","isNumber","isDate","isFile","isBlob","isStream","pipe","isURLSearchParams","URLSearchParams","isStandardBrowserEnv","product","assignValue","extend","stripBOM","content","checkDCE","__REACT_DEVTOOLS_GLOBAL_HOOK__","prefix","condition","_ToastContainer","ToastContainer","_ToastElement","DefaultToast","_ToastProvider","ToastConsumer","ToastProvider","withToastManager","useToasts","_taggedTemplateLiteral","strings","raw","freeze","isAbsolute","spliceOne","list","resolvePathname","hasTrailingSlash","toParts","fromParts","isToAbs","isFromAbs","mustEndAbs","up","part","valueEqual","item","aValue","bValue","stripLeadingSlash","hasBasename","stripTrailingSlash","hash","hashIndex","searchIndex","parsePath","URIError","createTransitionManager","prompt","setPrompt","nextPrompt","confirmTransitionTo","getUserConfirmation","appendListener","notifyListeners","_len","_key","canUseDOM","createElement","getConfirmation","confirm","PopStateEvent","HashChangeEvent","getHistoryState","createBrowserHistory","globalHistory","canUseHistory","supportsHistory","needsHashChangeListener","_props","_props$forceRefresh","_props$getUserConfirm","_props$keyLength","keyLength","getDOMLocation","historyState","_ref","_window$location","createKey","transitionManager","setState","nextState","handlePopState","isExtraneousPopstateEvent","handlePop","handleHashChange","forceNextPop","ok","fromLocation","toIndex","allKeys","fromIndex","delta","revertPop","initialLocation","createHref","listenerCount","checkDOMListeners","isBlocked","pushState","prevIndex","nextKeys","replaceState","goBack","goForward","block","unblock","HashChangeEvent$1","HashPathCoders","hashbang","encodePath","decodePath","noslash","slash","stripHash","getHashPath","replaceHashPath","createHashHistory","_props$hashType","hashType","_HashPathCoders$hashT","ignorePath","encodedPath","allPaths","lastIndexOf","baseTag","querySelector","getAttribute","pushHashPath","nextPaths","clamp","createMemoryHistory","_props$initialEntries","initialEntries","_props$initialIndex","initialIndex","entry","nextIndex","nextEntries","canGo","toArray","promisifyRequest","request","promisifyRequestCall","promisifyCursorRequestCall","Cursor","proxyProperties","ProxyClass","targetProp","properties","proxyRequestMethods","Constructor","proxyMethods","proxyCursorRequestMethods","Index","_index","_cursor","_request","ObjectStore","_store","Transaction","idbTransaction","_tx","UpgradeDB","_db","DB","openDb","upgradeCallback","deleteDb","IDBIndex","IDBCursor","IDBObjectStore","IDBTransaction","IDBDatabase","funcName","nativeObject","getAll","items","iterateCursor","factory","_toConsumableArray","arrayLikeToArray","iter","isDataUrl","clonedNode","css","svg","_arrayLikeToArray","len","arr2","FUNC_ERROR_TEXT","HASH_UNDEFINED","WRAP_CURRY_RIGHT_FLAG","WRAP_PARTIAL_FLAG","WRAP_PARTIAL_RIGHT_FLAG","WRAP_ARY_FLAG","WRAP_REARG_FLAG","INFINITY","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","reTrim","reTrimStart","reTrimEnd","reWrapComment","reWrapDetails","reSplitDetails","reAsciiWord","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","freeSelf","freeExports","nodeType","freeModule","moduleExports","freeProcess","nodeUtil","types","binding","nodeIsArrayBuffer","nodeIsDate","nodeIsMap","isMap","nodeIsRegExp","isRegExp","nodeIsSet","isSet","nodeIsTypedArray","isTypedArray","func","arrayAggregator","array","setter","iteratee","accumulator","arrayEach","arrayEachRight","arrayEvery","predicate","arrayFilter","resIndex","arrayIncludes","baseIndexOf","arrayIncludesWith","comparator","arrayMap","arrayPush","arrayReduce","initAccum","arrayReduceRight","arraySome","asciiSize","baseProperty","baseFindKey","eachFunc","baseFindIndex","fromRight","strictIndexOf","baseIsNaN","baseIndexOfWith","baseMean","baseSum","basePropertyOf","baseReduce","current","baseTimes","baseUnary","baseValues","cacheHas","charsStartIndex","strSymbols","chrSymbols","charsEndIndex","countHolders","placeholder","deburrLetter","escapeHtmlChar","escapeStringChar","chr","hasUnicode","string","mapToArray","overArg","replaceHolders","setToArray","setToPairs","stringSize","lastIndex","unicodeSize","stringToArray","unicodeToArray","asciiToArray","unescapeHtmlChar","runInContext","defaults","pick","arrayProto","funcProto","objectProto","coreJsData","funcToString","idCounter","maskSrcKey","IE_PROTO","nativeObjectToString","objectCtorString","oldDash","reIsNative","Buffer","allocUnsafe","getPrototype","objectCreate","propertyIsEnumerable","spreadableSymbol","isConcatSpreadable","symIterator","symToStringTag","toStringTag","getNative","ctxClearTimeout","ctxNow","ctxSetTimeout","nativeCeil","ceil","nativeFloor","nativeGetSymbols","nativeIsBuffer","nativeIsFinite","nativeJoin","nativeKeys","nativeMax","nativeMin","nativeNow","nativeParseInt","nativeRandom","nativeReverse","DataView","nativeCreate","metaMap","realNames","dataViewCtorString","toSource","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","symbolProto","symbolValueOf","symbolToString","lodash","isObjectLike","LazyWrapper","LodashWrapper","wrapperClone","baseCreate","baseLodash","chainAll","__wrapped__","__actions__","__chain__","__index__","__values__","__dir__","__filtered__","__iteratees__","__takeCount__","__views__","Hash","ListCache","MapCache","SetCache","Stack","arrayLikeKeys","inherited","isArr","isArg","isArguments","isBuff","isType","skipIndexes","isIndex","arraySample","baseRandom","arraySampleSize","shuffleSelf","copyArray","baseClamp","arrayShuffle","assignMergeValue","eq","baseAssignValue","objValue","assocIndexOf","baseAggregator","baseEach","baseAssign","copyObject","baseAt","paths","skip","number","lower","upper","baseClone","bitmask","customizer","isDeep","isFlat","isFull","initCloneArray","tag","getTag","isFunc","cloneBuffer","initCloneObject","getSymbolsIn","copySymbolsIn","keysIn","baseAssignIn","getSymbols","copySymbols","Ctor","cloneArrayBuffer","dataView","byteOffset","cloneDataView","cloneTypedArray","cloneRegExp","symbol","initCloneByTag","stacked","subValue","getAllKeysIn","getAllKeys","baseConformsTo","baseDelay","wait","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","baseGet","castPath","toKey","baseGetAllKeys","keysFunc","symbolsFunc","baseGetTag","isOwn","unmasked","getRawTag","objectToString","baseGt","other","baseHas","baseHasIn","baseIntersection","arrays","othLength","othIndex","caches","maxLength","Infinity","seen","baseInvoke","baseIsArguments","baseIsEqual","equalFunc","objIsArr","othIsArr","objTag","othTag","objIsObj","othIsObj","isSameTag","equalArrays","convert","isPartial","equalByTag","objIsWrapped","othIsWrapped","objUnwrapped","othUnwrapped","objProps","objLength","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","isKey","isStrictComparable","hasIn","baseMerge","srcIndex","mergeFunc","isTyped","isArrayLikeObject","toPlainObject","baseMergeDeep","baseNth","baseOrderBy","iteratees","orders","getIteratee","comparer","baseSortBy","objCriteria","criteria","othCriteria","ordersLength","compareAscending","compareMultiple","basePickBy","baseSet","basePullAll","basePullAt","indexes","previous","baseUnset","baseRepeat","baseRest","setToString","overRest","baseSample","baseSampleSize","nested","baseSetData","baseSetToString","constant","baseShuffle","baseSlice","baseSome","baseSortedIndex","retHighest","low","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","stringToPath","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","trailing","createCompounder","words","deburr","createCtor","thisBinding","createFind","findIndexFunc","createFlow","flatRest","funcs","prereq","thru","wrapper","getFuncName","getData","isLaziable","plant","createHybrid","partialsRight","holdersRight","argPos","ary","arity","isAry","isBind","isBindKey","isFlip","getHolder","holdersCount","newHolders","createRecurry","reorder","createInverter","toIteratee","baseInverter","createMathOperation","operator","defaultValue","createOver","arrayFunc","createPadding","chars","charsLength","createRange","toFinite","baseRange","createRelationalOperation","toNumber","wrapFunc","isCurry","newData","setData","setWrapToString","createRound","precision","toInteger","pair","createToPairs","baseToPairs","createWrap","srcBitmask","newBitmask","isCombo","mergeData","createCurry","createPartial","createBind","customDefaultsAssignIn","customDefaultsMerge","customOmitClone","arrLength","arrValue","flatten","otherFunc","isKeyable","getValue","stubArray","hasPath","hasFunc","isLength","ctorString","isMaskable","stubFalse","otherArgs","oldArray","shortOut","reference","details","insertWrapDetails","updateWrapDetails","getWrapDetails","lastCalled","stamp","remaining","rand","memoize","memoizeCapped","quote","subString","clone","difference","differenceBy","differenceWith","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","bindKey","WRAP_BIND_FLAG","debounce","lastArgs","lastThis","maxWait","timerId","lastCallTime","lastInvokeTime","leading","maxing","invokeFunc","time","leadingEdge","timerExpired","shouldInvoke","timeSinceLastCall","trailingEdge","timeWaiting","remainingWait","debounced","isInvoking","flush","defer","delay","resolver","memoized","Cache","negate","overArgs","transforms","funcsLength","partial","partialRight","rearg","gte","isError","lte","iteratorToArray","remainder","toLength","isBinary","assignIn","assignInWith","assignWith","propsIndex","propsLength","defaultsDeep","mergeWith","invert","invertBy","invoke","omit","CLONE_DEEP_FLAG","basePick","pickBy","toPairs","toPairsIn","camelCase","word","capitalize","upperFirst","kebabCase","lowerCase","lowerFirst","snakeCase","startCase","upperCase","pattern","hasUnicodeWord","unicodeWords","asciiWords","attempt","bindAll","methodNames","flow","flowRight","methodOf","mixin","over","overEvery","overSome","basePropertyDeep","rangeRight","augend","addend","divide","dividend","divisor","multiply","multiplier","multiplicand","subtract","minuend","subtrahend","after","castArray","chunk","compact","cond","conforms","baseConforms","curry","curryRight","drop","dropRight","dropRightWhile","dropWhile","fill","baseFill","flatMap","flatMapDeep","flatMapDepth","flattenDeep","flattenDepth","flip","fromPairs","functions","functionsIn","initial","mapKeys","mapValues","matchesProperty","nthArg","omitBy","propertyOf","pullAllBy","pullAllWith","sampleSize","setWith","shuffle","sortedUniq","sortedUniqBy","separator","spread","tail","take","takeRight","takeRightWhile","takeWhile","tap","throttle","toPath","isArrLike","unary","uniq","uniqBy","uniqWith","unset","updateWith","valuesIn","wrap","zipObject","zipObjectDeep","entriesIn","extendWith","cloneDeep","cloneDeepWith","cloneWith","conformsTo","defaultTo","endsWith","escape","escapeRegExp","findKey","findLastKey","forIn","forInRight","forOwn","forOwnRight","inRange","baseInRange","isBoolean","isElement","isEqualWith","isMatch","isMatchWith","isNative","isNil","isNull","isSafeInteger","isWeakMap","isWeakSet","strictLastIndexOf","maxBy","mean","meanBy","minBy","stubObject","stubString","stubTrue","nth","noConflict","pad","strLength","padEnd","radix","floating","temp","reduceRight","repeat","sample","sortedIndex","sortedIndexBy","sortedIndexOf","sortedLastIndex","sortedLastIndexBy","sortedLastIndexOf","startsWith","sum","sumBy","template","isEscaping","isEvaluating","imports","importsKeys","importsValues","interpolate","reDelimiters","evaluate","sourceURL","escapeValue","interpolateValue","esTemplateValue","evaluateValue","variable","times","toLower","toSafeInteger","toUpper","trimEnd","trimStart","truncate","omission","newEnd","unescape","uniqueId","each","eachRight","VERSION","isFilter","takeName","dropName","checkIteratee","isTaker","lodashFunc","retUnwrapped","isLazy","useLazy","isHybrid","isUnwrapped","onlyLazy","chainName","isRight","getView","iterLength","takeCount","iterIndex","wrapped","define","propIsEnumerable","toObject","test1","getOwnPropertyNames","test2","test3","letter","shouldUseNative","_unsupportedIterableToArray","minLen","SVG","animate","backgroundColor","backgroundOpacity","baseUrl","foregroundColor","foregroundOpacity","gradientRatio","uniqueKey","interval","rtl","speed","title","fixedId","idClip","idGradient","idAria","rtlStyle","keyTimes","dur","React.createElement","role","width","height","clipPath","stopColor","stopOpacity","attributeName","repeatCount","defaultProps","ContentLoader","Svg","Facebook","ReactContentLoaderFacebook","viewBox","rx","cx","cy","firestoreNamespace","Firestore","GeoPoint","Timestamp","Blob","WriteBatch","DocumentReference","DocumentSnapshot","Query","QueryDocumentSnapshot","QuerySnapshot","CollectionReference","FieldPath","FieldValue","CACHE_SIZE_UNLIMITED","firestoreFactory","ExpFirebaseFirestore","IndexedDbPersistenceProvider","errorCodeMap","HttpsErrorImpl","authProvider","messagingProvider","messaging","getAuthToken","getInstanceIdToken","Notification","permission","getContext","authToken","instanceIdToken","json","app_","regionOrCustomDomain_","fetchImpl","serializer","Serializer","emulatorOrigin","deleteService","contextProvider","cancelAllRequests","URL","customDomain","origin","region","_url","useFunctionsEmulator","httpsCallable","postJSON","response","millis","timer","failAfter","failAfterPromise","race","clearTimeoutWrapper","bodyJSON","codeForHTTPStatus","description","errorJSON","_errorForResponse","responseData","namespaceExports","Functions","regionOrCustomDomain","getInstallationsEndpoint","INSTALLATIONS_API_URL","extractAuthTokenInfoFromResponse","requestStatus","expiresIn","responseExpiresIn","creationTime","getErrorFromResponse","requestName","responseJson","errorData","serverCode","serverMessage","serverStatus","getHeaders","apiKey","Headers","Accept","getHeadersWithAuth","appConfig","refreshToken","append","INTERNAL_AUTH_VERSION","getAuthorizationHeader","retryIfServerError","createInstallationRequest","fid","endpoint","authVersion","appId","sdkVersion","PACKAGE_VERSION","fetch","responseValue","registrationStatus","sleep","VALID_FID_PATTERN","generateFid","fidByteArray","getKey","fidChangeCallbacks","fidChanged","callFidChangeCallbacks","channel","getBroadcastChannel","postMessage","closeBroadcastChannel","broadcastFidChange","callbacks","broadcastChannel","BroadcastChannel","onmessage","OBJECT_STORE_NAME","dbPromise","getInstallationEntry","oldEntry","installationEntry","clearTimedOutRequest","updateOrCreateInstallationEntry","entryWithPromise","onLine","registrationPromise","inProgressEntry","registrationTime","registeredInstallationEntry","isServerError","customData","registerInstallation","waitUntilFidRegistration","triggerRegistrationIfNecessary","updateInstallationRequest","PENDING_TIMEOUT_MS","generateAuthTokenRequest","platformLoggerProvider","getGenerateAuthTokenEndpoint","platformLogger","installation","refreshAuthToken","dependencies","isEntryRegistered","oldAuthToken","TOKEN_EXPIRATION_BUFFER","isAuthTokenExpired","isAuthTokenValid","tokenPromise","updateAuthTokenRequest","waitUntilAuthTokenRequest","inProgressAuthToken","requestTime","makeAuthTokenRequestInProgressEntry","updatedInstallationEntry","fetchAuthTokenFromServer","completeInstallationRegistration","deleteInstallationRequest","getDeleteEndpoint","callbackSet","addCallback","removeCallback","MessageType","ERROR_MAP","DEFAULT_VAPID_KEY","CONSOLE_CAMPAIGN_ID","arrayToBase64","uint8Array","base64ToArray","base64String","rawData","outputArray","OLD_DB_NAME","OLD_OBJECT_STORE_NAME","migrateOldDatabase","senderId","databases","tokenDetails","oldDetails","p256dh","fcmToken","subscriptionOptions","swScope","vapidKey","checkTokenDetails","upgradeDb","dbGet","firebaseDependencies","oldTokenDetails","dbSet","tx","dbRemove","requestGetToken","getBody","subscribeOptions","getEndpoint","errorInfo","requestUpdateToken","updateOptions","requestDeleteToken","unsubscribeOptions","ENDPOINT","installations","web","applicationPubKey","swRegistration","getPushSubscription","pushSubscription","scope","getNewToken","dbOptions","currentOptions","isVapidKeyEqual","isEndpointEqual","isAuthEqual","isP256dhEqual","isTokenValid","updateToken","deleteToken","pushManager","getSubscription","unsubscribe","updatedToken","updatedTokenDetails","subscription","userVisibleOnly","applicationServerKey","isConsoleMessage","isOnBackgroundMessageUsed","bgMessageHandler","waitUntil","onPush","onSubChange","onNotificationClick","setBackgroundMessageHandler","onBackgroundMessage","registration","requestPermission","usePublicVapidKey","useServiceWorker","onTokenRefresh","internalPayload","getMessagePayloadInternal","getClientList","TAG","clientList","hasVisibleClients","sendMessagePayloadInternalToWindows","isNotificationShown","notification","showNotification","wrapInternalPayload","collapseKey","collapse_key","messagePayloadInternal","image","propagateNotificationPayload","propagateDataPayload","fcmOptions","link","analyticsLabel","analytics_label","propagateFcmOptions","externalizePayload","stopImmediatePropagation","click_action","getLink","originUrl","getWindowClient","clients","openWindow","focus","messageType","NOTIFICATION_CLICKED","isFirebaseMessaging","wrappedInternalPayload","clientUrl","PUSH_RECEIVED","matchAll","includeUncontrolled","notificationPayloadInternal","maxActions","onMessageCallback","serviceWorker","messageEventListener","stripInternalFields","dataPayload","logEvent","getVapidKey","getSwReg","updateVapidKey","updateSwReg","serviceWorkerRegistration","registerDefaultSw","ServiceWorkerRegistration","register","browserErrorMessage","permissionResult","eventType","getEventType","analyticsProvider","message_id","message_name","message_time","message_device_time","valueName","keyName","messagingSenderId","DEFAULT_HOST","prependCode","serverResponse","FirebaseStorageError","_codeEquals","unknown","cannotSliceBlob","invalidArgument","appDeleted","invalidRootOperation","invalidFormat","format","internalError","StringFormat","RAW","BASE64","BASE64URL","DATA_URL","contentType","dataFromString","stringData","StringData","utf8Bytes_","base64Bytes_","dataUrl","DataURLParts","decoded","percentEncodedBytes_","dataURLBytes_","hasMinus","hasUnder","hasPlus","hasSlash","dataURL","middle","TaskEvent","STATE_CHANGED","TaskState","RUNNING","PAUSED","SUCCESS","CANCELED","taskStateFromInternalTaskState","sent_","xhr_","errorCode_","sendPromise_","ABORT","NETWORK_ERROR","getErrorCode","addUploadProgressListener","upload","removeUploadProgressListener","createXhrIo","NetworkXhrIo","isNativeBlob","isNativeBlobDefined","validateNumber","argument","minValue","getBlobBuilder","BlobBuilder","WebKitBlobBuilder","getBlob","elideCopy","blobType","data_","size_","type_","startByte","endByte","sliced","blob","webkitSlice","mozSlice","sliceBlob","FbsBlob","blobby","uint8Arrays","uploadData","bucket","path_","fullServerUrl","bucketOnlyServerUrl","makeFromBucketSpec","bucketString","bucketLocation","Location","makeFromUrl","bucketDomain","gsRegex","httpModify","loc","firebaseStorageHost","groups","regex","indices","postModify","captures","bucketValue","pathValue","invalidUrl","jsonObjectOrNull","lastComponent","makeUrl","urlPart","makeQueryString","queryPart","noXform_","server","local","xform","mappings_","getMappings","mappings","Mapping","nameMapping","_metadata","fullPath","xformPath","sizeMapping","fromResource","resource","mapping","_makeStorageReference","addRef","fromResourceString","resourceString","toResourceString","fromResponseString","listResult","prefixes","nextPageToken","pathWithoutTrailingSlash","fromBackendResponse","handler","urlParams","errorHandler","progressCallback","successCodes","additionalRetryCodes","handlerCheck","cndn","metadataHandler","xhr","text","downloadUrlHandler","tokens","alt","downloadUrlFromResourceString","sharedErrorHandler","newErr","objectErrorHandler","shared","maxOperationRetryTime","requestInfo","RequestInfo","delimiter","pageToken","maxResults","isRoot","listHandler","metadataForUpload_","metadataClone","determineContentType_","total","checkResumeHeader_","allowed","RESUMABLE_UPLOAD_CHUNK_SIZE","continueResumableUpload","chunkSize","status_","ResumableUploadStatus","bytesLeft","bytesToUpload","maxUploadRetryTime","uploadStatus","newCurrent","argsToForward","_transferred","_needToFetchStatus","_needToFetchMetadata","_observers","_error","_uploadUrl","_chunkMultiplier","_resolve","_reject","_blob","_mappings","_resumable","_shouldDoResumable","_state","_errorHandler","completeTransitions_","_transition","_metadataErrorHandler","_promise","_start","_makeProgressCallback","sizeBefore","loaded","_updateProgress","_createResumable","_fetchStatus","_fetchMetadata","_continueUpload","_oneShotUpload","_resolveToken","_getAuthToken","metadataForUpload","createResumableUpload","_location","createRequest","_makeRequest","getPromise","sizeString","getResumableUploadStatus","statusRequest","uploadRequest","newStatus","_increaseMultiplier","metadataRequest","boundary","genBoundary","metadata_","preBlobPart","postBlobPart","multipartUpload","multipartRequest","transferred","old","_notifyObservers","wasPaused","externalState","bytesTransferred","completed","Observer","_addObserver","_removeObserver","onFulfilled","onRejected","_notifyObserver","_finishPromise","triggered","fbsAsync","resume","valid","pause","_service","_newRef","Reference","newPath","_throwIfRoot","listAll","listAllHelper","nextPage","requestsList","requestsUpdateMetadata","getDownloadURL","requestsGetDownloadUrl","deleteObject","_xhr","_text","requestsDeleteObject","_getChild","childPath","canonicalChildPath","_delegate","UploadTaskSnapshotCompat","wrappedNextOrObserver","taskSnapshot","ReferenceCompat","UploadTaskCompat","UploadTask","uploadBytesResumable","putString","ListResultCompat","requestsGetMetadata","promise_","_appDelete","errorCallback","pool","pendingXhr_","backoffId_","canceled_","appDelete_","url_","method_","headers_","body_","successCodes_","additionalRetryCodes_","callback_","errorCallback_","progressCallback_","timeout_","pool_","resolve_","reject_","start_","backoffDone","requestWentThrough","wasSuccessCode","canceled","RequestEndStatus","waitSeconds","timeoutId","hitTimeout","cancelState","triggeredCallback","triggerCallback","callWithDelay","success","waitMillis","stopped","wasTimeout","backoffCallback","progressListener","hitServer","isRetryStatusCode_","successCode","wasCanceled","progressEvent","lengthComputable","appDelete","isFiveHundredCode","isExtraRetryCode","isRequestSpecificRetryCode","isUrl","refFromPath","_bucket","serviceOrRef","pathOrUrl","_authProvider","_pool","_firebaseVersion","_appId","_deleted","_maxOperationRetryTime","_maxUploadRetryTime","_requests","extractBucket","tokenData","FailRequest","firebaseVersion","addGmpidHeader_","addAuthHeader_","addVersionHeader_","NetworkRequest","makeRequest","refFromURL","setMaxUploadRetryTime","setMaxOperationRetryTime","StorageServiceCompat","XhrIoPool","Storage","registerStorage","apiInstance","windowInstance","consoleLogger","INFO","settingsServiceInstance","PerformanceObserver","windowLocation","perfMetrics","onFirstInputDelay","getUrl","mark","measure","measureName","mark1","mark2","getEntriesByName","getTimeOrigin","timeOrigin","timing","navigationStart","requiredApisAvailable","setupObserver","entryType","observe","entryTypes","getInstance","Api","mergeStrings","part1","part2","sizeDiff","resultArray","iid","VisibilityState","instrumentationEnabled","dataCollectionEnabled","loggingEnabled","tracesSamplingRate","networkRequestsSamplingRate","logEndPointUrl","flTransportEndpointUrl","transportKey","logSource","logTraceAfterSampling","logNetworkAfterSampling","configTimeToLive","getAppId","firebaseAppInstance","getProjectId","getApiKey","getFlTransportFullUrl","SettingsService","getIid","RESERVED_ATTRIBUTE_PREFIXES","ATTRIBUTE_FORMAT_REGEX","getServiceWorkerStatus","controller","getVisibilityState","VISIBLE","HIDDEN","getEffectiveConnectionType","navigatorConnection","connection","effectiveType","REMOTE_CONFIG_SDK_VERSION","DEFAULT_CONFIGS","FIS_AUTH_PREFIX","getConfig","expiryString","CONFIG_EXPIRY_LOCAL_STORAGE_KEY","expiry","configStringified","CONFIG_LOCAL_STORAGE_KEY","getStoredConfig","processConfig","authTokenPromise","installationsService","authTokenVal","getAuthTokenPromise","configEndPoint","Request","app_instance_id","app_instance_id_token","app_id","app_version","sdk_version","COULD_NOT_GET_CONFIG_MSG","getRemoteConfig","storeConfig","fpr_enabled","fpr_log_source","fpr_log_endpoint_url","fpr_log_transport_key","fpr_vc_network_request_sampling_rate","fpr_vc_trace_sampling_rate","shouldLogAfterSampling","samplingRate","initializationStatus","getInitializationPromise","getDocumentReadyComplete","iidPromise","getId","iidVal","getIidPromise","changeInitializationStatus","DEFAULT_SEND_INTERVAL_MS","remainingTries","queue","isTransportSetup","processQueue","timeOffset","staged","log_event","evt","source_extension_json_proto3","event_time_ms","eventTime","flTransportFullUrl","postToFlEndpoint","transportWait","nextRequestWaitMillis","requestOffset","logResponseDetails","responseAction","sendEventsToFl","request_time_ms","client_info","client_type","js_client_info","log_source","dispatchQueueEvents","addToQueue","sendLog","resourceType","transportHandler","logTrace","trace","settingsService","isAuto","sendTraceLog","networkRequest","networkRequestMetric","http_method","httpMethod","http_response_code","response_payload_bytes","responsePayloadBytes","client_start_time_us","startTimeUs","time_to_response_initiated_us","timeToResponseInitiatedUs","time_to_response_completed_us","timeToResponseCompletedUs","perfMetric","application_info","getApplicationInfo","network_request_metric","serializeNetworkRequest","traceMetric","is_auto","duration_us","durationUs","counters","customAttributes","getAttributes","custom_attributes","trace_metric","serializeTrace","google_app_id","web_app_info","page_url","service_worker_status","visibility_state","effective_connection_type","application_process_state","oobMetrics","FIRST_CONTENTFUL_PAINT_COUNTER_NAME","FIRST_INPUT_DELAY_COUNTER_NAME","traceMeasureName","api","randomId","traceStartMark","TRACE_START_MARK_PREFIX","traceStopMark","TRACE_STOP_MARK_PREFIX","traceMeasure","TRACE_MEASURE_PREFIX","calculateTraceMetrics","traceName","record","startTime","duration","attributes","metrics","metric","incrementMetric","counter","numAsInteger","putMetric","OOB_TRACE_PAGE_LOAD_PREFIX","customMetricName","providedValue","valueAsInteger","convertMetricValueToInteger","getMetric","putAttribute","attr","isValidName","isValidValue","isValidCustomAttributeValue","attributeValue","removeAttribute","setStartTime","setDuration","perfMeasureEntries","perfMeasureEntry","createOobTrace","navigationTimings","paintTimings","firstInputDelay","route","Trace","timeOriginUs","domInteractive","domContentLoadedEventEnd","loadEventEnd","firstPaint","paintObject","firstContentfulPaint","createUserTimingTrace","createNetworkRequestEntry","performanceEntry","responseStart","responseEnd","networkRequestUrl","logEndpointUrl","flEndpointUrl","logNetworkRequest","transferSize","setupOobResources","setupOobTraces","resources","setupNetworkRequests","measures","setupUserTimingTraces","isAvailable","GtagCommand","EventName","GTAG_URL","gtagOnConfig","gtagCore","initializationPromisesMap","dynamicConfigPromisesList","measurementIdToAppId","measurementId","gtagParams","correspondingAppId","dynamicConfigResults","foundConfig","CONFIG","gtagOnEvent","initializationPromisesToWaitFor","gaSendToList","sendToId","initializationPromise","EVENT","wrapOrCreateGtag","dataLayerName","gtagFunctionName","command","idOrNameOrParams","SET","wrapGtag","wrappedGtag","defaultRetryData","throttleMetadata","getThrottleMetadata","setThrottleMetadata","deleteThrottleMetadata","fetchDynamicConfig","appFields","appUrl","errorMessage","jsonResponse","httpStatus","responseMessage","attemptFetchDynamicConfigWithRetry","signal","retryData","throttleEndTimeMillis","setAbortableTimeout","isRetriableError","backoffMillis","initializeIds","dynamicConfigPromise","timeoutMillis","AnalyticsAbortSignal","fetchDynamicConfigWithRetry","fidPromise","validateIndexedDB","envIsValid","dynamicConfig","scriptTags","getElementsByTagName","findGtagScriptOnPage","script","async","appendChild","insertScriptTag","configProperties","gtagCoreFunction","wrappedGtagFunction","gtagName","globalInitDone","mismatchedEnvMessages","warnOnBrowserContextMismatch","dataLayer","getOrCreateDataLayer","eventName","eventParams","gtagFunction","setCurrentScreen","screenName","setUserId","setUserProperties","flatProperties","setAnalyticsCollectionEnabled","enabled","storageCache","isCachedDataFresh","cacheMaxAgeMillis","lastSuccessfulFetchTimestampMillis","cacheAgeMillis","getLastSuccessfulFetchTimestampMillis","getLastSuccessfulFetchResponse","lastSuccessfulFetchResponse","eTag","storageOperations","setLastSuccessfulFetchTimestampMillis","setLastSuccessfulFetchResponse","firebaseInstallations","installationId","installationToken","urlBase","FIREBASE_REMOTE_CONFIG_URL_BASE","requestBody","language_code","navigatorLanguage","languages","language","fetchPromise","timeoutPromise","errorCode","originalErrorMessage","responseEtag","responseBody","BOOLEAN_TRUTHY_VALUES","_source","_value","asString","asBoolean","asNumber","num","getSource","_client","_storageCache","_storage","_logger","_isInitializationComplete","fetchTimeoutMillis","minimumFetchIntervalMillis","defaultConfig","FirebaseLogLevel","SILENT","getLastFetchStatus","activate","getActiveConfigEtag","activeConfigEtag","setActiveConfig","setActiveConfigEtag","ensureInitialized","_initializePromise","loadFromStorage","abortSignal","RemoteConfigAbortSignal","setLastFetchStatus","lastFetchStatus","hasErrorCode","fetchAndActivate","obj1","obj2","getActiveConfig","allConfigs","getBoolean","getNumber","getString","activeConfig","Value","toFirebaseError","originalError","APP_NAMESPACE_STORE","openDbPromise","etag","compositeKey","createCompositeKey","lastFetchStatusPromise","lastSuccessfulFetchTimestampMillisPromise","activeConfigPromise","timestampMillis","attemptFetch","packageName","shrinkKeyframes","toastWidth","gutter","borderRadius","sliceIterator","_templateObject","_react","_core","_icons","colors","newObj","default","_interopRequireWildcard","_utils","_objectWithoutProperties","keyframes","A11yText","Tag","jsx","border","clip","overflow","padding","whiteSpace","appearances","icon","CheckIcon","G500","fg","G300","bg","G50","FlameIcon","R500","R300","R50","AlertIcon","Y500","Y300","Y50","InfoIcon","N400","B200","Button","flexShrink","opacity","transition","Content","flexGrow","fontSize","lineHeight","minHeight","Countdown","_ref2","autoDismissTimeout","isRunning","animation","animationPlayState","bottom","Icon","_ref3","appearance","autoDismiss","meta","Glyph","borderTopLeftRadius","borderBottomLeftRadius","paddingBottom","paddingTop","textAlign","zIndex","getTranslate","placement","top","toastStates","entering","entered","exiting","exited","ToastElement","_ref4","transitionDuration","transitionState","_useState","useState","_useState2","setHeight","elementRef","useRef","useEffect","offsetHeight","boxShadow","display","marginBottom","maxWidth","_ref5","onDismiss","onMouseEnter","onMouseLeave","otherProps","CloseIcon","NOOP","generateUEID","second","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","currentQueue","draining","queueIndex","cleanUpNextTick","drainQueue","marker","runClearTimeout","Item","nextTick","env","argv","versions","off","removeAllListeners","emit","prependListener","prependOnceListener","cwd","chdir","umask","replaceClassName","origClass","classToRemove","disabled","UNMOUNTED","EXITED","ENTERING","ENTERED","EXITING","Transition","_React$Component","initialStatus","appear","isMounting","enter","appearStatus","unmountOnExit","mountOnEnter","nextCallback","getDerivedStateFromProps","prevState","_proto","updateStatus","nextStatus","cancelNextCallback","getTimeouts","exit","mounting","performEnter","performExit","_this2","appearing","nodeRef","ReactDOM","findDOMNode","maybeNode","maybeAppearing","timeouts","enterTimeout","safeSetState","onEntered","onEnter","onEntering","onTransitionEnd","_this3","onExit","onExiting","onExited","setNextCallback","_this4","active","node","doesNotHaveTimeoutOrListener","addEndListener","maybeNextCallback","_this$props","childProps","TransitionGroupContext","cloneElement","Children","contextType","propTypes","removeClass","classes","classList","setAttribute","baseVal","CSSTransition","appliedClasses","_this$resolveArgument","resolveArguments","removeClasses","addClass","_this$resolveArgument2","_this$resolveArgument3","getClassNames","classNames","isStringClassNames","baseClassName","doneClassName","phase","scrollTop","hasClass","_addClass","_this$appliedClasses$","getChildMapping","mapFn","isValidElement","mapper","getProp","getNextChildMapping","nextProps","prevChildMapping","nextChildMapping","prev","getValueForKey","nextKeysPending","pendingKeys","prevKey","childMapping","nextKey","pendingNextKey","mergeChildMappings","hasPrev","hasNext","prevChild","isLeaving","TransitionGroup","handleExited","ReferenceError","_assertThisInitialized","contextValue","firstRender","mounted","currentChildMapping","childFactory","ReplaceTransition","_args","handleEnter","_len2","_key2","handleLifecycle","handleEntering","_len3","_key3","handleEntered","_len4","_key4","handleExit","_len5","_key5","handleExiting","_len6","_key6","_len7","_key7","idx","originalArgs","_child$props","inProp","_React$Children$toArr","_leaveRenders","_enterRenders","modes","callHook","_element$props","leaveRenders","changeState","enterRenders","SwitchTransition","appeared","oldChildren","newChildren","_this$state","MAX_SIGNED_31_BIT_INT","createEventEmitter","handlers","changedBits","calculateChangedBits","_Provider$childContex","_Consumer$contextType","contextProp","getUniqueId","_Component","emitter","getChildContext","componentWillReceiveProps","oldValue","childContextTypes","PropTypes","isRequired","Consumer","_Component2","observedBits","_proto2","contextTypes","isarray","compile","tokensToFunction","tokensToRegExp","PATH_REGEXP","defaultDelimiter","escaped","modifier","asterisk","escapeGroup","escapeString","encodeURIComponentPretty","flags","opts","segment","attachKeys","endsWithDelimiter","regexpToRegexp","arrayToRegexp","stringToRegexp","placements","hasToasts","boxSizing","maxHeight","pointerEvents","utils","paramsSerializer","serializedParams","hashmarkIndex","__CANCEL__","normalizeHeaderName","DEFAULT_CONTENT_TYPE","setContentTypeIfUnset","adapter","getDefaultAdapter","transformRequest","transformResponse","xsrfCookieName","xsrfHeaderName","maxContentLength","maxBodyLength","validateStatus","common","settle","cookies","buildURL","buildFullPath","parseHeaders","isURLSameOrigin","createError","requestData","requestHeaders","username","password","baseURL","responseURL","responseHeaders","getAllResponseHeaders","timeoutErrorMessage","xsrfValue","onDownloadProgress","onUploadProgress","cancelToken","enhanceError","config1","config2","valueFromConfig2Keys","mergeDeepPropertiesKeys","defaultToConfig2Keys","directMergeKeys","getMergedValue","mergeDeepProperties","axiosKeys","otherKeys","Cancel","StyleSheet","isSpeedy","speedy","tags","ctr","nonce","insert","rule","_tag","createTextNode","createStyleElement","nextSibling","insertBefore","sheet","styleSheets","ownerNode","sheetForTag","isImportRule","insertRule","cssRules","parentNode","removeChild","stylis_min","use","toSheet","Sheet","ruleSheet","selectors","parents","line","column","createCache","stylisOptions","stylis","Stylis","inserted","_insert","nodes","querySelectorAll","stylisPlugins","selector","serialized","shouldCache","styles","registered","getRegisteredStyles","registeredStyles","rawClassName","insertStyles","isStringTag","murmur2","unitlessKeys","animationIterationCount","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","columns","flex","flexPositive","flexNegative","flexOrder","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","msGridRow","msGridRowSpan","msGridColumn","msGridColumnSpan","fontWeight","order","orphans","tabSize","widows","zoom","WebkitLineClamp","fillOpacity","floodOpacity","strokeDasharray","strokeDashoffset","strokeMiterlimit","strokeOpacity","strokeWidth","hyphenateRegex","animationRegex","isCustomProperty","isProcessableValue","processStyleName","styleName","processStyleValue","p1","p2","unitless","handleInterpolation","mergedProps","interpolation","couldBeSelectorInterpolation","__emotion_styles","anim","interpolated","createStringFromObject","previousCursor","cached","labelPattern","serializeStyles","stringMode","identifierName","hashString","EmotionCacheContext","HTMLElement","ThemeContext","CacheProvider","withEmotionCache","typePropName","createEmotionProps","newProps","theme","cssProp","Emotion","createElementArgArray","Global","InnerGlobal","nextElementSibling","insertable","cls","toAdd","ClassNames","ele","skipInstances","refreshCall","requestQueueInterceptorId","interceptors","mergeOptions","defaultOptions","shouldInterceptError","pauseInstanceWhileRefreshing","createRefreshCall","createRequestQueueInterceptor","finally","unsetCache","resendFailedRequest","getRetryInstance","statusCodes","skipWhileRefreshing","skipAuthRefresh","interceptNetworkError","onRetry","eject","retryInstance","__createBinding","k2","__setModuleDefault","__importStar","mod","__importDefault","react_fast_compare_1","AnnounceKit","widgetHandlers","shouldComponentUpdate","oldProps","lang","widgetInstance","destroy","scripttag","scr","widgetStyle","styleParams","badge","float","floatWidget","widget","framework","framework_version","embed","embedWidget","onInit","_widget","conf","ann","catchClick","elem","onWidgetOpen","onWidgetClose","onWidgetResize","unread","onWidgetUnread","withWidget","unreadCount","reactIs","REACT_STATICS","getDefaultProps","getDerivedStateFromError","mixins","KNOWN_STATICS","caller","callee","MEMO_STATICS","compare","TYPE_STATICS","getStatics","isMemo","ForwardRef","Memo","objectPrototype","hoistNonReactStatics","targetComponent","sourceComponent","blacklist","inheritedComponent","targetStatics","sourceStatics","descriptor","strictUriEncode","objectAssign","keysSorter","extract","formatter","arrayFormat","parserForArrayFormat","ret","param","Boolean","encoderForArrayFormat","val2","sourceSymbolKeys","Fragment","for","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","ReactCurrentOwner","__self","__source","$$typeof","_owner","jsxs","StrictMode","Profiler","Suspense","isMounted","enqueueForceUpdate","enqueueReplaceState","enqueueSetState","refs","isReactComponent","forceUpdate","isPureReactComponent","_status","_result","ReactCurrentDispatcher","ReactCurrentBatchConfig","IsSomeRendererActing","PureComponent","_calculateChangedBits","_currentValue","_currentValue2","_threadCount","_context","createFactory","createRef","lazy","_payload","_init","useCallback","useDebugValue","useImperativeHandle","useLayoutEffect","useMemo","useReducer","ReactPropTypesSecret","emptyFunction","emptyFunctionWithReset","resetWarningCache","shim","propName","propFullName","secret","getShim","ReactPropTypes","bool","any","arrayOf","elementType","instanceOf","objectOf","oneOf","oneOfType","shape","checkPropTypes","acceptsBooleans","attributeNamespace","mustUseProperty","propertyName","sanitizeURL","removeEmptyString","setAttributeNS","xlinkHref","prepareStackTrace","Reflect","construct","_render","_valueTracker","setValue","stopTracking","checked","activeElement","defaultChecked","_wrapperState","initialChecked","initialValue","controlled","ownerDocument","selected","defaultSelected","dangerouslySetInnerHTML","textContent","namespaceURI","innerHTML","firstChild","MSApp","execUnsafeLocalFunction","lastChild","nodeValue","gridArea","lineClamp","setProperty","menuitem","area","col","img","keygen","wbr","correspondingUseElement","stateNode","alternate","memoizedState","dehydrated","sibling","blockedOn","domEventName","eventSystemFlags","nativeEvent","targetContainers","lanePriority","unstable_runWithPriority","priority","hydrate","containerInfo","unstable_scheduleCallback","unstable_NormalPriority","animationend","animationiteration","animationstart","transitionend","unstable_now","pendingLanes","expiredLanes","suspendedLanes","pingedLanes","entangledLanes","entanglements","eventTimes","clz32","LN2","unstable_UserBlockingPriority","charCode","_reactName","_targetInst","currentTarget","isDefaultPrevented","isPropagationStopped","stopPropagation","cancelBubble","persist","isPersistent","eventPhase","bubbles","cancelable","timeStamp","isTrusted","detail","getModifierState","buttons","movementX","movementY","dataTransfer","animationName","elapsedTime","pseudoElement","clipboardData","Esc","Spacebar","Left","Up","Right","Down","Del","Win","Menu","Apps","Scroll","MozPrintableKey","8","9","12","13","16","17","18","19","20","27","32","33","34","35","36","37","38","39","40","45","46","112","113","114","115","116","117","118","119","120","121","122","123","144","145","224","Alt","Control","Meta","Shift","locale","which","pressure","tangentialPressure","tiltX","tiltY","twist","touches","targetTouches","Xd","Zd","deltaX","wheelDeltaX","deltaY","wheelDeltaY","wheelDelta","deltaZ","deltaMode","$d","date","datetime","email","month","tel","week","oninput","compareDocumentPosition","HTMLIFrameElement","contentWindow","contentEditable","selectionStart","selectionEnd","anchorNode","defaultView","getSelection","anchorOffset","focusNode","focusOffset","passive","parentWindow","char","autoFocus","__html","of","previousSibling","__reactInternalMemoizedUnmaskedChildContext","__reactInternalMemoizedMaskedChildContext","__reactInternalMemoizedMergedChildContext","unstable_cancelCallback","unstable_shouldYield","unstable_requestPaint","unstable_getCurrentPriorityLevel","unstable_ImmediatePriority","unstable_LowPriority","unstable_IdlePriority","ag","cg","dg","eg","gg","hg","ig","jg","kg","lg","mg","ng","og","pg","qg","rg","sg","childLanes","tg","firstContext","lanes","ug","vg","responders","wg","xg","updateQueue","baseState","firstBaseUpdate","lastBaseUpdate","pending","effects","yg","zg","lane","Ag","Bg","Cg","Dg","Eg","Fg","Gg","Kg","_reactInternals","Hg","Ig","Jg","Lg","Mg","Ng","UNSAFE_componentWillReceiveProps","Og","getSnapshotBeforeUpdate","UNSAFE_componentWillMount","componentWillMount","Pg","Qg","_stringRef","Rg","Sg","lastEffect","nextEffect","firstEffect","Tg","Ug","Vg","implementation","Wg","Xg","Yg","Zg","$g","ch","documentElement","tagName","memoizedProps","revealOrder","pendingProps","_workInProgressVersionPrimary","vh","baseQueue","lastRenderedReducer","eagerReducer","eagerState","lastRenderedState","dispatch","_getVersion","mutableReadLanes","getSnapshot","setSnapshot","deps","readContext","useDeferredValue","useTransition","useMutableSource","useOpaqueIdentifier","unstable_isNewReconciler","baseLanes","UNSAFE_componentWillUpdate","componentWillUpdate","pendingContext","retryLane","fallback","unstable_avoidThisFallback","unstable_expectedLoadTime","isBackwards","rendering","renderingStartTime","tailMode","wasMultiple","multiple","onclick","createElementNS","componentDidCatch","componentStack","WeakSet","__reactInternalSnapshotBeforeUpdate","aj","bj","onCommitFiberUnmount","cj","dj","ej","fj","gj","hj","_reactRootContainer","ij","jj","kj","lj","mj","nj","oj","pj","qj","rj","sj","tj","uj","vj","wj","ck","xj","yj","zj","Aj","Bj","Cj","Dj","Ej","Fj","Gj","Hj","Ij","Jj","Kj","Lj","Mj","callbackNode","expirationTimes","callbackPriority","Nj","Oj","Pj","Qj","Rj","Sj","Tj","finishedWork","finishedLanes","Uj","timeoutHandle","Wj","Xj","pingCache","Yj","Zj","ak","bk","dk","rangeCount","focusedElem","selectionRange","ek","setStart","removeAllRanges","addRange","setEnd","scrollLeft","onCommitFiberRoot","fk","gk","ik","pendingChildren","jk","mutableSourceEagerHydrationData","kk","lk","mk","nk","qk","hydrationOptions","mutableSources","_internalRoot","rk","tk","hasAttribute","sk","uk","hk","unstable_observedBits","unmount","form","Vj","vk","Events","wk","findFiberByHostInstance","bundleType","rendererPackageName","xk","rendererConfig","overrideHookState","overrideHookStateDeletePath","overrideHookStateRenamePath","overrideProps","overridePropsDeletePath","overridePropsRenamePath","setSuspenseHandler","scheduleUpdate","currentDispatcherRef","findHostInstanceByFiber","findHostInstancesForRefresh","scheduleRefresh","scheduleRoot","setRefreshHandler","getCurrentFiber","yk","isDisabled","supportsFiber","inject","createPortal","flushSync","unmountComponentAtNode","unstable_batchedUpdates","unstable_createPortal","unstable_renderSubtreeIntoContainer","MessageChannel","unstable_forceFrameRate","cancelAnimationFrame","requestAnimationFrame","port2","port1","sortIndex","expirationTime","priorityLevel","unstable_Profiling","unstable_continueExecution","unstable_getFirstCallbackNode","unstable_next","unstable_pauseExecution","unstable_wrapCallback","_react2","verticalAlign","fillRule","R75","R100","R200","R400","Y75","Y100","Y200","Y400","G75","G100","G200","G400","B50","B75","B100","B300","B400","B500","P50","P75","P100","P200","P300","P400","P500","T50","T75","T100","T200","T300","T400","T500","N0","N10","N20","N30","N40","N50","N60","N70","N80","N90","N100","N200","N300","N500","N600","N700","N800","N900","N10A","N20A","N30A","N40A","N50A","N60A","N70A","N80A","N90A","N100A","N200A","N300A","N400A","N500A","N600A","N700A","N800A","_createClass","protoProps","staticProps","_reactDom","_reactTransitionGroup","_ToastController","_classCallCheck","_possibleConstructorReturn","defaultComponents","Toast","ToastContext","_temp","toasts","newToast","removeAll","updatedToast","_inherits","inheritedAutoDismiss","portalTargetSelector","_defaultComponents$co","portalTarget","unknownConsumerProps","ToastController","Comp","toastManager","ctx","addToast","removeToast","removeAllToasts","updateToast","toastStack","Timer","startTimer","clearTimer","handleMouseEnter","handleMouseLeave","Op","hasOwn","$Symbol","iteratorSymbol","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","innerFn","outerFn","tryLocsList","protoGenerator","Generator","Context","_invoke","GenStateSuspendedStart","GenStateExecuting","GenStateCompleted","doneResult","delegate","delegateResult","maybeInvokeDelegate","ContinueSentinel","_sent","dispatchException","abrupt","tryCatch","GenStateSuspendedYield","makeInvokeMethod","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","NativeIteratorPrototype","Gp","defineIteratorMethods","AsyncIterator","PromiseImpl","__await","unwrapped","previousPromise","callInvokeWithMethodAndArg","resultName","nextLoc","pushTryEntry","locs","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","iteratorMethod","isGeneratorFunction","genFun","ctor","awrap","skipTempReset","rootRecord","rval","exception","handle","caught","hasCatch","hasFinally","finallyEntry","finish","thrown","delegateYield","regeneratorRuntime","accidentalStrictMode","webpackPolyfill","deprecate","sep","maxKeys","kstr","vstr","stringifyPrimitive","objectKeys","Axios","mergeConfig","createInstance","axios","instanceConfig","CancelToken","isCancel","promises","isAxiosError","InterceptorManager","dispatchRequest","getUri","transformData","throwIfCancellationRequested","throwIfRequested","reason","fns","normalizedName","fileName","lineNumber","columnNumber","expires","domain","secure","cookie","toGMTString","isAbsoluteURL","combineURLs","requestedURL","relativeURL","ignoreDuplicateOf","parsed","originURL","msie","urlParsingNode","resolveURL","requestURL","resolvePromise","firebaseEndpoint","secureTokenEndpoint","identityPlatformEndpoint","$goog_Thenable","captureStackTrace","Element","trustedTypes","createPolicy","createHTML","createScript","createScriptURL","OffscreenCanvas","getElementById","cssText","htmlFor","cellpadding","cellspacing","colspan","frameborder","maxlength","rowspan","usemap","valign","setImmediate","Window","dispatchEvent","Sd","Ud","Wd","Yd","screen","availHeight","availWidth","resizable","statusbar","toolbar","scrollbars","standalone","noreferrer","createEvent","initMouseEvent","opener","noopener","WorkerGlobalScope","importScripts","___jsl","CP","toUTCString","abcd","factorId","enrollmentTime","phoneNumber","operation","continueUrl","languageCode","tenantId","recoverEmail","resetPassword","revertSecondFactorAddition","signIn","verifyAndChangeEmail","verifyEmail","canHandleCodeInApp","androidPackageName","androidMinimumVersion","androidInstallApp","iOSBundleId","dynamicLinkDomain","sub","iss","aud","exp","iat","provider_id","sign_in_provider","tenant","is_anonymous","isNewUser","kind","rawUserInfo","providerId","profile","login","pendingToken","requestUri","signInMethod","idToken","oauthToken","oauthTokenSecret","id_token","access_token","oauth_token_secret","postBody","oauthIdToken","oauthAccessToken","isOAuthProvider","credential","EMAIL_LINK_SIGN_IN_METHOD","EMAIL_PASSWORD_SIGN_IN_METHOD","verificationId","verificationCode","temporaryProof","sessionInfo","rawNonce","eventId","urlResponse","sessionId","multiFactorSession","pendingCredential","oobCode","PROVIDER_ID","session","phoneSessionInfo","phoneEnrollmentInfo","recaptchaToken","phoneResponseInfo","mfaPendingCredential","mfaEnrollmentId","multiFactorHint","multiFactorUid","phoneSignInInfo","PHONE_SIGN_IN_METHOD","ActiveXObject","XDomainRequest","onprogress","getResponse","mozResponseArrayBuffer","charset","secureTokenTimeout","secureTokenHeaders","firebaseTimeout","firebaseHeaders","gapi","setApiKey","setToken","authType","photoUrl","phoneVerificationInfo","needConfirmation","returnIdpCredential","autoCreate","deleteAttribute","requestType","newEmail","newPassword","deleteProvider","recaptchaSiteKey","USER_NOT_FOUND","returnSecureToken","errors","keyInvalid","ipRefererBlocked","INVALID_CUSTOM_TOKEN","CREDENTIAL_MISMATCH","MISSING_CUSTOM_TOKEN","INVALID_IDENTIFIER","MISSING_CONTINUE_URI","INVALID_EMAIL","INVALID_PASSWORD","USER_DISABLED","MISSING_PASSWORD","EMAIL_EXISTS","PASSWORD_LOGIN_DISABLED","INVALID_IDP_RESPONSE","INVALID_PENDING_TOKEN","FEDERATED_USER_ID_ALREADY_LINKED","MISSING_OR_INVALID_NONCE","INVALID_MESSAGE_PAYLOAD","INVALID_RECIPIENT_EMAIL","INVALID_SENDER","EMAIL_NOT_FOUND","RESET_PASSWORD_EXCEED_LIMIT","EXPIRED_OOB_CODE","INVALID_OOB_CODE","MISSING_OOB_CODE","INVALID_PROVIDER_ID","CREDENTIAL_TOO_OLD_LOGIN_AGAIN","INVALID_ID_TOKEN","TOKEN_EXPIRED","CORS_UNSUPPORTED","DYNAMIC_LINK_NOT_ACTIVATED","INVALID_APP_ID","TOO_MANY_ATTEMPTS_TRY_LATER","WEAK_PASSWORD","OPERATION_NOT_ALLOWED","USER_CANCELLED","CAPTCHA_CHECK_FAILED","INVALID_APP_CREDENTIAL","INVALID_CODE","INVALID_PHONE_NUMBER","INVALID_SESSION_INFO","INVALID_TEMPORARY_PROOF","MISSING_APP_CREDENTIAL","MISSING_CODE","MISSING_PHONE_NUMBER","MISSING_SESSION_INFO","QUOTA_EXCEEDED","SESSION_EXPIRED","REJECTED_CREDENTIAL","INVALID_CONTINUE_URI","MISSING_ANDROID_PACKAGE_NAME","MISSING_IOS_BUNDLE_ID","UNAUTHORIZED_DOMAIN","INVALID_DYNAMIC_LINK_DOMAIN","INVALID_OAUTH_CLIENT_ID","INVALID_CERT_HASH","UNSUPPORTED_TENANT_OPERATION","INVALID_TENANT_ID","TENANT_ID_MISMATCH","ADMIN_ONLY_OPERATION","INVALID_MFA_PENDING_CREDENTIAL","MFA_ENROLLMENT_NOT_FOUND","MISSING_MFA_PENDING_CREDENTIAL","MISSING_MFA_ENROLLMENT_ID","EMAIL_CHANGE_NEEDS_VERIFICATION","SECOND_FACTOR_EXISTS","SECOND_FACTOR_LIMIT_EXCEEDED","UNSUPPORTED_FIRST_FACTOR","UNVERIFIED_EMAIL","messageHandlersFilter","dontclear","restyle","setHideOnLeave","ping","authorizedDomains","authEvent","reactNative","AsyncStorage","webStorageSupport","messageChannel","pk","keyProcessed","ready","zk","fbase_key","Bk","Ck","Dk","Ek","Gk","Fk","Hk","Ik","Kk","sessionStorage","Jk","Lk","Browser","Mk","Node","Nk","ReactNative","Ok","Worker","Pk","ports","Ak","Qk","Uk","Rk","NONE","Tk","Vk","Wk","Xk","Zk","clearInterval","setInterval","$k","Int32Array","handleOpenURL","ibi","apn","appDisplayName","signInViaRedirect","linkViaRedirect","reauthViaRedirect","signInViaPopup","linkViaPopup","reauthViaPopup","bm","am","em","fm","gm","hm","auth_time","authTime","issuedAtTime","signInProvider","signInSecondFactor","sign_in_second_factor","im","jm","km","cm","dm","lm","mm","nm","qm","rm","sm","tm","multiFactor","enrolledFactors","um","xm","ym","zm","Am","Bm","Cm","Em","grant_type","refresh_token","expires_in","Fm","lastSignInTime","Hm","photoURL","Im","authDomain","emulatorConfig","Jm","Km","Lm","Mm","Nm","Om","Pm","Qm","Rm","Sm","Um","Vm","emailVerified","isAnonymous","createdAt","lastLoginAt","providerData","Wm","Xm","Ym","Zm","$m","Gm","Dm","wm","additionalUserInfo","operationType","reload","stsTokenManager","redirectEventId","om","pm","mfaInfo","vm","users","localId","providerUserInfo","rawId","passwordHash","Yk","logFramework","disableWarnings","Tm","_lat","Sk","userLanguage","innerText","margin","continueUri","signinMethods","execute","grecaptcha","hasChildNodes","appVerificationDisabledForTesting","Persistence","LOCAL","SESSION","appVerificationDisabled","ActionCodeInfo","Operation","EMAIL_SIGNIN","PASSWORD_RESET","RECOVER_EMAIL","REVERT_SECOND_FACTOR_ADDITION","VERIFY_AND_CHANGE_EMAIL","VERIFY_EMAIL","Auth","AuthCredential","App","User","domStorage_","prefix_","prefixedName_","storedVal","cache_","isInMemoryStorage","createStoragefor","domStorageName","domStorage","DOMStorageWrapper","MemoryStorage","PersistentStorage","SessionStorage","logClient","LUIDGenerator","sha1","sha1Bytes","buildLogMessage_","varArgs","firstLog_","enableLogging","logger_","persistent","VERBOSE","logWrapper","fatal","isInvalidJSONNumber","MIN_NAME","MAX_NAME","nameCompare","aAsInt","tryParseInt","bAsInt","stringCompare","requireKey","ObjectToUniqueKey","splitStringBySize","segsize","dataSegs","doubleToIEEE754String","bias","bits","hexByteString","hexByte","INTEGER_REGEXP_","INTEGER_32_MIN","INTEGER_32_MAX","intVal","exceptionGuard","setTimeoutNonBlocking","pathOrString","pieceNum","pieces_","copyTo","pieceNum_","pathString","newEmptyPath","Path","pathGetFront","pathGetLength","pathPopFront","pathGetBack","pathToUrlEncodedString","pathSlice","begin","pathParent","pieces","pathChild","childPathObj","childPieces","pathIsEmpty","newRelativePath","outerPath","innerPath","inner","pathCompare","leftKeys","rightKeys","cmp","pathEquals","pathContains","errorPrefix_","parts_","byteLength_","validationPathCheckValid","validationPath","validationPathToErrorString","PROTOCOL_VERSION","FORGE_DOMAIN_RE","WEBSOCKET","LONG_POLLING","webSocketOnly","nodeAdmin","includeNamespaceInQueryParams","_host","_domain","internalHost","isCacheableHost","isCustomHost","newHost","toURLString","repoInfoConnectionURL","repoInfo","connURL","repoInfoNeedsQueryParam","MAX_NODE","parseRepoInfo","parsedUrl","parseDatabaseURL","scheme","RepoInfo","subdomain","colonInd","slashInd","questionMarkInd","pathStringDecoded","piece","queryParams","queryString","results","kv","decodeQuery","hostWithoutPort","dotInd","INVALID_KEY_REGEX_","INVALID_PATH_REGEX_","MAX_LEAF_SIZE_","isValidKey","isValidPathString","isValidPriority","validateFirebaseDataArg","validateFirebaseData","errorPrefixFxn","ValidationPath","validationPathPop","validateFirebaseMergeDataArg","mergePaths","curPath","prevPath","validateFirebaseMergePaths","validatePriority","validateEventType","validateKey","validatePathString","validateRootPathString","validateWritablePath","validateUrl","isValidRootPathString","validateBoolean","__childrenNodeConstructor","nodeFromJSON","priorityHashText","validatePriorityNode","priorityNode","isLeafNode","getPriority","value_","priorityNode_","LeafNode","EMPTY_NODE","lazyHash_","updatePriority","newPriorityNode","getImmediateChild","childName","getChild","hasChild","getPredecessorChildName","childNode","updateImmediateChild","newChildNode","updateChild","front","numChildren","forEachChild","exportFormat","toHash","compareTo","compareToLeafNode_","otherLeaf","otherLeafType","thisLeafType","otherIndex","VALUE_TYPE_ORDER","thisIndex","withIndex","isIndexed","equals","startKey","isReverse_","resultGenerator_","nodeStack_","getNext","peek","LLRBNode","SortedMap","inorderTraversal","reverseTraversal","min_","minKey","maxKey","fixUp_","removeMin_","isRed_","moveRedLeft_","smallest","rotateRight_","moveRedRight_","rotateLeft_","colorFlip_","checkMaxDepth_","blackDepth","check_","BLACK","comparator_","root_","getPredecessorKey","rightParent","getIterator","resultGenerator","SortedMapIterator","getIteratorFrom","getReverseIteratorFrom","getReverseIterator","LLRBEmptyNode","Wrap","NamedNode","getCompare","indexedValueChanged","oldNode","newNode","oldWrapped","newWrapped","minPost","MIN","__EMPTY_NODE","_defaultIndexMap","PRIORITY_INDEX","aPriority","bPriority","indexCmp","isDefinedOn","maxPost","makePost","indexValue","KEY_INDEX","KeyIndex","LOG_2","current_","mask","bits_","nextBitIsOne","buildChildSet","childList","keyFn","mapSortFn","buildBalancedTree","namedNode","base12","buildPennant","childTree","attachPennant","pennant","isOne","buildFrom12Array","Base12Num","fallbackObject","indexes_","indexSet_","IndexMap","indexKey","sortedMap","hasIndex","indexDefinition","addIndex","existingChildren","sawIndexedValue","indexName","newIndexSet","newIndexes","addToIndexes","indexedChildren","existingSnap","removeFromIndexes","NAME_ONLY_COMPARATOR","NAME_COMPARATOR","children_","indexMap_","ChildrenNode","Default","newIndexMap","newPriority","newImmediateChild","numKeys","allIntegerKeys","childHash","resolveIndex_","predecessor","getFirstChildName","getFirstChild","getLastChildName","getLastChild","wrappedNode","startPost","endPost","otherChildrenNode","thisIter","otherIter","thisCurrent","otherCurrent","MAX","setPriorityMaxNode","OperationType","childData","childSet","sortedChildSet","newOperationSourceServerTaggedQuery","queryId","fromUser","fromServer","tagged","setNodeFromJSON","emptyChildrenSingleton","affectedTree","revert","ACK_USER_WRITE","operationForChild","subtree","AckUserWrite","fromObject","tree","ImmutableTree","childSnap","findRootMostMatchingPathAndValue","relativePath","childExistingPathAndValue","findRootMostValueAndPath","toSet","newChild","setTree","newTree","fold","fold_","pathSoFar","accum","childKey","findOnPath","findOnPath_","pathToFollow","nextChild","foreachOnPath","foreachOnPath_","currentRelativePath","foreach","foreach_","foreachChild","LISTEN_COMPLETE","ListenComplete","snap","OVERWRITE","Overwrite","MERGE","Merge","node_","fullyInitialized_","filtered_","isFullyInitialized","isFiltered","isCompleteForPath","isCompleteForChild","getNode","eventCache_","serverCache_","updateEventSnap","eventSnap","filtered","ViewCache","CacheNode","updateServerSnap","serverSnap","getEventCache","getCompleteEventSnap","getServerCache","getCompleteServerSnap","changeValue","snapshotNode","changeChildAdded","changeChildRemoved","changeChildChanged","oldSnap","index_","affectedPath","optChangeAccumulator","oldChild","trackChildChange","updateFullNode","newSnap","filtersNodes","getIndexedFilter","getIndex","changeMap","change","oldChange","oldType","getChanges","NO_COMPLETE_CHILD_SOURCE","getCompleteChild","getChildAfterChild","writes_","viewCache_","optCompleteServerCache_","serverNode","calcCompleteChild","completeServerData","calcIndexedSlice","viewCache","changes","filter_","assertIndexed","applyOperation","oldViewCache","writesCache","completeCache","newViewCache","filterServerNode","ChildChangeAccumulator","overwrite","applyUserOverwrite_","applyServerOverwrite_","applyUserMerge_","applyServerMerge_","ackUserWrite","revertUserWrite_","ackUserWrite_","listenComplete_","ViewProcessor","maybeAddValueEvent_","ProcessorResult","isLeafOrEmpty","oldCompleteSnap","generateEventCacheAfterServerEvent_","changePath","oldEventSnap","shadowingWrite","newEventCache","serverCache","completeChildren","completeEventChildren","calcCompleteEventChildren","completeNode","calcCompleteEventCache","oldEventNode","updatedPriority","calcEventCacheAfterServerOverwrite","childChangePath","newEventChild","eventChildUpdate","changedSnap","newServerCache","oldServerSnap","serverFilter","newServerNode","WriteTreeCompleteChildSource","newEventSnap","cacheHasChild_","changedChildren","curViewCache","writePath","applyMerge_","viewMergeTree","serverChild","childMergeTree","isUnknownDeepMerge","ackPath","mergePath","serverCachePath","oldServerNode","completeServerCache","oldEventCache","serverChildren","query_","getQueryParams","eventGeneratorGenerateEventsForType","eventGenerator","events","registrations","eventCache","filteredChanges","aWrapped","bWrapped","eventGeneratorCompareChanges","materializedChange","prevName","eventGeneratorMaterializeSingleChange","respondsTo","PUSH_CHARS","nextPushId","lastPushTime","lastRandChars","duplicateTime","timeStampChars","successor","keyAsInt","sourcePlusOne","VALUE_INDEX","valueNode","indexPath_","extractChild","aChild","bChild","indexedFilter_","IndexedFilter","startPost_","RangedFilter","getStartPost_","endPost_","getEndPost_","getStartPost","getEndPost","hasStart","startName","getIndexStartName","getIndexStartValue","hasEnd","endName","getIndexEndName","getIndexEndValue","rangedFilter_","limit_","getLimit","reverse_","isViewFromLeft","fullLimitUpdateChild_","foundStartPost","changeAccumulator","newChildNamedNode","windowBoundary","oldChildSnap","compareNext","limitSet_","startSet_","startNameSet_","startAfterSet_","endSet_","endNameSet_","endBeforeSet_","viewFrom_","indexStartValue_","indexStartName_","indexEndValue_","indexEndName_","hasStartAfter","hasEndBefore","hasLimit","hasAnchoredLimit","loadsAllData","isDefault","QueryParams","queryParamsLimitToFirst","newLimit","newParams","queryParamsLimitToLast","queryParamsStartAt","queryParamsStartAfter","queryParamsEndAt","queryParamsEndBefore","queryParamsOrderBy","queryParamsToRestQueryStringParameters","PathIndex","referenceConstructor","initialViewCache","eventRegistrations_","indexFilter","LimitedFilter","processor_","initialServerCache","initialEventCache","eventGenerator_","EventGenerator","getQuery","getCompleteNode","getCompleteServerCache","addEventRegistration","eventRegistration","removeEventRegistration","cancelError","cancelEvents","maybeEvent","createCancelEvent","existing","hasAnyCallback","generateEventsForChanges_","getInitialEvents","initialChanges","eventRegistrations","moves","eventGeneratorGenerateEventsForChanges","views","syncPointApplyOperation","syncPoint","optCompleteServerCache","syncPointGetView","serverCacheComplete","queryIdentifier","eventCacheComplete","View","syncPointRemoveEventRegistration","removed","hadCompleteView","syncPointHasCompleteView","viewQueryId","repo","syncPointGetQueryViews","syncPointGetCompleteServerCache","syncPointViewForQuery","syncPointGetCompleteView","syncPointViewExistsForQuery","writeTree_","CompoundWrite","compoundWriteAddWrite","compoundWrite","rootmost","rootMostPath","newWriteTree","compoundWriteAddWrites","updates","newWrite","compoundWriteRemoveWrite","compoundWriteHasCompleteWrite","compoundWriteGetCompleteNode","compoundWriteGetCompleteChildren","compoundWriteChildCompoundWrite","shadowingNode","compoundWriteIsEmpty","compoundWriteApply","applySubtreeWrite","writeTree","visibleWrites_","allWrites_","lastWriteId_","childWrites","WriteTreeRef","addOverwrite","writeId","visible","addMerge","getWrite","removeWrite","writeToRemove","removedWriteWasVisible","removedWriteOverlapsWithOtherWrites","currentWrite","recordContainsPath_","resetTree_","getCompleteWriteData","treePath","writeIdsToExclude","includeHiddenWrites","WriteTree","layerTree_","subMerge","completeServerChildren","topLevelSet","existingEventSnap","existingServerSnap","childMerge","toIterate","writeRecord","DefaultFilter_","treeRoot","deepNode","treePath_","existingServerCache","syncTreeNextQueryTag_","listenProvider_","syncPointTree_","pendingWriteTree_","tagToQueryMap","queryToTagMap","syncTreeApplyUserOverwrite","syncTree","syncTreeApplyOperationToSyncPoints_","syncTreeAckUserWrite","syncTreeApplyServerOverwrite","syncTreeRemoveEventRegistration","maybeSyncPoint","removedAndEvents","removingDefault","covered","parentSyncPoint","newViews","maybeChildSyncPoint","childMap","childViews","syncTreeCollectDistinctViewsForSubTree_","newQuery","syncTreeCreateListenerForView_","startListening","syncTreeQueryForListening_","syncTreeTagForQuery_","hashFn","onComplete","stopListening","queryToRemove","tagToRemove","syncTreeMakeQueryKey_","removedQuery","removedQueryKey","removedQueryTag","syncTreeRemoveTags_","syncTreeAddEventRegistration","foundAncestorDefaultView","pathToSyncPoint","sp","SyncPoint","childSyncPoint","viewAlreadyExists","queryKey","syncPointAddEventRegistration","queriesToStop","childQueries","queryToStop","syncTreeSetupListener_","syncTreeCalcCompleteEventCache","syncTreeApplyOperationHelper_","syncPointTree","syncTreeApplyOperationDescendantsHelper_","childOperation","childServerCache","childWritesCache","syncTreeQueryKeyForTag_","syncTreeParseQueryKey_","queryPath","syncTreeApplyTaggedOperation_","syncTreeApplyTaggedListenComplete","syncTreeApplyListenComplete","errorForServerCode","splitIndex","getRef","ExistingValueProvider","syncTree_","DeferredValueProvider","resolveDeferredLeafValue","existingVal","serverValues","resolveScalarDeferredValue","resolveComplexDeferredValue","unused","existingNode","resolveDeferredValueTree","resolveDeferredValue","resolveDeferredValueSnapshot","rawPri","leafNode","childrenNode","newSparseSnapshotTree","sparseSnapshotTreeRemember","sparseSnapshotTree","sparseSnapshotTreeForget","sparseSnapshotTreeForEachTree","prefixPath","sparseSnapshotTreeForEachChild","rootNode_","updateSnapshot","newSnapshotNode","counters_","incrementCounter","amount","collections","reporters","statsManagerGetCollection","StatsCollection","collection_","last_","newStats","server_","statsToReport_","statsListener_","StatsListener","reportStats_","stats","reportedStats","haveStatsToReport","reportStats","eventLists_","recursionDepth_","eventQueueQueueEvents","eventQueue","eventDataList","currList","getPath","eventQueueRaiseEventsAtPath","eventQueueRaiseQueuedEventsMatchingPredicate","eventPath","eventQueueRaiseEventsForChangedPath","changedPath","sentAll","eventList","eventListRaise","eventData","eventFn","getEventRunner","allowedEvents_","listeners_","trigger","validateEventType_","getInitialEvent","hidden","visibilityChange","visible_","VisibilityMonitor","EventEmitter","online_","OnlineMonitor","currentlyOnline","onMessage_","pendingResponses","currentResponseNum","closeAfterResponse","onClose","closeAfter","responseNum","handleResponse","requestNum","toProcess","FIREBASE_LONGPOLL_START_PARAM","FIREBASE_LONGPOLL_CLOSE_COMMAND","connId","applicationId","transportSessionId","lastSessionId","bytesSent","bytesReceived","everConnected_","log_","stats_","urlFn","onDisconnect","curSegmentNum","onDisconnect_","myPacketOrderer","PacketReceiver","isClosed_","connectTimeoutTimer_","onClosed_","executeWhenDOMReady","scriptTagHolder","FirebaseIFrameScriptHolder","arg1","arg2","incrementIncomingBytes_","sendNewPolls","pN","uniqueCallbackIdentifier","connectURL","addTag","startLongPoll","addDisconnectPingFrame","forceAllow","BrowserPollConnection","forceAllow_","forceDisallow","forceDisallow_","Windows","UI","markConnectionHealthy","shutdown_","myDisconnFrame","dataStr","base64data","MAX_URL_DATA_SIZE","enqueueSegment","pw","commandCB","onMessageCB","outstandingRequests","pendingSegs","currentSerial","myIFrame","createIFrame_","iframeContents","iframe","contentDocument","alive","myID","myPW","newRequest_","theURL","curDataString","theSeg","seg","addLongPollTag_","segnum","totalsegs","serial","doNewRequest","keepaliveTimeout","loadCB","doNodeLongPoll","rstate","setSDKVersion","WebSocketImpl","MozWebSocket","WebSocket","keepaliveTimer","frames","totalFrames","WebSocketConnection","connectionURL_","device","platform","mySock","onopen","onclose","handleIncomingFrame","isOldAndroid","oldAndroidMatch","previouslyFailed","appendFrame_","fullMess","jsonMess","handleNewFrameCount_","frameCount","extractFrameCount_","mess","resetKeepAlive","remainingData","sendString_","responsesRequiredToBeHealthy","healthyTimeout","initTransports_","isWebSocketsAvailable","isSkipPollConnection","transports_","transports","TransportManager","ALL_TRANSPORTS","transport","initialTransport","upgradeTransport","repoInfo_","applicationId_","onReady_","onKill_","connectionCount","pendingDataMessages","state_","transportManager_","conn","conn_","nextTransportId_","primaryResponsesRequired_","onMessageReceived","connReceiver_","onConnectionLost","disconnReceiver_","tx_","rx_","secondaryConn_","isHealthy_","healthyTimeoutMS","healthyTimeout_","everConnected","onConnectionLost_","onSecondaryConnectionLost_","onPrimaryMessageReceived_","onSecondaryMessageReceived_","sendRequest","dataMsg","msg","sendData_","tryCleanupConnection","onSecondaryControl_","controlData","cmd","upgradeIfSecondaryHealthy_","secondaryResponsesRequired_","parsedData","layer","proceedWithUpgrade_","onControl_","onDataMessage_","onPrimaryResponse_","onHandshake_","onConnectionShutdown_","onReset_","sendPingOnPrimaryIfNecessary_","handshake","onConnectionEstablished_","tryStartUpgrade_","startUpgrade_","closeConnections_","onDisconnectPut","onDisconnectMerge","onDisconnectCancel","RECONNECT_MIN_DELAY","onDataUpdate_","onConnectStatus_","onServerInfoUpdate_","authTokenProvider_","authOverride_","PersistentConnection","nextPersistentConnectionId_","interruptReasons_","listens","outstandingPuts_","outstandingGets_","outstandingPutCount_","outstandingGetCount_","onDisconnectRequestQueue_","connected_","reconnectDelay_","maxReconnectDelay_","securityDebugCallback_","establishConnectionTimer_","requestCBHash_","requestNumber_","realtime_","authToken_","forceTokenRefresh_","invalidAuthTokenCount_","firstConnection_","lastConnectionAttemptTime_","lastConnectionEstablishedTime_","scheduleConnect_","onVisible_","onOnline_","onResponse","curReqNum","queryObject","outstandingGet","sendGet_","currentHashFn","listenSpec","sendListen_","req","warnOnListenWarnings_","removeListen_","warnings","indexSpec","indexPath","tryAuth","reduceReconnectDelayIfAdminCredential_","authMethod","cred","onAuthRevoked_","sendUnlisten_","queryObj","sendOnDisconnect_","putInternal","sendPut_","queued","errorReason","reqNum","onDataPush_","onListenRevoked_","onSecurityDebugPacket_","handleTimestamp_","sendConnectStats_","restoreState_","establishConnection_","online","onRealtimeDisconnect_","cancelSentTransactions_","shouldReconnect_","timeSinceLastConnectAttempt","reconnectDelay","nextConnectionId_","Connection","interrupt","serverTimeOffset","normalizedPathString","statusCode","explanation","notifyForInvalidToken","clientName","ServerActions","listens_","getListenId_","listenId","ReadonlyRestClient","thisListen","queryStringParameters","restRequest_","authTokenData","ref_","exportVal","childPathString","childRef","DataSnapshot","hasChildren","childCount","treeSubTree","pathObj","Tree","treeGetValue","treeSetValue","treeUpdateParents","treeHasChildren","treeForEachChild","treeForEachDescendant","includeSelf","childrenFirst","treeGetPath","childEmpty","treeIsEmpty","childExists","treeUpdateChild","INTERRUPT_REASON","forceRestClient_","dataUpdateCount","eventQueue_","EventQueue","nextWriteId_","interceptServerDataCallback_","transactionQueueTree_","persistentConnection_","repoStart","isMerge","repoOnDataUpdate","repoOnConnectStatus","authOverride","connectStatus","repoUpdateInfo","repoOnServerInfoUpdate","addTokenChangeListener","statsReporter_","creatorFunction","statsManagerGetOrCreateReporter","StatsReporter","infoData_","SnapshotHolder","infoSyncTree_","SyncTree","infoEvents","serverSyncTree_","repoServerTime","repoGenerateServerValues","taggedChildren","changeTree","syncTreeApplyTaggedQueryMerge","taggedSnap","syncTreeApplyTaggedQueryOverwrite","syncTreeApplyServerMerge","repoRerunTransactions","repoLog","resolvedOnDisconnectTree","resolved","repoAbortTransactions","repoRunOnDisconnectEvents","repoGetNextWriteId","repoGetValue","serverCacheNode","syncTreeGetServerValue","repoSetWithPriority","newVal","newNodeUnresolved","clearEvents","repoCallOnCompleteCallback","repoUpdate","childrenToMerge","changedKey","changedValue","syncTreeApplyUserMerge","repoOnDisconnectCancel","repoOnDisconnectSet","repoOnDisconnectSetWithPriority","repoOnDisconnectUpdate","repoAddEventCallbackForQuery","repoRemoveEventCallbackForQuery","repoInterrupt","repoResume","repoGetDatabase","__database","Database","repoStartTransaction","transactionUpdate","applyLocally","valueCallback","watchRef","retryCount","unwatcher","abortReason","currentWriteId","currentInputSnapshot","currentOutputSnapshotRaw","currentOutputSnapshotResolved","currentState","repoGetLatestState","queueNode","nodeQueue","priorityForNode","repoSendReadyTransactions","excludeSets","repoPruneCompletedTransactionsBelowNode","repoBuildTransactionQueue","setsToIgnore","txn","latestState","snapToSend","latestHash","dataToSend","pathToSend","repoSendTransactionQueue","rootMostTransactionNode","repoGetAncestorTransactionNode","abortTransaction","currentNode","newDataNode","oldWriteId","newNodeResolved","lastInput","repoRerunTransactionQueue","transactionNode","transactionQueue","repoAggregateTransactionQueuesForNode","treeForEachAncestor","repoAbortTransactionsOnNode","lastSent","__referenceConstructor","repo_","setWithPriority","objectToMerge","newObjectToMerge","committed","getParent","cancelCallback_","context_","DataEvent","CancelEvent","ValueEventRegistration","callbacks_","eventToCheck","ChildEventRegistration","thisKeys","otherCount","otherKey","thisKey","queryParams_","orderByCalled_","validateQueryEndpoints_","startNode","endNode","tooManyArgsError","wrongArgTypeError","validateLimit_","validateNoPreviousOrderByCall_","cancelCallbackOrContext","getCancelAndContextArgs_","onValueEvent","onChildEvent","cancelCallback","userCallback","failureCallbackOrContext","firstCall","onceCallback","limitToFirst","orderByChild","parsedPath","orderByKey","orderByPriority","orderByValue","equalTo","viewFrom","queryParamsGetQueryObject","sameRepo","samePath","sameQueryIdentifier","cancelOrContext","Repo","getRoot","databaseProp","promiseComplete","TransactionResult","setPriority","thennablePushRef","pushRef","OnDisconnect","syncPointSetReferenceConstructor","authProvider_","auth_","removeTokenChangeListener","EmulatorAdminTokenProvider","EMULATOR_AUTH_TOKEN","repos","useRestClient","repoManagerDatabaseFromApp","dbUrl","databaseURL","isEmulator","dbEmulatorHost","authTokenProvider","FirebaseAuthTokenProvider","appRepos","repoManagerCreateRepo","repoInternal_","instanceStarted_","checkDeleted_","repoManagerDeleteRepo","rootInternal_","repoManagerApplyEmulatorSettings","apiName","parsedURL","goOffline","goOnline","ServerValue","TIMESTAMP","showDelta","longestName","currentValue","paddedStat","repoStats","reporter","repoStatsIncrementCounter","repoInterceptServerData","customAuthImpl","DataConnection","simpleListen","echo","onEcho","RealTimeConnection","ConnectionTarget","newHash","oldPut","forceRestClient","repoManagerForceRestClient","TEST_ACCESS","registerDatabase","originalModule","keyList","hasProp","hasElementType","equal","arrA","arrB","dateA","dateB","regexpA","regexpB","AsyncMode","ConcurrentMode","ContextConsumer","ContextProvider","Lazy","Portal","isAsyncMode","isConcurrentMode","isContextConsumer","isContextProvider","isForwardRef","isFragment","isPortal","isProfiler","isStrictMode","isSuspense","isValidElementType","typeOf"],"mappings":"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","file":"static/js/2.467ec61d.chunk.js","sourcesContent":["'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","/*! *****************************************************************************\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    Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\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) {\r\n    for (var i = 0, il = from.length, j = to.length; i < il; i++, j++)\r\n        to[j] = from[i];\r\n    return to;\r\n}\r\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, privateMap) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to get private field on non-instance\");\r\n    }\r\n    return privateMap.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, privateMap, value) {\r\n    if (!privateMap.has(receiver)) {\r\n        throw new TypeError(\"attempted to set private field on non-instance\");\r\n    }\r\n    privateMap.set(receiver, value);\r\n    return value;\r\n}\r\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n// Key to attach FID to in gtag params.\nexport const GA_FID_KEY = 'firebase_id';\nexport const ORIGIN_KEY = 'origin';\n\nexport const FETCH_TIMEOUT_MILLIS = 60 * 1000;\n\nexport const DYNAMIC_CONFIG_URL =\n  'https://firebase.googleapis.com/v1alpha/projects/-/apps/{app-id}/webConfig';\n\nexport const GTAG_URL = 'https://www.googletagmanager.com/gtag/js';\n\nexport enum GtagCommand {\n  EVENT = 'event',\n  SET = 'set',\n  CONFIG = 'config'\n}\n\n/**\n * Officially recommended event names for gtag.js\n * Any other string is also allowed.\n *\n * @public\n */\nexport enum EventName {\n  ADD_SHIPPING_INFO = 'add_shipping_info',\n  ADD_PAYMENT_INFO = 'add_payment_info',\n  ADD_TO_CART = 'add_to_cart',\n  ADD_TO_WISHLIST = 'add_to_wishlist',\n  BEGIN_CHECKOUT = 'begin_checkout',\n  /**\n   * @deprecated\n   * This event name is deprecated and is unsupported in updated\n   * Enhanced Ecommerce reports.\n   */\n  CHECKOUT_PROGRESS = 'checkout_progress',\n  EXCEPTION = 'exception',\n  GENERATE_LEAD = 'generate_lead',\n  LOGIN = 'login',\n  PAGE_VIEW = 'page_view',\n  PURCHASE = 'purchase',\n  REFUND = 'refund',\n  REMOVE_FROM_CART = 'remove_from_cart',\n  SCREEN_VIEW = 'screen_view',\n  SEARCH = 'search',\n  SELECT_CONTENT = 'select_content',\n  SELECT_ITEM = 'select_item',\n  SELECT_PROMOTION = 'select_promotion',\n  /** @deprecated */\n  SET_CHECKOUT_OPTION = 'set_checkout_option',\n  SHARE = 'share',\n  SIGN_UP = 'sign_up',\n  TIMING_COMPLETE = 'timing_complete',\n  VIEW_CART = 'view_cart',\n  VIEW_ITEM = 'view_item',\n  VIEW_ITEM_LIST = 'view_item_list',\n  VIEW_PROMOTION = 'view_promotion',\n  VIEW_SEARCH_RESULTS = 'view_search_results'\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { CONSTANTS } from './constants';\n\n/**\n * Throws an error if the provided assertion is falsy\n */\nexport const assert = function (assertion: unknown, message: string): void {\n  if (!assertion) {\n    throw assertionError(message);\n  }\n};\n\n/**\n * Returns an Error object suitable for throwing.\n */\nexport const assertionError = function (message: string): Error {\n  return new Error(\n    'Firebase Database (' +\n      CONSTANTS.SDK_VERSION +\n      ') INTERNAL ASSERT FAILED: ' +\n      message\n  );\n};\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nconst stringToByteArray = function (str: string): number[] {\n  // TODO(user): Use native implementations if/when available\n  const out: number[] = [];\n  let p = 0;\n  for (let i = 0; i < str.length; i++) {\n    let c = str.charCodeAt(i);\n    if (c < 128) {\n      out[p++] = c;\n    } else if (c < 2048) {\n      out[p++] = (c >> 6) | 192;\n      out[p++] = (c & 63) | 128;\n    } else if (\n      (c & 0xfc00) === 0xd800 &&\n      i + 1 < str.length &&\n      (str.charCodeAt(i + 1) & 0xfc00) === 0xdc00\n    ) {\n      // Surrogate Pair\n      c = 0x10000 + ((c & 0x03ff) << 10) + (str.charCodeAt(++i) & 0x03ff);\n      out[p++] = (c >> 18) | 240;\n      out[p++] = ((c >> 12) & 63) | 128;\n      out[p++] = ((c >> 6) & 63) | 128;\n      out[p++] = (c & 63) | 128;\n    } else {\n      out[p++] = (c >> 12) | 224;\n      out[p++] = ((c >> 6) & 63) | 128;\n      out[p++] = (c & 63) | 128;\n    }\n  }\n  return out;\n};\n\n/**\n * Turns an array of numbers into the string given by the concatenation of the\n * characters to which the numbers correspond.\n * @param bytes Array of numbers representing characters.\n * @return Stringification of the array.\n */\nconst byteArrayToString = function (bytes: number[]): string {\n  // TODO(user): Use native implementations if/when available\n  const out: string[] = [];\n  let pos = 0,\n    c = 0;\n  while (pos < bytes.length) {\n    const c1 = bytes[pos++];\n    if (c1 < 128) {\n      out[c++] = String.fromCharCode(c1);\n    } else if (c1 > 191 && c1 < 224) {\n      const c2 = bytes[pos++];\n      out[c++] = String.fromCharCode(((c1 & 31) << 6) | (c2 & 63));\n    } else if (c1 > 239 && c1 < 365) {\n      // Surrogate Pair\n      const c2 = bytes[pos++];\n      const c3 = bytes[pos++];\n      const c4 = bytes[pos++];\n      const u =\n        (((c1 & 7) << 18) | ((c2 & 63) << 12) | ((c3 & 63) << 6) | (c4 & 63)) -\n        0x10000;\n      out[c++] = String.fromCharCode(0xd800 + (u >> 10));\n      out[c++] = String.fromCharCode(0xdc00 + (u & 1023));\n    } else {\n      const c2 = bytes[pos++];\n      const c3 = bytes[pos++];\n      out[c++] = String.fromCharCode(\n        ((c1 & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63)\n      );\n    }\n  }\n  return out.join('');\n};\n\ninterface Base64 {\n  byteToCharMap_: { [key: number]: string } | null;\n  charToByteMap_: { [key: string]: number } | null;\n  byteToCharMapWebSafe_: { [key: number]: string } | null;\n  charToByteMapWebSafe_: { [key: string]: number } | null;\n  ENCODED_VALS_BASE: string;\n  readonly ENCODED_VALS: string;\n  readonly ENCODED_VALS_WEBSAFE: string;\n  HAS_NATIVE_SUPPORT: boolean;\n  encodeByteArray(input: number[] | Uint8Array, webSafe?: boolean): string;\n  encodeString(input: string, webSafe?: boolean): string;\n  decodeString(input: string, webSafe: boolean): string;\n  decodeStringToByteArray(input: string, webSafe: boolean): number[];\n  init_(): void;\n}\n\n// We define it as an object literal instead of a class because a class compiled down to es5 can't\n// be treeshaked. https://github.com/rollup/rollup/issues/1691\n// Static lookup maps, lazily populated by init_()\nexport const base64: Base64 = {\n  /**\n   * Maps bytes to characters.\n   */\n  byteToCharMap_: null,\n\n  /**\n   * Maps characters to bytes.\n   */\n  charToByteMap_: null,\n\n  /**\n   * Maps bytes to websafe characters.\n   * @private\n   */\n  byteToCharMapWebSafe_: null,\n\n  /**\n   * Maps websafe characters to bytes.\n   * @private\n   */\n  charToByteMapWebSafe_: null,\n\n  /**\n   * Our default alphabet, shared between\n   * ENCODED_VALS and ENCODED_VALS_WEBSAFE\n   */\n  ENCODED_VALS_BASE:\n    'ABCDEFGHIJKLMNOPQRSTUVWXYZ' + 'abcdefghijklmnopqrstuvwxyz' + '0123456789',\n\n  /**\n   * Our default alphabet. Value 64 (=) is special; it means \"nothing.\"\n   */\n  get ENCODED_VALS() {\n    return this.ENCODED_VALS_BASE + '+/=';\n  },\n\n  /**\n   * Our websafe alphabet.\n   */\n  get ENCODED_VALS_WEBSAFE() {\n    return this.ENCODED_VALS_BASE + '-_.';\n  },\n\n  /**\n   * Whether this browser supports the atob and btoa functions. This extension\n   * started at Mozilla but is now implemented by many browsers. We use the\n   * ASSUME_* variables to avoid pulling in the full useragent detection library\n   * but still allowing the standard per-browser compilations.\n   *\n   */\n  HAS_NATIVE_SUPPORT: typeof atob === 'function',\n\n  /**\n   * Base64-encode an array of bytes.\n   *\n   * @param input An array of bytes (numbers with\n   *     value in [0, 255]) to encode.\n   * @param webSafe Boolean indicating we should use the\n   *     alternative alphabet.\n   * @return The base64 encoded string.\n   */\n  encodeByteArray(input: number[] | Uint8Array, webSafe?: boolean): string {\n    if (!Array.isArray(input)) {\n      throw Error('encodeByteArray takes an array as a parameter');\n    }\n\n    this.init_();\n\n    const byteToCharMap = webSafe\n      ? this.byteToCharMapWebSafe_!\n      : this.byteToCharMap_!;\n\n    const output = [];\n\n    for (let i = 0; i < input.length; i += 3) {\n      const byte1 = input[i];\n      const haveByte2 = i + 1 < input.length;\n      const byte2 = haveByte2 ? input[i + 1] : 0;\n      const haveByte3 = i + 2 < input.length;\n      const byte3 = haveByte3 ? input[i + 2] : 0;\n\n      const outByte1 = byte1 >> 2;\n      const outByte2 = ((byte1 & 0x03) << 4) | (byte2 >> 4);\n      let outByte3 = ((byte2 & 0x0f) << 2) | (byte3 >> 6);\n      let outByte4 = byte3 & 0x3f;\n\n      if (!haveByte3) {\n        outByte4 = 64;\n\n        if (!haveByte2) {\n          outByte3 = 64;\n        }\n      }\n\n      output.push(\n        byteToCharMap[outByte1],\n        byteToCharMap[outByte2],\n        byteToCharMap[outByte3],\n        byteToCharMap[outByte4]\n      );\n    }\n\n    return output.join('');\n  },\n\n  /**\n   * Base64-encode a string.\n   *\n   * @param input A string to encode.\n   * @param webSafe If true, we should use the\n   *     alternative alphabet.\n   * @return The base64 encoded string.\n   */\n  encodeString(input: string, webSafe?: boolean): string {\n    // Shortcut for Mozilla browsers that implement\n    // a native base64 encoder in the form of \"btoa/atob\"\n    if (this.HAS_NATIVE_SUPPORT && !webSafe) {\n      return btoa(input);\n    }\n    return this.encodeByteArray(stringToByteArray(input), webSafe);\n  },\n\n  /**\n   * Base64-decode a string.\n   *\n   * @param input to decode.\n   * @param webSafe True if we should use the\n   *     alternative alphabet.\n   * @return string representing the decoded value.\n   */\n  decodeString(input: string, webSafe: boolean): string {\n    // Shortcut for Mozilla browsers that implement\n    // a native base64 encoder in the form of \"btoa/atob\"\n    if (this.HAS_NATIVE_SUPPORT && !webSafe) {\n      return atob(input);\n    }\n    return byteArrayToString(this.decodeStringToByteArray(input, webSafe));\n  },\n\n  /**\n   * Base64-decode a string.\n   *\n   * In base-64 decoding, groups of four characters are converted into three\n   * bytes.  If the encoder did not apply padding, the input length may not\n   * be a multiple of 4.\n   *\n   * In this case, the last group will have fewer than 4 characters, and\n   * padding will be inferred.  If the group has one or two characters, it decodes\n   * to one byte.  If the group has three characters, it decodes to two bytes.\n   *\n   * @param input Input to decode.\n   * @param webSafe True if we should use the web-safe alphabet.\n   * @return bytes representing the decoded value.\n   */\n  decodeStringToByteArray(input: string, webSafe: boolean): number[] {\n    this.init_();\n\n    const charToByteMap = webSafe\n      ? this.charToByteMapWebSafe_!\n      : this.charToByteMap_!;\n\n    const output: number[] = [];\n\n    for (let i = 0; i < input.length; ) {\n      const byte1 = charToByteMap[input.charAt(i++)];\n\n      const haveByte2 = i < input.length;\n      const byte2 = haveByte2 ? charToByteMap[input.charAt(i)] : 0;\n      ++i;\n\n      const haveByte3 = i < input.length;\n      const byte3 = haveByte3 ? charToByteMap[input.charAt(i)] : 64;\n      ++i;\n\n      const haveByte4 = i < input.length;\n      const byte4 = haveByte4 ? charToByteMap[input.charAt(i)] : 64;\n      ++i;\n\n      if (byte1 == null || byte2 == null || byte3 == null || byte4 == null) {\n        throw Error();\n      }\n\n      const outByte1 = (byte1 << 2) | (byte2 >> 4);\n      output.push(outByte1);\n\n      if (byte3 !== 64) {\n        const outByte2 = ((byte2 << 4) & 0xf0) | (byte3 >> 2);\n        output.push(outByte2);\n\n        if (byte4 !== 64) {\n          const outByte3 = ((byte3 << 6) & 0xc0) | byte4;\n          output.push(outByte3);\n        }\n      }\n    }\n\n    return output;\n  },\n\n  /**\n   * Lazy static initialization function. Called before\n   * accessing any of the static map variables.\n   * @private\n   */\n  init_() {\n    if (!this.byteToCharMap_) {\n      this.byteToCharMap_ = {};\n      this.charToByteMap_ = {};\n      this.byteToCharMapWebSafe_ = {};\n      this.charToByteMapWebSafe_ = {};\n\n      // We want quick mappings back and forth, so we precompute two maps.\n      for (let i = 0; i < this.ENCODED_VALS.length; i++) {\n        this.byteToCharMap_[i] = this.ENCODED_VALS.charAt(i);\n        this.charToByteMap_[this.byteToCharMap_[i]] = i;\n        this.byteToCharMapWebSafe_[i] = this.ENCODED_VALS_WEBSAFE.charAt(i);\n        this.charToByteMapWebSafe_[this.byteToCharMapWebSafe_[i]] = i;\n\n        // Be forgiving when decoding and correctly decode both encodings.\n        if (i >= this.ENCODED_VALS_BASE.length) {\n          this.charToByteMap_[this.ENCODED_VALS_WEBSAFE.charAt(i)] = i;\n          this.charToByteMapWebSafe_[this.ENCODED_VALS.charAt(i)] = i;\n        }\n      }\n    }\n  }\n};\n\n/**\n * URL-safe base64 encoding\n */\nexport const base64Encode = function (str: string): string {\n  const utf8Bytes = stringToByteArray(str);\n  return base64.encodeByteArray(utf8Bytes, true);\n};\n\n/**\n * URL-safe base64 decoding\n *\n * NOTE: DO NOT use the global atob() function - it does NOT support the\n * base64Url variant encoding.\n *\n * @param str To be decoded\n * @return Decoded result, if possible\n */\nexport const base64Decode = function (str: string): string | null {\n  try {\n    return base64.decodeString(str, true);\n  } catch (e) {\n    console.error('base64Decode failed: ', e);\n  }\n  return null;\n};\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Do a deep-copy of basic JavaScript Objects or Arrays.\n */\nexport function deepCopy<T>(value: T): T {\n  return deepExtend(undefined, value) as T;\n}\n\n/**\n * Copy properties from source to target (recursively allows extension\n * of Objects and Arrays).  Scalar values in the target are over-written.\n * If target is undefined, an object of the appropriate type will be created\n * (and returned).\n *\n * We recursively copy all child properties of plain Objects in the source- so\n * that namespace- like dictionaries are merged.\n *\n * Note that the target can be a function, in which case the properties in\n * the source Object are copied onto it as static properties of the Function.\n *\n * Note: we don't merge __proto__ to prevent prototype pollution\n */\nexport function deepExtend(target: unknown, source: unknown): unknown {\n  if (!(source instanceof Object)) {\n    return source;\n  }\n\n  switch (source.constructor) {\n    case Date:\n      // Treat Dates like scalars; if the target date object had any child\n      // properties - they will be lost!\n      const dateValue = source as Date;\n      return new Date(dateValue.getTime());\n\n    case Object:\n      if (target === undefined) {\n        target = {};\n      }\n      break;\n    case Array:\n      // Always copy the array source and overwrite the target.\n      target = [];\n      break;\n\n    default:\n      // Not a plain Object - treat it as a scalar.\n      return source;\n  }\n\n  for (const prop in source) {\n    // use isValidKey to guard against prototype pollution. See https://snyk.io/vuln/SNYK-JS-LODASH-450202\n    if (!source.hasOwnProperty(prop) || !isValidKey(prop)) {\n      continue;\n    }\n    (target as Record<string, unknown>)[prop] = deepExtend(\n      (target as Record<string, unknown>)[prop],\n      (source as Record<string, unknown>)[prop]\n    );\n  }\n\n  return target;\n}\n\nfunction isValidKey(key: string): boolean {\n  return key !== '__proto__';\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport class Deferred<R> {\n  promise: Promise<R>;\n  reject: (value?: unknown) => void = () => {};\n  resolve: (value?: unknown) => void = () => {};\n  constructor() {\n    this.promise = new Promise((resolve, reject) => {\n      this.resolve = resolve as (value?: unknown) => void;\n      this.reject = reject as (value?: unknown) => void;\n    });\n  }\n\n  /**\n   * Our API internals are not promiseified and cannot because our callback APIs have subtle expectations around\n   * invoking promises inline, which Promises are forbidden to do. This method accepts an optional node-style callback\n   * and returns a node-style callback which will resolve or reject the Deferred's promise.\n   */\n  wrapCallback(\n    callback?: (error?: unknown, value?: unknown) => void\n  ): (error: unknown, value?: unknown) => void {\n    return (error, value?) => {\n      if (error) {\n        this.reject(error);\n      } else {\n        this.resolve(value);\n      }\n      if (typeof callback === 'function') {\n        // Attaching noop handler just in case developer wasn't expecting\n        // promises\n        this.promise.catch(() => {});\n\n        // Some of our callbacks don't expect a value and our own tests\n        // assert that the parameter length is 1\n        if (callback.length === 1) {\n          callback(error);\n        } else {\n          callback(error, value);\n        }\n      }\n    };\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { CONSTANTS } from './constants';\n\n/**\n * Returns navigator.userAgent string or '' if it's not defined.\n * @return user agent string\n */\nexport function getUA(): string {\n  if (\n    typeof navigator !== 'undefined' &&\n    typeof navigator['userAgent'] === 'string'\n  ) {\n    return navigator['userAgent'];\n  } else {\n    return '';\n  }\n}\n\n/**\n * Detect Cordova / PhoneGap / Ionic frameworks on a mobile device.\n *\n * Deliberately does not rely on checking `file://` URLs (as this fails PhoneGap\n * in the Ripple emulator) nor Cordova `onDeviceReady`, which would normally\n * wait for a callback.\n */\nexport function isMobileCordova(): boolean {\n  return (\n    typeof window !== 'undefined' &&\n    // @ts-ignore Setting up an broadly applicable index signature for Window\n    // just to deal with this case would probably be a bad idea.\n    !!(window['cordova'] || window['phonegap'] || window['PhoneGap']) &&\n    /ios|iphone|ipod|ipad|android|blackberry|iemobile/i.test(getUA())\n  );\n}\n\n/**\n * Detect Node.js.\n *\n * @return true if Node.js environment is detected.\n */\n// Node detection logic from: https://github.com/iliakan/detect-node/\nexport function isNode(): boolean {\n  try {\n    return (\n      Object.prototype.toString.call(global.process) === '[object process]'\n    );\n  } catch (e) {\n    return false;\n  }\n}\n\n/**\n * Detect Browser Environment\n */\nexport function isBrowser(): boolean {\n  return typeof self === 'object' && self.self === self;\n}\n\n/**\n * Detect browser extensions (Chrome and Firefox at least).\n */\ninterface BrowserRuntime {\n  id?: unknown;\n}\ndeclare const chrome: { runtime?: BrowserRuntime };\ndeclare const browser: { runtime?: BrowserRuntime };\nexport function isBrowserExtension(): boolean {\n  const runtime =\n    typeof chrome === 'object'\n      ? chrome.runtime\n      : typeof browser === 'object'\n      ? browser.runtime\n      : undefined;\n  return typeof runtime === 'object' && runtime.id !== undefined;\n}\n\n/**\n * Detect React Native.\n *\n * @return true if ReactNative environment is detected.\n */\nexport function isReactNative(): boolean {\n  return (\n    typeof navigator === 'object' && navigator['product'] === 'ReactNative'\n  );\n}\n\n/** Detects Electron apps. */\nexport function isElectron(): boolean {\n  return getUA().indexOf('Electron/') >= 0;\n}\n\n/** Detects Internet Explorer. */\nexport function isIE(): boolean {\n  const ua = getUA();\n  return ua.indexOf('MSIE ') >= 0 || ua.indexOf('Trident/') >= 0;\n}\n\n/** Detects Universal Windows Platform apps. */\nexport function isUWP(): boolean {\n  return getUA().indexOf('MSAppHost/') >= 0;\n}\n\n/**\n * Detect whether the current SDK build is the Node version.\n *\n * @return true if it's the Node SDK build.\n */\nexport function isNodeSdk(): boolean {\n  return CONSTANTS.NODE_CLIENT === true || CONSTANTS.NODE_ADMIN === true;\n}\n\n/** Returns true if we are running in Safari. */\nexport function isSafari(): boolean {\n  return (\n    !isNode() &&\n    navigator.userAgent.includes('Safari') &&\n    !navigator.userAgent.includes('Chrome')\n  );\n}\n\n/**\n * This method checks if indexedDB is supported by current browser/service worker context\n * @return true if indexedDB is supported by current browser/service worker context\n */\nexport function isIndexedDBAvailable(): boolean {\n  return 'indexedDB' in self && indexedDB != null;\n}\n\n/**\n * This method validates browser context for indexedDB by opening a dummy indexedDB database and reject\n * if errors occur during the database open operation.\n */\nexport function validateIndexedDBOpenable(): Promise<boolean> {\n  return new Promise((resolve, reject) => {\n    try {\n      let preExist: boolean = true;\n      const DB_CHECK_NAME =\n        'validate-browser-context-for-indexeddb-analytics-module';\n      const request = window.indexedDB.open(DB_CHECK_NAME);\n      request.onsuccess = () => {\n        request.result.close();\n        // delete database only when it doesn't pre-exist\n        if (!preExist) {\n          window.indexedDB.deleteDatabase(DB_CHECK_NAME);\n        }\n        resolve(true);\n      };\n      request.onupgradeneeded = () => {\n        preExist = false;\n      };\n\n      request.onerror = () => {\n        reject(request.error?.message || '');\n      };\n    } catch (error) {\n      reject(error);\n    }\n  });\n}\n\n/**\n *\n * This method checks whether cookie is enabled within current browser\n * @return true if cookie is enabled within current browser\n */\nexport function areCookiesEnabled(): boolean {\n  if (!navigator || !navigator.cookieEnabled) {\n    return false;\n  }\n  return true;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ErrorFactory, FirebaseError } from '@firebase/util';\n\nexport const enum ErrorCode {\n  REGISTRATION_WINDOW = 'registration-window',\n  REGISTRATION_PROJECT_ID = 'registration-project-id',\n  REGISTRATION_API_KEY = 'registration-api-key',\n  REGISTRATION_APP_ID = 'registration-app-id',\n  STORAGE_OPEN = 'storage-open',\n  STORAGE_GET = 'storage-get',\n  STORAGE_SET = 'storage-set',\n  STORAGE_DELETE = 'storage-delete',\n  FETCH_NETWORK = 'fetch-client-network',\n  FETCH_TIMEOUT = 'fetch-timeout',\n  FETCH_THROTTLE = 'fetch-throttle',\n  FETCH_PARSE = 'fetch-client-parse',\n  FETCH_STATUS = 'fetch-status'\n}\n\nconst ERROR_DESCRIPTION_MAP: { readonly [key in ErrorCode]: string } = {\n  [ErrorCode.REGISTRATION_WINDOW]:\n    'Undefined window object. This SDK only supports usage in a browser environment.',\n  [ErrorCode.REGISTRATION_PROJECT_ID]:\n    'Undefined project identifier. Check Firebase app initialization.',\n  [ErrorCode.REGISTRATION_API_KEY]:\n    'Undefined API key. Check Firebase app initialization.',\n  [ErrorCode.REGISTRATION_APP_ID]:\n    'Undefined app identifier. Check Firebase app initialization.',\n  [ErrorCode.STORAGE_OPEN]:\n    'Error thrown when opening storage. Original error: {$originalErrorMessage}.',\n  [ErrorCode.STORAGE_GET]:\n    'Error thrown when reading from storage. Original error: {$originalErrorMessage}.',\n  [ErrorCode.STORAGE_SET]:\n    'Error thrown when writing to storage. Original error: {$originalErrorMessage}.',\n  [ErrorCode.STORAGE_DELETE]:\n    'Error thrown when deleting from storage. Original error: {$originalErrorMessage}.',\n  [ErrorCode.FETCH_NETWORK]:\n    'Fetch client failed to connect to a network. Check Internet connection.' +\n    ' Original error: {$originalErrorMessage}.',\n  [ErrorCode.FETCH_TIMEOUT]:\n    'The config fetch request timed out. ' +\n    ' Configure timeout using \"fetchTimeoutMillis\" SDK setting.',\n  [ErrorCode.FETCH_THROTTLE]:\n    'The config fetch request timed out while in an exponential backoff state.' +\n    ' Configure timeout using \"fetchTimeoutMillis\" SDK setting.' +\n    ' Unix timestamp in milliseconds when fetch request throttling ends: {$throttleEndTimeMillis}.',\n  [ErrorCode.FETCH_PARSE]:\n    'Fetch client could not parse response.' +\n    ' Original error: {$originalErrorMessage}.',\n  [ErrorCode.FETCH_STATUS]:\n    'Fetch server returned an HTTP error status. HTTP status: {$httpStatus}.'\n};\n\n// Note this is effectively a type system binding a code to params. This approach overlaps with the\n// role of TS interfaces, but works well for a few reasons:\n// 1) JS is unaware of TS interfaces, eg we can't test for interface implementation in JS\n// 2) callers should have access to a human-readable summary of the error and this interpolates\n//    params into an error message;\n// 3) callers should be able to programmatically access data associated with an error, which\n//    ErrorData provides.\ninterface ErrorParams {\n  [ErrorCode.STORAGE_OPEN]: { originalErrorMessage: string | undefined };\n  [ErrorCode.STORAGE_GET]: { originalErrorMessage: string | undefined };\n  [ErrorCode.STORAGE_SET]: { originalErrorMessage: string | undefined };\n  [ErrorCode.STORAGE_DELETE]: { originalErrorMessage: string | undefined };\n  [ErrorCode.FETCH_NETWORK]: { originalErrorMessage: string };\n  [ErrorCode.FETCH_THROTTLE]: { throttleEndTimeMillis: number };\n  [ErrorCode.FETCH_PARSE]: { originalErrorMessage: string };\n  [ErrorCode.FETCH_STATUS]: { httpStatus: number };\n}\n\nexport const ERROR_FACTORY = new ErrorFactory<ErrorCode, ErrorParams>(\n  'remoteconfig' /* service */,\n  'Remote Config' /* service name */,\n  ERROR_DESCRIPTION_MAP\n);\n\n// Note how this is like typeof/instanceof, but for ErrorCode.\nexport function hasErrorCode(e: Error, errorCode: ErrorCode): boolean {\n  return e instanceof FirebaseError && e.code.indexOf(errorCode) !== -1;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Evaluates a JSON string into a javascript object.\n *\n * @param {string} str A string containing JSON.\n * @return {*} The javascript object representing the specified JSON.\n */\nexport function jsonEval(str: string): unknown {\n  return JSON.parse(str);\n}\n\n/**\n * Returns JSON representing a javascript object.\n * @param {*} data Javascript object to be stringified.\n * @return {string} The JSON contents of the object.\n */\nexport function stringify(data: unknown): string {\n  return JSON.stringify(data);\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { base64Decode } from './crypt';\nimport { jsonEval } from './json';\n\ninterface Claims {\n  [key: string]: {};\n}\n\ninterface DecodedToken {\n  header: object;\n  claims: Claims;\n  data: object;\n  signature: string;\n}\n\n/**\n * Decodes a Firebase auth. token into constituent parts.\n *\n * Notes:\n * - May return with invalid / incomplete claims if there's no native base64 decoding support.\n * - Doesn't check if the token is actually valid.\n */\nexport const decode = function (token: string): DecodedToken {\n  let header = {},\n    claims: Claims = {},\n    data = {},\n    signature = '';\n\n  try {\n    const parts = token.split('.');\n    header = jsonEval(base64Decode(parts[0]) || '') as object;\n    claims = jsonEval(base64Decode(parts[1]) || '') as Claims;\n    signature = parts[2];\n    data = claims['d'] || {};\n    delete claims['d'];\n  } catch (e) {}\n\n  return {\n    header,\n    claims,\n    data,\n    signature\n  };\n};\n\ninterface DecodedToken {\n  header: object;\n  claims: Claims;\n  data: object;\n  signature: string;\n}\n\n/**\n * Decodes a Firebase auth. token and checks the validity of its time-based claims. Will return true if the\n * token is within the time window authorized by the 'nbf' (not-before) and 'iat' (issued-at) claims.\n *\n * Notes:\n * - May return a false negative if there's no native base64 decoding support.\n * - Doesn't check if the token is actually valid.\n */\nexport const isValidTimestamp = function (token: string): boolean {\n  const claims: Claims = decode(token).claims;\n  const now: number = Math.floor(new Date().getTime() / 1000);\n  let validSince: number = 0,\n    validUntil: number = 0;\n\n  if (typeof claims === 'object') {\n    if (claims.hasOwnProperty('nbf')) {\n      validSince = claims['nbf'] as number;\n    } else if (claims.hasOwnProperty('iat')) {\n      validSince = claims['iat'] as number;\n    }\n\n    if (claims.hasOwnProperty('exp')) {\n      validUntil = claims['exp'] as number;\n    } else {\n      // token will expire after 24h by default\n      validUntil = validSince + 86400;\n    }\n  }\n\n  return (\n    !!now &&\n    !!validSince &&\n    !!validUntil &&\n    now >= validSince &&\n    now <= validUntil\n  );\n};\n\n/**\n * Decodes a Firebase auth. token and returns its issued at time if valid, null otherwise.\n *\n * Notes:\n * - May return null if there's no native base64 decoding support.\n * - Doesn't check if the token is actually valid.\n */\nexport const issuedAtTime = function (token: string): number | null {\n  const claims: Claims = decode(token).claims;\n  if (typeof claims === 'object' && claims.hasOwnProperty('iat')) {\n    return claims['iat'] as number;\n  }\n  return null;\n};\n\n/**\n * Decodes a Firebase auth. token and checks the validity of its format. Expects a valid issued-at time.\n *\n * Notes:\n * - May return a false negative if there's no native base64 decoding support.\n * - Doesn't check if the token is actually valid.\n */\nexport const isValidFormat = function (token: string): boolean {\n  const decoded = decode(token),\n    claims = decoded.claims;\n\n  return !!claims && typeof claims === 'object' && claims.hasOwnProperty('iat');\n};\n\n/**\n * Attempts to peer into an auth token and determine if it's an admin auth token by looking at the claims portion.\n *\n * Notes:\n * - May return a false negative if there's no native base64 decoding support.\n * - Doesn't check if the token is actually valid.\n */\nexport const isAdmin = function (token: string): boolean {\n  const claims: Claims = decode(token).claims;\n  return typeof claims === 'object' && claims['admin'] === true;\n};\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport function contains<T extends object>(obj: T, key: string): boolean {\n  return Object.prototype.hasOwnProperty.call(obj, key);\n}\n\nexport function safeGet<T extends object, K extends keyof T>(\n  obj: T,\n  key: K\n): T[K] | undefined {\n  if (Object.prototype.hasOwnProperty.call(obj, key)) {\n    return obj[key];\n  } else {\n    return undefined;\n  }\n}\n\nexport function isEmpty(obj: object): obj is {} {\n  for (const key in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, key)) {\n      return false;\n    }\n  }\n  return true;\n}\n\nexport function map<K extends string, V, U>(\n  obj: { [key in K]: V },\n  fn: (value: V, key: K, obj: { [key in K]: V }) => U,\n  contextObj?: unknown\n): { [key in K]: U } {\n  const res: Partial<{ [key in K]: U }> = {};\n  for (const key in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, key)) {\n      res[key] = fn.call(contextObj, obj[key], key, obj);\n    }\n  }\n  return res as { [key in K]: U };\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Returns a querystring-formatted string (e.g. &arg=val&arg2=val2) from a\n * params object (e.g. {arg: 'val', arg2: 'val2'})\n * Note: You must prepend it with ? when adding it to a URL.\n */\nexport function querystring(querystringParams: {\n  [key: string]: string | number;\n}): string {\n  const params = [];\n  for (const [key, value] of Object.entries(querystringParams)) {\n    if (Array.isArray(value)) {\n      value.forEach(arrayVal => {\n        params.push(\n          encodeURIComponent(key) + '=' + encodeURIComponent(arrayVal)\n        );\n      });\n    } else {\n      params.push(encodeURIComponent(key) + '=' + encodeURIComponent(value));\n    }\n  }\n  return params.length ? '&' + params.join('&') : '';\n}\n\n/**\n * Decodes a querystring (e.g. ?arg=val&arg2=val2) into a params object\n * (e.g. {arg: 'val', arg2: 'val2'})\n */\nexport function querystringDecode(querystring: string): Record<string, string> {\n  const obj: Record<string, string> = {};\n  const tokens = querystring.replace(/^\\?/, '').split('&');\n\n  tokens.forEach(token => {\n    if (token) {\n      const [key, value] = token.split('=');\n      obj[decodeURIComponent(key)] = decodeURIComponent(value);\n    }\n  });\n  return obj;\n}\n\n/**\n * Extract the query string part of a URL, including the leading question mark (if present).\n */\nexport function extractQuerystring(url: string): string {\n  const queryStart = url.indexOf('?');\n  if (!queryStart) {\n    return '';\n  }\n  const fragmentStart = url.indexOf('#', queryStart);\n  return url.substring(\n    queryStart,\n    fragmentStart > 0 ? fragmentStart : undefined\n  );\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview SHA-1 cryptographic hash.\n * Variable names follow the notation in FIPS PUB 180-3:\n * http://csrc.nist.gov/publications/fips/fips180-3/fips180-3_final.pdf.\n *\n * Usage:\n *   var sha1 = new sha1();\n *   sha1.update(bytes);\n *   var hash = sha1.digest();\n *\n * Performance:\n *   Chrome 23:   ~400 Mbit/s\n *   Firefox 16:  ~250 Mbit/s\n *\n */\n\n/**\n * SHA-1 cryptographic hash constructor.\n *\n * The properties declared here are discussed in the above algorithm document.\n * @constructor\n * @final\n * @struct\n */\nexport class Sha1 {\n  /**\n   * Holds the previous values of accumulated variables a-e in the compress_\n   * function.\n   * @private\n   */\n  private chain_: number[] = [];\n\n  /**\n   * A buffer holding the partially computed hash result.\n   * @private\n   */\n  private buf_: number[] = [];\n\n  /**\n   * An array of 80 bytes, each a part of the message to be hashed.  Referred to\n   * as the message schedule in the docs.\n   * @private\n   */\n  private W_: number[] = [];\n\n  /**\n   * Contains data needed to pad messages less than 64 bytes.\n   * @private\n   */\n  private pad_: number[] = [];\n\n  /**\n   * @private {number}\n   */\n  private inbuf_: number = 0;\n\n  /**\n   * @private {number}\n   */\n  private total_: number = 0;\n\n  blockSize: number;\n\n  constructor() {\n    this.blockSize = 512 / 8;\n\n    this.pad_[0] = 128;\n    for (let i = 1; i < this.blockSize; ++i) {\n      this.pad_[i] = 0;\n    }\n\n    this.reset();\n  }\n\n  reset(): void {\n    this.chain_[0] = 0x67452301;\n    this.chain_[1] = 0xefcdab89;\n    this.chain_[2] = 0x98badcfe;\n    this.chain_[3] = 0x10325476;\n    this.chain_[4] = 0xc3d2e1f0;\n\n    this.inbuf_ = 0;\n    this.total_ = 0;\n  }\n\n  /**\n   * Internal compress helper function.\n   * @param buf Block to compress.\n   * @param offset Offset of the block in the buffer.\n   * @private\n   */\n  compress_(buf: number[] | Uint8Array | string, offset?: number): void {\n    if (!offset) {\n      offset = 0;\n    }\n\n    const W = this.W_;\n\n    // get 16 big endian words\n    if (typeof buf === 'string') {\n      for (let i = 0; i < 16; i++) {\n        // TODO(user): [bug 8140122] Recent versions of Safari for Mac OS and iOS\n        // have a bug that turns the post-increment ++ operator into pre-increment\n        // during JIT compilation.  We have code that depends heavily on SHA-1 for\n        // correctness and which is affected by this bug, so I've removed all uses\n        // of post-increment ++ in which the result value is used.  We can revert\n        // this change once the Safari bug\n        // (https://bugs.webkit.org/show_bug.cgi?id=109036) has been fixed and\n        // most clients have been updated.\n        W[i] =\n          (buf.charCodeAt(offset) << 24) |\n          (buf.charCodeAt(offset + 1) << 16) |\n          (buf.charCodeAt(offset + 2) << 8) |\n          buf.charCodeAt(offset + 3);\n        offset += 4;\n      }\n    } else {\n      for (let i = 0; i < 16; i++) {\n        W[i] =\n          (buf[offset] << 24) |\n          (buf[offset + 1] << 16) |\n          (buf[offset + 2] << 8) |\n          buf[offset + 3];\n        offset += 4;\n      }\n    }\n\n    // expand to 80 words\n    for (let i = 16; i < 80; i++) {\n      const t = W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16];\n      W[i] = ((t << 1) | (t >>> 31)) & 0xffffffff;\n    }\n\n    let a = this.chain_[0];\n    let b = this.chain_[1];\n    let c = this.chain_[2];\n    let d = this.chain_[3];\n    let e = this.chain_[4];\n    let f, k;\n\n    // TODO(user): Try to unroll this loop to speed up the computation.\n    for (let i = 0; i < 80; i++) {\n      if (i < 40) {\n        if (i < 20) {\n          f = d ^ (b & (c ^ d));\n          k = 0x5a827999;\n        } else {\n          f = b ^ c ^ d;\n          k = 0x6ed9eba1;\n        }\n      } else {\n        if (i < 60) {\n          f = (b & c) | (d & (b | c));\n          k = 0x8f1bbcdc;\n        } else {\n          f = b ^ c ^ d;\n          k = 0xca62c1d6;\n        }\n      }\n\n      const t = (((a << 5) | (a >>> 27)) + f + e + k + W[i]) & 0xffffffff;\n      e = d;\n      d = c;\n      c = ((b << 30) | (b >>> 2)) & 0xffffffff;\n      b = a;\n      a = t;\n    }\n\n    this.chain_[0] = (this.chain_[0] + a) & 0xffffffff;\n    this.chain_[1] = (this.chain_[1] + b) & 0xffffffff;\n    this.chain_[2] = (this.chain_[2] + c) & 0xffffffff;\n    this.chain_[3] = (this.chain_[3] + d) & 0xffffffff;\n    this.chain_[4] = (this.chain_[4] + e) & 0xffffffff;\n  }\n\n  update(bytes?: number[] | Uint8Array | string, length?: number): void {\n    // TODO(johnlenz): tighten the function signature and remove this check\n    if (bytes == null) {\n      return;\n    }\n\n    if (length === undefined) {\n      length = bytes.length;\n    }\n\n    const lengthMinusBlock = length - this.blockSize;\n    let n = 0;\n    // Using local instead of member variables gives ~5% speedup on Firefox 16.\n    const buf = this.buf_;\n    let inbuf = this.inbuf_;\n\n    // The outer while loop should execute at most twice.\n    while (n < length) {\n      // When we have no data in the block to top up, we can directly process the\n      // input buffer (assuming it contains sufficient data). This gives ~25%\n      // speedup on Chrome 23 and ~15% speedup on Firefox 16, but requires that\n      // the data is provided in large chunks (or in multiples of 64 bytes).\n      if (inbuf === 0) {\n        while (n <= lengthMinusBlock) {\n          this.compress_(bytes, n);\n          n += this.blockSize;\n        }\n      }\n\n      if (typeof bytes === 'string') {\n        while (n < length) {\n          buf[inbuf] = bytes.charCodeAt(n);\n          ++inbuf;\n          ++n;\n          if (inbuf === this.blockSize) {\n            this.compress_(buf);\n            inbuf = 0;\n            // Jump to the outer loop so we use the full-block optimization.\n            break;\n          }\n        }\n      } else {\n        while (n < length) {\n          buf[inbuf] = bytes[n];\n          ++inbuf;\n          ++n;\n          if (inbuf === this.blockSize) {\n            this.compress_(buf);\n            inbuf = 0;\n            // Jump to the outer loop so we use the full-block optimization.\n            break;\n          }\n        }\n      }\n    }\n\n    this.inbuf_ = inbuf;\n    this.total_ += length;\n  }\n\n  /** @override */\n  digest(): number[] {\n    const digest: number[] = [];\n    let totalBits = this.total_ * 8;\n\n    // Add pad 0x80 0x00*.\n    if (this.inbuf_ < 56) {\n      this.update(this.pad_, 56 - this.inbuf_);\n    } else {\n      this.update(this.pad_, this.blockSize - (this.inbuf_ - 56));\n    }\n\n    // Add # bits.\n    for (let i = this.blockSize - 1; i >= 56; i--) {\n      this.buf_[i] = totalBits & 255;\n      totalBits /= 256; // Don't use bit-shifting here!\n    }\n\n    this.compress_(this.buf_);\n\n    let n = 0;\n    for (let i = 0; i < 5; i++) {\n      for (let j = 24; j >= 0; j -= 8) {\n        digest[n] = (this.chain_[i] >> j) & 255;\n        ++n;\n      }\n    }\n    return digest;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nexport type NextFn<T> = (value: T) => void;\nexport type ErrorFn = (error: Error) => void;\nexport type CompleteFn = () => void;\n\nexport interface Observer<T> {\n  // Called once for each value in a stream of values.\n  next: NextFn<T>;\n\n  // A stream terminates by a single call to EITHER error() or complete().\n  error: ErrorFn;\n\n  // No events will be sent to next() once complete() is called.\n  complete: CompleteFn;\n}\n\nexport type PartialObserver<T> = Partial<Observer<T>>;\n\n// TODO: Support also Unsubscribe.unsubscribe?\nexport type Unsubscribe = () => void;\n\n/**\n * The Subscribe interface has two forms - passing the inline function\n * callbacks, or a object interface with callback properties.\n */\nexport interface Subscribe<T> {\n  (next?: NextFn<T>, error?: ErrorFn, complete?: CompleteFn): Unsubscribe;\n  (observer: PartialObserver<T>): Unsubscribe;\n}\n\nexport interface Observable<T> {\n  // Subscribe method\n  subscribe: Subscribe<T>;\n}\n\nexport type Executor<T> = (observer: Observer<T>) => void;\n\n/**\n * Helper to make a Subscribe function (just like Promise helps make a\n * Thenable).\n *\n * @param executor Function which can make calls to a single Observer\n *     as a proxy.\n * @param onNoObservers Callback when count of Observers goes to zero.\n */\nexport function createSubscribe<T>(\n  executor: Executor<T>,\n  onNoObservers?: Executor<T>\n): Subscribe<T> {\n  const proxy = new ObserverProxy<T>(executor, onNoObservers);\n  return proxy.subscribe.bind(proxy);\n}\n\n/**\n * Implement fan-out for any number of Observers attached via a subscribe\n * function.\n */\nclass ObserverProxy<T> implements Observer<T> {\n  private observers: Array<Observer<T>> | undefined = [];\n  private unsubscribes: Unsubscribe[] = [];\n  private onNoObservers: Executor<T> | undefined;\n  private observerCount = 0;\n  // Micro-task scheduling by calling task.then().\n  private task = Promise.resolve();\n  private finalized = false;\n  private finalError?: Error;\n\n  /**\n   * @param executor Function which can make calls to a single Observer\n   *     as a proxy.\n   * @param onNoObservers Callback when count of Observers goes to zero.\n   */\n  constructor(executor: Executor<T>, onNoObservers?: Executor<T>) {\n    this.onNoObservers = onNoObservers;\n    // Call the executor asynchronously so subscribers that are called\n    // synchronously after the creation of the subscribe function\n    // can still receive the very first value generated in the executor.\n    this.task\n      .then(() => {\n        executor(this);\n      })\n      .catch(e => {\n        this.error(e);\n      });\n  }\n\n  next(value: T): void {\n    this.forEachObserver((observer: Observer<T>) => {\n      observer.next(value);\n    });\n  }\n\n  error(error: Error): void {\n    this.forEachObserver((observer: Observer<T>) => {\n      observer.error(error);\n    });\n    this.close(error);\n  }\n\n  complete(): void {\n    this.forEachObserver((observer: Observer<T>) => {\n      observer.complete();\n    });\n    this.close();\n  }\n\n  /**\n   * Subscribe function that can be used to add an Observer to the fan-out list.\n   *\n   * - We require that no event is sent to a subscriber sychronously to their\n   *   call to subscribe().\n   */\n  subscribe(\n    nextOrObserver?: NextFn<T> | PartialObserver<T>,\n    error?: ErrorFn,\n    complete?: CompleteFn\n  ): Unsubscribe {\n    let observer: Observer<T>;\n\n    if (\n      nextOrObserver === undefined &&\n      error === undefined &&\n      complete === undefined\n    ) {\n      throw new Error('Missing Observer.');\n    }\n\n    // Assemble an Observer object when passed as callback functions.\n    if (\n      implementsAnyMethods(nextOrObserver as { [key: string]: unknown }, [\n        'next',\n        'error',\n        'complete'\n      ])\n    ) {\n      observer = nextOrObserver as Observer<T>;\n    } else {\n      observer = {\n        next: nextOrObserver as NextFn<T>,\n        error,\n        complete\n      } as Observer<T>;\n    }\n\n    if (observer.next === undefined) {\n      observer.next = noop as NextFn<T>;\n    }\n    if (observer.error === undefined) {\n      observer.error = noop as ErrorFn;\n    }\n    if (observer.complete === undefined) {\n      observer.complete = noop as CompleteFn;\n    }\n\n    const unsub = this.unsubscribeOne.bind(this, this.observers!.length);\n\n    // Attempt to subscribe to a terminated Observable - we\n    // just respond to the Observer with the final error or complete\n    // event.\n    if (this.finalized) {\n      // eslint-disable-next-line @typescript-eslint/no-floating-promises\n      this.task.then(() => {\n        try {\n          if (this.finalError) {\n            observer.error(this.finalError);\n          } else {\n            observer.complete();\n          }\n        } catch (e) {\n          // nothing\n        }\n        return;\n      });\n    }\n\n    this.observers!.push(observer as Observer<T>);\n\n    return unsub;\n  }\n\n  // Unsubscribe is synchronous - we guarantee that no events are sent to\n  // any unsubscribed Observer.\n  private unsubscribeOne(i: number): void {\n    if (this.observers === undefined || this.observers[i] === undefined) {\n      return;\n    }\n\n    delete this.observers[i];\n\n    this.observerCount -= 1;\n    if (this.observerCount === 0 && this.onNoObservers !== undefined) {\n      this.onNoObservers(this);\n    }\n  }\n\n  private forEachObserver(fn: (observer: Observer<T>) => void): void {\n    if (this.finalized) {\n      // Already closed by previous event....just eat the additional values.\n      return;\n    }\n\n    // Since sendOne calls asynchronously - there is no chance that\n    // this.observers will become undefined.\n    for (let i = 0; i < this.observers!.length; i++) {\n      this.sendOne(i, fn);\n    }\n  }\n\n  // Call the Observer via one of it's callback function. We are careful to\n  // confirm that the observe has not been unsubscribed since this asynchronous\n  // function had been queued.\n  private sendOne(i: number, fn: (observer: Observer<T>) => void): void {\n    // Execute the callback asynchronously\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.task.then(() => {\n      if (this.observers !== undefined && this.observers[i] !== undefined) {\n        try {\n          fn(this.observers[i]);\n        } catch (e) {\n          // Ignore exceptions raised in Observers or missing methods of an\n          // Observer.\n          // Log error to console. b/31404806\n          if (typeof console !== 'undefined' && console.error) {\n            console.error(e);\n          }\n        }\n      }\n    });\n  }\n\n  private close(err?: Error): void {\n    if (this.finalized) {\n      return;\n    }\n    this.finalized = true;\n    if (err !== undefined) {\n      this.finalError = err;\n    }\n    // Proxy is no longer needed - garbage collect references\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this.task.then(() => {\n      this.observers = undefined;\n      this.onNoObservers = undefined;\n    });\n  }\n}\n\n/** Turn synchronous function into one called asynchronously. */\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function async(fn: Function, onError?: ErrorFn): Function {\n  return (...args: unknown[]) => {\n    Promise.resolve(true)\n      .then(() => {\n        fn(...args);\n      })\n      .catch((error: Error) => {\n        if (onError) {\n          onError(error);\n        }\n      });\n  };\n}\n\n/**\n * Return true if the object passed in implements any of the named methods.\n */\nfunction implementsAnyMethods(\n  obj: { [key: string]: unknown },\n  methods: string[]\n): boolean {\n  if (typeof obj !== 'object' || obj === null) {\n    return false;\n  }\n\n  for (const method of methods) {\n    if (method in obj && typeof obj[method] === 'function') {\n      return true;\n    }\n  }\n\n  return false;\n}\n\nfunction noop(): void {\n  // do nothing\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Check to make sure the appropriate number of arguments are provided for a public function.\n * Throws an error if it fails.\n *\n * @param fnName The function name\n * @param minCount The minimum number of arguments to allow for the function call\n * @param maxCount The maximum number of argument to allow for the function call\n * @param argCount The actual number of arguments provided.\n */\nexport const validateArgCount = function (\n  fnName: string,\n  minCount: number,\n  maxCount: number,\n  argCount: number\n): void {\n  let argError;\n  if (argCount < minCount) {\n    argError = 'at least ' + minCount;\n  } else if (argCount > maxCount) {\n    argError = maxCount === 0 ? 'none' : 'no more than ' + maxCount;\n  }\n  if (argError) {\n    const error =\n      fnName +\n      ' failed: Was called with ' +\n      argCount +\n      (argCount === 1 ? ' argument.' : ' arguments.') +\n      ' Expects ' +\n      argError +\n      '.';\n    throw new Error(error);\n  }\n};\n\n/**\n * Generates a string to prefix an error message about failed argument validation\n *\n * @param fnName The function name\n * @param argumentNumber The index of the argument\n * @param optional Whether or not the argument is optional\n * @return The prefix to add to the error thrown for validation.\n */\nexport function errorPrefix(\n  fnName: string,\n  argumentNumber: number,\n  optional: boolean\n): string {\n  let argName = '';\n  switch (argumentNumber) {\n    case 1:\n      argName = optional ? 'first' : 'First';\n      break;\n    case 2:\n      argName = optional ? 'second' : 'Second';\n      break;\n    case 3:\n      argName = optional ? 'third' : 'Third';\n      break;\n    case 4:\n      argName = optional ? 'fourth' : 'Fourth';\n      break;\n    default:\n      throw new Error(\n        'errorPrefix called with argumentNumber > 4.  Need to update it?'\n      );\n  }\n\n  let error = fnName + ' failed: ';\n\n  error += argName + ' argument ';\n  return error;\n}\n\n/**\n * @param fnName\n * @param argumentNumber\n * @param namespace\n * @param optional\n */\nexport function validateNamespace(\n  fnName: string,\n  argumentNumber: number,\n  namespace: string,\n  optional: boolean\n): void {\n  if (optional && !namespace) {\n    return;\n  }\n  if (typeof namespace !== 'string') {\n    //TODO: I should do more validation here. We only allow certain chars in namespaces.\n    throw new Error(\n      errorPrefix(fnName, argumentNumber, optional) +\n        'must be a valid firebase namespace.'\n    );\n  }\n}\n\nexport function validateCallback(\n  fnName: string,\n  argumentNumber: number,\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  callback: Function,\n  optional: boolean\n): void {\n  if (optional && !callback) {\n    return;\n  }\n  if (typeof callback !== 'function') {\n    throw new Error(\n      errorPrefix(fnName, argumentNumber, optional) +\n        'must be a valid function.'\n    );\n  }\n}\n\nexport function validateContextObject(\n  fnName: string,\n  argumentNumber: number,\n  context: unknown,\n  optional: boolean\n): void {\n  if (optional && !context) {\n    return;\n  }\n  if (typeof context !== 'object' || context === null) {\n    throw new Error(\n      errorPrefix(fnName, argumentNumber, optional) +\n        'must be a valid context object.'\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert } from './assert';\n\n// Code originally came from goog.crypt.stringToUtf8ByteArray, but for some reason they\n// automatically replaced '\\r\\n' with '\\n', and they didn't handle surrogate pairs,\n// so it's been modified.\n\n// Note that not all Unicode characters appear as single characters in JavaScript strings.\n// fromCharCode returns the UTF-16 encoding of a character - so some Unicode characters\n// use 2 characters in Javascript.  All 4-byte UTF-8 characters begin with a first\n// character in the range 0xD800 - 0xDBFF (the first character of a so-called surrogate\n// pair).\n// See http://www.ecma-international.org/ecma-262/5.1/#sec-15.1.3\n\n/**\n * @param {string} str\n * @return {Array}\n */\nexport const stringToByteArray = function (str: string): number[] {\n  const out: number[] = [];\n  let p = 0;\n  for (let i = 0; i < str.length; i++) {\n    let c = str.charCodeAt(i);\n\n    // Is this the lead surrogate in a surrogate pair?\n    if (c >= 0xd800 && c <= 0xdbff) {\n      const high = c - 0xd800; // the high 10 bits.\n      i++;\n      assert(i < str.length, 'Surrogate pair missing trail surrogate.');\n      const low = str.charCodeAt(i) - 0xdc00; // the low 10 bits.\n      c = 0x10000 + (high << 10) + low;\n    }\n\n    if (c < 128) {\n      out[p++] = c;\n    } else if (c < 2048) {\n      out[p++] = (c >> 6) | 192;\n      out[p++] = (c & 63) | 128;\n    } else if (c < 65536) {\n      out[p++] = (c >> 12) | 224;\n      out[p++] = ((c >> 6) & 63) | 128;\n      out[p++] = (c & 63) | 128;\n    } else {\n      out[p++] = (c >> 18) | 240;\n      out[p++] = ((c >> 12) & 63) | 128;\n      out[p++] = ((c >> 6) & 63) | 128;\n      out[p++] = (c & 63) | 128;\n    }\n  }\n  return out;\n};\n\n/**\n * Calculate length without actually converting; useful for doing cheaper validation.\n * @param {string} str\n * @return {number}\n */\nexport const stringLength = function (str: string): number {\n  let p = 0;\n  for (let i = 0; i < str.length; i++) {\n    const c = str.charCodeAt(i);\n    if (c < 128) {\n      p++;\n    } else if (c < 2048) {\n      p += 2;\n    } else if (c >= 0xd800 && c <= 0xdbff) {\n      // Lead surrogate of a surrogate pair.  The pair together will take 4 bytes to represent.\n      p += 4;\n      i++; // skip trail surrogate.\n    } else {\n      p += 3;\n    }\n  }\n  return p;\n};\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * The amount of milliseconds to exponentially increase.\n */\nconst DEFAULT_INTERVAL_MILLIS = 1000;\n\n/**\n * The factor to backoff by.\n * Should be a number greater than 1.\n */\nconst DEFAULT_BACKOFF_FACTOR = 2;\n\n/**\n * The maximum milliseconds to increase to.\n *\n * <p>Visible for testing\n */\nexport const MAX_VALUE_MILLIS = 4 * 60 * 60 * 1000; // Four hours, like iOS and Android.\n\n/**\n * The percentage of backoff time to randomize by.\n * See\n * http://go/safe-client-behavior#step-1-determine-the-appropriate-retry-interval-to-handle-spike-traffic\n * for context.\n *\n * <p>Visible for testing\n */\nexport const RANDOM_FACTOR = 0.5;\n\n/**\n * Based on the backoff method from\n * https://github.com/google/closure-library/blob/master/closure/goog/math/exponentialbackoff.js.\n * Extracted here so we don't need to pass metadata and a stateful ExponentialBackoff object around.\n */\nexport function calculateBackoffMillis(\n  backoffCount: number,\n  intervalMillis: number = DEFAULT_INTERVAL_MILLIS,\n  backoffFactor: number = DEFAULT_BACKOFF_FACTOR\n): number {\n  // Calculates an exponentially increasing value.\n  // Deviation: calculates value from count and a constant interval, so we only need to save value\n  // and count to restore state.\n  const currBaseValue = intervalMillis * Math.pow(backoffFactor, backoffCount);\n\n  // A random \"fuzz\" to avoid waves of retries.\n  // Deviation: randomFactor is required.\n  const randomWait = Math.round(\n    // A fraction of the backoff value to add/subtract.\n    // Deviation: changes multiplication order to improve readability.\n    RANDOM_FACTOR *\n      currBaseValue *\n      // A random float (rounded to int by Math.round above) in the range [-1, 1]. Determines\n      // if we add or subtract.\n      (Math.random() - 0.5) *\n      2\n  );\n\n  // Limits backoff to max to avoid effectively permanent backoff.\n  return Math.min(MAX_VALUE_MILLIS, currBaseValue + randomWait);\n}\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","module.exports = require(\"regenerator-runtime\");\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}","import defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\n\nfunction ownKeys(object, enumerableOnly) {\n  var keys = Object.keys(object);\n\n  if (Object.getOwnPropertySymbols) {\n    var symbols = Object.getOwnPropertySymbols(object);\n    if (enumerableOnly) symbols = symbols.filter(function (sym) {\n      return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n    });\n    keys.push.apply(keys, symbols);\n  }\n\n  return keys;\n}\n\nexport default function _objectSpread2(target) {\n  for (var i = 1; i < arguments.length; i++) {\n    var source = arguments[i] != null ? arguments[i] : {};\n\n    if (i % 2) {\n      ownKeys(Object(source), true).forEach(function (key) {\n        defineProperty(target, key, source[key]);\n      });\n    } else if (Object.getOwnPropertyDescriptors) {\n      Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n    } else {\n      ownKeys(Object(source)).forEach(function (key) {\n        Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n      });\n    }\n  }\n\n  return target;\n}","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n  try {\n    var info = gen[key](arg);\n    var value = info.value;\n  } catch (error) {\n    reject(error);\n    return;\n  }\n\n  if (info.done) {\n    resolve(value);\n  } else {\n    Promise.resolve(value).then(_next, _throw);\n  }\n}\n\nexport default function _asyncToGenerator(fn) {\n  return function () {\n    var self = this,\n        args = arguments;\n    return new Promise(function (resolve, reject) {\n      var gen = fn.apply(self, args);\n\n      function _next(value) {\n        asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n      }\n\n      function _throw(err) {\n        asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n      }\n\n      _next(undefined);\n    });\n  };\n}","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Logger } from '@firebase/logger';\n\nexport const logger = new Logger('@firebase/analytics');\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  FirebaseApp,\n  FirebaseOptions,\n  FirebaseAppConfig\n} from '@firebase/app-types';\nimport {\n  _FirebaseNamespace,\n  FirebaseService\n} from '@firebase/app-types/private';\nimport { deepCopy } from '@firebase/util';\nimport {\n  ComponentContainer,\n  Component,\n  ComponentType,\n  Name\n} from '@firebase/component';\nimport { AppError, ERROR_FACTORY } from './errors';\nimport { DEFAULT_ENTRY_NAME } from './constants';\nimport { logger } from './logger';\n\n/**\n * Global context object for a collection of services using\n * a shared authentication state.\n */\nexport class FirebaseAppImpl implements FirebaseApp {\n  private readonly options_: FirebaseOptions;\n  private readonly name_: string;\n  private isDeleted_ = false;\n  private automaticDataCollectionEnabled_: boolean;\n  private container: ComponentContainer;\n\n  constructor(\n    options: FirebaseOptions,\n    config: FirebaseAppConfig,\n    private readonly firebase_: _FirebaseNamespace\n  ) {\n    this.name_ = config.name!;\n    this.automaticDataCollectionEnabled_ =\n      config.automaticDataCollectionEnabled || false;\n    this.options_ = deepCopy<FirebaseOptions>(options);\n    this.container = new ComponentContainer(config.name!);\n\n    // add itself to container\n    this._addComponent(new Component('app', () => this, ComponentType.PUBLIC));\n    // populate ComponentContainer with existing components\n    this.firebase_.INTERNAL.components.forEach(component =>\n      this._addComponent(component)\n    );\n  }\n\n  get automaticDataCollectionEnabled(): boolean {\n    this.checkDestroyed_();\n    return this.automaticDataCollectionEnabled_;\n  }\n\n  set automaticDataCollectionEnabled(val) {\n    this.checkDestroyed_();\n    this.automaticDataCollectionEnabled_ = val;\n  }\n\n  get name(): string {\n    this.checkDestroyed_();\n    return this.name_;\n  }\n\n  get options(): FirebaseOptions {\n    this.checkDestroyed_();\n    return this.options_;\n  }\n\n  delete(): Promise<void> {\n    return new Promise<void>(resolve => {\n      this.checkDestroyed_();\n      resolve();\n    })\n      .then(() => {\n        this.firebase_.INTERNAL.removeApp(this.name_);\n\n        return Promise.all(\n          this.container.getProviders().map(provider => provider.delete())\n        );\n      })\n      .then((): void => {\n        this.isDeleted_ = true;\n      });\n  }\n\n  /**\n   * Return a service instance associated with this app (creating it\n   * on demand), identified by the passed instanceIdentifier.\n   *\n   * NOTE: Currently storage and functions are the only ones that are leveraging this\n   * functionality. They invoke it by calling:\n   *\n   * ```javascript\n   * firebase.app().storage('STORAGE BUCKET ID')\n   * ```\n   *\n   * The service name is passed to this already\n   * @internal\n   */\n  _getService(\n    name: string,\n    instanceIdentifier: string = DEFAULT_ENTRY_NAME\n  ): FirebaseService {\n    this.checkDestroyed_();\n\n    // getImmediate will always succeed because _getService is only called for registered components.\n    return (this.container.getProvider(name as Name).getImmediate({\n      identifier: instanceIdentifier\n    }) as unknown) as FirebaseService;\n  }\n  /**\n   * Remove a service instance from the cache, so we will create a new instance for this service\n   * when people try to get this service again.\n   *\n   * NOTE: currently only firestore is using this functionality to support firestore shutdown.\n   *\n   * @param name The service name\n   * @param instanceIdentifier instance identifier in case multiple instances are allowed\n   * @internal\n   */\n  _removeServiceInstance(\n    name: string,\n    instanceIdentifier: string = DEFAULT_ENTRY_NAME\n  ): void {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    this.container.getProvider(name as any).clearInstance(instanceIdentifier);\n  }\n\n  /**\n   * @param component the component being added to this app's container\n   */\n  _addComponent(component: Component): void {\n    try {\n      this.container.addComponent(component);\n    } catch (e) {\n      logger.debug(\n        `Component ${component.name} failed to register with FirebaseApp ${this.name}`,\n        e\n      );\n    }\n  }\n\n  _addOrOverwriteComponent(component: Component): void {\n    this.container.addOrOverwriteComponent(component);\n  }\n\n  toJSON(): object {\n    return {\n      name: this.name,\n      automaticDataCollectionEnabled: this.automaticDataCollectionEnabled,\n      options: this.options\n    };\n  }\n\n  /**\n   * This function will throw an Error if the App has already been deleted -\n   * use before performing API actions on the App.\n   */\n  private checkDestroyed_(): void {\n    if (this.isDeleted_) {\n      throw ERROR_FACTORY.create(AppError.APP_DELETED, { appName: this.name_ });\n    }\n  }\n}\n\n// Prevent dead-code elimination of these methods w/o invalid property\n// copying.\n(FirebaseAppImpl.prototype.name && FirebaseAppImpl.prototype.options) ||\n  FirebaseAppImpl.prototype.delete ||\n  console.log('dc');\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FirebaseNamespace } from '@firebase/app-types';\nimport { _FirebaseNamespace } from '@firebase/app-types/private';\nimport { createSubscribe, deepExtend, ErrorFactory } from '@firebase/util';\nimport { FirebaseAppImpl } from './firebaseApp';\nimport { createFirebaseNamespaceCore } from './firebaseNamespaceCore';\n\n/**\n * Return a firebase namespace object.\n *\n * In production, this will be called exactly once and the result\n * assigned to the 'firebase' global.  It may be called multiple times\n * in unit tests.\n */\nexport function createFirebaseNamespace(): FirebaseNamespace {\n  const namespace = createFirebaseNamespaceCore(FirebaseAppImpl);\n  (namespace as _FirebaseNamespace).INTERNAL = {\n    ...(namespace as _FirebaseNamespace).INTERNAL,\n    createFirebaseNamespace,\n    extendNamespace,\n    createSubscribe,\n    ErrorFactory,\n    deepExtend\n  };\n\n  /**\n   * Patch the top-level firebase namespace with additional properties.\n   *\n   * firebase.INTERNAL.extendNamespace()\n   */\n  function extendNamespace(props: { [prop: string]: unknown }): void {\n    deepExtend(namespace, props);\n  }\n\n  return namespace;\n}\n\nexport const firebase = createFirebaseNamespace();\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  FirebaseApp,\n  FirebaseOptions,\n  FirebaseNamespace,\n  FirebaseAppConfig\n} from '@firebase/app-types';\nimport {\n  _FirebaseApp,\n  _FirebaseNamespace,\n  FirebaseService,\n  FirebaseServiceNamespace\n} from '@firebase/app-types/private';\nimport { deepExtend, contains } from '@firebase/util';\nimport { FirebaseAppImpl } from './firebaseApp';\nimport { ERROR_FACTORY, AppError } from './errors';\nimport { FirebaseAppLiteImpl } from './lite/firebaseAppLite';\nimport { DEFAULT_ENTRY_NAME, PLATFORM_LOG_STRING } from './constants';\nimport { version } from '../../firebase/package.json';\nimport { logger } from './logger';\nimport {\n  setUserLogHandler,\n  setLogLevel,\n  LogCallback,\n  LogOptions\n} from '@firebase/logger';\nimport { Component, ComponentType, Name } from '@firebase/component';\n\n/**\n * Because auth can't share code with other components, we attach the utility functions\n * in an internal namespace to share code.\n * This function return a firebase namespace object without\n * any utility functions, so it can be shared between the regular firebaseNamespace and\n * the lite version.\n */\nexport function createFirebaseNamespaceCore(\n  firebaseAppImpl: typeof FirebaseAppImpl | typeof FirebaseAppLiteImpl\n): FirebaseNamespace {\n  const apps: { [name: string]: FirebaseApp } = {};\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  const components = new Map<string, Component<any>>();\n\n  // A namespace is a plain JavaScript Object.\n  const namespace: FirebaseNamespace = {\n    // Hack to prevent Babel from modifying the object returned\n    // as the firebase namespace.\n    // @ts-ignore\n    __esModule: true,\n    initializeApp,\n    // @ts-ignore\n    app,\n    registerVersion,\n    setLogLevel,\n    onLog,\n    // @ts-ignore\n    apps: null,\n    SDK_VERSION: version,\n    INTERNAL: {\n      registerComponent,\n      removeApp,\n      components,\n      useAsService\n    }\n  };\n\n  // Inject a circular default export to allow Babel users who were previously\n  // using:\n  //\n  //   import firebase from 'firebase';\n  //   which becomes: var firebase = require('firebase').default;\n  //\n  // instead of\n  //\n  //   import * as firebase from 'firebase';\n  //   which becomes: var firebase = require('firebase');\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  (namespace as any)['default'] = namespace;\n\n  // firebase.apps is a read-only getter.\n  Object.defineProperty(namespace, 'apps', {\n    get: getApps\n  });\n\n  /**\n   * Called by App.delete() - but before any services associated with the App\n   * are deleted.\n   */\n  function removeApp(name: string): void {\n    delete apps[name];\n  }\n\n  /**\n   * Get the App object for a given name (or DEFAULT).\n   */\n  function app(name?: string): FirebaseApp {\n    name = name || DEFAULT_ENTRY_NAME;\n    if (!contains(apps, name)) {\n      throw ERROR_FACTORY.create(AppError.NO_APP, { appName: name });\n    }\n    return apps[name];\n  }\n\n  // @ts-ignore\n  app['App'] = firebaseAppImpl;\n  /**\n   * Create a new App instance (name must be unique).\n   */\n  function initializeApp(\n    options: FirebaseOptions,\n    config?: FirebaseAppConfig\n  ): FirebaseApp;\n  function initializeApp(options: FirebaseOptions, name?: string): FirebaseApp;\n  function initializeApp(\n    options: FirebaseOptions,\n    rawConfig = {}\n  ): FirebaseApp {\n    if (typeof rawConfig !== 'object' || rawConfig === null) {\n      const name = rawConfig;\n      rawConfig = { name };\n    }\n\n    const config = rawConfig as FirebaseAppConfig;\n\n    if (config.name === undefined) {\n      config.name = DEFAULT_ENTRY_NAME;\n    }\n\n    const { name } = config;\n\n    if (typeof name !== 'string' || !name) {\n      throw ERROR_FACTORY.create(AppError.BAD_APP_NAME, {\n        appName: String(name)\n      });\n    }\n\n    if (contains(apps, name)) {\n      throw ERROR_FACTORY.create(AppError.DUPLICATE_APP, { appName: name });\n    }\n\n    const app = new firebaseAppImpl(\n      options,\n      config,\n      namespace as _FirebaseNamespace\n    );\n\n    apps[name] = app;\n\n    return app;\n  }\n\n  /*\n   * Return an array of all the non-deleted FirebaseApps.\n   */\n  function getApps(): FirebaseApp[] {\n    // Make a copy so caller cannot mutate the apps list.\n    return Object.keys(apps).map(name => apps[name]);\n  }\n\n  function registerComponent(\n    component: Component\n  ): FirebaseServiceNamespace<FirebaseService> | null {\n    const componentName = component.name;\n    if (components.has(componentName)) {\n      logger.debug(\n        `There were multiple attempts to register component ${componentName}.`\n      );\n\n      return component.type === ComponentType.PUBLIC\n        ? // eslint-disable-next-line @typescript-eslint/no-explicit-any\n          (namespace as any)[componentName]\n        : null;\n    }\n\n    components.set(componentName, component);\n\n    // create service namespace for public components\n    if (component.type === ComponentType.PUBLIC) {\n      // The Service namespace is an accessor function ...\n      const serviceNamespace = (\n        appArg: FirebaseApp = app()\n      ): FirebaseService => {\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        if (typeof (appArg as any)[componentName] !== 'function') {\n          // Invalid argument.\n          // This happens in the following case: firebase.storage('gs:/')\n          throw ERROR_FACTORY.create(AppError.INVALID_APP_ARGUMENT, {\n            appName: componentName\n          });\n        }\n\n        // Forward service instance lookup to the FirebaseApp.\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        return (appArg as any)[componentName]();\n      };\n\n      // ... and a container for service-level properties.\n      if (component.serviceProps !== undefined) {\n        deepExtend(serviceNamespace, component.serviceProps);\n      }\n\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      (namespace as any)[componentName] = serviceNamespace;\n\n      // Patch the FirebaseAppImpl prototype\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      (firebaseAppImpl.prototype as any)[componentName] =\n        // TODO: The eslint disable can be removed and the 'ignoreRestArgs'\n        // option added to the no-explicit-any rule when ESlint releases it.\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        function (...args: any) {\n          const serviceFxn = this._getService.bind(this, componentName);\n          return serviceFxn.apply(\n            this,\n            component.multipleInstances ? args : []\n          );\n        };\n    }\n\n    // add the component to existing app instances\n    for (const appName of Object.keys(apps)) {\n      (apps[appName] as _FirebaseApp)._addComponent(component);\n    }\n\n    return component.type === ComponentType.PUBLIC\n      ? // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        (namespace as any)[componentName]\n      : null;\n  }\n\n  function registerVersion(\n    libraryKeyOrName: string,\n    version: string,\n    variant?: string\n  ): void {\n    // TODO: We can use this check to whitelist strings when/if we set up\n    // a good whitelist system.\n    let library = PLATFORM_LOG_STRING[libraryKeyOrName] ?? libraryKeyOrName;\n    if (variant) {\n      library += `-${variant}`;\n    }\n    const libraryMismatch = library.match(/\\s|\\//);\n    const versionMismatch = version.match(/\\s|\\//);\n    if (libraryMismatch || versionMismatch) {\n      const warning = [\n        `Unable to register library \"${library}\" with version \"${version}\":`\n      ];\n      if (libraryMismatch) {\n        warning.push(\n          `library name \"${library}\" contains illegal characters (whitespace or \"/\")`\n        );\n      }\n      if (libraryMismatch && versionMismatch) {\n        warning.push('and');\n      }\n      if (versionMismatch) {\n        warning.push(\n          `version name \"${version}\" contains illegal characters (whitespace or \"/\")`\n        );\n      }\n      logger.warn(warning.join(' '));\n      return;\n    }\n    registerComponent(\n      new Component(\n        `${library}-version` as Name,\n        () => ({ library, version }),\n        ComponentType.VERSION\n      )\n    );\n  }\n\n  function onLog(logCallback: LogCallback | null, options?: LogOptions): void {\n    if (logCallback !== null && typeof logCallback !== 'function') {\n      throw ERROR_FACTORY.create(AppError.INVALID_LOG_ARGUMENT);\n    }\n    setUserLogHandler(logCallback, options);\n  }\n\n  // Map the requested service to a registered service name\n  // (used to map auth to serverAuth service when needed).\n  function useAsService(app: FirebaseApp, name: string): string | null {\n    if (name === 'serverAuth') {\n      return null;\n    }\n\n    const useService = name;\n\n    return useService;\n  }\n\n  return namespace;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  ComponentContainer,\n  ComponentType,\n  Provider,\n  Name\n} from '@firebase/component';\n\nexport class PlatformLoggerService {\n  constructor(private readonly container: ComponentContainer) {}\n  // In initial implementation, this will be called by installations on\n  // auth token refresh, and installations will send this string.\n  getPlatformInfoString(): string {\n    const providers = this.container.getProviders();\n    // Loop through providers and get library/version pairs from any that are\n    // version components.\n    return providers\n      .map(provider => {\n        if (isVersionServiceProvider(provider)) {\n          const service = provider.getImmediate();\n          return `${service.library}/${service.version}`;\n        } else {\n          return null;\n        }\n      })\n      .filter(logString => logString)\n      .join(' ');\n  }\n}\n/**\n *\n * @param provider check if this provider provides a VersionService\n *\n * NOTE: Using Provider<'app-version'> is a hack to indicate that the provider\n * provides VersionService. The provider is not necessarily a 'app-version'\n * provider.\n */\nfunction isVersionServiceProvider(\n  provider: Provider<Name>\n): provider is Provider<'app-version'> {\n  const component = provider.getComponent();\n  return component?.type === ComponentType.VERSION;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport firebase from '@firebase/app';\nimport { FirebaseNamespace } from '@firebase/app-types';\nimport { _FirebaseNamespace } from '@firebase/app-types/private';\nimport { Database } from './src/api/Database';\nimport { DataSnapshot } from './src/api/DataSnapshot';\nimport { Query } from './src/api/Query';\nimport { Reference } from './src/api/Reference';\nimport { enableLogging } from './src/core/util/util';\nimport { repoManagerDatabaseFromApp } from './src/core/RepoManager';\nimport * as INTERNAL from './src/api/internal';\nimport * as TEST_ACCESS from './src/api/test_access';\nimport { isNodeSdk } from '@firebase/util';\nimport * as types from '@firebase/database-types';\nimport { setSDKVersion } from './src/core/version';\nimport { Component, ComponentType } from '@firebase/component';\n\nimport { name, version } from './package.json';\n\nconst ServerValue = Database.ServerValue;\n\nexport function registerDatabase(instance: FirebaseNamespace) {\n  // set SDK_VERSION\n  setSDKVersion(instance.SDK_VERSION);\n\n  // Register the Database Service with the 'firebase' namespace.\n  const namespace = (instance as _FirebaseNamespace).INTERNAL.registerComponent(\n    new Component(\n      'database',\n      (container, url) => {\n        /* Dependencies */\n        // getImmediate for FirebaseApp will always succeed\n        const app = container.getProvider('app').getImmediate();\n        const authProvider = container.getProvider('auth-internal');\n\n        return repoManagerDatabaseFromApp(app, authProvider, url, undefined);\n      },\n      ComponentType.PUBLIC\n    )\n      .setServiceProps(\n        // firebase.database namespace properties\n        {\n          Reference,\n          Query,\n          Database,\n          DataSnapshot,\n          enableLogging,\n          INTERNAL,\n          ServerValue,\n          TEST_ACCESS\n        }\n      )\n      .setMultipleInstances(true)\n  );\n\n  instance.registerVersion(name, version);\n\n  if (isNodeSdk()) {\n    module.exports = namespace;\n  }\n}\n\nregisterDatabase(firebase);\n\n// Types to export for the admin SDK\nexport { Database, Query, Reference, enableLogging, ServerValue };\n\nexport { DataSnapshot } from './src/api/DataSnapshot';\nexport { OnDisconnect } from './src/api/onDisconnect';\n\ndeclare module '@firebase/app-types' {\n  interface FirebaseNamespace {\n    database?: {\n      (app?: FirebaseApp): types.FirebaseDatabase;\n      enableLogging: typeof types.enableLogging;\n      ServerValue: types.ServerValue;\n      Database: typeof types.FirebaseDatabase;\n    };\n  }\n  interface FirebaseApp {\n    database?(databaseURL?: string): types.FirebaseDatabase;\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FirebaseNamespace } from '@firebase/app-types';\nimport { _FirebaseNamespace } from '@firebase/app-types/private';\nimport { Component, ComponentType } from '@firebase/component';\nimport { PlatformLoggerService } from './platformLoggerService';\nimport { name, version } from '../package.json';\n\nexport function registerCoreComponents(\n  firebase: FirebaseNamespace,\n  variant?: string\n): void {\n  (firebase as _FirebaseNamespace).INTERNAL.registerComponent(\n    new Component(\n      'platform-logger',\n      container => new PlatformLoggerService(container),\n      ComponentType.PRIVATE\n    )\n  );\n  // Register `app` package.\n  firebase.registerVersion(name, version, variant);\n  // Register platform SDK identifier (no version).\n  firebase.registerVersion('fire-js', '');\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n  InstantiationMode,\n  InstanceFactory,\n  ComponentType,\n  Dictionary,\n  Name\n} from './types';\n\n/**\n * Component for service name T, e.g. `auth`, `auth-internal`\n */\nexport class Component<T extends Name = Name> {\n  multipleInstances = false;\n  /**\n   * Properties to be added to the service namespace\n   */\n  serviceProps: Dictionary = {};\n\n  instantiationMode = InstantiationMode.LAZY;\n\n  /**\n   *\n   * @param name The public service name, e.g. app, auth, firestore, database\n   * @param instanceFactory Service factory responsible for creating the public interface\n   * @param type whether the service provided by the component is public or private\n   */\n  constructor(\n    readonly name: T,\n    readonly instanceFactory: InstanceFactory<T>,\n    readonly type: ComponentType\n  ) {}\n\n  setInstantiationMode(mode: InstantiationMode): this {\n    this.instantiationMode = mode;\n    return this;\n  }\n\n  setMultipleInstances(multipleInstances: boolean): this {\n    this.multipleInstances = multipleInstances;\n    return this;\n  }\n\n  setServiceProps(props: Dictionary): this {\n    this.serviceProps = props;\n    return this;\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Deferred } from '@firebase/util';\nimport { ComponentContainer } from './component_container';\nimport { DEFAULT_ENTRY_NAME } from './constants';\nimport { InstantiationMode, Name, NameServiceMapping } from './types';\nimport { Component } from './component';\n\n/**\n * Provider for instance for service name T, e.g. 'auth', 'auth-internal'\n * NameServiceMapping[T] is an alias for the type of the instance\n */\nexport class Provider<T extends Name> {\n  private component: Component<T> | null = null;\n  private readonly instances: Map<string, NameServiceMapping[T]> = new Map();\n  private readonly instancesDeferred: Map<\n    string,\n    Deferred<NameServiceMapping[T]>\n  > = new Map();\n\n  constructor(\n    private readonly name: T,\n    private readonly container: ComponentContainer\n  ) {}\n\n  /**\n   * @param identifier A provider can provide mulitple instances of a service\n   * if this.component.multipleInstances is true.\n   */\n  get(identifier: string = DEFAULT_ENTRY_NAME): Promise<NameServiceMapping[T]> {\n    // if multipleInstances is not supported, use the default name\n    const normalizedIdentifier = this.normalizeInstanceIdentifier(identifier);\n\n    if (!this.instancesDeferred.has(normalizedIdentifier)) {\n      const deferred = new Deferred<NameServiceMapping[T]>();\n      this.instancesDeferred.set(normalizedIdentifier, deferred);\n      // If the service instance is available, resolve the promise with it immediately\n      try {\n        const instance = this.getOrInitializeService(normalizedIdentifier);\n        if (instance) {\n          deferred.resolve(instance);\n        }\n      } catch (e) {\n        // when the instance factory throws an exception during get(), it should not cause\n        // a fatal error. We just return the unresolved promise in this case.\n      }\n    }\n\n    return this.instancesDeferred.get(normalizedIdentifier)!.promise;\n  }\n\n  /**\n   *\n   * @param options.identifier A provider can provide mulitple instances of a service\n   * if this.component.multipleInstances is true.\n   * @param options.optional If optional is false or not provided, the method throws an error when\n   * the service is not immediately available.\n   * If optional is true, the method returns null if the service is not immediately available.\n   */\n  getImmediate(options: {\n    identifier?: string;\n    optional: true;\n  }): NameServiceMapping[T] | null;\n  getImmediate(options?: {\n    identifier?: string;\n    optional?: false;\n  }): NameServiceMapping[T];\n  getImmediate(options?: {\n    identifier?: string;\n    optional?: boolean;\n  }): NameServiceMapping[T] | null {\n    const { identifier, optional } = {\n      identifier: DEFAULT_ENTRY_NAME,\n      optional: false,\n      ...options\n    };\n    // if multipleInstances is not supported, use the default name\n    const normalizedIdentifier = this.normalizeInstanceIdentifier(identifier);\n    try {\n      const instance = this.getOrInitializeService(normalizedIdentifier);\n\n      if (!instance) {\n        if (optional) {\n          return null;\n        }\n        throw Error(`Service ${this.name} is not available`);\n      }\n      return instance;\n    } catch (e) {\n      if (optional) {\n        return null;\n      } else {\n        throw e;\n      }\n    }\n  }\n\n  getComponent(): Component<T> | null {\n    return this.component;\n  }\n\n  setComponent(component: Component<T>): void {\n    if (component.name !== this.name) {\n      throw Error(\n        `Mismatching Component ${component.name} for Provider ${this.name}.`\n      );\n    }\n\n    if (this.component) {\n      throw Error(`Component for ${this.name} has already been provided`);\n    }\n\n    this.component = component;\n    // if the service is eager, initialize the default instance\n    if (isComponentEager(component)) {\n      try {\n        this.getOrInitializeService(DEFAULT_ENTRY_NAME);\n      } catch (e) {\n        // when the instance factory for an eager Component throws an exception during the eager\n        // initialization, it should not cause a fatal error.\n        // TODO: Investigate if we need to make it configurable, because some component may want to cause\n        // a fatal error in this case?\n      }\n    }\n\n    // Create service instances for the pending promises and resolve them\n    // NOTE: if this.multipleInstances is false, only the default instance will be created\n    // and all promises with resolve with it regardless of the identifier.\n    for (const [\n      instanceIdentifier,\n      instanceDeferred\n    ] of this.instancesDeferred.entries()) {\n      const normalizedIdentifier = this.normalizeInstanceIdentifier(\n        instanceIdentifier\n      );\n\n      try {\n        // `getOrInitializeService()` should always return a valid instance since a component is guaranteed. use ! to make typescript happy.\n        const instance = this.getOrInitializeService(normalizedIdentifier)!;\n        instanceDeferred.resolve(instance);\n      } catch (e) {\n        // when the instance factory throws an exception, it should not cause\n        // a fatal error. We just leave the promise unresolved.\n      }\n    }\n  }\n\n  clearInstance(identifier: string = DEFAULT_ENTRY_NAME): void {\n    this.instancesDeferred.delete(identifier);\n    this.instances.delete(identifier);\n  }\n\n  // app.delete() will call this method on every provider to delete the services\n  // TODO: should we mark the provider as deleted?\n  async delete(): Promise<void> {\n    const services = Array.from(this.instances.values());\n\n    await Promise.all([\n      ...services\n        .filter(service => 'INTERNAL' in service) // legacy services\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        .map(service => (service as any).INTERNAL!.delete()),\n      ...services\n        .filter(service => '_delete' in service) // modularized services\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        .map(service => (service as any)._delete())\n    ]);\n  }\n\n  isComponentSet(): boolean {\n    return this.component != null;\n  }\n\n  isInitialized(identifier: string = DEFAULT_ENTRY_NAME): boolean {\n    return this.instances.has(identifier);\n  }\n\n  private getOrInitializeService(\n    identifier: string\n  ): NameServiceMapping[T] | null {\n    let instance = this.instances.get(identifier);\n    if (!instance && this.component) {\n      instance = this.component.instanceFactory(\n        this.container,\n        normalizeIdentifierForFactory(identifier)\n      ) as NameServiceMapping[T];\n      this.instances.set(identifier, instance);\n    }\n\n    return instance || null;\n  }\n\n  private normalizeInstanceIdentifier(identifier: string): string {\n    if (this.component) {\n      return this.component.multipleInstances ? identifier : DEFAULT_ENTRY_NAME;\n    } else {\n      return identifier; // assume multiple instances are supported before the component is provided.\n    }\n  }\n}\n\n// undefined should be passed to the service factory for the default instance\nfunction normalizeIdentifierForFactory(identifier: string): string | undefined {\n  return identifier === DEFAULT_ENTRY_NAME ? undefined : identifier;\n}\n\nfunction isComponentEager(component: Component<Name>): boolean {\n  return component.instantiationMode === InstantiationMode.EAGER;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Provider } from './provider';\nimport { Component } from './component';\nimport { Name } from './types';\n\n/**\n * ComponentContainer that provides Providers for service name T, e.g. `auth`, `auth-internal`\n */\nexport class ComponentContainer {\n  private readonly providers = new Map<string, Provider<Name>>();\n\n  constructor(private readonly name: string) {}\n\n  /**\n   *\n   * @param component Component being added\n   * @param overwrite When a component with the same name has already been registered,\n   * if overwrite is true: overwrite the existing component with the new component and create a new\n   * provider with the new component. It can be useful in tests where you want to use different mocks\n   * for different tests.\n   * if overwrite is false: throw an exception\n   */\n  addComponent<T extends Name>(component: Component<T>): void {\n    const provider = this.getProvider(component.name);\n    if (provider.isComponentSet()) {\n      throw new Error(\n        `Component ${component.name} has already been registered with ${this.name}`\n      );\n    }\n\n    provider.setComponent(component);\n  }\n\n  addOrOverwriteComponent<T extends Name>(component: Component<T>): void {\n    const provider = this.getProvider(component.name);\n    if (provider.isComponentSet()) {\n      // delete the existing provider from the container, so we can register the new component\n      this.providers.delete(component.name);\n    }\n\n    this.addComponent(component);\n  }\n\n  /**\n   * getProvider provides a type safe interface where it can only be called with a field name\n   * present in NameServiceMapping interface.\n   *\n   * Firebase SDKs providing services should extend NameServiceMapping interface to register\n   * themselves.\n   */\n  getProvider<T extends Name>(name: T): Provider<T> {\n    if (this.providers.has(name)) {\n      return this.providers.get(name) as Provider<T>;\n    }\n\n    // create a Provider for a service that hasn't registered with Firebase\n    const provider = new Provider<T>(name, this);\n    this.providers.set(name, provider);\n\n    return provider as Provider<T>;\n  }\n\n  getProviders(): Array<Provider<Name>> {\n    return Array.from(this.providers.values());\n  }\n}\n","export default function _inheritsLoose(subClass, superClass) {\n  subClass.prototype = Object.create(superClass.prototype);\n  subClass.prototype.constructor = subClass;\n  subClass.__proto__ = superClass;\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 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 method = replace ? 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\",\n      activeStyle,\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          const className = isActive\n            ? joinClassnames(classNameProp, activeClassName)\n            : classNameProp;\n          const style = isActive ? { ...styleProp, ...activeStyle } : styleProp;\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  ]);\n\n  NavLink.propTypes = {\n    ...Link.propTypes,\n    \"aria-current\": ariaCurrentType,\n    activeClassName: PropTypes.string,\n    activeStyle: PropTypes.object,\n    className: PropTypes.string,\n    exact: PropTypes.bool,\n    isActive: PropTypes.func,\n    location: PropTypes.object,\n    sensitive: PropTypes.bool,\n    strict: PropTypes.bool,\n    style: PropTypes.object\n  };\n}\n\nexport default NavLink;\n","import { Logger as t, LogLevel as e } from \"@firebase/logger\";\n\nimport { getUA as n, isMobileCordova as r, isReactNative as i, isElectron as o, isIE as u, isUWP as s, isBrowserExtension as a } from \"@firebase/util\";\n\nimport { XhrIo as c, EventType as h, ErrorCode as f, createWebChannelTransport as l, getStatEventTarget as p, WebChannel as d, Event as v, Stat as y } from \"@firebase/webchannel-wrapper\";\n\nimport { __extends as m, __awaiter as g, __generator as w, __spreadArray as b } from \"tslib\";\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ var _ = \n/**\n     * Constructs a DatabaseInfo using the provided host, databaseId and\n     * persistenceKey.\n     *\n     * @param databaseId - The database to use.\n     * @param persistenceKey - A unique identifier for this Firestore's local\n     * storage (used in conjunction with the databaseId).\n     * @param host - The Firestore backend host to connect to.\n     * @param ssl - Whether to use SSL when connecting.\n     * @param forceLongPolling - Whether to use the forceLongPolling option\n     * when using WebChannel as the network transport.\n     * @param autoDetectLongPolling - Whether to use the detectBufferingProxy\n     * option when using WebChannel as the network transport.\n     */\nfunction(t, e, n, r, i, o) {\n    this.t = t, this.persistenceKey = e, this.host = n, this.ssl = r, this.forceLongPolling = i, \n    this.i = o;\n}, I = /** @class */ function() {\n    function t(t, e) {\n        this.projectId = t, this.database = e || \"(default)\";\n    }\n    return Object.defineProperty(t.prototype, \"o\", {\n        get: function() {\n            return \"(default)\" === this.database;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.isEqual = function(e) {\n        return e instanceof t && e.projectId === this.projectId && e.database === this.database;\n    }, t;\n}(), E = new t(\"@firebase/firestore\");\n\n/** The default database name for a project. */\n/** Represents the database ID a Firestore client is associated with. */\n// Helper methods are needed because variables can't be exported as read/write\nfunction T() {\n    return E.logLevel;\n}\n\n/**\n * Sets the verbosity of Cloud Firestore logs (debug, error, or silent).\n *\n * @param logLevel - The verbosity you set for activity and error logging. Can\n *   be any of the following values:\n *\n *   <ul>\n *     <li>`debug` for the most verbose logging level, primarily for\n *     debugging.</li>\n *     <li>`error` to log errors only.</li>\n *     <li><code>`silent` to turn off logging.</li>\n *   </ul>\n */ function N(t) {\n    for (var n = [], r = 1; r < arguments.length; r++) n[r - 1] = arguments[r];\n    if (E.logLevel <= e.DEBUG) {\n        var i = n.map(S);\n        E.debug.apply(E, b([ \"Firestore (8.3.0): \" + t ], i));\n    }\n}\n\nfunction A(t) {\n    for (var n = [], r = 1; r < arguments.length; r++) n[r - 1] = arguments[r];\n    if (E.logLevel <= e.ERROR) {\n        var i = n.map(S);\n        E.error.apply(E, b([ \"Firestore (8.3.0): \" + t ], i));\n    }\n}\n\nfunction D(t) {\n    for (var n = [], r = 1; r < arguments.length; r++) n[r - 1] = arguments[r];\n    if (E.logLevel <= e.WARN) {\n        var i = n.map(S);\n        E.warn.apply(E, b([ \"Firestore (8.3.0): \" + t ], i));\n    }\n}\n\n/**\n * Converts an additional log parameter to a string representation.\n */ function S(t) {\n    if (\"string\" == typeof t) return t;\n    try {\n        return e = t, JSON.stringify(e);\n    } catch (e) {\n        // Converting to JSON failed, just log the object directly\n        return t;\n    }\n    /**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n    /** Formats an object as a JSON string, suitable for logging. */    var e;\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Unconditionally fails, throwing an Error with the given message.\n * Messages are stripped in production builds.\n *\n * Returns `never` and can be used in expressions:\n * @example\n * let futureVar = fail('not implemented yet');\n */ function x(t) {\n    void 0 === t && (t = \"Unexpected state\");\n    // Log the failure in addition to throw an exception, just in case the\n    // exception is swallowed.\n        var e = \"FIRESTORE (8.3.0) INTERNAL ASSERTION FAILED: \" + t;\n    // NOTE: We don't use FirestoreError here because these are internal failures\n    // that cannot be handled by the user. (Also it would create a circular\n    // dependency between the error and assert modules which doesn't work.)\n        throw A(e), new Error(e)\n    /**\n * Fails if the given assertion condition is false, throwing an Error with the\n * given message if it did.\n *\n * Messages are stripped in production builds.\n */;\n}\n\nfunction k(t, e) {\n    t || x();\n}\n\n/**\n * Casts `obj` to `T`. In non-production builds, verifies that `obj` is an\n * instance of `T` before casting.\n */ function O(t, \n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ne) {\n    return t;\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Generates `nBytes` of random bytes.\n *\n * If `nBytes < 0` , an error will be thrown.\n */ function P(t) {\n    // Polyfills for IE and WebWorker by using `self` and `msCrypto` when `crypto` is not available.\n    var e = \n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    \"undefined\" != typeof self && (self.crypto || self.msCrypto), n = new Uint8Array(t);\n    if (e && \"function\" == typeof e.getRandomValues) e.getRandomValues(n); else \n    // Falls back to Math.random\n    for (var r = 0; r < t; r++) n[r] = Math.floor(256 * Math.random());\n    return n;\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ var V = /** @class */ function() {\n    function t() {}\n    return t.u = function() {\n        for (\n        // Alphanumeric characters\n        var t = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789\", e = Math.floor(256 / t.length) * t.length, n = \"\"\n        // The largest byte value that is a multiple of `char.length`.\n        ; n.length < 20; ) for (var r = P(40), i = 0; i < r.length; ++i) \n        // Only accept values that are [0, maxMultiple), this ensures they can\n        // be evenly mapped to indices of `chars` via a modulo operation.\n        n.length < 20 && r[i] < e && (n += t.charAt(r[i] % t.length));\n        return n;\n    }, t;\n}();\n\nfunction C(t, e) {\n    return t < e ? -1 : t > e ? 1 : 0;\n}\n\n/** Helper to compare arrays using isEqual(). */ function L(t, e, n) {\n    return t.length === e.length && t.every((function(t, r) {\n        return n(t, e[r]);\n    }));\n}\n\n/**\n * Returns the immediate lexicographically-following string. This is useful to\n * construct an inclusive range for indexeddb iterators.\n */ function R(t) {\n    // Return the input string, with an additional NUL byte appended.\n    return t + \"\\0\";\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Immutable class that represents a \"proto\" byte string.\n *\n * Proto byte strings can either be Base64-encoded strings or Uint8Arrays when\n * sent on the wire. This class abstracts away this differentiation by holding\n * the proto byte string in a common class that must be converted into a string\n * before being sent as a proto.\n */ var U = /** @class */ function() {\n    function t(t) {\n        this.h = t;\n    }\n    return t.fromBase64String = function(e) {\n        return new t(atob(e));\n    }, t.fromUint8Array = function(e) {\n        return new t(\n        /**\n * Helper function to convert an Uint8array to a binary string.\n */\n        function(t) {\n            for (var e = \"\", n = 0; n < t.length; ++n) e += String.fromCharCode(t[n]);\n            return e;\n        }(e));\n    }, t.prototype.toBase64 = function() {\n        return t = this.h, btoa(t);\n        /** Converts a binary string to a Base64 encoded string. */        var t;\n        /** True if and only if the Base64 conversion functions are available. */    }, \n    t.prototype.toUint8Array = function() {\n        return function(t) {\n            for (var e = new Uint8Array(t.length), n = 0; n < t.length; n++) e[n] = t.charCodeAt(n);\n            return e;\n        }(this.h);\n    }, t.prototype.l = function() {\n        return 2 * this.h.length;\n    }, t.prototype._ = function(t) {\n        return C(this.h, t.h);\n    }, t.prototype.isEqual = function(t) {\n        return this.h === t.h;\n    }, t;\n}();\n\nU.T = new U(\"\");\n\nvar M = {\n    // Causes are copied from:\n    // https://github.com/grpc/grpc/blob/bceec94ea4fc5f0085d81235d8e1c06798dc341a/include/grpc%2B%2B/impl/codegen/status_code_enum.h\n    /** Not an error; returned on success. */\n    OK: \"ok\",\n    /** The operation was cancelled (typically by the caller). */\n    CANCELLED: \"cancelled\",\n    /** Unknown error or an error from a different error domain. */\n    UNKNOWN: \"unknown\",\n    /**\n     * Client specified an invalid argument. Note that this differs from\n     * FAILED_PRECONDITION. INVALID_ARGUMENT indicates arguments that are\n     * problematic regardless of the state of the system (e.g., a malformed file\n     * name).\n     */\n    INVALID_ARGUMENT: \"invalid-argument\",\n    /**\n     * Deadline expired before operation could complete. For operations that\n     * change the state of the system, this error may be returned even if the\n     * operation has completed successfully. For example, a successful response\n     * from a server could have been delayed long enough for the deadline to\n     * expire.\n     */\n    DEADLINE_EXCEEDED: \"deadline-exceeded\",\n    /** Some requested entity (e.g., file or directory) was not found. */\n    NOT_FOUND: \"not-found\",\n    /**\n     * Some entity that we attempted to create (e.g., file or directory) already\n     * exists.\n     */\n    ALREADY_EXISTS: \"already-exists\",\n    /**\n     * The caller does not have permission to execute the specified operation.\n     * PERMISSION_DENIED must not be used for rejections caused by exhausting\n     * some resource (use RESOURCE_EXHAUSTED instead for those errors).\n     * PERMISSION_DENIED must not be used if the caller can not be identified\n     * (use UNAUTHENTICATED instead for those errors).\n     */\n    PERMISSION_DENIED: \"permission-denied\",\n    /**\n     * The request does not have valid authentication credentials for the\n     * operation.\n     */\n    UNAUTHENTICATED: \"unauthenticated\",\n    /**\n     * Some resource has been exhausted, perhaps a per-user quota, or perhaps the\n     * entire file system is out of space.\n     */\n    RESOURCE_EXHAUSTED: \"resource-exhausted\",\n    /**\n     * Operation was rejected because the system is not in a state required for\n     * the operation's execution. For example, directory to be deleted may be\n     * non-empty, an rmdir operation is applied to a non-directory, etc.\n     *\n     * A litmus test that may help a service implementor in deciding\n     * between FAILED_PRECONDITION, ABORTED, and UNAVAILABLE:\n     *  (a) Use UNAVAILABLE if the client can retry just the failing call.\n     *  (b) Use ABORTED if the client should retry at a higher-level\n     *      (e.g., restarting a read-modify-write sequence).\n     *  (c) Use FAILED_PRECONDITION if the client should not retry until\n     *      the system state has been explicitly fixed. E.g., if an \"rmdir\"\n     *      fails because the directory is non-empty, FAILED_PRECONDITION\n     *      should be returned since the client should not retry unless\n     *      they have first fixed up the directory by deleting files from it.\n     *  (d) Use FAILED_PRECONDITION if the client performs conditional\n     *      REST Get/Update/Delete on a resource and the resource on the\n     *      server does not match the condition. E.g., conflicting\n     *      read-modify-write on the same resource.\n     */\n    FAILED_PRECONDITION: \"failed-precondition\",\n    /**\n     * The operation was aborted, typically due to a concurrency issue like\n     * sequencer check failures, transaction aborts, etc.\n     *\n     * See litmus test above for deciding between FAILED_PRECONDITION, ABORTED,\n     * and UNAVAILABLE.\n     */\n    ABORTED: \"aborted\",\n    /**\n     * Operation was attempted past the valid range. E.g., seeking or reading\n     * past end of file.\n     *\n     * Unlike INVALID_ARGUMENT, this error indicates a problem that may be fixed\n     * if the system state changes. For example, a 32-bit file system will\n     * generate INVALID_ARGUMENT if asked to read at an offset that is not in the\n     * range [0,2^32-1], but it will generate OUT_OF_RANGE if asked to read from\n     * an offset past the current file size.\n     *\n     * There is a fair bit of overlap between FAILED_PRECONDITION and\n     * OUT_OF_RANGE. We recommend using OUT_OF_RANGE (the more specific error)\n     * when it applies so that callers who are iterating through a space can\n     * easily look for an OUT_OF_RANGE error to detect when they are done.\n     */\n    OUT_OF_RANGE: \"out-of-range\",\n    /** Operation is not implemented or not supported/enabled in this service. */\n    UNIMPLEMENTED: \"unimplemented\",\n    /**\n     * Internal errors. Means some invariants expected by underlying System has\n     * been broken. If you see one of these errors, Something is very broken.\n     */\n    INTERNAL: \"internal\",\n    /**\n     * The service is currently unavailable. This is a most likely a transient\n     * condition and may be corrected by retrying with a backoff.\n     *\n     * See litmus test above for deciding between FAILED_PRECONDITION, ABORTED,\n     * and UNAVAILABLE.\n     */\n    UNAVAILABLE: \"unavailable\",\n    /** Unrecoverable data loss or corruption. */\n    DATA_LOSS: \"data-loss\"\n}, q = /** @class */ function(t) {\n    /** @hideconstructor */\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, n) || this).code = e, r.message = n, r.name = \"FirebaseError\", \n        // HACK: We write a toString property directly because Error is not a real\n        // class and so inheritance does not work correctly. We could alternatively\n        // do the same \"back-door inheritance\" trick that FirebaseError does.\n        r.toString = function() {\n            return r.name + \": [code=\" + r.code + \"]: \" + r.message;\n        }, r;\n    }\n    return m(e, t), e;\n}(Error), F = /** @class */ function() {\n    /** @hideconstructor */\n    function t(t) {\n        this.I = t;\n    }\n    /**\n     * Creates a new `Bytes` object from the given Base64 string, converting it to\n     * bytes.\n     *\n     * @param base64 - The Base64 string used to create the `Bytes` object.\n     */    return t.fromBase64String = function(e) {\n        try {\n            return new t(U.fromBase64String(e));\n        } catch (e) {\n            throw new q(M.INVALID_ARGUMENT, \"Failed to construct data from Base64 string: \" + e);\n        }\n    }, \n    /**\n     * Creates a new `Bytes` object from the given Uint8Array.\n     *\n     * @param array - The Uint8Array used to create the `Bytes` object.\n     */\n    t.fromUint8Array = function(e) {\n        return new t(U.fromUint8Array(e));\n    }, \n    /**\n     * Returns the underlying bytes as a Base64-encoded string.\n     *\n     * @returns The Base64-encoded string created from the `Bytes` object.\n     */\n    t.prototype.toBase64 = function() {\n        return this.I.toBase64();\n    }, \n    /**\n     * Returns the underlying bytes in a new `Uint8Array`.\n     *\n     * @returns The Uint8Array created from the `Bytes` object.\n     */\n    t.prototype.toUint8Array = function() {\n        return this.I.toUint8Array();\n    }, \n    /**\n     * Returns a string representation of the `Bytes` object.\n     *\n     * @returns A string representation of the `Bytes` object.\n     */\n    t.prototype.toString = function() {\n        return \"Bytes(base64: \" + this.toBase64() + \")\";\n    }, \n    /**\n     * Returns true if this `Bytes` object is equal to the provided one.\n     *\n     * @param other - The `Bytes` object to compare against.\n     * @returns true if this `Bytes` object is equal to the provided one.\n     */\n    t.prototype.isEqual = function(t) {\n        return this.I.isEqual(t.I);\n    }, t;\n}(), j = /** @class */ function() {\n    function t(t) {\n        this.uid = t;\n    }\n    return t.prototype.m = function() {\n        return null != this.uid;\n    }, \n    /**\n     * Returns a key representing this user, suitable for inclusion in a\n     * dictionary.\n     */\n    t.prototype.A = function() {\n        return this.m() ? \"uid:\" + this.uid : \"anonymous-user\";\n    }, t.prototype.isEqual = function(t) {\n        return t.uid === this.uid;\n    }, t;\n}();\n\n/** An error returned by a Firestore operation. */\n/** A user with a null UID. */ j.UNAUTHENTICATED = new j(null), \n// TODO(mikelehen): Look into getting a proper uid-equivalent for\n// non-FirebaseAuth providers.\nj.R = new j(\"google-credentials-uid\"), j.P = new j(\"first-party-uid\");\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nvar z = function(t, e) {\n    this.user = e, this.type = \"OAuth\", this.g = {}, \n    // Set the headers using Object Literal notation to avoid minification\n    this.g.Authorization = \"Bearer \" + t;\n}, G = /** @class */ function() {\n    function t() {\n        /**\n         * Stores the listener registered with setChangeListener()\n         * This isn't actually necessary since the UID never changes, but we use this\n         * to verify the listen contract is adhered to in tests.\n         */\n        this.V = null;\n    }\n    return t.prototype.getToken = function() {\n        return Promise.resolve(null);\n    }, t.prototype.p = function() {}, t.prototype.v = function(t) {\n        this.V = t, \n        // Fire with initial user.\n        t(j.UNAUTHENTICATED);\n    }, t.prototype.S = function() {\n        this.V = null;\n    }, t;\n}(), B = /** @class */ function() {\n    function t(t) {\n        var e = this;\n        /**\n         * The auth token listener registered with FirebaseApp, retained here so we\n         * can unregister it.\n         */        this.D = null, \n        /** Tracks the current User. */\n        this.currentUser = j.UNAUTHENTICATED, this.C = !1, \n        /**\n             * Counter used to detect if the token changed while a getToken request was\n             * outstanding.\n             */\n        this.N = 0, \n        /** The listener registered with setChangeListener(). */\n        this.V = null, this.forceRefresh = !1, this.D = function() {\n            e.N++, e.currentUser = e.$(), e.C = !0, e.V && e.V(e.currentUser);\n        }, this.N = 0, this.auth = t.getImmediate({\n            optional: !0\n        }), this.auth ? this.auth.addAuthTokenListener(this.D) : (\n        // if auth is not available, invoke tokenListener once with null token\n        this.D(null), t.get().then((function(t) {\n            e.auth = t, e.D && \n            // tokenListener can be removed by removeChangeListener()\n            e.auth.addAuthTokenListener(e.D);\n        }), (function() {})));\n    }\n    return t.prototype.getToken = function() {\n        var t = this, e = this.N, n = this.forceRefresh;\n        // Take note of the current value of the tokenCounter so that this method\n        // can fail (with an ABORTED error) if there is a token change while the\n        // request is outstanding.\n                return this.forceRefresh = !1, this.auth ? this.auth.getToken(n).then((function(n) {\n            // Cancel the request since the token changed while the request was\n            // outstanding so the response is potentially for a previous user (which\n            // user, we can't be sure).\n            return t.N !== e ? (N(\"FirebaseCredentialsProvider\", \"getToken aborted due to token change.\"), \n            t.getToken()) : n ? (k(\"string\" == typeof n.accessToken), new z(n.accessToken, t.currentUser)) : null;\n        })) : Promise.resolve(null);\n    }, t.prototype.p = function() {\n        this.forceRefresh = !0;\n    }, t.prototype.v = function(t) {\n        this.V = t, \n        // Fire the initial event\n        this.C && t(this.currentUser);\n    }, t.prototype.S = function() {\n        this.auth && this.auth.removeAuthTokenListener(this.D), this.D = null, this.V = null;\n    }, \n    // Auth.getUid() can return null even with a user logged in. It is because\n    // getUid() is synchronous, but the auth code populating Uid is asynchronous.\n    // This method should only be called in the AuthTokenListener callback\n    // to guarantee to get the actual user.\n    t.prototype.$ = function() {\n        var t = this.auth && this.auth.getUid();\n        return k(null === t || \"string\" == typeof t), new j(t);\n    }, t;\n}(), Q = /** @class */ function() {\n    function t(t, e) {\n        this.F = t, this.O = e, this.type = \"FirstParty\", this.user = j.P;\n    }\n    return Object.defineProperty(t.prototype, \"g\", {\n        get: function() {\n            var t = {\n                \"X-Goog-AuthUser\": this.O\n            }, e = this.F.auth.getAuthHeaderValueForFirstParty([]);\n            // Use array notation to prevent minification\n                        return e && (t.Authorization = e), t;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t;\n}(), Y = /** @class */ function() {\n    function t(t, e) {\n        this.F = t, this.O = e;\n    }\n    return t.prototype.getToken = function() {\n        return Promise.resolve(new Q(this.F, this.O));\n    }, t.prototype.v = function(t) {\n        // Fire with initial uid.\n        t(j.P);\n    }, t.prototype.S = function() {}, t.prototype.p = function() {}, t;\n}(), H = /** @class */ function() {\n    function t(t, e) {\n        var n = this;\n        this.previousValue = t, e && (e.k = function(t) {\n            return n.M(t);\n        }, this.L = function(t) {\n            return e.B(t);\n        });\n    }\n    return t.prototype.M = function(t) {\n        return this.previousValue = Math.max(t, this.previousValue), this.previousValue;\n    }, t.prototype.next = function() {\n        var t = ++this.previousValue;\n        return this.L && this.L(t), t;\n    }, t;\n}();\n\n/** A CredentialsProvider that always yields an empty token. */ H.q = -1;\n\n/**\n * A `Timestamp` represents a point in time independent of any time zone or\n * calendar, represented as seconds and fractions of seconds at nanosecond\n * resolution in UTC Epoch time.\n *\n * It is encoded using the Proleptic Gregorian Calendar which extends the\n * Gregorian calendar backwards to year one. It is encoded assuming all minutes\n * are 60 seconds long, i.e. leap seconds are \"smeared\" so that no leap second\n * table is needed for interpretation. Range is from 0001-01-01T00:00:00Z to\n * 9999-12-31T23:59:59.999999999Z.\n *\n * For examples and further specifications, refer to the\n * {@link https://github.com/google/protobuf/blob/master/src/google/protobuf/timestamp.proto | Timestamp definition}.\n */\nvar K = /** @class */ function() {\n    /**\n     * Creates a new timestamp.\n     *\n     * @param seconds - The number of seconds of UTC time since Unix epoch\n     *     1970-01-01T00:00:00Z. Must be from 0001-01-01T00:00:00Z to\n     *     9999-12-31T23:59:59Z inclusive.\n     * @param nanoseconds - The non-negative fractions of a second at nanosecond\n     *     resolution. Negative second values with fractions must still have\n     *     non-negative nanoseconds values that count forward in time. Must be\n     *     from 0 to 999,999,999 inclusive.\n     */\n    function t(t, e) {\n        if (this.seconds = t, this.nanoseconds = e, e < 0) throw new q(M.INVALID_ARGUMENT, \"Timestamp nanoseconds out of range: \" + e);\n        if (e >= 1e9) throw new q(M.INVALID_ARGUMENT, \"Timestamp nanoseconds out of range: \" + e);\n        if (t < -62135596800) throw new q(M.INVALID_ARGUMENT, \"Timestamp seconds out of range: \" + t);\n        // This will break in the year 10,000.\n                if (t >= 253402300800) throw new q(M.INVALID_ARGUMENT, \"Timestamp seconds out of range: \" + t);\n    }\n    /**\n     * Creates a new timestamp with the current date, with millisecond precision.\n     *\n     * @returns a new timestamp representing the current date.\n     */    return t.now = function() {\n        return t.fromMillis(Date.now());\n    }, \n    /**\n     * Creates a new timestamp from the given date.\n     *\n     * @param date - The date to initialize the `Timestamp` from.\n     * @returns A new `Timestamp` representing the same point in time as the given\n     *     date.\n     */\n    t.fromDate = function(e) {\n        return t.fromMillis(e.getTime());\n    }, \n    /**\n     * Creates a new timestamp from the given number of milliseconds.\n     *\n     * @param milliseconds - Number of milliseconds since Unix epoch\n     *     1970-01-01T00:00:00Z.\n     * @returns A new `Timestamp` representing the same point in time as the given\n     *     number of milliseconds.\n     */\n    t.fromMillis = function(e) {\n        var n = Math.floor(e / 1e3);\n        return new t(n, 1e6 * (e - 1e3 * n));\n    }, \n    /**\n     * Converts a `Timestamp` to a JavaScript `Date` object. This conversion causes\n     * a loss of precision since `Date` objects only support millisecond precision.\n     *\n     * @returns JavaScript `Date` object representing the same point in time as\n     *     this `Timestamp`, with millisecond precision.\n     */\n    t.prototype.toDate = function() {\n        return new Date(this.toMillis());\n    }, \n    /**\n     * Converts a `Timestamp` to a numeric timestamp (in milliseconds since\n     * epoch). This operation causes a loss of precision.\n     *\n     * @returns The point in time corresponding to this timestamp, represented as\n     *     the number of milliseconds since Unix epoch 1970-01-01T00:00:00Z.\n     */\n    t.prototype.toMillis = function() {\n        return 1e3 * this.seconds + this.nanoseconds / 1e6;\n    }, t.prototype.U = function(t) {\n        return this.seconds === t.seconds ? C(this.nanoseconds, t.nanoseconds) : C(this.seconds, t.seconds);\n    }, \n    /**\n     * Returns true if this `Timestamp` is equal to the provided one.\n     *\n     * @param other - The `Timestamp` to compare against.\n     * @returns true if this `Timestamp` is equal to the provided one.\n     */\n    t.prototype.isEqual = function(t) {\n        return t.seconds === this.seconds && t.nanoseconds === this.nanoseconds;\n    }, t.prototype.toString = function() {\n        return \"Timestamp(seconds=\" + this.seconds + \", nanoseconds=\" + this.nanoseconds + \")\";\n    }, t.prototype.toJSON = function() {\n        return {\n            seconds: this.seconds,\n            nanoseconds: this.nanoseconds\n        };\n    }, \n    /**\n     * Converts this object to a primitive string, which allows Timestamp objects to be compared\n     * using the `>`, `<=`, `>=` and `>` operators.\n     */\n    t.prototype.valueOf = function() {\n        // This method returns a string of the form <seconds>.<nanoseconds> where <seconds> is\n        // translated to have a non-negative value and both <seconds> and <nanoseconds> are left-padded\n        // with zeroes to be a consistent length. Strings with this format then have a lexiographical\n        // ordering that matches the expected ordering. The <seconds> translation is done to avoid\n        // having a leading negative sign (i.e. a leading '-' character) in its string representation,\n        // which would affect its lexiographical ordering.\n        var t = this.seconds - -62135596800;\n        // Note: Up to 12 decimal digits are required to represent all valid 'seconds' values.\n                return String(t).padStart(12, \"0\") + \".\" + String(this.nanoseconds).padStart(9, \"0\");\n    }, t;\n}(), X = /** @class */ function() {\n    function t(t) {\n        this.timestamp = t;\n    }\n    return t.K = function(e) {\n        return new t(e);\n    }, t.min = function() {\n        return new t(new K(0, 0));\n    }, t.prototype._ = function(t) {\n        return this.timestamp.U(t.timestamp);\n    }, t.prototype.isEqual = function(t) {\n        return this.timestamp.isEqual(t.timestamp);\n    }, \n    /** Returns a number representation of the version for use in spec tests. */ t.prototype.W = function() {\n        // Convert to microseconds.\n        return 1e6 * this.timestamp.seconds + this.timestamp.nanoseconds / 1e3;\n    }, t.prototype.toString = function() {\n        return \"SnapshotVersion(\" + this.timestamp.toString() + \")\";\n    }, t.prototype.j = function() {\n        return this.timestamp;\n    }, t;\n}(), W = /** @class */ function() {\n    function t(t, e, n) {\n        void 0 === e ? e = 0 : e > t.length && x(), void 0 === n ? n = t.length - e : n > t.length - e && x(), \n        this.segments = t, this.offset = e, this.G = n;\n    }\n    return Object.defineProperty(t.prototype, \"length\", {\n        get: function() {\n            return this.G;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.isEqual = function(e) {\n        return 0 === t.H(this, e);\n    }, t.prototype.child = function(e) {\n        var n = this.segments.slice(this.offset, this.limit());\n        return e instanceof t ? e.forEach((function(t) {\n            n.push(t);\n        })) : n.push(e), this.J(n);\n    }, \n    /** The index of one past the last segment of the path. */ t.prototype.limit = function() {\n        return this.offset + this.length;\n    }, t.prototype.Y = function(t) {\n        return t = void 0 === t ? 1 : t, this.J(this.segments, this.offset + t, this.length - t);\n    }, t.prototype.X = function() {\n        return this.J(this.segments, this.offset, this.length - 1);\n    }, t.prototype.Z = function() {\n        return this.segments[this.offset];\n    }, t.prototype.tt = function() {\n        return this.get(this.length - 1);\n    }, t.prototype.get = function(t) {\n        return this.segments[this.offset + t];\n    }, t.prototype.et = function() {\n        return 0 === this.length;\n    }, t.prototype.nt = function(t) {\n        if (t.length < this.length) return !1;\n        for (var e = 0; e < this.length; e++) if (this.get(e) !== t.get(e)) return !1;\n        return !0;\n    }, t.prototype.st = function(t) {\n        if (this.length + 1 !== t.length) return !1;\n        for (var e = 0; e < this.length; e++) if (this.get(e) !== t.get(e)) return !1;\n        return !0;\n    }, t.prototype.forEach = function(t) {\n        for (var e = this.offset, n = this.limit(); e < n; e++) t(this.segments[e]);\n    }, t.prototype.it = function() {\n        return this.segments.slice(this.offset, this.limit());\n    }, t.H = function(t, e) {\n        for (var n = Math.min(t.length, e.length), r = 0; r < n; r++) {\n            var i = t.get(r), o = e.get(r);\n            if (i < o) return -1;\n            if (i > o) return 1;\n        }\n        return t.length < e.length ? -1 : t.length > e.length ? 1 : 0;\n    }, t;\n}(), Z = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    return m(e, t), e.prototype.J = function(t, n, r) {\n        return new e(t, n, r);\n    }, e.prototype.rt = function() {\n        // NOTE: The client is ignorant of any path segments containing escape\n        // sequences (e.g. __id123__) and just passes them through raw (they exist\n        // for legacy reasons and should not be used frequently).\n        return this.it().join(\"/\");\n    }, e.prototype.toString = function() {\n        return this.rt();\n    }, \n    /**\n     * Creates a resource path from the given slash-delimited string. If multiple\n     * arguments are provided, all components are combined. Leading and trailing\n     * slashes from all components are ignored.\n     */\n    e.ot = function() {\n        for (var t = [], n = 0; n < arguments.length; n++) t[n] = arguments[n];\n        // NOTE: The client is ignorant of any path segments containing escape\n        // sequences (e.g. __id123__) and just passes them through raw (they exist\n        // for legacy reasons and should not be used frequently).\n                for (var r = [], i = 0, o = t; i < o.length; i++) {\n            var u = o[i];\n            if (u.indexOf(\"//\") >= 0) throw new q(M.INVALID_ARGUMENT, \"Invalid segment (\" + u + \"). Paths must not contain // in them.\");\n            // Strip leading and traling slashed.\n                        r.push.apply(r, u.split(\"/\").filter((function(t) {\n                return t.length > 0;\n            })));\n        }\n        return new e(r);\n    }, e.ct = function() {\n        return new e([]);\n    }, e;\n}(W), J = /^[_a-zA-Z][_a-zA-Z0-9]*$/, $ = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    return m(e, t), e.prototype.J = function(t, n, r) {\n        return new e(t, n, r);\n    }, \n    /**\n     * Returns true if the string could be used as a segment in a field path\n     * without escaping.\n     */\n    e.at = function(t) {\n        return J.test(t);\n    }, e.prototype.rt = function() {\n        return this.it().map((function(t) {\n            return t = t.replace(/\\\\/g, \"\\\\\\\\\").replace(/`/g, \"\\\\`\"), e.at(t) || (t = \"`\" + t + \"`\"), \n            t;\n        })).join(\".\");\n    }, e.prototype.toString = function() {\n        return this.rt();\n    }, \n    /**\n     * Returns true if this field references the key of a document.\n     */\n    e.prototype.ut = function() {\n        return 1 === this.length && \"__name__\" === this.get(0);\n    }, \n    /**\n     * The field designating the key of a document.\n     */\n    e.ht = function() {\n        return new e([ \"__name__\" ]);\n    }, \n    /**\n     * Parses a field string from the given server-formatted string.\n     *\n     * - Splitting the empty string is not allowed (for now at least).\n     * - Empty segments within the string (e.g. if there are two consecutive\n     *   separators) are not allowed.\n     *\n     * TODO(b/37244157): we should make this more strict. Right now, it allows\n     * non-identifier path components, even if they aren't escaped.\n     */\n    e.lt = function(t) {\n        for (var n = [], r = \"\", i = 0, o = function() {\n            if (0 === r.length) throw new q(M.INVALID_ARGUMENT, \"Invalid field path (\" + t + \"). Paths must not be empty, begin with '.', end with '.', or contain '..'\");\n            n.push(r), r = \"\";\n        }, u = !1; i < t.length; ) {\n            var s = t[i];\n            if (\"\\\\\" === s) {\n                if (i + 1 === t.length) throw new q(M.INVALID_ARGUMENT, \"Path has trailing escape character: \" + t);\n                var a = t[i + 1];\n                if (\"\\\\\" !== a && \".\" !== a && \"`\" !== a) throw new q(M.INVALID_ARGUMENT, \"Path has invalid escape sequence: \" + t);\n                r += a, i += 2;\n            } else \"`\" === s ? (u = !u, i++) : \".\" !== s || u ? (r += s, i++) : (o(), i++);\n        }\n        if (o(), u) throw new q(M.INVALID_ARGUMENT, \"Unterminated ` in path: \" + t);\n        return new e(n);\n    }, e.ct = function() {\n        return new e([]);\n    }, e;\n}(W), tt = /** @class */ function() {\n    function t(t) {\n        this.path = t;\n    }\n    return t._t = function(e) {\n        return new t(Z.ot(e));\n    }, t.ft = function(e) {\n        return new t(Z.ot(e).Y(5));\n    }, \n    /** Returns true if the document is in the specified collectionId. */ t.prototype.dt = function(t) {\n        return this.path.length >= 2 && this.path.get(this.path.length - 2) === t;\n    }, t.prototype.isEqual = function(t) {\n        return null !== t && 0 === Z.H(this.path, t.path);\n    }, t.prototype.toString = function() {\n        return this.path.toString();\n    }, t.H = function(t, e) {\n        return Z.H(t.path, e.path);\n    }, t.wt = function(t) {\n        return t.length % 2 == 0;\n    }, \n    /**\n     * Creates and returns a new document key with the given segments.\n     *\n     * @param segments - The segments of the path to the document\n     * @returns A new instance of DocumentKey\n     */\n    t.Et = function(e) {\n        return new t(new Z(e.slice()));\n    }, t;\n}();\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A version of a document in Firestore. This corresponds to the version\n * timestamp, such as update_time or read_time.\n */\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nfunction et(t) {\n    var e = 0;\n    for (var n in t) Object.prototype.hasOwnProperty.call(t, n) && e++;\n    return e;\n}\n\nfunction nt(t, e) {\n    for (var n in t) Object.prototype.hasOwnProperty.call(t, n) && e(n, t[n]);\n}\n\nfunction rt(t) {\n    for (var e in t) if (Object.prototype.hasOwnProperty.call(t, e)) return !1;\n    return !0;\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Provides a set of fields that can be used to partially patch a document.\n * FieldMask is used in conjunction with ObjectValue.\n * Examples:\n *   foo - Overwrites foo entirely with the provided value. If foo is not\n *         present in the companion ObjectValue, the field is deleted.\n *   foo.bar - Overwrites only the field bar of the object foo.\n *             If foo is not an object, foo is replaced with an object\n *             containing foo\n */ var it = /** @class */ function() {\n    function t(t) {\n        this.fields = t, \n        // TODO(dimond): validation of FieldMask\n        // Sort the field mask to support `FieldMask.isEqual()` and assert below.\n        t.sort($.H)\n        /**\n     * Verifies that `fieldPath` is included by at least one field in this field\n     * mask.\n     *\n     * This is an O(n) operation, where `n` is the size of the field mask.\n     */;\n    }\n    return t.prototype.Tt = function(t) {\n        for (var e = 0, n = this.fields; e < n.length; e++) {\n            if (n[e].nt(t)) return !0;\n        }\n        return !1;\n    }, t.prototype.isEqual = function(t) {\n        return L(this.fields, t.fields, (function(t, e) {\n            return t.isEqual(e);\n        }));\n    }, t;\n}(), ot = new RegExp(/^\\d{4}-\\d\\d-\\d\\dT\\d\\d:\\d\\d:\\d\\d(?:\\.(\\d+))?Z$/);\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n// A RegExp matching ISO 8601 UTC timestamps with optional fraction.\n/**\n * Converts the possible Proto values for a timestamp value into a \"seconds and\n * nanos\" representation.\n */\nfunction ut(t) {\n    // The json interface (for the browser) will return an iso timestamp string,\n    // while the proto js library (for node) will return a\n    // google.protobuf.Timestamp instance.\n    if (k(!!t), \"string\" == typeof t) {\n        // The date string can have higher precision (nanos) than the Date class\n        // (millis), so we do some custom parsing here.\n        // Parse the nanos right out of the string.\n        var e = 0, n = ot.exec(t);\n        if (k(!!n), n[1]) {\n            // Pad the fraction out to 9 digits (nanos).\n            var r = n[1];\n            r = (r + \"000000000\").substr(0, 9), e = Number(r);\n        }\n        // Parse the date to get the seconds.\n                var i = new Date(t);\n        return {\n            seconds: Math.floor(i.getTime() / 1e3),\n            nanos: e\n        };\n    }\n    return {\n        seconds: st(t.seconds),\n        nanos: st(t.nanos)\n    };\n}\n\n/**\n * Converts the possible Proto types for numbers into a JavaScript number.\n * Returns 0 if the value is not numeric.\n */ function st(t) {\n    // TODO(bjornick): Handle int64 greater than 53 bits.\n    return \"number\" == typeof t ? t : \"string\" == typeof t ? Number(t) : 0;\n}\n\n/** Converts the possible Proto types for Blobs into a ByteString. */ function at(t) {\n    return \"string\" == typeof t ? U.fromBase64String(t) : U.fromUint8Array(t);\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Represents a locally-applied ServerTimestamp.\n *\n * Server Timestamps are backed by MapValues that contain an internal field\n * `__type__` with a value of `server_timestamp`. The previous value and local\n * write time are stored in its `__previous_value__` and `__local_write_time__`\n * fields respectively.\n *\n * Notes:\n * - ServerTimestampValue instances are created as the result of applying a\n *   transform. They can only exist in the local view of a document. Therefore\n *   they do not need to be parsed or serialized.\n * - When evaluated locally (e.g. for snapshot.data()), they by default\n *   evaluate to `null`. This behavior can be configured by passing custom\n *   FieldValueOptions to value().\n * - With respect to other ServerTimestampValues, they sort by their\n *   localWriteTime.\n */ function ct(t) {\n    var e, n;\n    return \"server_timestamp\" === (null === (n = ((null === (e = null == t ? void 0 : t.mapValue) || void 0 === e ? void 0 : e.fields) || {}).__type__) || void 0 === n ? void 0 : n.stringValue);\n}\n\n/**\n * Creates a new ServerTimestamp proto value (using the internal format).\n */\n/**\n * Returns the value of the field before this ServerTimestamp was set.\n *\n * Preserving the previous values allows the user to display the last resoled\n * value until the backend responds with the timestamp.\n */ function ht(t) {\n    var e = t.mapValue.fields.__previous_value__;\n    return ct(e) ? ht(e) : e;\n}\n\n/**\n * Returns the local time at which this timestamp was first set.\n */ function ft(t) {\n    var e = ut(t.mapValue.fields.__local_write_time__.timestampValue);\n    return new K(e.seconds, e.nanos);\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/** Sentinel value that sorts before any Mutation Batch ID. */\n/**\n * Returns whether a variable is either undefined or null.\n */ function lt(t) {\n    return null == t;\n}\n\n/** Returns whether the value represents -0. */ function pt(t) {\n    // Detect if the value is -0.0. Based on polyfill from\n    // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n    return 0 === t && 1 / t == -1 / 0;\n}\n\n/**\n * Returns whether a value is an integer and in the safe integer range\n * @param value - The value to test for being an integer and in the safe range\n */ function dt(t) {\n    return \"number\" == typeof t && Number.isInteger(t) && !pt(t) && t <= Number.MAX_SAFE_INTEGER && t >= Number.MIN_SAFE_INTEGER;\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/** Extracts the backend's type order for the provided value. */ function vt(t) {\n    return \"nullValue\" in t ? 0 /* NullValue */ : \"booleanValue\" in t ? 1 /* BooleanValue */ : \"integerValue\" in t || \"doubleValue\" in t ? 2 /* NumberValue */ : \"timestampValue\" in t ? 3 /* TimestampValue */ : \"stringValue\" in t ? 5 /* StringValue */ : \"bytesValue\" in t ? 6 /* BlobValue */ : \"referenceValue\" in t ? 7 /* RefValue */ : \"geoPointValue\" in t ? 8 /* GeoPointValue */ : \"arrayValue\" in t ? 9 /* ArrayValue */ : \"mapValue\" in t ? ct(t) ? 4 /* ServerTimestampValue */ : 10 /* ObjectValue */ : x();\n}\n\n/** Tests `left` and `right` for equality based on the backend semantics. */ function yt(t, e) {\n    var n = vt(t);\n    if (n !== vt(e)) return !1;\n    switch (n) {\n      case 0 /* NullValue */ :\n        return !0;\n\n      case 1 /* BooleanValue */ :\n        return t.booleanValue === e.booleanValue;\n\n      case 4 /* ServerTimestampValue */ :\n        return ft(t).isEqual(ft(e));\n\n      case 3 /* TimestampValue */ :\n        return function(t, e) {\n            if (\"string\" == typeof t.timestampValue && \"string\" == typeof e.timestampValue && t.timestampValue.length === e.timestampValue.length) \n            // Use string equality for ISO 8601 timestamps\n            return t.timestampValue === e.timestampValue;\n            var n = ut(t.timestampValue), r = ut(e.timestampValue);\n            return n.seconds === r.seconds && n.nanos === r.nanos;\n        }(t, e);\n\n      case 5 /* StringValue */ :\n        return t.stringValue === e.stringValue;\n\n      case 6 /* BlobValue */ :\n        return function(t, e) {\n            return at(t.bytesValue).isEqual(at(e.bytesValue));\n        }(t, e);\n\n      case 7 /* RefValue */ :\n        return t.referenceValue === e.referenceValue;\n\n      case 8 /* GeoPointValue */ :\n        return function(t, e) {\n            return st(t.geoPointValue.latitude) === st(e.geoPointValue.latitude) && st(t.geoPointValue.longitude) === st(e.geoPointValue.longitude);\n        }(t, e);\n\n      case 2 /* NumberValue */ :\n        return function(t, e) {\n            if (\"integerValue\" in t && \"integerValue\" in e) return st(t.integerValue) === st(e.integerValue);\n            if (\"doubleValue\" in t && \"doubleValue\" in e) {\n                var n = st(t.doubleValue), r = st(e.doubleValue);\n                return n === r ? pt(n) === pt(r) : isNaN(n) && isNaN(r);\n            }\n            return !1;\n        }(t, e);\n\n      case 9 /* ArrayValue */ :\n        return L(t.arrayValue.values || [], e.arrayValue.values || [], yt);\n\n      case 10 /* ObjectValue */ :\n        return function(t, e) {\n            var n = t.mapValue.fields || {}, r = e.mapValue.fields || {};\n            if (et(n) !== et(r)) return !1;\n            for (var i in n) if (n.hasOwnProperty(i) && (void 0 === r[i] || !yt(n[i], r[i]))) return !1;\n            return !0;\n        }(t, e);\n\n      default:\n        return x();\n    }\n}\n\nfunction mt(t, e) {\n    return void 0 !== (t.values || []).find((function(t) {\n        return yt(t, e);\n    }));\n}\n\nfunction gt(t, e) {\n    var n = vt(t), r = vt(e);\n    if (n !== r) return C(n, r);\n    switch (n) {\n      case 0 /* NullValue */ :\n        return 0;\n\n      case 1 /* BooleanValue */ :\n        return C(t.booleanValue, e.booleanValue);\n\n      case 2 /* NumberValue */ :\n        return function(t, e) {\n            var n = st(t.integerValue || t.doubleValue), r = st(e.integerValue || e.doubleValue);\n            return n < r ? -1 : n > r ? 1 : n === r ? 0 : \n            // one or both are NaN.\n            isNaN(n) ? isNaN(r) ? 0 : -1 : 1;\n        }(t, e);\n\n      case 3 /* TimestampValue */ :\n        return wt(t.timestampValue, e.timestampValue);\n\n      case 4 /* ServerTimestampValue */ :\n        return wt(ft(t), ft(e));\n\n      case 5 /* StringValue */ :\n        return C(t.stringValue, e.stringValue);\n\n      case 6 /* BlobValue */ :\n        return function(t, e) {\n            var n = at(t), r = at(e);\n            return n._(r);\n        }(t.bytesValue, e.bytesValue);\n\n      case 7 /* RefValue */ :\n        return function(t, e) {\n            for (var n = t.split(\"/\"), r = e.split(\"/\"), i = 0; i < n.length && i < r.length; i++) {\n                var o = C(n[i], r[i]);\n                if (0 !== o) return o;\n            }\n            return C(n.length, r.length);\n        }(t.referenceValue, e.referenceValue);\n\n      case 8 /* GeoPointValue */ :\n        return function(t, e) {\n            var n = C(st(t.latitude), st(e.latitude));\n            return 0 !== n ? n : C(st(t.longitude), st(e.longitude));\n        }(t.geoPointValue, e.geoPointValue);\n\n      case 9 /* ArrayValue */ :\n        return function(t, e) {\n            for (var n = t.values || [], r = e.values || [], i = 0; i < n.length && i < r.length; ++i) {\n                var o = gt(n[i], r[i]);\n                if (o) return o;\n            }\n            return C(n.length, r.length);\n        }(t.arrayValue, e.arrayValue);\n\n      case 10 /* ObjectValue */ :\n        return function(t, e) {\n            var n = t.fields || {}, r = Object.keys(n), i = e.fields || {}, o = Object.keys(i);\n            // Even though MapValues are likely sorted correctly based on their insertion\n            // order (e.g. when received from the backend), local modifications can bring\n            // elements out of order. We need to re-sort the elements to ensure that\n            // canonical IDs are independent of insertion order.\n                        r.sort(), o.sort();\n            for (var u = 0; u < r.length && u < o.length; ++u) {\n                var s = C(r[u], o[u]);\n                if (0 !== s) return s;\n                var a = gt(n[r[u]], i[o[u]]);\n                if (0 !== a) return a;\n            }\n            return C(r.length, o.length);\n        }(t.mapValue, e.mapValue);\n\n      default:\n        throw x();\n    }\n}\n\nfunction wt(t, e) {\n    if (\"string\" == typeof t && \"string\" == typeof e && t.length === e.length) return C(t, e);\n    var n = ut(t), r = ut(e), i = C(n.seconds, r.seconds);\n    return 0 !== i ? i : C(n.nanos, r.nanos);\n}\n\nfunction bt(t) {\n    return _t(t);\n}\n\nfunction _t(t) {\n    return \"nullValue\" in t ? \"null\" : \"booleanValue\" in t ? \"\" + t.booleanValue : \"integerValue\" in t ? \"\" + t.integerValue : \"doubleValue\" in t ? \"\" + t.doubleValue : \"timestampValue\" in t ? function(t) {\n        var e = ut(t);\n        return \"time(\" + e.seconds + \",\" + e.nanos + \")\";\n    }(t.timestampValue) : \"stringValue\" in t ? t.stringValue : \"bytesValue\" in t ? at(t.bytesValue).toBase64() : \"referenceValue\" in t ? (n = t.referenceValue, \n    tt.ft(n).toString()) : \"geoPointValue\" in t ? \"geo(\" + (e = t.geoPointValue).latitude + \",\" + e.longitude + \")\" : \"arrayValue\" in t ? function(t) {\n        for (var e = \"[\", n = !0, r = 0, i = t.values || []; r < i.length; r++) {\n            n ? n = !1 : e += \",\", e += _t(i[r]);\n        }\n        return e + \"]\";\n    }(t.arrayValue) : \"mapValue\" in t ? function(t) {\n        for (\n        // Iteration order in JavaScript is not guaranteed. To ensure that we generate\n        // matching canonical IDs for identical maps, we need to sort the keys.\n        var e = \"{\", n = !0, r = 0, i = Object.keys(t.fields || {}).sort(); r < i.length; r++) {\n            var o = i[r];\n            n ? n = !1 : e += \",\", e += o + \":\" + _t(t.fields[o]);\n        }\n        return e + \"}\";\n    }(t.mapValue) : x();\n    var e, n;\n}\n\nfunction It(t, e) {\n    return {\n        referenceValue: \"projects/\" + t.projectId + \"/databases/\" + t.database + \"/documents/\" + e.path.rt()\n    };\n}\n\n/** Returns true if `value` is an IntegerValue . */ function Et(t) {\n    return !!t && \"integerValue\" in t;\n}\n\n/** Returns true if `value` is a DoubleValue. */\n/** Returns true if `value` is an ArrayValue. */ function Tt(t) {\n    return !!t && \"arrayValue\" in t;\n}\n\n/** Returns true if `value` is a NullValue. */ function Nt(t) {\n    return !!t && \"nullValue\" in t;\n}\n\n/** Returns true if `value` is NaN. */ function At(t) {\n    return !!t && \"doubleValue\" in t && isNaN(Number(t.doubleValue));\n}\n\n/** Returns true if `value` is a MapValue. */ function Dt(t) {\n    return !!t && \"mapValue\" in t;\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * An ObjectValue represents a MapValue in the Firestore Proto and offers the\n * ability to add and remove fields (via the ObjectValueBuilder).\n */ var St = /** @class */ function() {\n    function t(t) {\n        this.proto = t;\n    }\n    return t.empty = function() {\n        return new t({\n            mapValue: {}\n        });\n    }, \n    /**\n     * Returns the value at the given path or null.\n     *\n     * @param path - the path to search\n     * @returns The value at the path or if there it doesn't exist.\n     */\n    t.prototype.field = function(t) {\n        if (t.et()) return this.proto;\n        for (var e = this.proto, n = 0; n < t.length - 1; ++n) {\n            if (!e.mapValue.fields) return null;\n            if (!Dt(e = e.mapValue.fields[t.get(n)])) return null;\n        }\n        return (e = (e.mapValue.fields || {})[t.tt()]) || null;\n    }, t.prototype.isEqual = function(t) {\n        return yt(this.proto, t.proto);\n    }, t;\n}(), xt = /** @class */ function() {\n    /**\n     * @param baseObject - The object to mutate.\n     */\n    function t(t) {\n        void 0 === t && (t = St.empty()), this.It = t, \n        /** A map that contains the accumulated changes in this builder. */\n        this.At = new Map;\n    }\n    /**\n     * Sets the field to the provided value.\n     *\n     * @param path - The field path to set.\n     * @param value - The value to set.\n     * @returns The current Builder instance.\n     */    return t.prototype.set = function(t, e) {\n        return this.Rt(t, e), this;\n    }, \n    /**\n     * Removes the field at the specified path. If there is no field at the\n     * specified path, nothing is changed.\n     *\n     * @param path - The field path to remove.\n     * @returns The current Builder instance.\n     */\n    t.prototype.delete = function(t) {\n        return this.Rt(t, null), this;\n    }, \n    /**\n     * Adds `value` to the overlay map at `path`. Creates nested map entries if\n     * needed.\n     */\n    t.prototype.Rt = function(t, e) {\n        for (var n = this.At, r = 0; r < t.length - 1; ++r) {\n            var i = t.get(r), o = n.get(i);\n            o instanceof Map ? \n            // Re-use a previously created map\n            n = o : o && 10 /* ObjectValue */ === vt(o) ? (\n            // Convert the existing Protobuf MapValue into a map\n            o = new Map(Object.entries(o.mapValue.fields || {})), n.set(i, o), n = o) : (\n            // Create an empty map to represent the current nesting level\n            o = new Map, n.set(i, o), n = o);\n        }\n        n.set(t.tt(), e);\n    }, \n    /** Returns an ObjectValue with all mutations applied. */ t.prototype.Pt = function() {\n        var t = this.yt($.ct(), this.At);\n        return null != t ? new St(t) : this.It;\n    }, \n    /**\n     * Applies any overlays from `currentOverlays` that exist at `currentPath`\n     * and returns the merged data at `currentPath` (or null if there were no\n     * changes).\n     *\n     * @param currentPath - The path at the current nesting level. Can be set to\n     * FieldValue.emptyPath() to represent the root.\n     * @param currentOverlays - The overlays at the current nesting level in the\n     * same format as `overlayMap`.\n     * @returns The merged data at `currentPath` or null if no modifications\n     * were applied.\n     */\n    t.prototype.yt = function(t, e) {\n        var n = this, r = !1, i = this.It.field(t), o = Dt(i) ? // If there is already data at the current path, base our\n        Object.assign({}, i.mapValue.fields) : {};\n        return e.forEach((function(e, i) {\n            if (e instanceof Map) {\n                var u = n.yt(t.child(i), e);\n                null != u && (o[i] = u, r = !0);\n            } else null !== e ? (o[i] = e, r = !0) : o.hasOwnProperty(i) && (delete o[i], r = !0);\n        })), r ? {\n            mapValue: {\n                fields: o\n            }\n        } : null;\n    }, t;\n}();\n\n/**\n * An ObjectValueBuilder provides APIs to set and delete fields from an\n * ObjectValue.\n */\n/**\n * Returns a FieldMask built from all fields in a MapValue.\n */\nfunction kt(t) {\n    var e = [];\n    return nt(t.fields || {}, (function(t, n) {\n        var r = new $([ t ]);\n        if (Dt(n)) {\n            var i = kt(n.mapValue).fields;\n            if (0 === i.length) \n            // Preserve the empty map by adding it to the FieldMask.\n            e.push(r); else \n            // For nested and non-empty ObjectValues, add the FieldPath of the\n            // leaf nodes.\n            for (var o = 0, u = i; o < u.length; o++) {\n                var s = u[o];\n                e.push(r.child(s));\n            }\n        } else \n        // For nested and non-empty ObjectValues, add the FieldPath of the leaf\n        // nodes.\n        e.push(r);\n    })), new it(e)\n    /**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n    /**\n * The result of a lookup for a given path may be an existing document or a\n * marker that this document does not exist at a given version.\n */;\n}\n\nvar Ot = function(t, e) {\n    this.key = t, this.version = e;\n}, Pt = /** @class */ function(t) {\n    function e(e, n, r, i) {\n        var o = this;\n        return (o = t.call(this, e, n) || this).gt = r, o.Vt = !!i.Vt, o.hasCommittedMutations = !!i.hasCommittedMutations, \n        o;\n    }\n    return m(e, t), e.prototype.field = function(t) {\n        return this.gt.field(t);\n    }, e.prototype.data = function() {\n        return this.gt;\n    }, e.prototype.bt = function() {\n        return this.gt.proto;\n    }, e.prototype.isEqual = function(t) {\n        return t instanceof e && this.key.isEqual(t.key) && this.version.isEqual(t.version) && this.Vt === t.Vt && this.hasCommittedMutations === t.hasCommittedMutations && this.gt.isEqual(t.gt);\n    }, e.prototype.toString = function() {\n        return \"Document(\" + this.key + \", \" + this.version + \", \" + this.gt.toString() + \", {hasLocalMutations: \" + this.Vt + \"}), {hasCommittedMutations: \" + this.hasCommittedMutations + \"})\";\n    }, Object.defineProperty(e.prototype, \"hasPendingWrites\", {\n        get: function() {\n            return this.Vt || this.hasCommittedMutations;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), e;\n}(Ot), Vt = /** @class */ function(t) {\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this, e, n) || this).hasCommittedMutations = !(!r || !r.hasCommittedMutations), \n        i;\n    }\n    return m(e, t), e.prototype.toString = function() {\n        return \"NoDocument(\" + this.key + \", \" + this.version + \")\";\n    }, Object.defineProperty(e.prototype, \"hasPendingWrites\", {\n        get: function() {\n            return this.hasCommittedMutations;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), e.prototype.isEqual = function(t) {\n        return t instanceof e && t.hasCommittedMutations === this.hasCommittedMutations && t.version.isEqual(this.version) && t.key.isEqual(this.key);\n    }, e;\n}(Ot), Ct = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    return m(e, t), e.prototype.toString = function() {\n        return \"UnknownDocument(\" + this.key + \", \" + this.version + \")\";\n    }, Object.defineProperty(e.prototype, \"hasPendingWrites\", {\n        get: function() {\n            return !0;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), e.prototype.isEqual = function(t) {\n        return t instanceof e && t.version.isEqual(this.version) && t.key.isEqual(this.key);\n    }, e;\n}(Ot), Lt = function(t, e, n, r, i, o, u) {\n    void 0 === e && (e = null), void 0 === n && (n = []), void 0 === r && (r = []), \n    void 0 === i && (i = null), void 0 === o && (o = null), void 0 === u && (u = null), \n    this.path = t, this.collectionGroup = e, this.orderBy = n, this.filters = r, this.limit = i, \n    this.startAt = o, this.endAt = u, this.vt = null;\n};\n\n/**\n * Represents a document in Firestore with a key, version, data and whether the\n * data has local mutations applied to it.\n */\n/**\n * Initializes a Target with a path and optional additional query constraints.\n * Path must currently be empty if this is a collection group query.\n *\n * NOTE: you should always construct `Target` from `Query.toTarget` instead of\n * using this factory method, because `Query` provides an implicit `orderBy`\n * property.\n */\nfunction Rt(t, e, n, r, i, o, u) {\n    return void 0 === e && (e = null), void 0 === n && (n = []), void 0 === r && (r = []), \n    void 0 === i && (i = null), void 0 === o && (o = null), void 0 === u && (u = null), \n    new Lt(t, e, n, r, i, o, u);\n}\n\nfunction Ut(t) {\n    var e = O(t);\n    if (null === e.vt) {\n        var n = e.path.rt();\n        null !== e.collectionGroup && (n += \"|cg:\" + e.collectionGroup), n += \"|f:\", n += e.filters.map((function(t) {\n            return function(t) {\n                // TODO(b/29183165): Technically, this won't be unique if two values have\n                // the same description, such as the int 3 and the string \"3\". So we should\n                // add the types in here somehow, too.\n                return t.field.rt() + t.op.toString() + bt(t.value);\n            }(t);\n        })).join(\",\"), n += \"|ob:\", n += e.orderBy.map((function(t) {\n            return function(t) {\n                // TODO(b/29183165): Make this collision robust.\n                return t.field.rt() + t.dir;\n            }(t);\n        })).join(\",\"), lt(e.limit) || (n += \"|l:\", n += e.limit), e.startAt && (n += \"|lb:\", \n        n += Wt(e.startAt)), e.endAt && (n += \"|ub:\", n += Wt(e.endAt)), e.vt = n;\n    }\n    return e.vt;\n}\n\nfunction Mt(t, e) {\n    if (t.limit !== e.limit) return !1;\n    if (t.orderBy.length !== e.orderBy.length) return !1;\n    for (var n = 0; n < t.orderBy.length; n++) if (!Jt(t.orderBy[n], e.orderBy[n])) return !1;\n    if (t.filters.length !== e.filters.length) return !1;\n    for (var r = 0; r < t.filters.length; r++) if (i = t.filters[r], o = e.filters[r], \n    i.op !== o.op || !i.field.isEqual(o.field) || !yt(i.value, o.value)) return !1;\n    var i, o;\n    return t.collectionGroup === e.collectionGroup && !!t.path.isEqual(e.path) && !!te(t.startAt, e.startAt) && te(t.endAt, e.endAt);\n}\n\nfunction qt(t) {\n    return tt.wt(t.path) && null === t.collectionGroup && 0 === t.filters.length;\n}\n\nvar Ft = /** @class */ function(t) {\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this) || this).field = e, i.op = n, i.value = r, i;\n    }\n    /**\n     * Creates a filter based on the provided arguments.\n     */    return m(e, t), e.create = function(t, n, r) {\n        return t.ut() ? \"in\" /* IN */ === n || \"not-in\" /* NOT_IN */ === n ? this.St(t, n, r) : new jt(t, n, r) : \"array-contains\" /* ARRAY_CONTAINS */ === n ? new Qt(t, r) : \"in\" /* IN */ === n ? new Yt(t, r) : \"not-in\" /* NOT_IN */ === n ? new Ht(t, r) : \"array-contains-any\" /* ARRAY_CONTAINS_ANY */ === n ? new Kt(t, r) : new e(t, n, r);\n    }, e.St = function(t, e, n) {\n        return \"in\" /* IN */ === e ? new zt(t, n) : new Gt(t, n);\n    }, e.prototype.matches = function(t) {\n        var e = t.field(this.field);\n        // Types do not have to match in NOT_EQUAL filters.\n                return \"!=\" /* NOT_EQUAL */ === this.op ? null !== e && this.Dt(gt(e, this.value)) : null !== e && vt(this.value) === vt(e) && this.Dt(gt(e, this.value));\n        // Only compare types with matching backend order (such as double and int).\n        }, e.prototype.Dt = function(t) {\n        switch (this.op) {\n          case \"<\" /* LESS_THAN */ :\n            return t < 0;\n\n          case \"<=\" /* LESS_THAN_OR_EQUAL */ :\n            return t <= 0;\n\n          case \"==\" /* EQUAL */ :\n            return 0 === t;\n\n          case \"!=\" /* NOT_EQUAL */ :\n            return 0 !== t;\n\n          case \">\" /* GREATER_THAN */ :\n            return t > 0;\n\n          case \">=\" /* GREATER_THAN_OR_EQUAL */ :\n            return t >= 0;\n\n          default:\n            return x();\n        }\n    }, e.prototype.Ct = function() {\n        return [ \"<\" /* LESS_THAN */ , \"<=\" /* LESS_THAN_OR_EQUAL */ , \">\" /* GREATER_THAN */ , \">=\" /* GREATER_THAN_OR_EQUAL */ , \"!=\" /* NOT_EQUAL */ , \"not-in\" /* NOT_IN */ ].indexOf(this.op) >= 0;\n    }, e;\n}((function() {}));\n\nvar jt = /** @class */ function(t) {\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this, e, n, r) || this).key = tt.ft(r.referenceValue), i;\n    }\n    return m(e, t), e.prototype.matches = function(t) {\n        var e = tt.H(t.key, this.key);\n        return this.Dt(e);\n    }, e;\n}(Ft), zt = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, e, \"in\" /* IN */ , n) || this).keys = Bt(\"in\" /* IN */ , n), \n        r;\n    }\n    return m(e, t), e.prototype.matches = function(t) {\n        return this.keys.some((function(e) {\n            return e.isEqual(t.key);\n        }));\n    }, e;\n}(Ft), Gt = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, e, \"not-in\" /* NOT_IN */ , n) || this).keys = Bt(\"not-in\" /* NOT_IN */ , n), \n        r;\n    }\n    return m(e, t), e.prototype.matches = function(t) {\n        return !this.keys.some((function(e) {\n            return e.isEqual(t.key);\n        }));\n    }, e;\n}(Ft);\n\n/** Filter that matches on key fields within an array. */ function Bt(t, e) {\n    var n;\n    return ((null === (n = e.arrayValue) || void 0 === n ? void 0 : n.values) || []).map((function(t) {\n        return tt.ft(t.referenceValue);\n    }));\n}\n\n/** A Filter that implements the array-contains operator. */ var Qt = /** @class */ function(t) {\n    function e(e, n) {\n        return t.call(this, e, \"array-contains\" /* ARRAY_CONTAINS */ , n) || this;\n    }\n    return m(e, t), e.prototype.matches = function(t) {\n        var e = t.field(this.field);\n        return Tt(e) && mt(e.arrayValue, this.value);\n    }, e;\n}(Ft), Yt = /** @class */ function(t) {\n    function e(e, n) {\n        return t.call(this, e, \"in\" /* IN */ , n) || this;\n    }\n    return m(e, t), e.prototype.matches = function(t) {\n        var e = t.field(this.field);\n        return null !== e && mt(this.value.arrayValue, e);\n    }, e;\n}(Ft), Ht = /** @class */ function(t) {\n    function e(e, n) {\n        return t.call(this, e, \"not-in\" /* NOT_IN */ , n) || this;\n    }\n    return m(e, t), e.prototype.matches = function(t) {\n        if (mt(this.value.arrayValue, {\n            nullValue: \"NULL_VALUE\"\n        })) return !1;\n        var e = t.field(this.field);\n        return null !== e && !mt(this.value.arrayValue, e);\n    }, e;\n}(Ft), Kt = /** @class */ function(t) {\n    function e(e, n) {\n        return t.call(this, e, \"array-contains-any\" /* ARRAY_CONTAINS_ANY */ , n) || this;\n    }\n    return m(e, t), e.prototype.matches = function(t) {\n        var e = this, n = t.field(this.field);\n        return !(!Tt(n) || !n.arrayValue.values) && n.arrayValue.values.some((function(t) {\n            return mt(e.value.arrayValue, t);\n        }));\n    }, e;\n}(Ft), Xt = function(t, e) {\n    this.position = t, this.before = e;\n};\n\n/** A Filter that implements the IN operator. */ function Wt(t) {\n    // TODO(b/29183165): Make this collision robust.\n    return (t.before ? \"b\" : \"a\") + \":\" + t.position.map((function(t) {\n        return bt(t);\n    })).join(\",\");\n}\n\n/**\n * An ordering on a field, in some Direction. Direction defaults to ASCENDING.\n */ var Zt = function(t, e /* ASCENDING */) {\n    void 0 === e && (e = \"asc\"), this.field = t, this.dir = e;\n};\n\nfunction Jt(t, e) {\n    return t.dir === e.dir && t.field.isEqual(e.field);\n}\n\n/**\n * Returns true if a document sorts before a bound using the provided sort\n * order.\n */ function $t(t, e, n) {\n    for (var r = 0, i = 0; i < t.position.length; i++) {\n        var o = e[i], u = t.position[i];\n        if (r = o.field.ut() ? tt.H(tt.ft(u.referenceValue), n.key) : gt(u, n.field(o.field)), \n        \"desc\" /* DESCENDING */ === o.dir && (r *= -1), 0 !== r) break;\n    }\n    return t.before ? r <= 0 : r < 0;\n}\n\nfunction te(t, e) {\n    if (null === t) return null === e;\n    if (null === e) return !1;\n    if (t.before !== e.before || t.position.length !== e.position.length) return !1;\n    for (var n = 0; n < t.position.length; n++) if (!yt(t.position[n], e.position[n])) return !1;\n    return !0;\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Query encapsulates all the query attributes we support in the SDK. It can\n * be run against the LocalStore, as well as be converted to a `Target` to\n * query the RemoteStore results.\n *\n * Visible for testing.\n */ var ee = \n/**\n     * Initializes a Query with a path and optional additional query constraints.\n     * Path must currently be empty if this is a collection group query.\n     */\nfunction(t, e, n, r, i, o /* First */ , u, s) {\n    void 0 === e && (e = null), void 0 === n && (n = []), void 0 === r && (r = []), \n    void 0 === i && (i = null), void 0 === o && (o = \"F\"), void 0 === u && (u = null), \n    void 0 === s && (s = null), this.path = t, this.collectionGroup = e, this.xt = n, \n    this.filters = r, this.limit = i, this.limitType = o, this.startAt = u, this.endAt = s, \n    this.Nt = null, \n    // The corresponding `Target` of this `Query` instance.\n    this.$t = null, this.startAt, this.endAt;\n};\n\n/** Creates a new Query instance with the options provided. */ function ne(t, e, n, r, i, o, u, s) {\n    return new ee(t, e, n, r, i, o, u, s);\n}\n\n/** Creates a new Query for a query that matches all documents at `path` */ function re(t) {\n    return new ee(t);\n}\n\n/**\n * Helper to convert a collection group query into a collection query at a\n * specific path. This is used when executing collection group queries, since\n * we have to split the query into a set of collection queries at multiple\n * paths.\n */ function ie(t) {\n    return !lt(t.limit) && \"F\" /* First */ === t.limitType;\n}\n\nfunction oe(t) {\n    return !lt(t.limit) && \"L\" /* Last */ === t.limitType;\n}\n\nfunction ue(t) {\n    return t.xt.length > 0 ? t.xt[0].field : null;\n}\n\nfunction se(t) {\n    for (var e = 0, n = t.filters; e < n.length; e++) {\n        var r = n[e];\n        if (r.Ct()) return r.field;\n    }\n    return null;\n}\n\n/**\n * Checks if any of the provided Operators are included in the query and\n * returns the first one that is, or null if none are.\n */\n/**\n * Returns whether the query matches a collection group rather than a specific\n * collection.\n */ function ae(t) {\n    return null !== t.collectionGroup;\n}\n\n/**\n * Returns the implicit order by constraint that is used to execute the Query,\n * which can be different from the order by constraints the user provided (e.g.\n * the SDK and backend always orders by `__name__`).\n */ function ce(t) {\n    var e = O(t);\n    if (null === e.Nt) {\n        e.Nt = [];\n        var n = se(e), r = ue(e);\n        if (null !== n && null === r) \n        // In order to implicitly add key ordering, we must also add the\n        // inequality filter field for it to be a valid query.\n        // Note that the default inequality field and key ordering is ascending.\n        n.ut() || e.Nt.push(new Zt(n)), e.Nt.push(new Zt($.ht(), \"asc\" /* ASCENDING */)); else {\n            for (var i = !1, o = 0, u = e.xt; o < u.length; o++) {\n                var s = u[o];\n                e.Nt.push(s), s.field.ut() && (i = !0);\n            }\n            if (!i) {\n                // The order of the implicit key ordering always matches the last\n                // explicit order by\n                var a = e.xt.length > 0 ? e.xt[e.xt.length - 1].dir : \"asc\" /* ASCENDING */;\n                e.Nt.push(new Zt($.ht(), a));\n            }\n        }\n    }\n    return e.Nt;\n}\n\n/**\n * Converts this `Query` instance to it's corresponding `Target` representation.\n */ function he(t) {\n    var e = O(t);\n    if (!e.$t) if (\"F\" /* First */ === e.limitType) e.$t = Rt(e.path, e.collectionGroup, ce(e), e.filters, e.limit, e.startAt, e.endAt); else {\n        for (\n        // Flip the orderBy directions since we want the last results\n        var n = [], r = 0, i = ce(e); r < i.length; r++) {\n            var o = i[r], u = \"desc\" /* DESCENDING */ === o.dir ? \"asc\" /* ASCENDING */ : \"desc\" /* DESCENDING */;\n            n.push(new Zt(o.field, u));\n        }\n        // We need to swap the cursors to match the now-flipped query ordering.\n                var s = e.endAt ? new Xt(e.endAt.position, !e.endAt.before) : null, a = e.startAt ? new Xt(e.startAt.position, !e.startAt.before) : null;\n        // Now return as a LimitType.First query.\n                e.$t = Rt(e.path, e.collectionGroup, n, e.filters, e.limit, s, a);\n    }\n    return e.$t;\n}\n\nfunction fe(t, e, n) {\n    return new ee(t.path, t.collectionGroup, t.xt.slice(), t.filters.slice(), e, n, t.startAt, t.endAt);\n}\n\nfunction le(t, e) {\n    return Mt(he(t), he(e)) && t.limitType === e.limitType;\n}\n\n// TODO(b/29183165): This is used to get a unique string from a query to, for\n// example, use as a dictionary key, but the implementation is subject to\n// collisions. Make it collision-free.\nfunction pe(t) {\n    return Ut(he(t)) + \"|lt:\" + t.limitType;\n}\n\nfunction de(t) {\n    return \"Query(target=\" + function(t) {\n        var e = t.path.rt();\n        return null !== t.collectionGroup && (e += \" collectionGroup=\" + t.collectionGroup), \n        t.filters.length > 0 && (e += \", filters: [\" + t.filters.map((function(t) {\n            return (e = t).field.rt() + \" \" + e.op + \" \" + bt(e.value);\n            /** Returns a debug description for `filter`. */            var e;\n            /** Filter that matches on key fields (i.e. '__name__'). */        })).join(\", \") + \"]\"), \n        lt(t.limit) || (e += \", limit: \" + t.limit), t.orderBy.length > 0 && (e += \", orderBy: [\" + t.orderBy.map((function(t) {\n            return function(t) {\n                return t.field.rt() + \" (\" + t.dir + \")\";\n            }(t);\n        })).join(\", \") + \"]\"), t.startAt && (e += \", startAt: \" + Wt(t.startAt)), t.endAt && (e += \", endAt: \" + Wt(t.endAt)), \n        \"Target(\" + e + \")\";\n    }(he(t)) + \"; limitType=\" + t.limitType + \")\";\n}\n\n/** Returns whether `doc` matches the constraints of `query`. */ function ve(t, e) {\n    return function(t, e) {\n        var n = e.key.path;\n        return null !== t.collectionGroup ? e.key.dt(t.collectionGroup) && t.path.nt(n) : tt.wt(t.path) ? t.path.isEqual(n) : t.path.st(n);\n    }(t, e) && function(t, e) {\n        for (var n = 0, r = t.xt; n < r.length; n++) {\n            var i = r[n];\n            // order by key always matches\n                        if (!i.field.ut() && null === e.field(i.field)) return !1;\n        }\n        return !0;\n    }(t, e) && function(t, e) {\n        for (var n = 0, r = t.filters; n < r.length; n++) {\n            if (!r[n].matches(e)) return !1;\n        }\n        return !0;\n    }(t, e) && function(t, e) {\n        return !(t.startAt && !$t(t.startAt, ce(t), e)) && (!t.endAt || !$t(t.endAt, ce(t), e));\n    }(t, e);\n}\n\nfunction ye(t) {\n    return function(e, n) {\n        for (var r = !1, i = 0, o = ce(t); i < o.length; i++) {\n            var u = o[i], s = me(u, e, n);\n            if (0 !== s) return s;\n            r = r || u.field.ut();\n        }\n        return 0;\n    };\n}\n\nfunction me(t, e, n) {\n    var r = t.field.ut() ? tt.H(e.key, n.key) : function(t, e, n) {\n        var r = e.field(t), i = n.field(t);\n        return null !== r && null !== i ? gt(r, i) : x();\n    }(t.field, e, n);\n    switch (t.dir) {\n      case \"asc\" /* ASCENDING */ :\n        return r;\n\n      case \"desc\" /* DESCENDING */ :\n        return -1 * r;\n\n      default:\n        return x();\n    }\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * An immutable set of metadata that the local store tracks for each target.\n */ var ge = /** @class */ function() {\n    function t(\n    /** The target being listened to. */\n    t, \n    /**\n     * The target ID to which the target corresponds; Assigned by the\n     * LocalStore for user listens and by the SyncEngine for limbo watches.\n     */\n    e, \n    /** The purpose of the target. */\n    n, \n    /**\n     * The sequence number of the last transaction during which this target data\n     * was modified.\n     */\n    r, \n    /** The latest snapshot version seen for this target. */\n    i\n    /**\n     * The maximum snapshot version at which the associated view\n     * contained no limbo documents.\n     */ , o\n    /**\n     * An opaque, server-assigned token that allows watching a target to be\n     * resumed after disconnecting without retransmitting all the data that\n     * matches the target. The resume token essentially identifies a point in\n     * time from which the server should resume sending results.\n     */ , u) {\n        void 0 === i && (i = X.min()), void 0 === o && (o = X.min()), void 0 === u && (u = U.T), \n        this.target = t, this.targetId = e, this.Ft = n, this.sequenceNumber = r, this.Ot = i, \n        this.lastLimboFreeSnapshotVersion = o, this.resumeToken = u;\n    }\n    /** Creates a new target data instance with an updated sequence number. */    return t.prototype.kt = function(e) {\n        return new t(this.target, this.targetId, this.Ft, e, this.Ot, this.lastLimboFreeSnapshotVersion, this.resumeToken);\n    }, \n    /**\n     * Creates a new target data instance with an updated resume token and\n     * snapshot version.\n     */\n    t.prototype.Mt = function(e, n) {\n        return new t(this.target, this.targetId, this.Ft, this.sequenceNumber, n, this.lastLimboFreeSnapshotVersion, e);\n    }, \n    /**\n     * Creates a new target data instance with an updated last limbo free\n     * snapshot version number.\n     */\n    t.prototype.Lt = function(e) {\n        return new t(this.target, this.targetId, this.Ft, this.sequenceNumber, this.Ot, e, this.resumeToken);\n    }, t;\n}();\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Returns an DoubleValue for `value` that is encoded based the serializer's\n * `useProto3Json` setting.\n */ function we(t, e) {\n    if (t.Bt) {\n        if (isNaN(e)) return {\n            doubleValue: \"NaN\"\n        };\n        if (e === 1 / 0) return {\n            doubleValue: \"Infinity\"\n        };\n        if (e === -1 / 0) return {\n            doubleValue: \"-Infinity\"\n        };\n    }\n    return {\n        doubleValue: pt(e) ? \"-0\" : e\n    };\n}\n\n/**\n * Returns an IntegerValue for `value`.\n */ function be(t) {\n    return {\n        integerValue: \"\" + t\n    };\n}\n\n/**\n * Returns a value for a number that's appropriate to put into a proto.\n * The return value is an IntegerValue if it can safely represent the value,\n * otherwise a DoubleValue is returned.\n */ function _e(t, e) {\n    return dt(e) ? be(e) : we(t, e);\n}\n\n/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/** Used to represent a field transform on a mutation. */ var Ie = function() {\n    // Make sure that the structural type of `TransformOperation` is unique.\n    // See https://github.com/microsoft/TypeScript/issues/5451\n    this.qt = void 0;\n};\n\n/**\n * Computes the local transform result against the provided `previousValue`,\n * optionally using the provided localWriteTime.\n */ function Ee(t, e, n) {\n    return t instanceof Ae ? function(t, e) {\n        var n = {\n            fields: {\n                __type__: {\n                    stringValue: \"server_timestamp\"\n                },\n                __local_write_time__: {\n                    timestampValue: {\n                        seconds: t.seconds,\n                        nanos: t.nanoseconds\n                    }\n                }\n            }\n        };\n        return e && (n.fields.__previous_value__ = e), {\n            mapValue: n\n        };\n    }(n, e) : t instanceof De ? Se(t, e) : t instanceof xe ? ke(t, e) : function(t, e) {\n        // PORTING NOTE: Since JavaScript's integer arithmetic is limited to 53 bit\n        // precision and resolves overflows by reducing precision, we do not\n        // manually cap overflows at 2^63.\n        var n = Ne(t, e), r = Pe(n) + Pe(t.Ut);\n        return Et(n) && Et(t.Ut) ? be(r) : we(t.Qt, r);\n    }(t, e);\n}\n\n/**\n * Computes a final transform result after the transform has been acknowledged\n * by the server, potentially using the server-provided transformResult.\n */ function Te(t, e, n) {\n    // The server just sends null as the transform result for array operations,\n    // so we have to calculate a result the same as we do for local\n    // applications.\n    return t instanceof De ? Se(t, e) : t instanceof xe ? ke(t, e) : n;\n}\n\n/**\n * If this transform operation is not idempotent, returns the base value to\n * persist for this transform. If a base value is returned, the transform\n * operation is always applied to this base value, even if document has\n * already been updated.\n *\n * Base values provide consistent behavior for non-idempotent transforms and\n * allow us to return the same latency-compensated value even if the backend\n * has already applied the transform operation. The base value is null for\n * idempotent transforms, as they can be re-played even if the backend has\n * already applied them.\n *\n * @returns a base value to store along with the mutation, or null for\n * idempotent transforms.\n */ function Ne(t, e) {\n    return t instanceof Oe ? Et(n = e) || function(t) {\n        return !!t && \"doubleValue\" in t;\n    }(n) ? e : {\n        integerValue: 0\n    } : null;\n    var n;\n}\n\n/** Transforms a value into a server-generated timestamp. */ var Ae = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    return m(e, t), e;\n}(Ie), De = /** @class */ function(t) {\n    function e(e) {\n        var n = this;\n        return (n = t.call(this) || this).elements = e, n;\n    }\n    return m(e, t), e;\n}(Ie);\n\n/** Transforms an array value via a union operation. */ function Se(t, e) {\n    for (var n = Ve(e), r = function(t) {\n        n.some((function(e) {\n            return yt(e, t);\n        })) || n.push(t);\n    }, i = 0, o = t.elements; i < o.length; i++) {\n        r(o[i]);\n    }\n    return {\n        arrayValue: {\n            values: n\n        }\n    };\n}\n\n/** Transforms an array value via a remove operation. */ var xe = /** @class */ function(t) {\n    function e(e) {\n        var n = this;\n        return (n = t.call(this) || this).elements = e, n;\n    }\n    return m(e, t), e;\n}(Ie);\n\nfunction ke(t, e) {\n    for (var n = Ve(e), r = function(t) {\n        n = n.filter((function(e) {\n            return !yt(e, t);\n        }));\n    }, i = 0, o = t.elements; i < o.length; i++) {\n        r(o[i]);\n    }\n    return {\n        arrayValue: {\n            values: n\n        }\n    };\n}\n\n/**\n * Implements the backend semantics for locally computed NUMERIC_ADD (increment)\n * transforms. Converts all field values to integers or doubles, but unlike the\n * backend does not cap integer values at 2^63. Instead, JavaScript number\n * arithmetic is used and precision loss can occur for values greater than 2^53.\n */ var Oe = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this) || this).Qt = e, r.Ut = n, r;\n    }\n    return m(e, t), e;\n}(Ie);\n\nfunction Pe(t) {\n    return st(t.integerValue || t.doubleValue);\n}\n\nfunction Ve(t) {\n    return Tt(t) && t.arrayValue.values ? t.arrayValue.values.slice() : [];\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/** A field path and the TransformOperation to perform upon it. */ var Ce = function(t, e) {\n    this.field = t, this.transform = e;\n};\n\n/** The result of successfully applying a mutation to the backend. */\nvar Le = function(\n/**\n     * The version at which the mutation was committed:\n     *\n     * - For most operations, this is the updateTime in the WriteResult.\n     * - For deletes, the commitTime of the WriteResponse (because deletes are\n     *   not stored and have no updateTime).\n     *\n     * Note that these versions can be different: No-op writes will not change\n     * the updateTime even though the commitTime advances.\n     */\nt, \n/**\n     * The resulting fields returned from the backend after a mutation\n     * containing field transforms has been committed. Contains one FieldValue\n     * for each FieldTransform that was in the mutation.\n     *\n     * Will be empty if the mutation did not contain any field transforms.\n     */\ne) {\n    this.version = t, this.transformResults = e;\n}, Re = /** @class */ function() {\n    function t(t, e) {\n        this.updateTime = t, this.exists = e\n        /** Creates a new empty Precondition. */;\n    }\n    return t.Kt = function() {\n        return new t;\n    }, \n    /** Creates a new Precondition with an exists flag. */ t.exists = function(e) {\n        return new t(void 0, e);\n    }, \n    /** Creates a new Precondition based on a version a document exists at. */ t.updateTime = function(e) {\n        return new t(e);\n    }, Object.defineProperty(t.prototype, \"Wt\", {\n        /** Returns whether this Precondition is empty. */ get: function() {\n            return void 0 === this.updateTime && void 0 === this.exists;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.isEqual = function(t) {\n        return this.exists === t.exists && (this.updateTime ? !!t.updateTime && this.updateTime.isEqual(t.updateTime) : !t.updateTime);\n    }, t;\n}();\n\n/**\n * Encodes a precondition for a mutation. This follows the model that the\n * backend accepts with the special case of an explicit \"empty\" precondition\n * (meaning no precondition).\n */\n/**\n * Returns true if the preconditions is valid for the given document\n * (or null if no document is available).\n */\nfunction Ue(t, e) {\n    return void 0 !== t.updateTime ? e instanceof Pt && e.version.isEqual(t.updateTime) : void 0 === t.exists || t.exists === e instanceof Pt;\n}\n\n/**\n * A mutation describes a self-contained change to a document. Mutations can\n * create, replace, delete, and update subsets of documents.\n *\n * Mutations not only act on the value of the document but also its version.\n *\n * For local mutations (mutations that haven't been committed yet), we preserve\n * the existing version for Set and Patch mutations. For Delete mutations, we\n * reset the version to 0.\n *\n * Here's the expected transition table.\n *\n * MUTATION           APPLIED TO            RESULTS IN\n *\n * SetMutation        Document(v3)          Document(v3)\n * SetMutation        NoDocument(v3)        Document(v0)\n * SetMutation        null                  Document(v0)\n * PatchMutation      Document(v3)          Document(v3)\n * PatchMutation      NoDocument(v3)        NoDocument(v3)\n * PatchMutation      null                  null\n * DeleteMutation     Document(v3)          NoDocument(v0)\n * DeleteMutation     NoDocument(v3)        NoDocument(v0)\n * DeleteMutation     null                  NoDocument(v0)\n *\n * For acknowledged mutations, we use the updateTime of the WriteResponse as\n * the resulting version for Set and Patch mutations. As deletes have no\n * explicit update time, we use the commitTime of the WriteResponse for\n * Delete mutations.\n *\n * If a mutation is acknowledged by the backend but fails the precondition check\n * locally, we return an `UnknownDocument` and rely on Watch to send us the\n * updated version.\n *\n * Field transforms are used only with Patch and Set Mutations. We use the\n * `updateTransforms` message to store transforms, rather than the `transforms`s\n * messages.\n *\n * ## Subclassing Notes\n *\n * Subclasses of Mutation need to implement applyToRemoteDocument() and\n * applyToLocalView() to implement the actual behavior of applying the mutation\n * to some source document.\n */ var Me = function() {};\n\n/**\n * Applies this mutation to the given MaybeDocument or null for the purposes\n * of computing a new remote document. If the input document doesn't match the\n * expected state (e.g. it is null or outdated), an `UnknownDocument` can be\n * returned.\n *\n * @param mutation - The mutation to apply.\n * @param maybeDoc - The document to mutate. The input document can be null if\n *     the client has no knowledge of the pre-mutation state of the document.\n * @param mutationResult - The result of applying the mutation from the backend.\n * @returns The mutated document. The returned document may be an\n *     UnknownDocument if the mutation could not be applied to the locally\n *     cached base document.\n */ function qe(t, e, n) {\n    return t instanceof Be ? function(t, e, n) {\n        // Unlike applySetMutationToLocalView, if we're applying a mutation to a\n        // remote document the server has accepted the mutation so the precondition\n        // must have held.\n        var r = t.value, i = He(t.fieldTransforms, e, n.transformResults);\n        return r = Xe(t.fieldTransforms, r, i), new Pt(t.key, n.version, r, {\n            hasCommittedMutations: !0\n        });\n    }(t, e, n) : t instanceof Qe ? function(t, e, n) {\n        if (!Ue(t.jt, e)) \n        // Since the mutation was not rejected, we know that the precondition\n        // matched on the backend. We therefore must not have the expected version\n        // of the document in our cache and return an UnknownDocument with the\n        // known updateTime.\n        return new Ct(t.key, n.version);\n        var r = Ye(t, e, He(t.fieldTransforms, e, n.transformResults));\n        return new Pt(t.key, n.version, r, {\n            hasCommittedMutations: !0\n        });\n    }(t, e, n) : function(t, e, n) {\n        // Unlike applyToLocalView, if we're applying a mutation to a remote\n        // document the server has accepted the mutation so the precondition must\n        // have held.\n        return new Vt(t.key, n.version, {\n            hasCommittedMutations: !0\n        });\n    }(t, 0, n);\n}\n\n/**\n * Applies this mutation to the given MaybeDocument or null for the purposes\n * of computing the new local view of a document. Both the input and returned\n * documents can be null.\n *\n * @param mutation - The mutation to apply.\n * @param maybeDoc - The document to mutate. The input document can be null if\n *     the client has no knowledge of the pre-mutation state of the document.\n * @param localWriteTime - A timestamp indicating the local write time of the\n *     batch this mutation is a part of.\n * @returns The mutated document. The returned document may be null, but only\n *     if maybeDoc was null and the mutation would not create a new document.\n */ function Fe(t, e, n) {\n    return t instanceof Be ? function(t, e, n) {\n        if (!Ue(t.jt, e)) return e;\n        var r = t.value, i = Ke(t.fieldTransforms, n, e);\n        r = Xe(t.fieldTransforms, r, i);\n        var o = Ge(e);\n        return new Pt(t.key, o, r, {\n            Vt: !0\n        });\n    }(t, e, n) : t instanceof Qe ? function(t, e, n) {\n        if (!Ue(t.jt, e)) return e;\n        var r = Ge(e), i = Ye(t, e, Ke(t.fieldTransforms, n, e));\n        return new Pt(t.key, r, i, {\n            Vt: !0\n        });\n    }(t, e, n) : function(t, e) {\n        return Ue(t.jt, e) ? new Vt(t.key, X.min()) : e;\n    }(t, e);\n}\n\n/**\n * If this mutation is not idempotent, returns the base value to persist with\n * this mutation. If a base value is returned, the mutation is always applied\n * to this base value, even if document has already been updated.\n *\n * The base value is a sparse object that consists of only the document\n * fields for which this mutation contains a non-idempotent transformation\n * (e.g. a numeric increment). The provided value guarantees consistent\n * behavior for non-idempotent transforms and allow us to return the same\n * latency-compensated value even if the backend has already applied the\n * mutation. The base value is null for idempotent mutations, as they can be\n * re-played even if the backend has already applied them.\n *\n * @returns a base value to store along with the mutation, or null for\n * idempotent mutations.\n */ function je(t, e) {\n    return function(t, e) {\n        for (var n = null, r = 0, i = t; r < i.length; r++) {\n            var o = i[r], u = e instanceof Pt ? e.field(o.field) : void 0, s = Ne(o.transform, u || null);\n            null != s && (n = null == n ? (new xt).set(o.field, s) : n.set(o.field, s));\n        }\n        return n ? n.Pt() : null;\n    }(t.fieldTransforms, e);\n}\n\nfunction ze(t, e) {\n    return t.type === e.type && !!t.key.isEqual(e.key) && !!t.jt.isEqual(e.jt) && !!function(t, e) {\n        return void 0 === t && void 0 === e || !(!t || !e) && L(t, e, (function(t, e) {\n            return function(t, e) {\n                return t.field.isEqual(e.field) && function(t, e) {\n                    return t instanceof De && e instanceof De || t instanceof xe && e instanceof xe ? L(t.elements, e.elements, yt) : t instanceof Oe && e instanceof Oe ? yt(t.Ut, e.Ut) : t instanceof Ae && e instanceof Ae;\n                }(t.transform, e.transform);\n            }(t, e);\n        }));\n    }(t.fieldTransforms, e.fieldTransforms) && (0 /* Set */ === t.type ? t.value.isEqual(e.value) : 1 /* Patch */ !== t.type || t.data.isEqual(e.data) && t.Gt.isEqual(e.Gt));\n}\n\n/**\n * Returns the version from the given document for use as the result of a\n * mutation. Mutations are defined to return the version of the base document\n * only if it is an existing document. Deleted and unknown documents have a\n * post-mutation version of SnapshotVersion.min().\n */ function Ge(t) {\n    return t instanceof Pt ? t.version : X.min();\n}\n\n/**\n * A mutation that creates or replaces the document at the given key with the\n * object value contents.\n */ var Be = /** @class */ function(t) {\n    function e(e, n, r, i) {\n        void 0 === i && (i = []);\n        var o = this;\n        return (o = t.call(this) || this).key = e, o.value = n, o.jt = r, o.fieldTransforms = i, \n        o.type = 0 /* Set */ , o;\n    }\n    return m(e, t), e;\n}(Me), Qe = /** @class */ function(t) {\n    function e(e, n, r, i, o) {\n        void 0 === o && (o = []);\n        var u = this;\n        return (u = t.call(this) || this).key = e, u.data = n, u.Gt = r, u.jt = i, u.fieldTransforms = o, \n        u.type = 1 /* Patch */ , u;\n    }\n    return m(e, t), e;\n}(Me);\n\nfunction Ye(t, e, n) {\n    var r;\n    return r = function(t, e) {\n        var n = new xt(e);\n        return t.Gt.fields.forEach((function(e) {\n            if (!e.et()) {\n                var r = t.data.field(e);\n                null !== r ? n.set(e, r) : n.delete(e);\n            }\n        })), n.Pt();\n    }(t, r = e instanceof Pt ? e.data() : St.empty()), r = Xe(t.fieldTransforms, r, n);\n}\n\nfunction He(t, e, n) {\n    var r = [];\n    k(t.length === n.length);\n    for (var i = 0; i < n.length; i++) {\n        var o = t[i], u = o.transform, s = null;\n        e instanceof Pt && (s = e.field(o.field)), r.push(Te(u, s, n[i]));\n    }\n    return r;\n}\n\n/**\n * Creates a list of \"transform results\" (a transform result is a field value\n * representing the result of applying a transform) for use when applying a\n * transform locally.\n *\n * @param fieldTransforms - The field transforms to apply the result to.\n * @param localWriteTime - The local time of the mutation (used to\n *     generate ServerTimestampValues).\n * @param maybeDoc - The current state of the document after applying all\n *     previous mutations.\n * @returns The transform results list.\n */ function Ke(t, e, n) {\n    for (var r = [], i = 0, o = t; i < o.length; i++) {\n        var u = o[i], s = u.transform, a = null;\n        n instanceof Pt && (a = n.field(u.field)), r.push(Ee(s, a, e));\n    }\n    return r;\n}\n\nfunction Xe(t, e, n) {\n    for (var r = new xt(e), i = 0; i < t.length; i++) {\n        var o = t[i];\n        r.set(o.field, n[i]);\n    }\n    return r.Pt();\n}\n\n/** A mutation that deletes the document at the given key. */ var We, Ze, Je = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this) || this).key = e, r.jt = n, r.type = 2 /* Delete */ , r.fieldTransforms = [], \n        r;\n    }\n    return m(e, t), e;\n}(Me), $e = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this) || this).key = e, r.jt = n, r.type = 3 /* Verify */ , r.fieldTransforms = [], \n        r;\n    }\n    return m(e, t), e;\n}(Me), tn = \n// TODO(b/33078163): just use simplest form of existence filter for now\nfunction(t) {\n    this.count = t;\n};\n\n/**\n * Determines whether an error code represents a permanent error when received\n * in response to a non-write operation.\n *\n * See isPermanentWriteError for classifying write errors.\n */\nfunction en(t) {\n    switch (t) {\n      case M.OK:\n        return x();\n\n      case M.CANCELLED:\n      case M.UNKNOWN:\n      case M.DEADLINE_EXCEEDED:\n      case M.RESOURCE_EXHAUSTED:\n      case M.INTERNAL:\n      case M.UNAVAILABLE:\n // Unauthenticated means something went wrong with our token and we need\n        // to retry with new credentials which will happen automatically.\n              case M.UNAUTHENTICATED:\n        return !1;\n\n      case M.INVALID_ARGUMENT:\n      case M.NOT_FOUND:\n      case M.ALREADY_EXISTS:\n      case M.PERMISSION_DENIED:\n      case M.FAILED_PRECONDITION:\n // Aborted might be retried in some scenarios, but that is dependant on\n        // the context and should handled individually by the calling code.\n        // See https://cloud.google.com/apis/design/errors.\n              case M.ABORTED:\n      case M.OUT_OF_RANGE:\n      case M.UNIMPLEMENTED:\n      case M.DATA_LOSS:\n        return !0;\n\n      default:\n        return x();\n    }\n}\n\n/**\n * Determines whether an error code represents a permanent error when received\n * in response to a write operation.\n *\n * Write operations must be handled specially because as of b/119437764, ABORTED\n * errors on the write stream should be retried too (even though ABORTED errors\n * are not generally retryable).\n *\n * Note that during the initial handshake on the write stream an ABORTED error\n * signals that we should discard our stream token (i.e. it is permanent). This\n * means a handshake error should be classified with isPermanentError, above.\n */\n/**\n * Maps an error Code from GRPC status code number, like 0, 1, or 14. These\n * are not the same as HTTP status codes.\n *\n * @returns The Code equivalent to the given GRPC status code. Fails if there\n *     is no match.\n */ function nn(t) {\n    if (void 0 === t) \n    // This shouldn't normally happen, but in certain error cases (like trying\n    // to send invalid proto messages) we may get an error with no GRPC code.\n    return A(\"GRPC error has no .code\"), M.UNKNOWN;\n    switch (t) {\n      case We.OK:\n        return M.OK;\n\n      case We.CANCELLED:\n        return M.CANCELLED;\n\n      case We.UNKNOWN:\n        return M.UNKNOWN;\n\n      case We.DEADLINE_EXCEEDED:\n        return M.DEADLINE_EXCEEDED;\n\n      case We.RESOURCE_EXHAUSTED:\n        return M.RESOURCE_EXHAUSTED;\n\n      case We.INTERNAL:\n        return M.INTERNAL;\n\n      case We.UNAVAILABLE:\n        return M.UNAVAILABLE;\n\n      case We.UNAUTHENTICATED:\n        return M.UNAUTHENTICATED;\n\n      case We.INVALID_ARGUMENT:\n        return M.INVALID_ARGUMENT;\n\n      case We.NOT_FOUND:\n        return M.NOT_FOUND;\n\n      case We.ALREADY_EXISTS:\n        return M.ALREADY_EXISTS;\n\n      case We.PERMISSION_DENIED:\n        return M.PERMISSION_DENIED;\n\n      case We.FAILED_PRECONDITION:\n        return M.FAILED_PRECONDITION;\n\n      case We.ABORTED:\n        return M.ABORTED;\n\n      case We.OUT_OF_RANGE:\n        return M.OUT_OF_RANGE;\n\n      case We.UNIMPLEMENTED:\n        return M.UNIMPLEMENTED;\n\n      case We.DATA_LOSS:\n        return M.DATA_LOSS;\n\n      default:\n        return x();\n    }\n}\n\n/**\n * Converts an HTTP response's error status to the equivalent error code.\n *\n * @param status - An HTTP error response status (\"FAILED_PRECONDITION\",\n * \"UNKNOWN\", etc.)\n * @returns The equivalent Code. Non-matching responses are mapped to\n *     Code.UNKNOWN.\n */ (Ze = We || (We = {}))[Ze.OK = 0] = \"OK\", Ze[Ze.CANCELLED = 1] = \"CANCELLED\", \nZe[Ze.UNKNOWN = 2] = \"UNKNOWN\", Ze[Ze.INVALID_ARGUMENT = 3] = \"INVALID_ARGUMENT\", \nZe[Ze.DEADLINE_EXCEEDED = 4] = \"DEADLINE_EXCEEDED\", Ze[Ze.NOT_FOUND = 5] = \"NOT_FOUND\", \nZe[Ze.ALREADY_EXISTS = 6] = \"ALREADY_EXISTS\", Ze[Ze.PERMISSION_DENIED = 7] = \"PERMISSION_DENIED\", \nZe[Ze.UNAUTHENTICATED = 16] = \"UNAUTHENTICATED\", Ze[Ze.RESOURCE_EXHAUSTED = 8] = \"RESOURCE_EXHAUSTED\", \nZe[Ze.FAILED_PRECONDITION = 9] = \"FAILED_PRECONDITION\", Ze[Ze.ABORTED = 10] = \"ABORTED\", \nZe[Ze.OUT_OF_RANGE = 11] = \"OUT_OF_RANGE\", Ze[Ze.UNIMPLEMENTED = 12] = \"UNIMPLEMENTED\", \nZe[Ze.INTERNAL = 13] = \"INTERNAL\", Ze[Ze.UNAVAILABLE = 14] = \"UNAVAILABLE\", Ze[Ze.DATA_LOSS = 15] = \"DATA_LOSS\";\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n// An immutable sorted map implementation, based on a Left-leaning Red-Black\n// tree.\nvar rn = /** @class */ function() {\n    function t(t, e) {\n        this.H = t, this.root = e || un.EMPTY;\n    }\n    // Returns a copy of the map, with the specified key/value added or replaced.\n        return t.prototype.zt = function(e, n) {\n        return new t(this.H, this.root.zt(e, n, this.H).copy(null, null, un.Ht, null, null));\n    }, \n    // Returns a copy of the map, with the specified key removed.\n    t.prototype.remove = function(e) {\n        return new t(this.H, this.root.remove(e, this.H).copy(null, null, un.Ht, null, null));\n    }, \n    // Returns the value of the node with the given key, or null.\n    t.prototype.get = function(t) {\n        for (var e = this.root; !e.et(); ) {\n            var n = this.H(t, e.key);\n            if (0 === n) return e.value;\n            n < 0 ? e = e.left : n > 0 && (e = e.right);\n        }\n        return null;\n    }, \n    // Returns the index of the element in this sorted map, or -1 if it doesn't\n    // exist.\n    t.prototype.indexOf = function(t) {\n        for (\n        // Number of nodes that were pruned when descending right\n        var e = 0, n = this.root; !n.et(); ) {\n            var r = this.H(t, n.key);\n            if (0 === r) return e + n.left.size;\n            r < 0 ? n = n.left : (\n            // Count all nodes left of the node plus the node itself\n            e += n.left.size + 1, n = n.right);\n        }\n        // Node not found\n                return -1;\n    }, t.prototype.et = function() {\n        return this.root.et();\n    }, Object.defineProperty(t.prototype, \"size\", {\n        // Returns the total number of nodes in the map.\n        get: function() {\n            return this.root.size;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    // Returns the minimum key in the map.\n    t.prototype.Jt = function() {\n        return this.root.Jt();\n    }, \n    // Returns the maximum key in the map.\n    t.prototype.Yt = function() {\n        return this.root.Yt();\n    }, \n    // Traverses the map in key order and calls the specified action function\n    // for each key/value pair. If action returns true, traversal is aborted.\n    // Returns the first truthy value returned by action, or the last falsey\n    // value returned by action.\n    t.prototype.Xt = function(t) {\n        return this.root.Xt(t);\n    }, t.prototype.forEach = function(t) {\n        this.Xt((function(e, n) {\n            return t(e, n), !1;\n        }));\n    }, t.prototype.toString = function() {\n        var t = [];\n        return this.Xt((function(e, n) {\n            return t.push(e + \":\" + n), !1;\n        })), \"{\" + t.join(\", \") + \"}\";\n    }, \n    // Traverses the map in reverse key order and calls the specified action\n    // function for each key/value pair. If action returns true, traversal is\n    // aborted.\n    // Returns the first truthy value returned by action, or the last falsey\n    // value returned by action.\n    t.prototype.Zt = function(t) {\n        return this.root.Zt(t);\n    }, \n    // Returns an iterator over the SortedMap.\n    t.prototype.te = function() {\n        return new on(this.root, null, this.H, !1);\n    }, t.prototype.ee = function(t) {\n        return new on(this.root, t, this.H, !1);\n    }, t.prototype.ne = function() {\n        return new on(this.root, null, this.H, !0);\n    }, t.prototype.se = function(t) {\n        return new on(this.root, t, this.H, !0);\n    }, t;\n}(), on = /** @class */ function() {\n    function t(t, e, n, r) {\n        this.ie = r, this.re = [];\n        for (var i = 1; !t.et(); ) if (i = e ? n(t.key, e) : 1, \n        // flip the comparison if we're going in reverse\n        r && (i *= -1), i < 0) \n        // This node is less than our start key. ignore it\n        t = this.ie ? t.left : t.right; else {\n            if (0 === i) {\n                // This node is exactly equal to our start key. Push it on the stack,\n                // but stop iterating;\n                this.re.push(t);\n                break;\n            }\n            // This node is greater than our start key, add it to the stack and move\n            // to the next one\n                        this.re.push(t), t = this.ie ? t.right : t.left;\n        }\n    }\n    return t.prototype.oe = function() {\n        var t = this.re.pop(), e = {\n            key: t.key,\n            value: t.value\n        };\n        if (this.ie) for (t = t.left; !t.et(); ) this.re.push(t), t = t.right; else for (t = t.right; !t.et(); ) this.re.push(t), \n        t = t.left;\n        return e;\n    }, t.prototype.ce = function() {\n        return this.re.length > 0;\n    }, t.prototype.ae = function() {\n        if (0 === this.re.length) return null;\n        var t = this.re[this.re.length - 1];\n        return {\n            key: t.key,\n            value: t.value\n        };\n    }, t;\n}(), un = /** @class */ function() {\n    function t(e, n, r, i, o) {\n        this.key = e, this.value = n, this.color = null != r ? r : t.RED, this.left = null != i ? i : t.EMPTY, \n        this.right = null != o ? o : t.EMPTY, this.size = this.left.size + 1 + this.right.size;\n    }\n    // Returns a copy of the current node, optionally replacing pieces of it.\n        return t.prototype.copy = function(e, n, r, i, o) {\n        return new t(null != e ? e : this.key, null != n ? n : this.value, null != r ? r : this.color, null != i ? i : this.left, null != o ? o : this.right);\n    }, t.prototype.et = function() {\n        return !1;\n    }, \n    // Traverses the tree in key order and calls the specified action function\n    // for each node. If action returns true, traversal is aborted.\n    // Returns the first truthy value returned by action, or the last falsey\n    // value returned by action.\n    t.prototype.Xt = function(t) {\n        return this.left.Xt(t) || t(this.key, this.value) || this.right.Xt(t);\n    }, \n    // Traverses the tree in reverse key order and calls the specified action\n    // function for each node. If action returns true, traversal is aborted.\n    // Returns the first truthy value returned by action, or the last falsey\n    // value returned by action.\n    t.prototype.Zt = function(t) {\n        return this.right.Zt(t) || t(this.key, this.value) || this.left.Zt(t);\n    }, \n    // Returns the minimum node in the tree.\n    t.prototype.min = function() {\n        return this.left.et() ? this : this.left.min();\n    }, \n    // Returns the maximum key in the tree.\n    t.prototype.Jt = function() {\n        return this.min().key;\n    }, \n    // Returns the maximum key in the tree.\n    t.prototype.Yt = function() {\n        return this.right.et() ? this.key : this.right.Yt();\n    }, \n    // Returns new tree, with the key/value added.\n    t.prototype.zt = function(t, e, n) {\n        var r = this, i = n(t, r.key);\n        return (r = i < 0 ? r.copy(null, null, null, r.left.zt(t, e, n), null) : 0 === i ? r.copy(null, e, null, null, null) : r.copy(null, null, null, null, r.right.zt(t, e, n))).ue();\n    }, t.prototype.he = function() {\n        if (this.left.et()) return t.EMPTY;\n        var e = this;\n        return e.left.le() || e.left.left.le() || (e = e._e()), (e = e.copy(null, null, null, e.left.he(), null)).ue();\n    }, \n    // Returns new tree, with the specified item removed.\n    t.prototype.remove = function(e, n) {\n        var r, i = this;\n        if (n(e, i.key) < 0) i.left.et() || i.left.le() || i.left.left.le() || (i = i._e()), \n        i = i.copy(null, null, null, i.left.remove(e, n), null); else {\n            if (i.left.le() && (i = i.fe()), i.right.et() || i.right.le() || i.right.left.le() || (i = i.de()), \n            0 === n(e, i.key)) {\n                if (i.right.et()) return t.EMPTY;\n                r = i.right.min(), i = i.copy(r.key, r.value, null, null, i.right.he());\n            }\n            i = i.copy(null, null, null, null, i.right.remove(e, n));\n        }\n        return i.ue();\n    }, t.prototype.le = function() {\n        return this.color;\n    }, \n    // Returns new tree after performing any needed rotations.\n    t.prototype.ue = function() {\n        var t = this;\n        return t.right.le() && !t.left.le() && (t = t.we()), t.left.le() && t.left.left.le() && (t = t.fe()), \n        t.left.le() && t.right.le() && (t = t.Ee()), t;\n    }, t.prototype._e = function() {\n        var t = this.Ee();\n        return t.right.left.le() && (t = (t = (t = t.copy(null, null, null, null, t.right.fe())).we()).Ee()), \n        t;\n    }, t.prototype.de = function() {\n        var t = this.Ee();\n        return t.left.left.le() && (t = (t = t.fe()).Ee()), t;\n    }, t.prototype.we = function() {\n        var e = this.copy(null, null, t.RED, null, this.right.left);\n        return this.right.copy(null, null, this.color, e, null);\n    }, t.prototype.fe = function() {\n        var e = this.copy(null, null, t.RED, this.left.right, null);\n        return this.left.copy(null, null, this.color, null, e);\n    }, t.prototype.Ee = function() {\n        var t = this.left.copy(null, null, !this.left.color, null, null), e = this.right.copy(null, null, !this.right.color, null, null);\n        return this.copy(null, null, !this.color, t, e);\n    }, \n    // For testing.\n    t.prototype.Te = function() {\n        var t = this.Ie();\n        return Math.pow(2, t) <= this.size + 1;\n    }, \n    // In a balanced RB tree, the black-depth (number of black nodes) from root to\n    // leaves is equal on both sides.  This function verifies that or asserts.\n    t.prototype.Ie = function() {\n        if (this.le() && this.left.le()) throw x();\n        if (this.right.le()) throw x();\n        var t = this.left.Ie();\n        if (t !== this.right.Ie()) throw x();\n        return t + (this.le() ? 0 : 1);\n    }, t;\n}();\n\n// end SortedMap\n// An iterator over an LLRBNode.\n// end LLRBNode\n// Empty node is shared between all LLRB trees.\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nun.EMPTY = null, un.RED = !0, un.Ht = !1, \n// end LLRBEmptyNode\nun.EMPTY = new (/** @class */ function() {\n    function t() {\n        this.size = 0;\n    }\n    return Object.defineProperty(t.prototype, \"key\", {\n        get: function() {\n            throw x();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"value\", {\n        get: function() {\n            throw x();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"color\", {\n        get: function() {\n            throw x();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"left\", {\n        get: function() {\n            throw x();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"right\", {\n        get: function() {\n            throw x();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    // Returns a copy of the current node.\n    t.prototype.copy = function(t, e, n, r, i) {\n        return this;\n    }, \n    // Returns a copy of the tree, with the specified key/value added.\n    t.prototype.zt = function(t, e, n) {\n        return new un(t, e);\n    }, \n    // Returns a copy of the tree, with the specified key removed.\n    t.prototype.remove = function(t, e) {\n        return this;\n    }, t.prototype.et = function() {\n        return !0;\n    }, t.prototype.Xt = function(t) {\n        return !1;\n    }, t.prototype.Zt = function(t) {\n        return !1;\n    }, t.prototype.Jt = function() {\n        return null;\n    }, t.prototype.Yt = function() {\n        return null;\n    }, t.prototype.le = function() {\n        return !1;\n    }, \n    // For testing.\n    t.prototype.Te = function() {\n        return !0;\n    }, t.prototype.Ie = function() {\n        return 0;\n    }, t;\n}());\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * SortedSet is an immutable (copy-on-write) collection that holds elements\n * in order specified by the provided comparator.\n *\n * NOTE: if provided comparator returns 0 for two elements, we consider them to\n * be equal!\n */\nvar sn = /** @class */ function() {\n    function t(t) {\n        this.H = t, this.data = new rn(this.H);\n    }\n    return t.prototype.has = function(t) {\n        return null !== this.data.get(t);\n    }, t.prototype.first = function() {\n        return this.data.Jt();\n    }, t.prototype.last = function() {\n        return this.data.Yt();\n    }, Object.defineProperty(t.prototype, \"size\", {\n        get: function() {\n            return this.data.size;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.indexOf = function(t) {\n        return this.data.indexOf(t);\n    }, \n    /** Iterates elements in order defined by \"comparator\" */ t.prototype.forEach = function(t) {\n        this.data.Xt((function(e, n) {\n            return t(e), !1;\n        }));\n    }, \n    /** Iterates over `elem`s such that: range[0] &lt;= elem &lt; range[1]. */ t.prototype.me = function(t, e) {\n        for (var n = this.data.ee(t[0]); n.ce(); ) {\n            var r = n.oe();\n            if (this.H(r.key, t[1]) >= 0) return;\n            e(r.key);\n        }\n    }, \n    /**\n     * Iterates over `elem`s such that: start &lt;= elem until false is returned.\n     */\n    t.prototype.Ae = function(t, e) {\n        var n;\n        for (n = void 0 !== e ? this.data.ee(e) : this.data.te(); n.ce(); ) if (!t(n.oe().key)) return;\n    }, \n    /** Finds the least element greater than or equal to `elem`. */ t.prototype.Re = function(t) {\n        var e = this.data.ee(t);\n        return e.ce() ? e.oe().key : null;\n    }, t.prototype.te = function() {\n        return new an(this.data.te());\n    }, t.prototype.ee = function(t) {\n        return new an(this.data.ee(t));\n    }, \n    /** Inserts or updates an element */ t.prototype.add = function(t) {\n        return this.copy(this.data.remove(t).zt(t, !0));\n    }, \n    /** Deletes an element */ t.prototype.delete = function(t) {\n        return this.has(t) ? this.copy(this.data.remove(t)) : this;\n    }, t.prototype.et = function() {\n        return this.data.et();\n    }, t.prototype.Pe = function(t) {\n        var e = this;\n        // Make sure `result` always refers to the larger one of the two sets.\n                return e.size < t.size && (e = t, t = this), t.forEach((function(t) {\n            e = e.add(t);\n        })), e;\n    }, t.prototype.isEqual = function(e) {\n        if (!(e instanceof t)) return !1;\n        if (this.size !== e.size) return !1;\n        for (var n = this.data.te(), r = e.data.te(); n.ce(); ) {\n            var i = n.oe().key, o = r.oe().key;\n            if (0 !== this.H(i, o)) return !1;\n        }\n        return !0;\n    }, t.prototype.it = function() {\n        var t = [];\n        return this.forEach((function(e) {\n            t.push(e);\n        })), t;\n    }, t.prototype.toString = function() {\n        var t = [];\n        return this.forEach((function(e) {\n            return t.push(e);\n        })), \"SortedSet(\" + t.toString() + \")\";\n    }, t.prototype.copy = function(e) {\n        var n = new t(this.H);\n        return n.data = e, n;\n    }, t;\n}(), an = /** @class */ function() {\n    function t(t) {\n        this.ye = t;\n    }\n    return t.prototype.oe = function() {\n        return this.ye.oe().key;\n    }, t.prototype.ce = function() {\n        return this.ye.ce();\n    }, t;\n}(), cn = new rn(tt.H);\n\nfunction hn() {\n    return cn;\n}\n\nfunction fn() {\n    return hn();\n}\n\nvar ln = new rn(tt.H);\n\nfunction pn() {\n    return ln;\n}\n\nvar dn = new rn(tt.H);\n\nfunction vn() {\n    return dn;\n}\n\nvar yn = new sn(tt.H);\n\nfunction mn() {\n    for (var t = [], e = 0; e < arguments.length; e++) t[e] = arguments[e];\n    for (var n = yn, r = 0, i = t; r < i.length; r++) {\n        var o = i[r];\n        n = n.add(o);\n    }\n    return n;\n}\n\nvar gn = new sn(C);\n\nfunction wn() {\n    return gn;\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * DocumentSet is an immutable (copy-on-write) collection that holds documents\n * in order specified by the provided comparator. We always add a document key\n * comparator on top of what is provided to guarantee document equality based on\n * the key.\n */ var bn = /** @class */ function() {\n    /** The default ordering is by key if the comparator is omitted */\n    function t(t) {\n        // We are adding document key comparator to the end as it's the only\n        // guaranteed unique property of a document.\n        this.H = t ? function(e, n) {\n            return t(e, n) || tt.H(e.key, n.key);\n        } : function(t, e) {\n            return tt.H(t.key, e.key);\n        }, this.ge = pn(), this.Ve = new rn(this.H)\n        /**\n     * Returns an empty copy of the existing DocumentSet, using the same\n     * comparator.\n     */;\n    }\n    return t.pe = function(e) {\n        return new t(e.H);\n    }, t.prototype.has = function(t) {\n        return null != this.ge.get(t);\n    }, t.prototype.get = function(t) {\n        return this.ge.get(t);\n    }, t.prototype.first = function() {\n        return this.Ve.Jt();\n    }, t.prototype.last = function() {\n        return this.Ve.Yt();\n    }, t.prototype.et = function() {\n        return this.Ve.et();\n    }, \n    /**\n     * Returns the index of the provided key in the document set, or -1 if the\n     * document key is not present in the set;\n     */\n    t.prototype.indexOf = function(t) {\n        var e = this.ge.get(t);\n        return e ? this.Ve.indexOf(e) : -1;\n    }, Object.defineProperty(t.prototype, \"size\", {\n        get: function() {\n            return this.Ve.size;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    /** Iterates documents in order defined by \"comparator\" */ t.prototype.forEach = function(t) {\n        this.Ve.Xt((function(e, n) {\n            return t(e), !1;\n        }));\n    }, \n    /** Inserts or updates a document with the same key */ t.prototype.add = function(t) {\n        // First remove the element if we have it.\n        var e = this.delete(t.key);\n        return e.copy(e.ge.zt(t.key, t), e.Ve.zt(t, null));\n    }, \n    /** Deletes a document with a given key */ t.prototype.delete = function(t) {\n        var e = this.get(t);\n        return e ? this.copy(this.ge.remove(t), this.Ve.remove(e)) : this;\n    }, t.prototype.isEqual = function(e) {\n        if (!(e instanceof t)) return !1;\n        if (this.size !== e.size) return !1;\n        for (var n = this.Ve.te(), r = e.Ve.te(); n.ce(); ) {\n            var i = n.oe().key, o = r.oe().key;\n            if (!i.isEqual(o)) return !1;\n        }\n        return !0;\n    }, t.prototype.toString = function() {\n        var t = [];\n        return this.forEach((function(e) {\n            t.push(e.toString());\n        })), 0 === t.length ? \"DocumentSet ()\" : \"DocumentSet (\\n  \" + t.join(\"  \\n\") + \"\\n)\";\n    }, t.prototype.copy = function(e, n) {\n        var r = new t;\n        return r.H = this.H, r.ge = e, r.Ve = n, r;\n    }, t;\n}(), _n = /** @class */ function() {\n    function t() {\n        this.be = new rn(tt.H);\n    }\n    return t.prototype.track = function(t) {\n        var e = t.doc.key, n = this.be.get(e);\n        n ? \n        // Merge the new change with the existing change.\n        0 /* Added */ !== t.type && 3 /* Metadata */ === n.type ? this.be = this.be.zt(e, t) : 3 /* Metadata */ === t.type && 1 /* Removed */ !== n.type ? this.be = this.be.zt(e, {\n            type: n.type,\n            doc: t.doc\n        }) : 2 /* Modified */ === t.type && 2 /* Modified */ === n.type ? this.be = this.be.zt(e, {\n            type: 2 /* Modified */ ,\n            doc: t.doc\n        }) : 2 /* Modified */ === t.type && 0 /* Added */ === n.type ? this.be = this.be.zt(e, {\n            type: 0 /* Added */ ,\n            doc: t.doc\n        }) : 1 /* Removed */ === t.type && 0 /* Added */ === n.type ? this.be = this.be.remove(e) : 1 /* Removed */ === t.type && 2 /* Modified */ === n.type ? this.be = this.be.zt(e, {\n            type: 1 /* Removed */ ,\n            doc: n.doc\n        }) : 0 /* Added */ === t.type && 1 /* Removed */ === n.type ? this.be = this.be.zt(e, {\n            type: 2 /* Modified */ ,\n            doc: t.doc\n        }) : \n        // This includes these cases, which don't make sense:\n        // Added->Added\n        // Removed->Removed\n        // Modified->Added\n        // Removed->Modified\n        // Metadata->Added\n        // Removed->Metadata\n        x() : this.be = this.be.zt(e, t);\n    }, t.prototype.ve = function() {\n        var t = [];\n        return this.be.Xt((function(e, n) {\n            t.push(n);\n        })), t;\n    }, t;\n}(), In = /** @class */ function() {\n    function t(t, e, n, r, i, o, u, s) {\n        this.query = t, this.docs = e, this.Se = n, this.docChanges = r, this.De = i, this.fromCache = o, \n        this.Ce = u, this.xe = s\n        /** Returns a view snapshot as if all documents in the snapshot were added. */;\n    }\n    return t.Ne = function(e, n, r, i) {\n        var o = [];\n        return n.forEach((function(t) {\n            o.push({\n                type: 0 /* Added */ ,\n                doc: t\n            });\n        })), new t(e, n, bn.pe(n), o, r, i, \n        /* syncStateChanged= */ !0, \n        /* excludesMetadataChanges= */ !1);\n    }, Object.defineProperty(t.prototype, \"hasPendingWrites\", {\n        get: function() {\n            return !this.De.et();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.isEqual = function(t) {\n        if (!(this.fromCache === t.fromCache && this.Ce === t.Ce && this.De.isEqual(t.De) && le(this.query, t.query) && this.docs.isEqual(t.docs) && this.Se.isEqual(t.Se))) return !1;\n        var e = this.docChanges, n = t.docChanges;\n        if (e.length !== n.length) return !1;\n        for (var r = 0; r < e.length; r++) if (e[r].type !== n[r].type || !e[r].doc.isEqual(n[r].doc)) return !1;\n        return !0;\n    }, t;\n}(), En = /** @class */ function() {\n    function t(\n    /**\n     * The snapshot version this event brings us up to, or MIN if not set.\n     */\n    t, \n    /**\n     * A map from target to changes to the target. See TargetChange.\n     */\n    e, \n    /**\n     * A set of targets that is known to be inconsistent. Listens for these\n     * targets should be re-established without resume tokens.\n     */\n    n, \n    /**\n     * A set of which documents have changed or been deleted, along with the\n     * doc's new values (if not deleted).\n     */\n    r, \n    /**\n     * A set of which document updates are due only to limbo resolution targets.\n     */\n    i) {\n        this.Ot = t, this.$e = e, this.Fe = n, this.Oe = r, this.ke = i;\n    }\n    /**\n     * HACK: Views require RemoteEvents in order to determine whether the view is\n     * CURRENT, but secondary tabs don't receive remote events. So this method is\n     * used to create a synthesized RemoteEvent that can be used to apply a\n     * CURRENT status change to a View, for queries executed in a different tab.\n     */\n    // PORTING NOTE: Multi-tab only\n        return t.Me = function(e, n) {\n        var r = new Map;\n        return r.set(e, Tn.Le(e, n)), new t(X.min(), r, wn(), hn(), mn());\n    }, t;\n}(), Tn = /** @class */ function() {\n    function t(\n    /**\n     * An opaque, server-assigned token that allows watching a query to be resumed\n     * after disconnecting without retransmitting all the data that matches the\n     * query. The resume token essentially identifies a point in time from which\n     * the server should resume sending results.\n     */\n    t, \n    /**\n     * The \"current\" (synced) status of this target. Note that \"current\"\n     * has special meaning in the RPC protocol that implies that a target is\n     * both up-to-date and consistent with the rest of the watch stream.\n     */\n    e, \n    /**\n     * The set of documents that were newly assigned to this target as part of\n     * this remote event.\n     */\n    n, \n    /**\n     * The set of documents that were already assigned to this target but received\n     * an update during this remote event.\n     */\n    r, \n    /**\n     * The set of documents that were removed from this target as part of this\n     * remote event.\n     */\n    i) {\n        this.resumeToken = t, this.Be = e, this.qe = n, this.Ue = r, this.Qe = i\n        /**\n     * This method is used to create a synthesized TargetChanges that can be used to\n     * apply a CURRENT status change to a View (for queries executed in a different\n     * tab) or for new queries (to raise snapshots with correct CURRENT status).\n     */;\n    }\n    return t.Le = function(e, n) {\n        return new t(U.T, n, mn(), mn(), mn());\n    }, t;\n}(), Nn = function(\n/** The new document applies to all of these targets. */\nt, \n/** The new document is removed from all of these targets. */\ne, \n/** The key of the document for this change. */\nn, \n/**\n     * The new document or NoDocument if it was deleted. Is null if the\n     * document went out of view without the server sending a new document.\n     */\nr) {\n    this.Ke = t, this.removedTargetIds = e, this.key = n, this.We = r;\n}, An = function(t, e) {\n    this.targetId = t, this.je = e;\n}, Dn = function(\n/** What kind of change occurred to the watch target. */\nt, \n/** The target IDs that were added/removed/set. */\ne, \n/**\n     * An opaque, server-assigned token that allows watching a target to be\n     * resumed after disconnecting without retransmitting all the data that\n     * matches the target. The resume token essentially identifies a point in\n     * time from which the server should resume sending results.\n     */\nn\n/** An RPC error indicating why the watch failed. */ , r) {\n    void 0 === n && (n = U.T), void 0 === r && (r = null), this.state = t, this.targetIds = e, \n    this.resumeToken = n, this.cause = r;\n}, Sn = /** @class */ function() {\n    function t() {\n        /**\n         * The number of pending responses (adds or removes) that we are waiting on.\n         * We only consider targets active that have no pending responses.\n         */\n        this.Ge = 0, \n        /**\n             * Keeps track of the document changes since the last raised snapshot.\n             *\n             * These changes are continuously updated as we receive document updates and\n             * always reflect the current set of changes against the last issued snapshot.\n             */\n        this.ze = On(), \n        /** See public getters for explanations of these fields. */\n        this.He = U.T, this.Je = !1, \n        /**\n             * Whether this target state should be included in the next snapshot. We\n             * initialize to true so that newly-added targets are included in the next\n             * RemoteEvent.\n             */\n        this.Ye = !0;\n    }\n    return Object.defineProperty(t.prototype, \"Be\", {\n        /**\n         * Whether this target has been marked 'current'.\n         *\n         * 'Current' has special meaning in the RPC protocol: It implies that the\n         * Watch backend has sent us all changes up to the point at which the target\n         * was added and that the target is consistent with the rest of the watch\n         * stream.\n         */\n        get: function() {\n            return this.Je;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"resumeToken\", {\n        /** The last resume token sent to us for this target. */ get: function() {\n            return this.He;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"Xe\", {\n        /** Whether this target has pending target adds or target removes. */ get: function() {\n            return 0 !== this.Ge;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"Ze\", {\n        /** Whether we have modified any state that should trigger a snapshot. */ get: function() {\n            return this.Ye;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    /**\n     * Applies the resume token to the TargetChange, but only when it has a new\n     * value. Empty resumeTokens are discarded.\n     */\n    t.prototype.tn = function(t) {\n        t.l() > 0 && (this.Ye = !0, this.He = t);\n    }, \n    /**\n     * Creates a target change from the current set of changes.\n     *\n     * To reset the document changes after raising this snapshot, call\n     * `clearPendingChanges()`.\n     */\n    t.prototype.en = function() {\n        var t = mn(), e = mn(), n = mn();\n        return this.ze.forEach((function(r, i) {\n            switch (i) {\n              case 0 /* Added */ :\n                t = t.add(r);\n                break;\n\n              case 2 /* Modified */ :\n                e = e.add(r);\n                break;\n\n              case 1 /* Removed */ :\n                n = n.add(r);\n                break;\n\n              default:\n                x();\n            }\n        })), new Tn(this.He, this.Je, t, e, n);\n    }, \n    /**\n     * Resets the document changes and sets `hasPendingChanges` to false.\n     */\n    t.prototype.nn = function() {\n        this.Ye = !1, this.ze = On();\n    }, t.prototype.sn = function(t, e) {\n        this.Ye = !0, this.ze = this.ze.zt(t, e);\n    }, t.prototype.rn = function(t) {\n        this.Ye = !0, this.ze = this.ze.remove(t);\n    }, t.prototype.on = function() {\n        this.Ge += 1;\n    }, t.prototype.cn = function() {\n        this.Ge -= 1;\n    }, t.prototype.an = function() {\n        this.Ye = !0, this.Je = !0;\n    }, t;\n}(), xn = /** @class */ function() {\n    function t(t) {\n        this.un = t, \n        /** The internal state of all tracked targets. */\n        this.hn = new Map, \n        /** Keeps track of the documents to update since the last raised snapshot. */\n        this.ln = hn(), \n        /** A mapping of document keys to their set of target IDs. */\n        this._n = kn(), \n        /**\n             * A list of targets with existence filter mismatches. These targets are\n             * known to be inconsistent and their listens needs to be re-established by\n             * RemoteStore.\n             */\n        this.fn = new sn(C)\n        /**\n     * Processes and adds the DocumentWatchChange to the current set of changes.\n     */;\n    }\n    return t.prototype.dn = function(t) {\n        for (var e = 0, n = t.Ke; e < n.length; e++) {\n            var r = n[e];\n            t.We instanceof Pt ? this.wn(r, t.We) : t.We instanceof Vt && this.En(r, t.key, t.We);\n        }\n        for (var i = 0, o = t.removedTargetIds; i < o.length; i++) {\n            r = o[i];\n            this.En(r, t.key, t.We);\n        }\n    }, \n    /** Processes and adds the WatchTargetChange to the current set of changes. */ t.prototype.Tn = function(t) {\n        var e = this;\n        this.In(t, (function(n) {\n            var r = e.mn(n);\n            switch (t.state) {\n              case 0 /* NoChange */ :\n                e.An(n) && r.tn(t.resumeToken);\n                break;\n\n              case 1 /* Added */ :\n                // We need to decrement the number of pending acks needed from watch\n                // for this targetId.\n                r.cn(), r.Xe || \n                // We have a freshly added target, so we need to reset any state\n                // that we had previously. This can happen e.g. when remove and add\n                // back a target for existence filter mismatches.\n                r.nn(), r.tn(t.resumeToken);\n                break;\n\n              case 2 /* Removed */ :\n                // We need to keep track of removed targets to we can post-filter and\n                // remove any target changes.\n                // We need to decrement the number of pending acks needed from watch\n                // for this targetId.\n                r.cn(), r.Xe || e.removeTarget(n);\n                break;\n\n              case 3 /* Current */ :\n                e.An(n) && (r.an(), r.tn(t.resumeToken));\n                break;\n\n              case 4 /* Reset */ :\n                e.An(n) && (\n                // Reset the target and synthesizes removes for all existing\n                // documents. The backend will re-add any documents that still\n                // match the target before it sends the next global snapshot.\n                e.Rn(n), r.tn(t.resumeToken));\n                break;\n\n              default:\n                x();\n            }\n        }));\n    }, \n    /**\n     * Iterates over all targetIds that the watch change applies to: either the\n     * targetIds explicitly listed in the change or the targetIds of all currently\n     * active targets.\n     */\n    t.prototype.In = function(t, e) {\n        var n = this;\n        t.targetIds.length > 0 ? t.targetIds.forEach(e) : this.hn.forEach((function(t, r) {\n            n.An(r) && e(r);\n        }));\n    }, \n    /**\n     * Handles existence filters and synthesizes deletes for filter mismatches.\n     * Targets that are invalidated by filter mismatches are added to\n     * `pendingTargetResets`.\n     */\n    t.prototype.Pn = function(t) {\n        var e = t.targetId, n = t.je.count, r = this.yn(e);\n        if (r) {\n            var i = r.target;\n            if (qt(i)) if (0 === n) {\n                // The existence filter told us the document does not exist. We deduce\n                // that this document does not exist and apply a deleted document to\n                // our updates. Without applying this deleted document there might be\n                // another query that will raise this document as part of a snapshot\n                // until it is resolved, essentially exposing inconsistency between\n                // queries.\n                var o = new tt(i.path);\n                this.En(e, o, new Vt(o, X.min()));\n            } else k(1 === n); else this.gn(e) !== n && (\n            // Existence filter mismatch: We reset the mapping and raise a new\n            // snapshot with `isFromCache:true`.\n            this.Rn(e), this.fn = this.fn.add(e));\n        }\n    }, \n    /**\n     * Converts the currently accumulated state into a remote event at the\n     * provided snapshot version. Resets the accumulated changes before returning.\n     */\n    t.prototype.Vn = function(t) {\n        var e = this, n = new Map;\n        this.hn.forEach((function(r, i) {\n            var o = e.yn(i);\n            if (o) {\n                if (r.Be && qt(o.target)) {\n                    // Document queries for document that don't exist can produce an empty\n                    // result set. To update our local cache, we synthesize a document\n                    // delete if we have not previously received the document. This\n                    // resolves the limbo state of the document, removing it from\n                    // limboDocumentRefs.\n                    // TODO(dimond): Ideally we would have an explicit lookup target\n                    // instead resulting in an explicit delete message and we could\n                    // remove this special logic.\n                    var u = new tt(o.target.path);\n                    null !== e.ln.get(u) || e.pn(i, u) || e.En(i, u, new Vt(u, t));\n                }\n                r.Ze && (n.set(i, r.en()), r.nn());\n            }\n        }));\n        var r = mn();\n        // We extract the set of limbo-only document updates as the GC logic\n        // special-cases documents that do not appear in the target cache.\n        // TODO(gsoltis): Expand on this comment once GC is available in the JS\n        // client.\n                this._n.forEach((function(t, n) {\n            var i = !0;\n            n.Ae((function(t) {\n                var n = e.yn(t);\n                return !n || 2 /* LimboResolution */ === n.Ft || (i = !1, !1);\n            })), i && (r = r.add(t));\n        }));\n        var i = new En(t, n, this.fn, this.ln, r);\n        return this.ln = hn(), this._n = kn(), this.fn = new sn(C), i;\n    }, \n    /**\n     * Adds the provided document to the internal list of document updates and\n     * its document key to the given target's mapping.\n     */\n    // Visible for testing.\n    t.prototype.wn = function(t, e) {\n        if (this.An(t)) {\n            var n = this.pn(t, e.key) ? 2 /* Modified */ : 0 /* Added */;\n            this.mn(t).sn(e.key, n), this.ln = this.ln.zt(e.key, e), this._n = this._n.zt(e.key, this.bn(e.key).add(t));\n        }\n    }, \n    /**\n     * Removes the provided document from the target mapping. If the\n     * document no longer matches the target, but the document's state is still\n     * known (e.g. we know that the document was deleted or we received the change\n     * that caused the filter mismatch), the new document can be provided\n     * to update the remote document cache.\n     */\n    // Visible for testing.\n    t.prototype.En = function(t, e, n) {\n        if (this.An(t)) {\n            var r = this.mn(t);\n            this.pn(t, e) ? r.sn(e, 1 /* Removed */) : \n            // The document may have entered and left the target before we raised a\n            // snapshot, so we can just ignore the change.\n            r.rn(e), this._n = this._n.zt(e, this.bn(e).delete(t)), n && (this.ln = this.ln.zt(e, n));\n        }\n    }, t.prototype.removeTarget = function(t) {\n        this.hn.delete(t);\n    }, \n    /**\n     * Returns the current count of documents in the target. This includes both\n     * the number of documents that the LocalStore considers to be part of the\n     * target as well as any accumulated changes.\n     */\n    t.prototype.gn = function(t) {\n        var e = this.mn(t).en();\n        return this.un.vn(t).size + e.qe.size - e.Qe.size;\n    }, \n    /**\n     * Increment the number of acks needed from watch before we can consider the\n     * server to be 'in-sync' with the client's active targets.\n     */\n    t.prototype.on = function(t) {\n        this.mn(t).on();\n    }, t.prototype.mn = function(t) {\n        var e = this.hn.get(t);\n        return e || (e = new Sn, this.hn.set(t, e)), e;\n    }, t.prototype.bn = function(t) {\n        var e = this._n.get(t);\n        return e || (e = new sn(C), this._n = this._n.zt(t, e)), e;\n    }, \n    /**\n     * Verifies that the user is still interested in this target (by calling\n     * `getTargetDataForTarget()`) and that we are not waiting for pending ADDs\n     * from watch.\n     */\n    t.prototype.An = function(t) {\n        var e = null !== this.yn(t);\n        return e || N(\"WatchChangeAggregator\", \"Detected inactive target\", t), e;\n    }, \n    /**\n     * Returns the TargetData for an active target (i.e. a target that the user\n     * is still interested in that has no outstanding target change requests).\n     */\n    t.prototype.yn = function(t) {\n        var e = this.hn.get(t);\n        return e && e.Xe ? null : this.un.Sn(t);\n    }, \n    /**\n     * Resets the state of a Watch target to its initial state (e.g. sets\n     * 'current' to false, clears the resume token and removes its target mapping\n     * from all documents).\n     */\n    t.prototype.Rn = function(t) {\n        var e = this;\n        this.hn.set(t, new Sn), this.un.vn(t).forEach((function(n) {\n            e.En(t, n, /*updatedDocument=*/ null);\n        }));\n    }, \n    /**\n     * Returns whether the LocalStore considers the document to be part of the\n     * specified target.\n     */\n    t.prototype.pn = function(t, e) {\n        return this.un.vn(t).has(e);\n    }, t;\n}();\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * DocumentChangeSet keeps track of a set of changes to docs in a query, merging\n * duplicate events for the same doc.\n */ function kn() {\n    return new rn(tt.H);\n}\n\nfunction On() {\n    return new rn(tt.H);\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ var Pn = {\n    asc: \"ASCENDING\",\n    desc: \"DESCENDING\"\n}, Vn = {\n    \"<\": \"LESS_THAN\",\n    \"<=\": \"LESS_THAN_OR_EQUAL\",\n    \">\": \"GREATER_THAN\",\n    \">=\": \"GREATER_THAN_OR_EQUAL\",\n    \"==\": \"EQUAL\",\n    \"!=\": \"NOT_EQUAL\",\n    \"array-contains\": \"ARRAY_CONTAINS\",\n    in: \"IN\",\n    \"not-in\": \"NOT_IN\",\n    \"array-contains-any\": \"ARRAY_CONTAINS_ANY\"\n}, Cn = function(t, e) {\n    this.t = t, this.Bt = e;\n};\n\n/**\n * This class generates JsonObject values for the Datastore API suitable for\n * sending to either GRPC stub methods or via the JSON/HTTP REST API.\n *\n * The serializer supports both Protobuf.js and Proto3 JSON formats. By\n * setting `useProto3Json` to true, the serializer will use the Proto3 JSON\n * format.\n *\n * For a description of the Proto3 JSON format check\n * https://developers.google.com/protocol-buffers/docs/proto3#json\n *\n * TODO(klimt): We can remove the databaseId argument if we keep the full\n * resource name in documents.\n */\n/**\n * Returns a value for a Date that's appropriate to put into a proto.\n */\nfunction Ln(t, e) {\n    return t.Bt ? new Date(1e3 * e.seconds).toISOString().replace(/\\.\\d*/, \"\").replace(\"Z\", \"\") + \".\" + (\"000000000\" + e.nanoseconds).slice(-9) + \"Z\" : {\n        seconds: \"\" + e.seconds,\n        nanos: e.nanoseconds\n    };\n}\n\n/**\n * Returns a value for bytes that's appropriate to put in a proto.\n *\n * Visible for testing.\n */ function Rn(t, e) {\n    return t.Bt ? e.toBase64() : e.toUint8Array();\n}\n\n/**\n * Returns a ByteString based on the proto string value.\n */ function Un(t, e) {\n    return Ln(t, e.j());\n}\n\nfunction Mn(t) {\n    return k(!!t), X.K(function(t) {\n        var e = ut(t);\n        return new K(e.seconds, e.nanos);\n    }(t));\n}\n\nfunction qn(t, e) {\n    return function(t) {\n        return new Z([ \"projects\", t.projectId, \"databases\", t.database ]);\n    }(t).child(\"documents\").child(e).rt();\n}\n\nfunction Fn(t) {\n    var e = Z.ot(t);\n    return k(hr(e)), e;\n}\n\nfunction jn(t, e) {\n    return qn(t.t, e.path);\n}\n\nfunction zn(t, e) {\n    var n = Fn(e);\n    if (n.get(1) !== t.t.projectId) throw new q(M.INVALID_ARGUMENT, \"Tried to deserialize key from different project: \" + n.get(1) + \" vs \" + t.t.projectId);\n    if (n.get(3) !== t.t.database) throw new q(M.INVALID_ARGUMENT, \"Tried to deserialize key from different database: \" + n.get(3) + \" vs \" + t.t.database);\n    return new tt(Yn(n));\n}\n\nfunction Gn(t, e) {\n    return qn(t.t, e);\n}\n\nfunction Bn(t) {\n    var e = Fn(t);\n    // In v1beta1 queries for collections at the root did not have a trailing\n    // \"/documents\". In v1 all resource paths contain \"/documents\". Preserve the\n    // ability to read the v1beta1 form for compatibility with queries persisted\n    // in the local target cache.\n        return 4 === e.length ? Z.ct() : Yn(e);\n}\n\nfunction Qn(t) {\n    return new Z([ \"projects\", t.t.projectId, \"databases\", t.t.database ]).rt();\n}\n\nfunction Yn(t) {\n    return k(t.length > 4 && \"documents\" === t.get(4)), t.Y(5)\n    /** Creates a Document proto from key and fields (but no create/update time) */;\n}\n\nfunction Hn(t, e, n) {\n    return {\n        name: jn(t, e),\n        fields: n.proto.mapValue.fields\n    };\n}\n\nfunction Kn(t, e, n) {\n    var r = zn(t, e.name), i = Mn(e.updateTime), o = new St({\n        mapValue: {\n            fields: e.fields\n        }\n    });\n    return new Pt(r, i, o, {\n        hasCommittedMutations: !!n\n    });\n}\n\nfunction Xn(t, e) {\n    var n;\n    if (e instanceof Be) n = {\n        update: Hn(t, e.key, e.value)\n    }; else if (e instanceof Je) n = {\n        delete: jn(t, e.key)\n    }; else if (e instanceof Qe) n = {\n        update: Hn(t, e.key, e.data),\n        updateMask: cr(e.Gt)\n    }; else {\n        if (!(e instanceof $e)) return x();\n        n = {\n            verify: jn(t, e.key)\n        };\n    }\n    return e.fieldTransforms.length > 0 && (n.updateTransforms = e.fieldTransforms.map((function(t) {\n        return function(t, e) {\n            var n = e.transform;\n            if (n instanceof Ae) return {\n                fieldPath: e.field.rt(),\n                setToServerValue: \"REQUEST_TIME\"\n            };\n            if (n instanceof De) return {\n                fieldPath: e.field.rt(),\n                appendMissingElements: {\n                    values: n.elements\n                }\n            };\n            if (n instanceof xe) return {\n                fieldPath: e.field.rt(),\n                removeAllFromArray: {\n                    values: n.elements\n                }\n            };\n            if (n instanceof Oe) return {\n                fieldPath: e.field.rt(),\n                increment: n.Ut\n            };\n            throw x();\n        }(0, t);\n    }))), e.jt.Wt || (n.currentDocument = function(t, e) {\n        return void 0 !== e.updateTime ? {\n            updateTime: Un(t, e.updateTime)\n        } : void 0 !== e.exists ? {\n            exists: e.exists\n        } : x();\n    }(t, e.jt)), n;\n}\n\nfunction Wn(t, e) {\n    var n = e.currentDocument ? function(t) {\n        return void 0 !== t.updateTime ? Re.updateTime(Mn(t.updateTime)) : void 0 !== t.exists ? Re.exists(t.exists) : Re.Kt();\n    }(e.currentDocument) : Re.Kt(), r = e.updateTransforms ? e.updateTransforms.map((function(e) {\n        return function(t, e) {\n            var n = null;\n            if (\"setToServerValue\" in e) k(\"REQUEST_TIME\" === e.setToServerValue), n = new Ae; else if (\"appendMissingElements\" in e) {\n                var r = e.appendMissingElements.values || [];\n                n = new De(r);\n            } else if (\"removeAllFromArray\" in e) {\n                var i = e.removeAllFromArray.values || [];\n                n = new xe(i);\n            } else \"increment\" in e ? n = new Oe(t, e.increment) : x();\n            var o = $.lt(e.fieldPath);\n            return new Ce(o, n);\n        }(t, e);\n    })) : [];\n    if (e.update) {\n        e.update.name;\n        var i = zn(t, e.update.name), o = new St({\n            mapValue: {\n                fields: e.update.fields\n            }\n        });\n        if (e.updateMask) {\n            var u = function(t) {\n                var e = t.fieldPaths || [];\n                return new it(e.map((function(t) {\n                    return $.lt(t);\n                })));\n            }(e.updateMask);\n            return new Qe(i, o, u, n, r);\n        }\n        return new Be(i, o, n, r);\n    }\n    if (e.delete) {\n        var s = zn(t, e.delete);\n        return new Je(s, n);\n    }\n    if (e.verify) {\n        var a = zn(t, e.verify);\n        return new $e(a, n);\n    }\n    return x();\n}\n\nfunction Zn(t, e) {\n    return {\n        documents: [ Gn(t, e.path) ]\n    };\n}\n\nfunction Jn(t, e) {\n    // Dissect the path into parent, collectionId, and optional key filter.\n    var n = {\n        structuredQuery: {}\n    }, r = e.path;\n    null !== e.collectionGroup ? (n.parent = Gn(t, r), n.structuredQuery.from = [ {\n        collectionId: e.collectionGroup,\n        allDescendants: !0\n    } ]) : (n.parent = Gn(t, r.X()), n.structuredQuery.from = [ {\n        collectionId: r.tt()\n    } ]);\n    var i = function(t) {\n        if (0 !== t.length) {\n            var e = t.map((function(t) {\n                // visible for testing\n                return function(t) {\n                    if (\"==\" /* EQUAL */ === t.op) {\n                        if (At(t.value)) return {\n                            unaryFilter: {\n                                field: or(t.field),\n                                op: \"IS_NAN\"\n                            }\n                        };\n                        if (Nt(t.value)) return {\n                            unaryFilter: {\n                                field: or(t.field),\n                                op: \"IS_NULL\"\n                            }\n                        };\n                    } else if (\"!=\" /* NOT_EQUAL */ === t.op) {\n                        if (At(t.value)) return {\n                            unaryFilter: {\n                                field: or(t.field),\n                                op: \"IS_NOT_NAN\"\n                            }\n                        };\n                        if (Nt(t.value)) return {\n                            unaryFilter: {\n                                field: or(t.field),\n                                op: \"IS_NOT_NULL\"\n                            }\n                        };\n                    }\n                    return {\n                        fieldFilter: {\n                            field: or(t.field),\n                            op: ir(t.op),\n                            value: t.value\n                        }\n                    };\n                }(t);\n            }));\n            return 1 === e.length ? e[0] : {\n                compositeFilter: {\n                    op: \"AND\",\n                    filters: e\n                }\n            };\n        }\n    }(e.filters);\n    i && (n.structuredQuery.where = i);\n    var o = function(t) {\n        if (0 !== t.length) return t.map((function(t) {\n            // visible for testing\n            return function(t) {\n                return {\n                    field: or(t.field),\n                    direction: rr(t.dir)\n                };\n            }(t);\n        }));\n    }(e.orderBy);\n    o && (n.structuredQuery.orderBy = o);\n    var u = function(t, e) {\n        return t.Bt || lt(e) ? e : {\n            value: e\n        };\n    }(t, e.limit);\n    return null !== u && (n.structuredQuery.limit = u), e.startAt && (n.structuredQuery.startAt = er(e.startAt)), \n    e.endAt && (n.structuredQuery.endAt = er(e.endAt)), n;\n}\n\nfunction $n(t) {\n    var e = Bn(t.parent), n = t.structuredQuery, r = n.from ? n.from.length : 0, i = null;\n    if (r > 0) {\n        k(1 === r);\n        var o = n.from[0];\n        o.allDescendants ? i = o.collectionId : e = e.child(o.collectionId);\n    }\n    var u = [];\n    n.where && (u = tr(n.where));\n    var s = [];\n    n.orderBy && (s = n.orderBy.map((function(t) {\n        return function(t) {\n            return new Zt(ur(t.field), \n            // visible for testing\n            function(t) {\n                switch (t) {\n                  case \"ASCENDING\":\n                    return \"asc\" /* ASCENDING */;\n\n                  case \"DESCENDING\":\n                    return \"desc\" /* DESCENDING */;\n\n                  default:\n                    return;\n                }\n            }(t.direction));\n        }(t);\n    })));\n    var a = null;\n    n.limit && (a = function(t) {\n        var e;\n        return lt(e = \"object\" == typeof t ? t.value : t) ? null : e;\n    }(n.limit));\n    var c = null;\n    n.startAt && (c = nr(n.startAt));\n    var h = null;\n    return n.endAt && (h = nr(n.endAt)), ne(e, i, s, u, a, \"F\" /* First */ , c, h);\n}\n\nfunction tr(t) {\n    return t ? void 0 !== t.unaryFilter ? [ ar(t) ] : void 0 !== t.fieldFilter ? [ sr(t) ] : void 0 !== t.compositeFilter ? t.compositeFilter.filters.map((function(t) {\n        return tr(t);\n    })).reduce((function(t, e) {\n        return t.concat(e);\n    })) : x() : [];\n}\n\nfunction er(t) {\n    return {\n        before: t.before,\n        values: t.position\n    };\n}\n\nfunction nr(t) {\n    var e = !!t.before, n = t.values || [];\n    return new Xt(n, e);\n}\n\n// visible for testing\nfunction rr(t) {\n    return Pn[t];\n}\n\nfunction ir(t) {\n    return Vn[t];\n}\n\nfunction or(t) {\n    return {\n        fieldPath: t.rt()\n    };\n}\n\nfunction ur(t) {\n    return $.lt(t.fieldPath);\n}\n\nfunction sr(t) {\n    return Ft.create(ur(t.fieldFilter.field), function(t) {\n        switch (t) {\n          case \"EQUAL\":\n            return \"==\" /* EQUAL */;\n\n          case \"NOT_EQUAL\":\n            return \"!=\" /* NOT_EQUAL */;\n\n          case \"GREATER_THAN\":\n            return \">\" /* GREATER_THAN */;\n\n          case \"GREATER_THAN_OR_EQUAL\":\n            return \">=\" /* GREATER_THAN_OR_EQUAL */;\n\n          case \"LESS_THAN\":\n            return \"<\" /* LESS_THAN */;\n\n          case \"LESS_THAN_OR_EQUAL\":\n            return \"<=\" /* LESS_THAN_OR_EQUAL */;\n\n          case \"ARRAY_CONTAINS\":\n            return \"array-contains\" /* ARRAY_CONTAINS */;\n\n          case \"IN\":\n            return \"in\" /* IN */;\n\n          case \"NOT_IN\":\n            return \"not-in\" /* NOT_IN */;\n\n          case \"ARRAY_CONTAINS_ANY\":\n            return \"array-contains-any\" /* ARRAY_CONTAINS_ANY */;\n\n          case \"OPERATOR_UNSPECIFIED\":\n          default:\n            return x();\n        }\n    }(t.fieldFilter.op), t.fieldFilter.value);\n}\n\nfunction ar(t) {\n    switch (t.unaryFilter.op) {\n      case \"IS_NAN\":\n        var e = ur(t.unaryFilter.field);\n        return Ft.create(e, \"==\" /* EQUAL */ , {\n            doubleValue: NaN\n        });\n\n      case \"IS_NULL\":\n        var n = ur(t.unaryFilter.field);\n        return Ft.create(n, \"==\" /* EQUAL */ , {\n            nullValue: \"NULL_VALUE\"\n        });\n\n      case \"IS_NOT_NAN\":\n        var r = ur(t.unaryFilter.field);\n        return Ft.create(r, \"!=\" /* NOT_EQUAL */ , {\n            doubleValue: NaN\n        });\n\n      case \"IS_NOT_NULL\":\n        var i = ur(t.unaryFilter.field);\n        return Ft.create(i, \"!=\" /* NOT_EQUAL */ , {\n            nullValue: \"NULL_VALUE\"\n        });\n\n      case \"OPERATOR_UNSPECIFIED\":\n      default:\n        return x();\n    }\n}\n\nfunction cr(t) {\n    var e = [];\n    return t.fields.forEach((function(t) {\n        return e.push(t.rt());\n    })), {\n        fieldPaths: e\n    };\n}\n\nfunction hr(t) {\n    // Resource names have at least 4 components (project ID, database ID)\n    return t.length >= 4 && \"projects\" === t.get(0) && \"databases\" === t.get(2);\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ var fr = function() {\n    var t = this;\n    this.promise = new Promise((function(e, n) {\n        t.resolve = e, t.reject = n;\n    }));\n}, lr = /** @class */ function() {\n    function t(t) {\n        var e = this;\n        // NOTE: next/catchCallback will always point to our own wrapper functions,\n        // not the user's raw next() or catch() callbacks.\n                this.Dn = null, this.Cn = null, \n        // When the operation resolves, we'll set result or error and mark isDone.\n        this.result = void 0, this.error = void 0, this.xn = !1, \n        // Set to true when .then() or .catch() are called and prevents additional\n        // chaining.\n        this.Nn = !1, t((function(t) {\n            e.xn = !0, e.result = t, e.Dn && \n            // value should be defined unless T is Void, but we can't express\n            // that in the type system.\n            e.Dn(t);\n        }), (function(t) {\n            e.xn = !0, e.error = t, e.Cn && e.Cn(t);\n        }));\n    }\n    return t.prototype.catch = function(t) {\n        return this.next(void 0, t);\n    }, t.prototype.next = function(e, n) {\n        var r = this;\n        return this.Nn && x(), this.Nn = !0, this.xn ? this.error ? this.$n(n, this.error) : this.Fn(e, this.result) : new t((function(t, i) {\n            r.Dn = function(n) {\n                r.Fn(e, n).next(t, i);\n            }, r.Cn = function(e) {\n                r.$n(n, e).next(t, i);\n            };\n        }));\n    }, t.prototype.On = function() {\n        var t = this;\n        return new Promise((function(e, n) {\n            t.next(e, n);\n        }));\n    }, t.prototype.kn = function(e) {\n        try {\n            var n = e();\n            return n instanceof t ? n : t.resolve(n);\n        } catch (e) {\n            return t.reject(e);\n        }\n    }, t.prototype.Fn = function(e, n) {\n        return e ? this.kn((function() {\n            return e(n);\n        })) : t.resolve(n);\n    }, t.prototype.$n = function(e, n) {\n        return e ? this.kn((function() {\n            return e(n);\n        })) : t.reject(n);\n    }, t.resolve = function(e) {\n        return new t((function(t, n) {\n            t(e);\n        }));\n    }, t.reject = function(e) {\n        return new t((function(t, n) {\n            n(e);\n        }));\n    }, t.Mn = function(\n    // Accept all Promise types in waitFor().\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    e) {\n        return new t((function(t, n) {\n            var r = 0, i = 0, o = !1;\n            e.forEach((function(e) {\n                ++r, e.next((function() {\n                    ++i, o && i === r && t();\n                }), (function(t) {\n                    return n(t);\n                }));\n            })), o = !0, i === r && t();\n        }));\n    }, \n    /**\n     * Given an array of predicate functions that asynchronously evaluate to a\n     * boolean, implements a short-circuiting `or` between the results. Predicates\n     * will be evaluated until one of them returns `true`, then stop. The final\n     * result will be whether any of them returned `true`.\n     */\n    t.Ln = function(e) {\n        for (var n = t.resolve(!1), r = function(e) {\n            n = n.next((function(n) {\n                return n ? t.resolve(n) : e();\n            }));\n        }, i = 0, o = e; i < o.length; i++) {\n            r(o[i]);\n        }\n        return n;\n    }, t.forEach = function(t, e) {\n        var n = this, r = [];\n        return t.forEach((function(t, i) {\n            r.push(e.call(n, t, i));\n        })), this.Mn(r);\n    }, t;\n}(), pr = /** @class */ function() {\n    function t(t, e) {\n        var n = this;\n        this.action = t, this.transaction = e, this.aborted = !1, \n        /**\n             * A promise that resolves with the result of the IndexedDb transaction.\n             */\n        this.Bn = new fr, this.transaction.oncomplete = function() {\n            n.Bn.resolve();\n        }, this.transaction.onabort = function() {\n            e.error ? n.Bn.reject(new yr(t, e.error)) : n.Bn.resolve();\n        }, this.transaction.onerror = function(e) {\n            var r = _r(e.target.error);\n            n.Bn.reject(new yr(t, r));\n        };\n    }\n    return t.open = function(e, n, r, i) {\n        try {\n            return new t(n, e.transaction(i, r));\n        } catch (e) {\n            throw new yr(n, e);\n        }\n    }, Object.defineProperty(t.prototype, \"qn\", {\n        get: function() {\n            return this.Bn.promise;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.abort = function(t) {\n        t && this.Bn.reject(t), this.aborted || (N(\"SimpleDb\", \"Aborting transaction:\", t ? t.message : \"Client-initiated abort\"), \n        this.aborted = !0, this.transaction.abort());\n    }, \n    /**\n     * Returns a SimpleDbStore<KeyType, ValueType> for the specified store. All\n     * operations performed on the SimpleDbStore happen within the context of this\n     * transaction and it cannot be used anymore once the transaction is\n     * completed.\n     *\n     * Note that we can't actually enforce that the KeyType and ValueType are\n     * correct, but they allow type safety through the rest of the consuming code.\n     */\n    t.prototype.store = function(t) {\n        var e = this.transaction.objectStore(t);\n        return new gr(e);\n    }, t;\n}(), dr = /** @class */ function() {\n    /*\n     * Creates a new SimpleDb wrapper for IndexedDb database `name`.\n     *\n     * Note that `version` must not be a downgrade. IndexedDB does not support\n     * downgrading the schema version. We currently do not support any way to do\n     * versioning outside of IndexedDB's versioning mechanism, as only\n     * version-upgrade transactions are allowed to do things like create\n     * objectstores.\n     */\n    function t(e, r, i) {\n        this.name = e, this.version = r, this.Un = i, \n        // NOTE: According to https://bugs.webkit.org/show_bug.cgi?id=197050, the\n        // bug we're checking for should exist in iOS >= 12.2 and < 13, but for\n        // whatever reason it's much harder to hit after 12.2 so we only proactively\n        // log on 12.2.\n        12.2 === t.Qn(n()) && A(\"Firestore persistence suffers from a bug in iOS 12.2 Safari that may cause your app to stop working. See https://stackoverflow.com/q/56496296/110915 for details and a potential workaround.\");\n    }\n    /** Deletes the specified database. */    return t.delete = function(t) {\n        return N(\"SimpleDb\", \"Removing database:\", t), wr(window.indexedDB.deleteDatabase(t)).On();\n    }, \n    /** Returns true if IndexedDB is available in the current environment. */ t.Kn = function() {\n        if (\"undefined\" == typeof indexedDB) return !1;\n        if (t.Wn()) return !0;\n        // We extensively use indexed array values and compound keys,\n        // which IE and Edge do not support. However, they still have indexedDB\n        // defined on the window, so we need to check for them here and make sure\n        // to return that persistence is not enabled for those browsers.\n        // For tracking support of this feature, see here:\n        // https://developer.microsoft.com/en-us/microsoft-edge/platform/status/indexeddbarraysandmultientrysupport/\n        // Check the UA string to find out the browser.\n                var e = n(), r = t.Qn(e), i = 0 < r && r < 10, o = t.jn(e), u = 0 < o && o < 4.5;\n        // IE 10\n        // ua = 'Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.2; Trident/6.0)';\n        // IE 11\n        // ua = 'Mozilla/5.0 (Windows NT 6.3; Trident/7.0; rv:11.0) like Gecko';\n        // Edge\n        // ua = 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML,\n        // like Gecko) Chrome/39.0.2171.71 Safari/537.36 Edge/12.0';\n        // iOS Safari: Disable for users running iOS version < 10.\n                return !(e.indexOf(\"MSIE \") > 0 || e.indexOf(\"Trident/\") > 0 || e.indexOf(\"Edge/\") > 0 || i || u);\n    }, \n    /**\n     * Returns true if the backing IndexedDB store is the Node IndexedDBShim\n     * (see https://github.com/axemclion/IndexedDBShim).\n     */\n    t.Wn = function() {\n        var t;\n        return \"undefined\" != typeof process && \"YES\" === (null === (t = process.env) || void 0 === t ? void 0 : t.Gn);\n    }, \n    /** Helper to get a typed SimpleDbStore from a transaction. */ t.zn = function(t, e) {\n        return t.store(e);\n    }, \n    // visible for testing\n    /** Parse User Agent to determine iOS version. Returns -1 if not found. */\n    t.Qn = function(t) {\n        var e = t.match(/i(?:phone|pad|pod) os ([\\d_]+)/i), n = e ? e[1].split(\"_\").slice(0, 2).join(\".\") : \"-1\";\n        return Number(n);\n    }, \n    // visible for testing\n    /** Parse User Agent to determine Android version. Returns -1 if not found. */\n    t.jn = function(t) {\n        var e = t.match(/Android ([\\d.]+)/i), n = e ? e[1].split(\".\").slice(0, 2).join(\".\") : \"-1\";\n        return Number(n);\n    }, \n    /**\n     * Opens the specified database, creating or upgrading it if necessary.\n     */\n    t.prototype.Hn = function(t) {\n        return g(this, void 0, void 0, (function() {\n            var e, n = this;\n            return w(this, (function(r) {\n                switch (r.label) {\n                  case 0:\n                    return this.db ? [ 3 /*break*/ , 2 ] : (N(\"SimpleDb\", \"Opening database:\", this.name), \n                    e = this, [ 4 /*yield*/ , new Promise((function(e, r) {\n                        // TODO(mikelehen): Investigate browser compatibility.\n                        // https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API/Using_IndexedDB\n                        // suggests IE9 and older WebKit browsers handle upgrade\n                        // differently. They expect setVersion, as described here:\n                        // https://developer.mozilla.org/en-US/docs/Web/API/IDBVersionChangeRequest/setVersion\n                        var i = indexedDB.open(n.name, n.version);\n                        i.onsuccess = function(t) {\n                            var n = t.target.result;\n                            e(n);\n                        }, i.onblocked = function() {\n                            r(new yr(t, \"Cannot upgrade IndexedDB schema while another tab is open. Close all tabs that access Firestore and reload this page to proceed.\"));\n                        }, i.onerror = function(e) {\n                            var n = e.target.error;\n                            \"VersionError\" === n.name ? r(new q(M.FAILED_PRECONDITION, \"A newer version of the Firestore SDK was previously used and so the persisted data is not compatible with the version of the SDK you are now using. The SDK will operate with persistence disabled. If you need persistence, please re-upgrade to a newer version of the SDK or else clear the persisted IndexedDB data for your app to start fresh.\")) : r(new yr(t, n));\n                        }, i.onupgradeneeded = function(t) {\n                            N(\"SimpleDb\", 'Database \"' + n.name + '\" requires upgrade from version:', t.oldVersion);\n                            var e = t.target.result;\n                            n.Un.Jn(e, i.transaction, t.oldVersion, n.version).next((function() {\n                                N(\"SimpleDb\", \"Database upgrade to version \" + n.version + \" complete\");\n                            }));\n                        };\n                    })) ]);\n\n                  case 1:\n                    e.db = r.sent(), r.label = 2;\n\n                  case 2:\n                    return [ 2 /*return*/ , (this.Yn && (this.db.onversionchange = function(t) {\n                        return n.Yn(t);\n                    }), this.db) ];\n                }\n            }));\n        }));\n    }, t.prototype.Xn = function(t) {\n        this.Yn = t, this.db && (this.db.onversionchange = function(e) {\n            return t(e);\n        });\n    }, t.prototype.runTransaction = function(t, e, n, r) {\n        return g(this, void 0, void 0, (function() {\n            var i, o, u, s, a;\n            return w(this, (function(c) {\n                switch (c.label) {\n                  case 0:\n                    i = \"readonly\" === e, o = 0, u = function() {\n                        var e, u, a, c, h;\n                        return w(this, (function(f) {\n                            switch (f.label) {\n                              case 0:\n                                ++o, f.label = 1;\n\n                              case 1:\n                                return f.trys.push([ 1, 4, , 5 ]), [ 4 /*yield*/ , s.Hn(t) ];\n\n                              case 2:\n                                // Wait for the transaction to complete (i.e. IndexedDb's onsuccess event to\n                                // fire), but still return the original transactionFnResult back to the\n                                // caller.\n                                return s.db = f.sent(), e = pr.open(s.db, t, i ? \"readonly\" : \"readwrite\", n), u = r(e).catch((function(t) {\n                                    // Abort the transaction if there was an error.\n                                    return e.abort(t), lr.reject(t);\n                                })).On(), a = {}, u.catch((function() {})), [ 4 /*yield*/ , e.qn ];\n\n                              case 3:\n                                return [ 2 /*return*/ , (a.value = (\n                                // Wait for the transaction to complete (i.e. IndexedDb's onsuccess event to\n                                // fire), but still return the original transactionFnResult back to the\n                                // caller.\n                                f.sent(), u), a) ];\n\n                              case 4:\n                                return c = f.sent(), h = \"FirebaseError\" !== c.name && o < 3, N(\"SimpleDb\", \"Transaction failed with error:\", c.message, \"Retrying:\", h), \n                                s.close(), h ? [ 3 /*break*/ , 5 ] : [ 2 /*return*/ , {\n                                    value: Promise.reject(c)\n                                } ];\n\n                              case 5:\n                                return [ 2 /*return*/ ];\n                            }\n                        }));\n                    }, s = this, c.label = 1;\n\n                  case 1:\n                    return [ 5 /*yield**/ , u() ];\n\n                  case 2:\n                    if (\"object\" == typeof (a = c.sent())) return [ 2 /*return*/ , a.value ];\n                    c.label = 3;\n\n                  case 3:\n                    return [ 3 /*break*/ , 1 ];\n\n                  case 4:\n                    return [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, t.prototype.close = function() {\n        this.db && this.db.close(), this.db = void 0;\n    }, t;\n}(), vr = /** @class */ function() {\n    function t(t) {\n        this.Zn = t, this.ts = !1, this.es = null;\n    }\n    return Object.defineProperty(t.prototype, \"xn\", {\n        get: function() {\n            return this.ts;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"ns\", {\n        get: function() {\n            return this.es;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"cursor\", {\n        set: function(t) {\n            this.Zn = t;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    /**\n     * This function can be called to stop iteration at any point.\n     */\n    t.prototype.done = function() {\n        this.ts = !0;\n    }, \n    /**\n     * This function can be called to skip to that next key, which could be\n     * an index or a primary key.\n     */\n    t.prototype.ss = function(t) {\n        this.es = t;\n    }, \n    /**\n     * Delete the current cursor value from the object store.\n     *\n     * NOTE: You CANNOT do this with a keysOnly query.\n     */\n    t.prototype.delete = function() {\n        return wr(this.Zn.delete());\n    }, t;\n}(), yr = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, M.UNAVAILABLE, \"IndexedDB transaction '\" + e + \"' failed: \" + n) || this).name = \"IndexedDbTransactionError\", \n        r;\n    }\n    return m(e, t), e;\n}(q);\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * PersistencePromise is essentially a re-implementation of Promise except\n * it has a .next() method instead of .then() and .next() and .catch() callbacks\n * are executed synchronously when a PersistencePromise resolves rather than\n * asynchronously (Promise implementations use setImmediate() or similar).\n *\n * This is necessary to interoperate with IndexedDB which will automatically\n * commit transactions if control is returned to the event loop without\n * synchronously initiating another operation on the transaction.\n *\n * NOTE: .then() and .catch() only allow a single consumer, unlike normal\n * Promises.\n */\n/** Verifies whether `e` is an IndexedDbTransactionError. */ function mr(t) {\n    // Use name equality, as instanceof checks on errors don't work with errors\n    // that wrap other errors.\n    return \"IndexedDbTransactionError\" === t.name;\n}\n\n/**\n * A wrapper around an IDBObjectStore providing an API that:\n *\n * 1) Has generic KeyType / ValueType parameters to provide strongly-typed\n * methods for acting against the object store.\n * 2) Deals with IndexedDB's onsuccess / onerror event callbacks, making every\n * method return a PersistencePromise instead.\n * 3) Provides a higher-level API to avoid needing to do excessive wrapping of\n * intermediate IndexedDB types (IDBCursorWithValue, etc.)\n */ var gr = /** @class */ function() {\n    function t(t) {\n        this.store = t;\n    }\n    return t.prototype.put = function(t, e) {\n        var n;\n        return void 0 !== e ? (N(\"SimpleDb\", \"PUT\", this.store.name, t, e), n = this.store.put(e, t)) : (N(\"SimpleDb\", \"PUT\", this.store.name, \"<auto-key>\", t), \n        n = this.store.put(t)), wr(n);\n    }, \n    /**\n     * Adds a new value into an Object Store and returns the new key. Similar to\n     * IndexedDb's `add()`, this method will fail on primary key collisions.\n     *\n     * @param value - The object to write.\n     * @returns The key of the value to add.\n     */\n    t.prototype.add = function(t) {\n        return N(\"SimpleDb\", \"ADD\", this.store.name, t, t), wr(this.store.add(t));\n    }, \n    /**\n     * Gets the object with the specified key from the specified store, or null\n     * if no object exists with the specified key.\n     *\n     * @key The key of the object to get.\n     * @returns The object with the specified key or null if no object exists.\n     */\n    t.prototype.get = function(t) {\n        var e = this;\n        // We're doing an unsafe cast to ValueType.\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n                return wr(this.store.get(t)).next((function(n) {\n            // Normalize nonexistence to null.\n            return void 0 === n && (n = null), N(\"SimpleDb\", \"GET\", e.store.name, t, n), n;\n        }));\n    }, t.prototype.delete = function(t) {\n        return N(\"SimpleDb\", \"DELETE\", this.store.name, t), wr(this.store.delete(t));\n    }, \n    /**\n     * If we ever need more of the count variants, we can add overloads. For now,\n     * all we need is to count everything in a store.\n     *\n     * Returns the number of rows in the store.\n     */\n    t.prototype.count = function() {\n        return N(\"SimpleDb\", \"COUNT\", this.store.name), wr(this.store.count());\n    }, t.prototype.rs = function(t, e) {\n        var n = this.cursor(this.options(t, e)), r = [];\n        return this.os(n, (function(t, e) {\n            r.push(e);\n        })).next((function() {\n            return r;\n        }));\n    }, t.prototype.cs = function(t, e) {\n        N(\"SimpleDb\", \"DELETE ALL\", this.store.name);\n        var n = this.options(t, e);\n        n.us = !1;\n        var r = this.cursor(n);\n        return this.os(r, (function(t, e, n) {\n            return n.delete();\n        }));\n    }, t.prototype.hs = function(t, e) {\n        var n;\n        e ? n = t : (n = {}, e = t);\n        var r = this.cursor(n);\n        return this.os(r, e);\n    }, \n    /**\n     * Iterates over a store, but waits for the given callback to complete for\n     * each entry before iterating the next entry. This allows the callback to do\n     * asynchronous work to determine if this iteration should continue.\n     *\n     * The provided callback should return `true` to continue iteration, and\n     * `false` otherwise.\n     */\n    t.prototype.ls = function(t) {\n        var e = this.cursor({});\n        return new lr((function(n, r) {\n            e.onerror = function(t) {\n                var e = _r(t.target.error);\n                r(e);\n            }, e.onsuccess = function(e) {\n                var r = e.target.result;\n                r ? t(r.primaryKey, r.value).next((function(t) {\n                    t ? r.continue() : n();\n                })) : n();\n            };\n        }));\n    }, t.prototype.os = function(t, e) {\n        var n = [];\n        return new lr((function(r, i) {\n            t.onerror = function(t) {\n                i(t.target.error);\n            }, t.onsuccess = function(t) {\n                var i = t.target.result;\n                if (i) {\n                    var o = new vr(i), u = e(i.primaryKey, i.value, o);\n                    if (u instanceof lr) {\n                        var s = u.catch((function(t) {\n                            return o.done(), lr.reject(t);\n                        }));\n                        n.push(s);\n                    }\n                    o.xn ? r() : null === o.ns ? i.continue() : i.continue(o.ns);\n                } else r();\n            };\n        })).next((function() {\n            return lr.Mn(n);\n        }));\n    }, t.prototype.options = function(t, e) {\n        var n;\n        return void 0 !== t && (\"string\" == typeof t ? n = t : e = t), {\n            index: n,\n            range: e\n        };\n    }, t.prototype.cursor = function(t) {\n        var e = \"next\";\n        if (t.reverse && (e = \"prev\"), t.index) {\n            var n = this.store.index(t.index);\n            return t.us ? n.openKeyCursor(t.range, e) : n.openCursor(t.range, e);\n        }\n        return this.store.openCursor(t.range, e);\n    }, t;\n}();\n\n/**\n * Wraps an IDBRequest in a PersistencePromise, using the onsuccess / onerror\n * handlers to resolve / reject the PersistencePromise as appropriate.\n */ function wr(t) {\n    return new lr((function(e, n) {\n        t.onsuccess = function(t) {\n            var n = t.target.result;\n            e(n);\n        }, t.onerror = function(t) {\n            var e = _r(t.target.error);\n            n(e);\n        };\n    }));\n}\n\n// Guard so we only report the error once.\nvar br = !1;\n\nfunction _r(t) {\n    var e = dr.Qn(n());\n    if (e >= 12.2 && e < 13) {\n        var r = \"An internal error was encountered in the Indexed Database server\";\n        if (t.message.indexOf(r) >= 0) {\n            // Wrap error in a more descriptive one.\n            var i = new q(\"internal\", \"IOS_INDEXEDDB_BUG1: IndexedDb has thrown '\" + r + \"'. This is likely due to an unavoidable bug in iOS. See https://stackoverflow.com/q/56496296/110915 for details and a potential workaround.\");\n            return br || (br = !0, \n            // Throw a global exception outside of this promise chain, for the user to\n            // potentially catch.\n            setTimeout((function() {\n                throw i;\n            }), 0)), i;\n        }\n    }\n    return t;\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Represents an operation scheduled to be run in the future on an AsyncQueue.\n *\n * It is created via DelayedOperation.createAndSchedule().\n *\n * Supports cancellation (via cancel()) and early execution (via skipDelay()).\n *\n * Note: We implement `PromiseLike` instead of `Promise`, as the `Promise` type\n * in newer versions of TypeScript defines `finally`, which is not available in\n * IE.\n */ var Ir = /** @class */ function() {\n    function t(t, e, n, r, i) {\n        this._s = t, this.fs = e, this.ds = n, this.op = r, this.ws = i, this.Es = new fr, \n        this.then = this.Es.promise.then.bind(this.Es.promise), \n        // It's normal for the deferred promise to be canceled (due to cancellation)\n        // and so we attach a dummy catch callback to avoid\n        // 'UnhandledPromiseRejectionWarning' log spam.\n        this.Es.promise.catch((function(t) {}))\n        /**\n     * Creates and returns a DelayedOperation that has been scheduled to be\n     * executed on the provided asyncQueue after the provided delayMs.\n     *\n     * @param asyncQueue - The queue to schedule the operation on.\n     * @param id - A Timer ID identifying the type of operation this is.\n     * @param delayMs - The delay (ms) before the operation should be scheduled.\n     * @param op - The operation to run.\n     * @param removalCallback - A callback to be called synchronously once the\n     *   operation is executed or canceled, notifying the AsyncQueue to remove it\n     *   from its delayedOperations list.\n     *   PORTING NOTE: This exists to prevent making removeDelayedOperation() and\n     *   the DelayedOperation class public.\n     */;\n    }\n    return t.Ts = function(e, n, r, i, o) {\n        var u = new t(e, n, Date.now() + r, i, o);\n        return u.start(r), u;\n    }, \n    /**\n     * Starts the timer. This is called immediately after construction by\n     * createAndSchedule().\n     */\n    t.prototype.start = function(t) {\n        var e = this;\n        this.Is = setTimeout((function() {\n            return e.As();\n        }), t);\n    }, \n    /**\n     * Queues the operation to run immediately (if it hasn't already been run or\n     * canceled).\n     */\n    t.prototype.Rs = function() {\n        return this.As();\n    }, \n    /**\n     * Cancels the operation if it hasn't already been executed or canceled. The\n     * promise will be rejected.\n     *\n     * As long as the operation has not yet been run, calling cancel() provides a\n     * guarantee that the operation will not be run.\n     */\n    t.prototype.cancel = function(t) {\n        null !== this.Is && (this.clearTimeout(), this.Es.reject(new q(M.CANCELLED, \"Operation cancelled\" + (t ? \": \" + t : \"\"))));\n    }, t.prototype.As = function() {\n        var t = this;\n        this._s.Ps((function() {\n            return null !== t.Is ? (t.clearTimeout(), t.op().then((function(e) {\n                return t.Es.resolve(e);\n            }))) : Promise.resolve();\n        }));\n    }, t.prototype.clearTimeout = function() {\n        null !== this.Is && (this.ws(this), clearTimeout(this.Is), this.Is = null);\n    }, t;\n}();\n\n/**\n * Returns a FirestoreError that can be surfaced to the user if the provided\n * error is an IndexedDbTransactionError. Re-throws the error otherwise.\n */ function Er(t, e) {\n    if (A(\"AsyncQueue\", e + \": \" + t), mr(t)) return new q(M.UNAVAILABLE, e + \": \" + t);\n    throw t;\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ var Tr = \"The current tab is not in the required state to perform this operation. It might be necessary to refresh the browser tab.\", Nr = /** @class */ function() {\n    function t() {\n        this.ys = [];\n    }\n    return t.prototype.gs = function(t) {\n        this.ys.push(t);\n    }, t.prototype.Vs = function() {\n        this.ys.forEach((function(t) {\n            return t();\n        }));\n    }, t;\n}();\n\n/**\n * A base class representing a persistence transaction, encapsulating both the\n * transaction's sequence numbers as well as a list of onCommitted listeners.\n *\n * When you call Persistence.runTransaction(), it will create a transaction and\n * pass it to your callback. You then pass it to any method that operates\n * on persistence.\n */\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Encodes a resource path into a IndexedDb-compatible string form.\n */\nfunction Ar(t) {\n    for (var e = \"\", n = 0; n < t.length; n++) e.length > 0 && (e = Sr(e)), e = Dr(t.get(n), e);\n    return Sr(e);\n}\n\n/** Encodes a single segment of a resource path into the given result */ function Dr(t, e) {\n    for (var n = e, r = t.length, i = 0; i < r; i++) {\n        var o = t.charAt(i);\n        switch (o) {\n          case \"\\0\":\n            n += \"\u0001\u0010\";\n            break;\n\n          case \"\u0001\":\n            n += \"\u0001\u0011\";\n            break;\n\n          default:\n            n += o;\n        }\n    }\n    return n;\n}\n\n/** Encodes a path separator into the given result */ function Sr(t) {\n    return t + \"\u0001\u0001\";\n}\n\n/**\n * Decodes the given IndexedDb-compatible string form of a resource path into\n * a ResourcePath instance. Note that this method is not suitable for use with\n * decoding resource names from the server; those are One Platform format\n * strings.\n */ function xr(t) {\n    // Event the empty path must encode as a path of at least length 2. A path\n    // with exactly 2 must be the empty path.\n    var e = t.length;\n    if (k(e >= 2), 2 === e) return k(\"\u0001\" === t.charAt(0) && \"\u0001\" === t.charAt(1)), Z.ct();\n    // Escape characters cannot exist past the second-to-last position in the\n    // source value.\n        for (var n = e - 2, r = [], i = \"\", o = 0; o < e; ) {\n        // The last two characters of a valid encoded path must be a separator, so\n        // there must be an end to this segment.\n        var u = t.indexOf(\"\u0001\", o);\n        switch ((u < 0 || u > n) && x(), t.charAt(u + 1)) {\n          case \"\u0001\":\n            var s = t.substring(o, u), a = void 0;\n            0 === i.length ? \n            // Avoid copying for the common case of a segment that excludes \\0\n            // and \\001\n            a = s : (a = i += s, i = \"\"), r.push(a);\n            break;\n\n          case \"\u0010\":\n            i += t.substring(o, u), i += \"\\0\";\n            break;\n\n          case \"\u0011\":\n            // The escape character can be used in the output to encode itself.\n            i += t.substring(o, u + 1);\n            break;\n\n          default:\n            x();\n        }\n        o = u + 2;\n    }\n    return new Z(r);\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Schema Version for the Web client:\n * 1.  Initial version including Mutation Queue, Query Cache, and Remote\n *     Document Cache\n * 2.  Used to ensure a targetGlobal object exists and add targetCount to it. No\n *     longer required because migration 3 unconditionally clears it.\n * 3.  Dropped and re-created Query Cache to deal with cache corruption related\n *     to limbo resolution. Addresses\n *     https://github.com/firebase/firebase-ios-sdk/issues/1548\n * 4.  Multi-Tab Support.\n * 5.  Removal of held write acks.\n * 6.  Create document global for tracking document cache size.\n * 7.  Ensure every cached document has a sentinel row with a sequence number.\n * 8.  Add collection-parent index for Collection Group queries.\n * 9.  Change RemoteDocumentChanges store to be keyed by readTime rather than\n *     an auto-incrementing ID. This is required for Index-Free queries.\n * 10. Rewrite the canonical IDs to the explicit Protobuf-based format.\n * 11. Add bundles and named_queries for bundle support.\n */\n/**\n * Wrapper class to store timestamps (seconds and nanos) in IndexedDb objects.\n */ var kr = function(t, e) {\n    this.seconds = t, this.nanoseconds = e;\n}, Or = function(t, \n/** Whether to allow shared access from multiple tabs. */\ne, n) {\n    this.ownerId = t, this.allowTabSynchronization = e, this.leaseTimestampMs = n;\n};\n\n/**\n * A singleton object to be stored in the 'owner' store in IndexedDb.\n *\n * A given database can have a single primary tab assigned at a given time. That\n * tab must validate that it is still holding the primary lease before every\n * operation that requires locked access. The primary tab should regularly\n * write an updated timestamp to this lease to prevent other tabs from\n * \"stealing\" the primary lease\n */\n/**\n * Name of the IndexedDb object store.\n *\n * Note that the name 'owner' is chosen to ensure backwards compatibility with\n * older clients that only supported single locked access to the persistence\n * layer.\n */\nOr.store = \"owner\", \n/**\n     * The key string used for the single object that exists in the\n     * DbPrimaryClient store.\n     */\nOr.key = \"owner\";\n\n/**\n * An object to be stored in the 'mutationQueues' store in IndexedDb.\n *\n * Each user gets a single queue of MutationBatches to apply to the server.\n * DbMutationQueue tracks the metadata about the queue.\n */\nvar Pr = function(\n/**\n     * The normalized user ID to which this queue belongs.\n     */\nt, \n/**\n     * An identifier for the highest numbered batch that has been acknowledged\n     * by the server. All MutationBatches in this queue with batchIds less\n     * than or equal to this value are considered to have been acknowledged by\n     * the server.\n     *\n     * NOTE: this is deprecated and no longer used by the code.\n     */\ne, \n/**\n     * A stream token that was previously sent by the server.\n     *\n     * See StreamingWriteRequest in datastore.proto for more details about\n     * usage.\n     *\n     * After sending this token, earlier tokens may not be used anymore so\n     * only a single stream token is retained.\n     *\n     * NOTE: this is deprecated and no longer used by the code.\n     */\nn) {\n    this.userId = t, this.lastAcknowledgedBatchId = e, this.lastStreamToken = n;\n};\n\n/** Name of the IndexedDb object store.  */ Pr.store = \"mutationQueues\", \n/** Keys are automatically assigned via the userId property. */\nPr.keyPath = \"userId\";\n\n/**\n * An object to be stored in the 'mutations' store in IndexedDb.\n *\n * Represents a batch of user-level mutations intended to be sent to the server\n * in a single write. Each user-level batch gets a separate DbMutationBatch\n * with a new batchId.\n */\nvar Vr = function(\n/**\n     * The normalized user ID to which this batch belongs.\n     */\nt, \n/**\n     * An identifier for this batch, allocated using an auto-generated key.\n     */\ne, \n/**\n     * The local write time of the batch, stored as milliseconds since the\n     * epoch.\n     */\nn, \n/**\n     * A list of \"mutations\" that represent a partial base state from when this\n     * write batch was initially created. During local application of the write\n     * batch, these baseMutations are applied prior to the real writes in order\n     * to override certain document fields from the remote document cache. This\n     * is necessary in the case of non-idempotent writes (e.g. `increment()`\n     * transforms) to make sure that the local view of the modified documents\n     * doesn't flicker if the remote document cache receives the result of the\n     * non-idempotent write before the write is removed from the queue.\n     *\n     * These mutations are never sent to the backend.\n     */\nr, \n/**\n     * A list of mutations to apply. All mutations will be applied atomically.\n     *\n     * Mutations are serialized via toMutation().\n     */\ni) {\n    this.userId = t, this.batchId = e, this.localWriteTimeMs = n, this.baseMutations = r, \n    this.mutations = i;\n};\n\n/** Name of the IndexedDb object store.  */ Vr.store = \"mutations\", \n/** Keys are automatically assigned via the userId, batchId properties. */\nVr.keyPath = \"batchId\", \n/** The index name for lookup of mutations by user. */\nVr.userMutationsIndex = \"userMutationsIndex\", \n/** The user mutations index is keyed by [userId, batchId] pairs. */\nVr.userMutationsKeyPath = [ \"userId\", \"batchId\" ];\n\n/**\n * An object to be stored in the 'documentMutations' store in IndexedDb.\n *\n * A manually maintained index of all the mutation batches that affect a given\n * document key. The rows in this table are references based on the contents of\n * DbMutationBatch.mutations.\n */\nvar Cr = /** @class */ function() {\n    function t() {}\n    /**\n     * Creates a [userId] key for use in the DbDocumentMutations index to iterate\n     * over all of a user's document mutations.\n     */    return t.prefixForUser = function(t) {\n        return [ t ];\n    }, \n    /**\n     * Creates a [userId, encodedPath] key for use in the DbDocumentMutations\n     * index to iterate over all at document mutations for a given path or lower.\n     */\n    t.prefixForPath = function(t, e) {\n        return [ t, Ar(e) ];\n    }, \n    /**\n     * Creates a full index key of [userId, encodedPath, batchId] for inserting\n     * and deleting into the DbDocumentMutations index.\n     */\n    t.key = function(t, e, n) {\n        return [ t, Ar(e), n ];\n    }, t;\n}();\n\nCr.store = \"documentMutations\", \n/**\n     * Because we store all the useful information for this store in the key,\n     * there is no useful information to store as the value. The raw (unencoded)\n     * path cannot be stored because IndexedDb doesn't store prototype\n     * information.\n     */\nCr.PLACEHOLDER = new Cr;\n\n/**\n * Represents the known absence of a document at a particular version.\n * Stored in IndexedDb as part of a DbRemoteDocument object.\n */\nvar Lr = function(t, e) {\n    this.path = t, this.readTime = e;\n}, Rr = function(t, e) {\n    this.path = t, this.version = e;\n}, Ur = \n// TODO: We are currently storing full document keys almost three times\n// (once as part of the primary key, once - partly - as `parentPath` and once\n// inside the encoded documents). During our next migration, we should\n// rewrite the primary key as parentPath + document ID which would allow us\n// to drop one value.\nfunction(\n/**\n     * Set to an instance of DbUnknownDocument if the data for a document is\n     * not known, but it is known that a document exists at the specified\n     * version (e.g. it had a successful update applied to it)\n     */\nt, \n/**\n     * Set to an instance of a DbNoDocument if it is known that no document\n     * exists.\n     */\ne, \n/**\n     * Set to an instance of a Document if there's a cached version of the\n     * document.\n     */\nn, \n/**\n     * Documents that were written to the remote document store based on\n     * a write acknowledgment are marked with `hasCommittedMutations`. These\n     * documents are potentially inconsistent with the backend's copy and use\n     * the write's commit version as their document version.\n     */\nr, \n/**\n     * When the document was read from the backend. Undefined for data written\n     * prior to schema version 9.\n     */\ni, \n/**\n     * The path of the collection this document is part of. Undefined for data\n     * written prior to schema version 9.\n     */\no) {\n    this.unknownDocument = t, this.noDocument = e, this.document = n, this.hasCommittedMutations = r, \n    this.readTime = i, this.parentPath = o;\n};\n\n/**\n * Represents a document that is known to exist but whose data is unknown.\n * Stored in IndexedDb as part of a DbRemoteDocument object.\n */ Ur.store = \"remoteDocuments\", \n/**\n     * An index that provides access to all entries sorted by read time (which\n     * corresponds to the last modification time of each row).\n     *\n     * This index is used to provide a changelog for Multi-Tab.\n     */\nUr.readTimeIndex = \"readTimeIndex\", Ur.readTimeIndexPath = \"readTime\", \n/**\n     * An index that provides access to documents in a collection sorted by read\n     * time.\n     *\n     * This index is used to allow the RemoteDocumentCache to fetch newly changed\n     * documents in a collection.\n     */\nUr.collectionReadTimeIndex = \"collectionReadTimeIndex\", Ur.collectionReadTimeIndexPath = [ \"parentPath\", \"readTime\" ];\n\n/**\n * Contains a single entry that has metadata about the remote document cache.\n */\nvar Mr = \n/**\n     * @param byteSize - Approximately the total size in bytes of all the\n     * documents in the document cache.\n     */\nfunction(t) {\n    this.byteSize = t;\n};\n\nMr.store = \"remoteDocumentGlobal\", Mr.key = \"remoteDocumentGlobalKey\";\n\n/**\n * An object to be stored in the 'targets' store in IndexedDb.\n *\n * This is based on and should be kept in sync with the proto used in the iOS\n * client.\n *\n * Each query the client listens to against the server is tracked on disk so\n * that the query can be efficiently resumed on restart.\n */\nvar qr = function(\n/**\n     * An auto-generated sequential numeric identifier for the query.\n     *\n     * Queries are stored using their canonicalId as the key, but these\n     * canonicalIds can be quite long so we additionally assign a unique\n     * queryId which can be used by referenced data structures (e.g.\n     * indexes) to minimize the on-disk cost.\n     */\nt, \n/**\n     * The canonical string representing this query. This is not unique.\n     */\ne, \n/**\n     * The last readTime received from the Watch Service for this query.\n     *\n     * This is the same value as TargetChange.read_time in the protos.\n     */\nn, \n/**\n     * An opaque, server-assigned token that allows watching a query to be\n     * resumed after disconnecting without retransmitting all the data\n     * that matches the query. The resume token essentially identifies a\n     * point in time from which the server should resume sending results.\n     *\n     * This is related to the snapshotVersion in that the resumeToken\n     * effectively also encodes that value, but the resumeToken is opaque\n     * and sometimes encodes additional information.\n     *\n     * A consequence of this is that the resumeToken should be used when\n     * asking the server to reason about where this client is in the watch\n     * stream, but the client should use the snapshotVersion for its own\n     * purposes.\n     *\n     * This is the same value as TargetChange.resume_token in the protos.\n     */\nr, \n/**\n     * A sequence number representing the last time this query was\n     * listened to, used for garbage collection purposes.\n     *\n     * Conventionally this would be a timestamp value, but device-local\n     * clocks are unreliable and they must be able to create new listens\n     * even while disconnected. Instead this should be a monotonically\n     * increasing number that's incremented on each listen call.\n     *\n     * This is different from the queryId since the queryId is an\n     * immutable identifier assigned to the Query on first use while\n     * lastListenSequenceNumber is updated every time the query is\n     * listened to.\n     */\ni, \n/**\n     * Denotes the maximum snapshot version at which the associated query view\n     * contained no limbo documents.  Undefined for data written prior to\n     * schema version 9.\n     */\no, \n/**\n     * The query for this target.\n     *\n     * Because canonical ids are not unique we must store the actual query. We\n     * use the proto to have an object we can persist without having to\n     * duplicate translation logic to and from a `Query` object.\n     */\nu) {\n    this.targetId = t, this.canonicalId = e, this.readTime = n, this.resumeToken = r, \n    this.lastListenSequenceNumber = i, this.lastLimboFreeSnapshotVersion = o, this.query = u;\n};\n\nqr.store = \"targets\", \n/** Keys are automatically assigned via the targetId property. */\nqr.keyPath = \"targetId\", \n/** The name of the queryTargets index. */\nqr.queryTargetsIndexName = \"queryTargetsIndex\", \n/**\n     * The index of all canonicalIds to the targets that they match. This is not\n     * a unique mapping because canonicalId does not promise a unique name for all\n     * possible queries, so we append the targetId to make the mapping unique.\n     */\nqr.queryTargetsKeyPath = [ \"canonicalId\", \"targetId\" ];\n\n/**\n * An object representing an association between a target and a document, or a\n * sentinel row marking the last sequence number at which a document was used.\n * Each document cached must have a corresponding sentinel row before lru\n * garbage collection is enabled.\n *\n * The target associations and sentinel rows are co-located so that orphaned\n * documents and their sequence numbers can be identified efficiently via a scan\n * of this store.\n */\nvar Fr = function(\n/**\n     * The targetId identifying a target or 0 for a sentinel row.\n     */\nt, \n/**\n     * The path to the document, as encoded in the key.\n     */\ne, \n/**\n     * If this is a sentinel row, this should be the sequence number of the last\n     * time the document specified by `path` was used. Otherwise, it should be\n     * `undefined`.\n     */\nn) {\n    this.targetId = t, this.path = e, this.sequenceNumber = n;\n};\n\n/** Name of the IndexedDb object store.  */ Fr.store = \"targetDocuments\", \n/** Keys are automatically assigned via the targetId, path properties. */\nFr.keyPath = [ \"targetId\", \"path\" ], \n/** The index name for the reverse index. */\nFr.documentTargetsIndex = \"documentTargetsIndex\", \n/** We also need to create the reverse index for these properties. */\nFr.documentTargetsKeyPath = [ \"path\", \"targetId\" ];\n\n/**\n * A record of global state tracked across all Targets, tracked separately\n * to avoid the need for extra indexes.\n *\n * This should be kept in-sync with the proto used in the iOS client.\n */\nvar jr = function(\n/**\n     * The highest numbered target id across all targets.\n     *\n     * See DbTarget.targetId.\n     */\nt, \n/**\n     * The highest numbered lastListenSequenceNumber across all targets.\n     *\n     * See DbTarget.lastListenSequenceNumber.\n     */\ne, \n/**\n     * A global snapshot version representing the last consistent snapshot we\n     * received from the backend. This is monotonically increasing and any\n     * snapshots received from the backend prior to this version (e.g. for\n     * targets resumed with a resumeToken) should be suppressed (buffered)\n     * until the backend has caught up to this snapshot version again. This\n     * prevents our cache from ever going backwards in time.\n     */\nn, \n/**\n     * The number of targets persisted.\n     */\nr) {\n    this.highestTargetId = t, this.highestListenSequenceNumber = e, this.lastRemoteSnapshotVersion = n, \n    this.targetCount = r;\n};\n\n/**\n * The key string used for the single object that exists in the\n * DbTargetGlobal store.\n */ jr.key = \"targetGlobalKey\", jr.store = \"targetGlobal\";\n\n/**\n * An object representing an association between a Collection id (e.g. 'messages')\n * to a parent path (e.g. '/chats/123') that contains it as a (sub)collection.\n * This is used to efficiently find all collections to query when performing\n * a Collection Group query.\n */\nvar zr = function(\n/**\n     * The collectionId (e.g. 'messages')\n     */\nt, \n/**\n     * The path to the parent (either a document location or an empty path for\n     * a root-level collection).\n     */\ne) {\n    this.collectionId = t, this.parent = e;\n};\n\n/** Name of the IndexedDb object store. */ zr.store = \"collectionParents\", \n/** Keys are automatically assigned via the collectionId, parent properties. */\nzr.keyPath = [ \"collectionId\", \"parent\" ];\n\n/**\n * A record of the metadata state of each client.\n *\n * PORTING NOTE: This is used to synchronize multi-tab state and does not need\n * to be ported to iOS or Android.\n */\nvar Gr = function(\n// Note: Previous schema versions included a field\n// \"lastProcessedDocumentChangeId\". Don't use anymore.\n/** The auto-generated client id assigned at client startup. */\nt, \n/** The last time this state was updated. */\ne, \n/** Whether the client's network connection is enabled. */\nn, \n/** Whether this client is running in a foreground tab. */\nr) {\n    this.clientId = t, this.updateTimeMs = e, this.networkEnabled = n, this.inForeground = r;\n};\n\n/** Name of the IndexedDb object store. */ Gr.store = \"clientMetadata\", \n/** Keys are automatically assigned via the clientId properties. */\nGr.keyPath = \"clientId\";\n\n/**\n * A object representing a bundle loaded by the SDK.\n */\nvar Br = function(\n/** The ID of the loaded bundle. */\nt, \n/** The create time of the loaded bundle. */\ne, \n/** The schema version of the loaded bundle. */\nn) {\n    this.bundleId = t, this.createTime = e, this.version = n;\n};\n\n/** Name of the IndexedDb object store. */ Br.store = \"bundles\", Br.keyPath = \"bundleId\";\n\n/**\n * A object representing a named query loaded by the SDK via a bundle.\n */\nvar Qr = function(\n/** The name of the query. */\nt, \n/** The read time of the results saved in the bundle from the named query. */\ne, \n/** The query saved in the bundle. */\nn) {\n    this.name = t, this.readTime = e, this.bundledQuery = n;\n};\n\n/** Name of the IndexedDb object store. */ Qr.store = \"namedQueries\", Qr.keyPath = \"name\";\n\n// Visible for testing\nvar Yr = b(b([], b(b([], b(b([], b(b([], [ Pr.store, Vr.store, Cr.store, Ur.store, qr.store, Or.store, jr.store, Fr.store ]), [ Gr.store ])), [ Mr.store ])), [ zr.store ])), [ Br.store, Qr.store ]), Hr = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this) || this).ps = e, r.bs = n, r;\n    }\n    return m(e, t), e;\n}(Nr);\n\n// V2 is no longer usable (see comment at top of file)\n// Visible for testing\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ function Kr(t, e) {\n    var n = O(t);\n    return dr.zn(n.ps, e);\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A batch of mutations that will be sent as one unit to the backend.\n */ var Xr = /** @class */ function() {\n    /**\n     * @param batchId - The unique ID of this mutation batch.\n     * @param localWriteTime - The original write time of this mutation.\n     * @param baseMutations - Mutations that are used to populate the base\n     * values when this mutation is applied locally. This can be used to locally\n     * overwrite values that are persisted in the remote document cache. Base\n     * mutations are never sent to the backend.\n     * @param mutations - The user-provided mutations in this mutation batch.\n     * User-provided mutations are applied both locally and remotely on the\n     * backend.\n     */\n    function t(t, e, n, r) {\n        this.batchId = t, this.vs = e, this.baseMutations = n, this.mutations = r\n        /**\n     * Applies all the mutations in this MutationBatch to the specified document\n     * to create a new remote document\n     *\n     * @param docKey - The key of the document to apply mutations to.\n     * @param maybeDoc - The document to apply mutations to.\n     * @param batchResult - The result of applying the MutationBatch to the\n     * backend.\n     */;\n    }\n    return t.prototype.Ss = function(t, e, n) {\n        for (var r = n.Ds, i = 0; i < this.mutations.length; i++) {\n            var o = this.mutations[i];\n            o.key.isEqual(t) && (e = qe(o, e, r[i]));\n        }\n        return e;\n    }, \n    /**\n     * Computes the local view of a document given all the mutations in this\n     * batch.\n     *\n     * @param docKey - The key of the document to apply mutations to.\n     * @param maybeDoc - The document to apply mutations to.\n     */\n    t.prototype.Cs = function(t, e) {\n        // First, apply the base state. This allows us to apply non-idempotent\n        // transform against a consistent set of values.\n        for (var n = 0, r = this.baseMutations; n < r.length; n++) {\n            (u = r[n]).key.isEqual(t) && (e = Fe(u, e, this.vs));\n        }\n        // Second, apply all user-provided mutations.\n                for (var i = 0, o = this.mutations; i < o.length; i++) {\n            var u;\n            (u = o[i]).key.isEqual(t) && (e = Fe(u, e, this.vs));\n        }\n        return e;\n    }, \n    /**\n     * Computes the local view for all provided documents given the mutations in\n     * this batch.\n     */\n    t.prototype.xs = function(t) {\n        var e = this, n = t;\n        // TODO(mrschmidt): This implementation is O(n^2). If we apply the mutations\n        // directly (as done in `applyToLocalView()`), we can reduce the complexity\n        // to O(n).\n                return this.mutations.forEach((function(r) {\n            var i = e.Cs(r.key, t.get(r.key));\n            i && (n = n.zt(r.key, i));\n        })), n;\n    }, t.prototype.keys = function() {\n        return this.mutations.reduce((function(t, e) {\n            return t.add(e.key);\n        }), mn());\n    }, t.prototype.isEqual = function(t) {\n        return this.batchId === t.batchId && L(this.mutations, t.mutations, (function(t, e) {\n            return ze(t, e);\n        })) && L(this.baseMutations, t.baseMutations, (function(t, e) {\n            return ze(t, e);\n        }));\n    }, t;\n}(), Wr = /** @class */ function() {\n    function t(t, e, n, \n    /**\n     * A pre-computed mapping from each mutated document to the resulting\n     * version.\n     */\n    r) {\n        this.batch = t, this.Ns = e, this.Ds = n, this.$s = r\n        /**\n     * Creates a new MutationBatchResult for the given batch and results. There\n     * must be one result for each mutation in the batch. This static factory\n     * caches a document=&gt;version mapping (docVersions).\n     */;\n    }\n    return t.from = function(e, n, r) {\n        k(e.mutations.length === r.length);\n        for (var i = vn(), o = e.mutations, u = 0; u < o.length; u++) i = i.zt(o[u].key, r[u].version);\n        return new t(e, n, r, i);\n    }, t;\n}(), Zr = function(t) {\n    this.Fs = t;\n};\n\n/** The result of applying a mutation batch to the backend. */\n/** Decodes a remote document from storage locally to a Document. */ function Jr(t, e) {\n    if (e.document) return Kn(t.Fs, e.document, !!e.hasCommittedMutations);\n    if (e.noDocument) {\n        var n = tt.Et(e.noDocument.path), r = ri(e.noDocument.readTime);\n        return new Vt(n, r, {\n            hasCommittedMutations: !!e.hasCommittedMutations\n        });\n    }\n    if (e.unknownDocument) {\n        var i = tt.Et(e.unknownDocument.path);\n        r = ri(e.unknownDocument.version);\n        return new Ct(i, r);\n    }\n    return x();\n}\n\n/** Encodes a document for storage locally. */ function $r(t, e, n) {\n    var r = ti(n), i = e.key.path.X().it();\n    if (e instanceof Pt) {\n        var o = function(t, e) {\n            return {\n                name: jn(t, e.key),\n                fields: e.bt().mapValue.fields,\n                updateTime: Ln(t, e.version.j())\n            };\n        }(t.Fs, e), u = e.hasCommittedMutations;\n        return new Ur(\n        /* unknownDocument= */ null, \n        /* noDocument= */ null, o, u, r, i);\n    }\n    if (e instanceof Vt) {\n        var s = e.key.path.it(), a = ni(e.version);\n        u = e.hasCommittedMutations;\n        return new Ur(\n        /* unknownDocument= */ null, new Lr(s, a), \n        /* document= */ null, u, r, i);\n    }\n    if (e instanceof Ct) {\n        var c = e.key.path.it(), h = ni(e.version);\n        return new Ur(new Rr(c, h), \n        /* noDocument= */ null, \n        /* document= */ null, \n        /* hasCommittedMutations= */ !0, r, i);\n    }\n    return x();\n}\n\nfunction ti(t) {\n    var e = t.j();\n    return [ e.seconds, e.nanoseconds ];\n}\n\nfunction ei(t) {\n    var e = new K(t[0], t[1]);\n    return X.K(e);\n}\n\nfunction ni(t) {\n    var e = t.j();\n    return new kr(e.seconds, e.nanoseconds);\n}\n\nfunction ri(t) {\n    var e = new K(t.seconds, t.nanoseconds);\n    return X.K(e);\n}\n\n/** Encodes a batch of mutations into a DbMutationBatch for local storage. */\n/** Decodes a DbMutationBatch into a MutationBatch */ function ii(t, e) {\n    // Squash old transform mutations into existing patch or set mutations.\n    // The replacement of representing `transforms` with `update_transforms`\n    // on the SDK means that old `transform` mutations stored in IndexedDB need\n    // to be updated to `update_transforms`.\n    // TODO(b/174608374): Remove this code once we perform a schema migration.\n    for (var n = (e.baseMutations || []).map((function(e) {\n        return Wn(t.Fs, e);\n    })), r = 0; r < e.mutations.length - 1; ++r) {\n        var i = e.mutations[r];\n        if (r + 1 < e.mutations.length && void 0 !== e.mutations[r + 1].transform) {\n            var o = e.mutations[r + 1];\n            i.updateTransforms = o.transform.fieldTransforms, e.mutations.splice(r + 1, 1), \n            ++r;\n        }\n    }\n    var u = e.mutations.map((function(e) {\n        return Wn(t.Fs, e);\n    })), s = K.fromMillis(e.localWriteTimeMs);\n    return new Xr(e.batchId, s, n, u);\n}\n\n/** Decodes a DbTarget into TargetData */ function oi(t) {\n    var e, n, r = ri(t.readTime), i = void 0 !== t.lastLimboFreeSnapshotVersion ? ri(t.lastLimboFreeSnapshotVersion) : X.min();\n    return void 0 !== t.query.documents ? (k(1 === (n = t.query).documents.length), \n    e = he(re(Bn(n.documents[0])))) : e = function(t) {\n        return he($n(t));\n    }(t.query), new ge(e, t.targetId, 0 /* Listen */ , t.lastListenSequenceNumber, r, i, U.fromBase64String(t.resumeToken))\n    /** Encodes TargetData into a DbTarget for storage locally. */;\n}\n\nfunction ui(t, e) {\n    var n, r = ni(e.Ot), i = ni(e.lastLimboFreeSnapshotVersion);\n    n = qt(e.target) ? Zn(t.Fs, e.target) : Jn(t.Fs, e.target);\n    // We can't store the resumeToken as a ByteString in IndexedDb, so we\n    // convert it to a base64 string for storage.\n    var o = e.resumeToken.toBase64();\n    // lastListenSequenceNumber is always 0 until we do real GC.\n        return new qr(e.targetId, Ut(e.target), r, o, e.sequenceNumber, i, n);\n}\n\n/**\n * A helper function for figuring out what kind of query has been stored.\n */\n/**\n * Encodes a `BundledQuery` from bundle proto to a Query object.\n *\n * This reconstructs the original query used to build the bundle being loaded,\n * including features exists only in SDKs (for example: limit-to-last).\n */ function si(t) {\n    var e = $n({\n        parent: t.parent,\n        structuredQuery: t.structuredQuery\n    });\n    return \"LAST\" === t.limitType ? fe(e, e.limit, \"L\" /* Last */) : e;\n}\n\n/** Encodes a NamedQuery proto object to a NamedQuery model object. */\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ var ai = /** @class */ function() {\n    function t() {}\n    return t.prototype.Os = function(t, e) {\n        return ci(t).get(e).next((function(t) {\n            if (t) return {\n                id: (e = t).bundleId,\n                createTime: ri(e.createTime),\n                version: e.version\n            };\n            /** Encodes a DbBundle to a BundleMetadata object. */            var e;\n            /** Encodes a BundleMetadata to a DbBundle. */        }));\n    }, t.prototype.ks = function(t, e) {\n        return ci(t).put({\n            bundleId: (n = e).id,\n            createTime: ni(Mn(n.createTime)),\n            version: n.version\n        });\n        var n;\n        /** Encodes a DbNamedQuery to a NamedQuery. */    }, t.prototype.Ms = function(t, e) {\n        return hi(t).get(e).next((function(t) {\n            if (t) return {\n                name: (e = t).name,\n                query: si(e.bundledQuery),\n                readTime: ri(e.readTime)\n            };\n            var e;\n            /** Encodes a NamedQuery from a bundle proto to a DbNamedQuery. */        }));\n    }, t.prototype.Ls = function(t, e) {\n        return hi(t).put(function(t) {\n            return {\n                name: t.name,\n                readTime: ni(Mn(t.readTime)),\n                bundledQuery: t.bundledQuery\n            };\n        }(e));\n    }, t;\n}();\n\n/**\n * Helper to get a typed SimpleDbStore for the bundles object store.\n */ function ci(t) {\n    return Kr(t, Br.store);\n}\n\n/**\n * Helper to get a typed SimpleDbStore for the namedQueries object store.\n */ function hi(t) {\n    return Kr(t, Qr.store);\n}\n\n/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * An in-memory implementation of IndexManager.\n */ var fi = /** @class */ function() {\n    function t() {\n        this.Bs = new li;\n    }\n    return t.prototype.qs = function(t, e) {\n        return this.Bs.add(e), lr.resolve();\n    }, t.prototype.Us = function(t, e) {\n        return lr.resolve(this.Bs.getEntries(e));\n    }, t;\n}(), li = /** @class */ function() {\n    function t() {\n        this.index = {};\n    }\n    // Returns false if the entry already existed.\n        return t.prototype.add = function(t) {\n        var e = t.tt(), n = t.X(), r = this.index[e] || new sn(Z.H), i = !r.has(n);\n        return this.index[e] = r.add(n), i;\n    }, t.prototype.has = function(t) {\n        var e = t.tt(), n = t.X(), r = this.index[e];\n        return r && r.has(n);\n    }, t.prototype.getEntries = function(t) {\n        return (this.index[t] || new sn(Z.H)).it();\n    }, t;\n}(), pi = /** @class */ function() {\n    function t() {\n        /**\n         * An in-memory copy of the index entries we've already written since the SDK\n         * launched. Used to avoid re-writing the same entry repeatedly.\n         *\n         * This is *NOT* a complete cache of what's in persistence and so can never be used to\n         * satisfy reads.\n         */\n        this.Qs = new li;\n    }\n    /**\n     * Adds a new entry to the collection parent index.\n     *\n     * Repeated calls for the same collectionPath should be avoided within a\n     * transaction as IndexedDbIndexManager only caches writes once a transaction\n     * has been committed.\n     */    return t.prototype.qs = function(t, e) {\n        var n = this;\n        if (!this.Qs.has(e)) {\n            var r = e.tt(), i = e.X();\n            t.gs((function() {\n                // Add the collection to the in memory cache only if the transaction was\n                // successfully committed.\n                n.Qs.add(e);\n            }));\n            var o = {\n                collectionId: r,\n                parent: Ar(i)\n            };\n            return di(t).put(o);\n        }\n        return lr.resolve();\n    }, t.prototype.Us = function(t, e) {\n        var n = [], r = IDBKeyRange.bound([ e, \"\" ], [ R(e), \"\" ], \n        /*lowerOpen=*/ !1, \n        /*upperOpen=*/ !0);\n        return di(t).rs(r).next((function(t) {\n            for (var r = 0, i = t; r < i.length; r++) {\n                var o = i[r];\n                // This collectionId guard shouldn't be necessary (and isn't as long\n                // as we're running in a real browser), but there's a bug in\n                // indexeddbshim that breaks our range in our tests running in node:\n                // https://github.com/axemclion/IndexedDBShim/issues/334\n                                if (o.collectionId !== e) break;\n                n.push(xr(o.parent));\n            }\n            return n;\n        }));\n    }, t;\n}();\n\n/**\n * Internal implementation of the collection-parent index exposed by MemoryIndexManager.\n * Also used for in-memory caching by IndexedDbIndexManager and initial index population\n * in indexeddb_schema.ts\n */\n/**\n * Helper to get a typed SimpleDbStore for the collectionParents\n * document store.\n */\nfunction di(t) {\n    return Kr(t, zr.store);\n}\n\n/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ var vi = {\n    Ks: !1,\n    Ws: 0,\n    js: 0,\n    Gs: 0\n}, yi = /** @class */ function() {\n    function t(\n    // When we attempt to collect, we will only do so if the cache size is greater than this\n    // threshold. Passing `COLLECTION_DISABLED` here will cause collection to always be skipped.\n    t, \n    // The percentage of sequence numbers that we will attempt to collect\n    e, \n    // A cap on the total number of sequence numbers that will be collected. This prevents\n    // us from collecting a huge number of sequence numbers if the cache has grown very large.\n    n) {\n        this.zs = t, this.Hs = e, this.Js = n;\n    }\n    return t.Ys = function(e) {\n        return new t(e, t.Xs, t.Zs);\n    }, t;\n}();\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Verifies the error thrown by a LocalStore operation. If a LocalStore\n * operation fails because the primary lease has been taken by another client,\n * we ignore the error (the persistence layer will immediately call\n * `applyPrimaryLease` to propagate the primary state change). All other errors\n * are re-thrown.\n *\n * @param err - An error returned by a LocalStore operation.\n * @returns A Promise that resolves after we recovered, or the original error.\n */\nfunction mi(t) {\n    return g(this, void 0, void 0, (function() {\n        return w(this, (function(e) {\n            if (t.code !== M.FAILED_PRECONDITION || t.message !== Tr) throw t;\n            return N(\"LocalStore\", \"Unexpectedly lost primary lease\"), [ 2 /*return*/ ];\n        }));\n    }));\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A map implementation that uses objects as keys. Objects must have an\n * associated equals function and must be immutable. Entries in the map are\n * stored together with the key being produced from the mapKeyFn. This map\n * automatically handles collisions of keys.\n */ yi.Xs = 10, yi.Zs = 1e3, yi.ti = new yi(41943040, yi.Xs, yi.Zs), yi.ei = new yi(-1, 0, 0);\n\nvar gi = /** @class */ function() {\n    function t(t, e) {\n        this.ni = t, this.si = e, \n        /**\n             * The inner map for a key/value pair. Due to the possibility of collisions we\n             * keep a list of entries that we do a linear search through to find an actual\n             * match. Note that collisions should be rare, so we still expect near\n             * constant time lookups in practice.\n             */\n        this.ii = {}\n        /** Get a value for this key, or undefined if it does not exist. */;\n    }\n    return t.prototype.get = function(t) {\n        var e = this.ni(t), n = this.ii[e];\n        if (void 0 !== n) for (var r = 0, i = n; r < i.length; r++) {\n            var o = i[r], u = o[0], s = o[1];\n            if (this.si(u, t)) return s;\n        }\n    }, t.prototype.has = function(t) {\n        return void 0 !== this.get(t);\n    }, \n    /** Put this key and value in the map. */ t.prototype.set = function(t, e) {\n        var n = this.ni(t), r = this.ii[n];\n        if (void 0 !== r) {\n            for (var i = 0; i < r.length; i++) if (this.si(r[i][0], t)) return void (r[i] = [ t, e ]);\n            r.push([ t, e ]);\n        } else this.ii[n] = [ [ t, e ] ];\n    }, \n    /**\n     * Remove this key from the map. Returns a boolean if anything was deleted.\n     */\n    t.prototype.delete = function(t) {\n        var e = this.ni(t), n = this.ii[e];\n        if (void 0 === n) return !1;\n        for (var r = 0; r < n.length; r++) if (this.si(n[r][0], t)) return 1 === n.length ? delete this.ii[e] : n.splice(r, 1), \n        !0;\n        return !1;\n    }, t.prototype.forEach = function(t) {\n        nt(this.ii, (function(e, n) {\n            for (var r = 0, i = n; r < i.length; r++) {\n                var o = i[r], u = o[0], s = o[1];\n                t(u, s);\n            }\n        }));\n    }, t.prototype.et = function() {\n        return rt(this.ii);\n    }, t;\n}(), wi = /** @class */ function() {\n    function t() {\n        // A mapping of document key to the new cache entry that should be written (or null if any\n        // existing cache entry should be removed).\n        this.ri = new gi((function(t) {\n            return t.toString();\n        }), (function(t, e) {\n            return t.isEqual(e);\n        })), this.oi = !1;\n    }\n    return t.prototype.ci = function(t) {\n        var e = this.ri.get(t);\n        return e ? e.readTime : X.min();\n    }, \n    /**\n     * Buffers a `RemoteDocumentCache.addEntry()` call.\n     *\n     * You can only modify documents that have already been retrieved via\n     * `getEntry()/getEntries()` (enforced via IndexedDbs `apply()`).\n     */\n    t.prototype.ai = function(t, e) {\n        this.ui(), this.ri.set(t.key, {\n            hi: t,\n            readTime: e\n        });\n    }, \n    /**\n     * Buffers a `RemoteDocumentCache.removeEntry()` call.\n     *\n     * You can only remove documents that have already been retrieved via\n     * `getEntry()/getEntries()` (enforced via IndexedDbs `apply()`).\n     */\n    t.prototype.li = function(t, e) {\n        void 0 === e && (e = null), this.ui(), this.ri.set(t, {\n            hi: null,\n            readTime: e\n        });\n    }, \n    /**\n     * Looks up an entry in the cache. The buffered changes will first be checked,\n     * and if no buffered change applies, this will forward to\n     * `RemoteDocumentCache.getEntry()`.\n     *\n     * @param transaction - The transaction in which to perform any persistence\n     *     operations.\n     * @param documentKey - The key of the entry to look up.\n     * @returns The cached Document or NoDocument entry, or null if we have\n     *     nothing cached.\n     */\n    t.prototype._i = function(t, e) {\n        this.ui();\n        var n = this.ri.get(e);\n        return void 0 !== n ? lr.resolve(n.hi) : this.fi(t, e);\n    }, \n    /**\n     * Looks up several entries in the cache, forwarding to\n     * `RemoteDocumentCache.getEntry()`.\n     *\n     * @param transaction - The transaction in which to perform any persistence\n     *     operations.\n     * @param documentKeys - The keys of the entries to look up.\n     * @returns A map of cached `Document`s or `NoDocument`s, indexed by key. If\n     *     an entry cannot be found, the corresponding key will be mapped to a\n     *     null value.\n     */\n    t.prototype.getEntries = function(t, e) {\n        return this.di(t, e);\n    }, \n    /**\n     * Applies buffered changes to the underlying RemoteDocumentCache, using\n     * the provided transaction.\n     */\n    t.prototype.apply = function(t) {\n        return this.ui(), this.oi = !0, this.wi(t);\n    }, \n    /** Helper to assert this.changes is not null  */ t.prototype.ui = function() {}, \n    t;\n}();\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * An in-memory buffer of entries to be written to a RemoteDocumentCache.\n * It can be used to batch up a set of changes to be written to the cache, but\n * additionally supports reading entries back with the `getEntry()` method,\n * falling back to the underlying RemoteDocumentCache if no entry is\n * buffered.\n *\n * Entries added to the cache *must* be read first. This is to facilitate\n * calculating the size delta of the pending changes.\n *\n * PORTING NOTE: This class was implemented then removed from other platforms.\n * If byte-counting ends up being needed on the other platforms, consider\n * porting this class as part of that implementation work.\n */\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Delete a mutation batch and the associated document mutations.\n * @returns A PersistencePromise of the document mutations that were removed.\n */\nfunction bi(t, e, n) {\n    var r = t.store(Vr.store), i = t.store(Cr.store), o = [], u = IDBKeyRange.only(n.batchId), s = 0, a = r.hs({\n        range: u\n    }, (function(t, e, n) {\n        return s++, n.delete();\n    }));\n    o.push(a.next((function() {\n        k(1 === s);\n    })));\n    for (var c = [], h = 0, f = n.mutations; h < f.length; h++) {\n        var l = f[h], p = Cr.key(e, l.key.path, n.batchId);\n        o.push(i.delete(p)), c.push(l.key);\n    }\n    return lr.Mn(o).next((function() {\n        return c;\n    }));\n}\n\n/**\n * Returns an approximate size for the given document.\n */ function _i(t) {\n    var e;\n    if (t.document) e = t.document; else if (t.unknownDocument) e = t.unknownDocument; else {\n        if (!t.noDocument) throw x();\n        e = t.noDocument;\n    }\n    return JSON.stringify(e).length;\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/** A mutation queue for a specific user, backed by IndexedDB. */ var Ii = /** @class */ function() {\n    function t(\n    /**\n     * The normalized userId (e.g. null UID => \"\" userId) used to store /\n     * retrieve mutations.\n     */\n    t, e, n, r) {\n        this.userId = t, this.Qt = e, this.Ei = n, this.Ti = r, \n        /**\n             * Caches the document keys for pending mutation batches. If the mutation\n             * has been removed from IndexedDb, the cached value may continue to\n             * be used to retrieve the batch's document keys. To remove a cached value\n             * locally, `removeCachedMutationKeys()` should be invoked either directly\n             * or through `removeMutationBatches()`.\n             *\n             * With multi-tab, when the primary client acknowledges or rejects a mutation,\n             * this cache is used by secondary clients to invalidate the local\n             * view of the documents that were previously affected by the mutation.\n             */\n        // PORTING NOTE: Multi-tab only.\n        this.Ii = {}\n        /**\n     * Creates a new mutation queue for the given user.\n     * @param user - The user for which to create a mutation queue.\n     * @param serializer - The serializer to use when persisting to IndexedDb.\n     */;\n    }\n    return t.mi = function(e, n, r, i) {\n        // TODO(mcg): Figure out what constraints there are on userIDs\n        // In particular, are there any reserved characters? are empty ids allowed?\n        // For the moment store these together in the same mutations table assuming\n        // that empty userIDs aren't allowed.\n        return k(\"\" !== e.uid), new t(e.m() ? e.uid : \"\", n, r, i);\n    }, t.prototype.Ai = function(t) {\n        var e = !0, n = IDBKeyRange.bound([ this.userId, Number.NEGATIVE_INFINITY ], [ this.userId, Number.POSITIVE_INFINITY ]);\n        return Ti(t).hs({\n            index: Vr.userMutationsIndex,\n            range: n\n        }, (function(t, n, r) {\n            e = !1, r.done();\n        })).next((function() {\n            return e;\n        }));\n    }, t.prototype.Ri = function(t, e, n, r) {\n        var i = this, o = Ni(t), u = Ti(t);\n        // The IndexedDb implementation in Chrome (and Firefox) does not handle\n        // compound indices that include auto-generated keys correctly. To ensure\n        // that the index entry is added correctly in all browsers, we perform two\n        // writes: The first write is used to retrieve the next auto-generated Batch\n        // ID, and the second write populates the index and stores the actual\n        // mutation batch.\n        // See: https://bugs.chromium.org/p/chromium/issues/detail?id=701972\n        // We write an empty object to obtain key\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        return u.add({}).next((function(s) {\n            k(\"number\" == typeof s);\n            for (var a = new Xr(s, e, n, r), c = function(t, e, n) {\n                var r = n.baseMutations.map((function(e) {\n                    return Xn(t.Fs, e);\n                })), i = n.mutations.map((function(e) {\n                    return Xn(t.Fs, e);\n                }));\n                return new Vr(e, n.batchId, n.vs.toMillis(), r, i);\n            }(i.Qt, i.userId, a), h = [], f = new sn((function(t, e) {\n                return C(t.rt(), e.rt());\n            })), l = 0, p = r; l < p.length; l++) {\n                var d = p[l], v = Cr.key(i.userId, d.key.path, s);\n                f = f.add(d.key.path.X()), h.push(u.put(c)), h.push(o.put(v, Cr.PLACEHOLDER));\n            }\n            return f.forEach((function(e) {\n                h.push(i.Ei.qs(t, e));\n            })), t.gs((function() {\n                i.Ii[s] = a.keys();\n            })), lr.Mn(h).next((function() {\n                return a;\n            }));\n        }));\n    }, t.prototype.Pi = function(t, e) {\n        var n = this;\n        return Ti(t).get(e).next((function(t) {\n            return t ? (k(t.userId === n.userId), ii(n.Qt, t)) : null;\n        }));\n    }, \n    /**\n     * Returns the document keys for the mutation batch with the given batchId.\n     * For primary clients, this method returns `null` after\n     * `removeMutationBatches()` has been called. Secondary clients return a\n     * cached result until `removeCachedMutationKeys()` is invoked.\n     */\n    // PORTING NOTE: Multi-tab only.\n    t.prototype.yi = function(t, e) {\n        var n = this;\n        return this.Ii[e] ? lr.resolve(this.Ii[e]) : this.Pi(t, e).next((function(t) {\n            if (t) {\n                var r = t.keys();\n                return n.Ii[e] = r, r;\n            }\n            return null;\n        }));\n    }, t.prototype.gi = function(t, e) {\n        var n = this, r = e + 1, i = IDBKeyRange.lowerBound([ this.userId, r ]), o = null;\n        return Ti(t).hs({\n            index: Vr.userMutationsIndex,\n            range: i\n        }, (function(t, e, i) {\n            e.userId === n.userId && (k(e.batchId >= r), o = ii(n.Qt, e)), i.done();\n        })).next((function() {\n            return o;\n        }));\n    }, t.prototype.Vi = function(t) {\n        var e = IDBKeyRange.upperBound([ this.userId, Number.POSITIVE_INFINITY ]), n = -1;\n        return Ti(t).hs({\n            index: Vr.userMutationsIndex,\n            range: e,\n            reverse: !0\n        }, (function(t, e, r) {\n            n = e.batchId, r.done();\n        })).next((function() {\n            return n;\n        }));\n    }, t.prototype.pi = function(t) {\n        var e = this, n = IDBKeyRange.bound([ this.userId, -1 ], [ this.userId, Number.POSITIVE_INFINITY ]);\n        return Ti(t).rs(Vr.userMutationsIndex, n).next((function(t) {\n            return t.map((function(t) {\n                return ii(e.Qt, t);\n            }));\n        }));\n    }, t.prototype.bi = function(t, e) {\n        var n = this, r = Cr.prefixForPath(this.userId, e.path), i = IDBKeyRange.lowerBound(r), o = [];\n        // Scan the document-mutation index starting with a prefix starting with\n        // the given documentKey.\n                return Ni(t).hs({\n            range: i\n        }, (function(r, i, u) {\n            var s = r[0], a = r[1], c = r[2], h = xr(a);\n            // Only consider rows matching exactly the specific key of\n            // interest. Note that because we order by path first, and we\n            // order terminators before path separators, we'll encounter all\n            // the index rows for documentKey contiguously. In particular, all\n            // the rows for documentKey will occur before any rows for\n            // documents nested in a subcollection beneath documentKey so we\n            // can stop as soon as we hit any such row.\n                        if (s === n.userId && e.path.isEqual(h)) \n            // Look up the mutation batch in the store.\n            return Ti(t).get(c).next((function(t) {\n                if (!t) throw x();\n                k(t.userId === n.userId), o.push(ii(n.Qt, t));\n            }));\n            u.done();\n        })).next((function() {\n            return o;\n        }));\n    }, t.prototype.vi = function(t, e) {\n        var n = this, r = new sn(C), i = [];\n        return e.forEach((function(e) {\n            var o = Cr.prefixForPath(n.userId, e.path), u = IDBKeyRange.lowerBound(o), s = Ni(t).hs({\n                range: u\n            }, (function(t, i, o) {\n                var u = t[0], s = t[1], a = t[2], c = xr(s);\n                // Only consider rows matching exactly the specific key of\n                // interest. Note that because we order by path first, and we\n                // order terminators before path separators, we'll encounter all\n                // the index rows for documentKey contiguously. In particular, all\n                // the rows for documentKey will occur before any rows for\n                // documents nested in a subcollection beneath documentKey so we\n                // can stop as soon as we hit any such row.\n                                u === n.userId && e.path.isEqual(c) ? r = r.add(a) : o.done();\n            }));\n            i.push(s);\n        })), lr.Mn(i).next((function() {\n            return n.Si(t, r);\n        }));\n    }, t.prototype.Di = function(t, e) {\n        var n = this, r = e.path, i = r.length + 1, o = Cr.prefixForPath(this.userId, r), u = IDBKeyRange.lowerBound(o), s = new sn(C);\n        return Ni(t).hs({\n            range: u\n        }, (function(t, e, o) {\n            var u = t[0], a = t[1], c = t[2], h = xr(a);\n            u === n.userId && r.nt(h) ? \n            // Rows with document keys more than one segment longer than the\n            // query path can't be matches. For example, a query on 'rooms'\n            // can't match the document /rooms/abc/messages/xyx.\n            // TODO(mcg): we'll need a different scanner when we implement\n            // ancestor queries.\n            h.length === i && (s = s.add(c)) : o.done();\n        })).next((function() {\n            return n.Si(t, s);\n        }));\n    }, t.prototype.Si = function(t, e) {\n        var n = this, r = [], i = [];\n        // TODO(rockwood): Implement this using iterate.\n        return e.forEach((function(e) {\n            i.push(Ti(t).get(e).next((function(t) {\n                if (null === t) throw x();\n                k(t.userId === n.userId), r.push(ii(n.Qt, t));\n            })));\n        })), lr.Mn(i).next((function() {\n            return r;\n        }));\n    }, t.prototype.Ci = function(t, e) {\n        var n = this;\n        return bi(t.ps, this.userId, e).next((function(r) {\n            return t.gs((function() {\n                n.xi(e.batchId);\n            })), lr.forEach(r, (function(e) {\n                return n.Ti.Ni(t, e);\n            }));\n        }));\n    }, \n    /**\n     * Clears the cached keys for a mutation batch. This method should be\n     * called by secondary clients after they process mutation updates.\n     *\n     * Note that this method does not have to be called from primary clients as\n     * the corresponding cache entries are cleared when an acknowledged or\n     * rejected batch is removed from the mutation queue.\n     */\n    // PORTING NOTE: Multi-tab only\n    t.prototype.xi = function(t) {\n        delete this.Ii[t];\n    }, t.prototype.$i = function(t) {\n        var e = this;\n        return this.Ai(t).next((function(n) {\n            if (!n) return lr.resolve();\n            // Verify that there are no entries in the documentMutations index if\n            // the queue is empty.\n                        var r = IDBKeyRange.lowerBound(Cr.prefixForUser(e.userId)), i = [];\n            return Ni(t).hs({\n                range: r\n            }, (function(t, n, r) {\n                if (t[0] === e.userId) {\n                    var o = xr(t[1]);\n                    i.push(o);\n                } else r.done();\n            })).next((function() {\n                k(0 === i.length);\n            }));\n        }));\n    }, t.prototype.Fi = function(t, e) {\n        return Ei(t, this.userId, e);\n    }, \n    // PORTING NOTE: Multi-tab only (state is held in memory in other clients).\n    /** Returns the mutation queue's metadata from IndexedDb. */\n    t.prototype.Oi = function(t) {\n        var e = this;\n        return Ai(t).get(this.userId).next((function(t) {\n            return t || new Pr(e.userId, -1, \n            /*lastStreamToken=*/ \"\");\n        }));\n    }, t;\n}();\n\n/**\n * @returns true if the mutation queue for the given user contains a pending\n *         mutation for the given key.\n */ function Ei(t, e, n) {\n    var r = Cr.prefixForPath(e, n.path), i = r[1], o = IDBKeyRange.lowerBound(r), u = !1;\n    return Ni(t).hs({\n        range: o,\n        us: !0\n    }, (function(t, n, r) {\n        var o = t[0], s = t[1];\n        t[2];\n        o === e && s === i && (u = !0), r.done();\n    })).next((function() {\n        return u;\n    }));\n}\n\n/** Returns true if any mutation queue contains the given document. */\n/**\n * Helper to get a typed SimpleDbStore for the mutations object store.\n */ function Ti(t) {\n    return Kr(t, Vr.store);\n}\n\n/**\n * Helper to get a typed SimpleDbStore for the mutationQueues object store.\n */ function Ni(t) {\n    return Kr(t, Cr.store);\n}\n\n/**\n * Helper to get a typed SimpleDbStore for the mutationQueues object store.\n */ function Ai(t) {\n    return Kr(t, Pr.store);\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/** Offset to ensure non-overlapping target ids. */\n/**\n * Generates monotonically increasing target IDs for sending targets to the\n * watch stream.\n *\n * The client constructs two generators, one for the target cache, and one for\n * for the sync engine (to generate limbo documents targets). These\n * generators produce non-overlapping IDs (by using even and odd IDs\n * respectively).\n *\n * By separating the target ID space, the query cache can generate target IDs\n * that persist across client restarts, while sync engine can independently\n * generate in-memory target IDs that are transient and can be reused after a\n * restart.\n */ var Di = /** @class */ function() {\n    function t(t) {\n        this.ki = t;\n    }\n    return t.prototype.next = function() {\n        return this.ki += 2, this.ki;\n    }, t.Mi = function() {\n        // The target cache generator must return '2' in its first call to `next()`\n        // as there is no differentiation in the protocol layer between an unset\n        // number and the number '0'. If we were to sent a target with target ID\n        // '0', the backend would consider it unset and replace it with its own ID.\n        return new t(0);\n    }, t.Li = function() {\n        // Sync engine assigns target IDs for limbo document detection.\n        return new t(-1);\n    }, t;\n}(), Si = /** @class */ function() {\n    function t(t, e) {\n        this.Ti = t, this.Qt = e;\n    }\n    // PORTING NOTE: We don't cache global metadata for the target cache, since\n    // some of it (in particular `highestTargetId`) can be modified by secondary\n    // tabs. We could perhaps be more granular (and e.g. still cache\n    // `lastRemoteSnapshotVersion` in memory) but for simplicity we currently go\n    // to IndexedDb whenever we need to read metadata. We can revisit if it turns\n    // out to have a meaningful performance impact.\n        return t.prototype.Bi = function(t) {\n        var e = this;\n        return this.qi(t).next((function(n) {\n            var r = new Di(n.highestTargetId);\n            return n.highestTargetId = r.next(), e.Ui(t, n).next((function() {\n                return n.highestTargetId;\n            }));\n        }));\n    }, t.prototype.Qi = function(t) {\n        return this.qi(t).next((function(t) {\n            return X.K(new K(t.lastRemoteSnapshotVersion.seconds, t.lastRemoteSnapshotVersion.nanoseconds));\n        }));\n    }, t.prototype.Ki = function(t) {\n        return this.qi(t).next((function(t) {\n            return t.highestListenSequenceNumber;\n        }));\n    }, t.prototype.Wi = function(t, e, n) {\n        var r = this;\n        return this.qi(t).next((function(i) {\n            return i.highestListenSequenceNumber = e, n && (i.lastRemoteSnapshotVersion = n.j()), \n            e > i.highestListenSequenceNumber && (i.highestListenSequenceNumber = e), r.Ui(t, i);\n        }));\n    }, t.prototype.ji = function(t, e) {\n        var n = this;\n        return this.Gi(t, e).next((function() {\n            return n.qi(t).next((function(r) {\n                return r.targetCount += 1, n.zi(e, r), n.Ui(t, r);\n            }));\n        }));\n    }, t.prototype.Hi = function(t, e) {\n        return this.Gi(t, e);\n    }, t.prototype.Ji = function(t, e) {\n        var n = this;\n        return this.Yi(t, e.targetId).next((function() {\n            return xi(t).delete(e.targetId);\n        })).next((function() {\n            return n.qi(t);\n        })).next((function(e) {\n            return k(e.targetCount > 0), e.targetCount -= 1, n.Ui(t, e);\n        }));\n    }, \n    /**\n     * Drops any targets with sequence number less than or equal to the upper bound, excepting those\n     * present in `activeTargetIds`. Document associations for the removed targets are also removed.\n     * Returns the number of targets removed.\n     */\n    t.prototype.Xi = function(t, e, n) {\n        var r = this, i = 0, o = [];\n        return xi(t).hs((function(u, s) {\n            var a = oi(s);\n            a.sequenceNumber <= e && null === n.get(a.targetId) && (i++, o.push(r.Ji(t, a)));\n        })).next((function() {\n            return lr.Mn(o);\n        })).next((function() {\n            return i;\n        }));\n    }, \n    /**\n     * Call provided function with each `TargetData` that we have cached.\n     */\n    t.prototype.In = function(t, e) {\n        return xi(t).hs((function(t, n) {\n            var r = oi(n);\n            e(r);\n        }));\n    }, t.prototype.qi = function(t) {\n        return ki(t).get(jr.key).next((function(t) {\n            return k(null !== t), t;\n        }));\n    }, t.prototype.Ui = function(t, e) {\n        return ki(t).put(jr.key, e);\n    }, t.prototype.Gi = function(t, e) {\n        return xi(t).put(ui(this.Qt, e));\n    }, \n    /**\n     * In-place updates the provided metadata to account for values in the given\n     * TargetData. Saving is done separately. Returns true if there were any\n     * changes to the metadata.\n     */\n    t.prototype.zi = function(t, e) {\n        var n = !1;\n        return t.targetId > e.highestTargetId && (e.highestTargetId = t.targetId, n = !0), \n        t.sequenceNumber > e.highestListenSequenceNumber && (e.highestListenSequenceNumber = t.sequenceNumber, \n        n = !0), n;\n    }, t.prototype.Zi = function(t) {\n        return this.qi(t).next((function(t) {\n            return t.targetCount;\n        }));\n    }, t.prototype.tr = function(t, e) {\n        // Iterating by the canonicalId may yield more than one result because\n        // canonicalId values are not required to be unique per target. This query\n        // depends on the queryTargets index to be efficient.\n        var n = Ut(e), r = IDBKeyRange.bound([ n, Number.NEGATIVE_INFINITY ], [ n, Number.POSITIVE_INFINITY ]), i = null;\n        return xi(t).hs({\n            range: r,\n            index: qr.queryTargetsIndexName\n        }, (function(t, n, r) {\n            var o = oi(n);\n            // After finding a potential match, check that the target is\n            // actually equal to the requested target.\n                        Mt(e, o.target) && (i = o, r.done());\n        })).next((function() {\n            return i;\n        }));\n    }, t.prototype.er = function(t, e, n) {\n        var r = this, i = [], o = Oi(t);\n        // PORTING NOTE: The reverse index (documentsTargets) is maintained by\n        // IndexedDb.\n                return e.forEach((function(e) {\n            var u = Ar(e.path);\n            i.push(o.put(new Fr(n, u))), i.push(r.Ti.nr(t, n, e));\n        })), lr.Mn(i);\n    }, t.prototype.sr = function(t, e, n) {\n        var r = this, i = Oi(t);\n        // PORTING NOTE: The reverse index (documentsTargets) is maintained by\n        // IndexedDb.\n                return lr.forEach(e, (function(e) {\n            var o = Ar(e.path);\n            return lr.Mn([ i.delete([ n, o ]), r.Ti.ir(t, n, e) ]);\n        }));\n    }, t.prototype.Yi = function(t, e) {\n        var n = Oi(t), r = IDBKeyRange.bound([ e ], [ e + 1 ], \n        /*lowerOpen=*/ !1, \n        /*upperOpen=*/ !0);\n        return n.delete(r);\n    }, t.prototype.rr = function(t, e) {\n        var n = IDBKeyRange.bound([ e ], [ e + 1 ], \n        /*lowerOpen=*/ !1, \n        /*upperOpen=*/ !0), r = Oi(t), i = mn();\n        return r.hs({\n            range: n,\n            us: !0\n        }, (function(t, e, n) {\n            var r = xr(t[1]), o = new tt(r);\n            i = i.add(o);\n        })).next((function() {\n            return i;\n        }));\n    }, t.prototype.Fi = function(t, e) {\n        var n = Ar(e.path), r = IDBKeyRange.bound([ n ], [ R(n) ], \n        /*lowerOpen=*/ !1, \n        /*upperOpen=*/ !0), i = 0;\n        return Oi(t).hs({\n            index: Fr.documentTargetsIndex,\n            us: !0,\n            range: r\n        }, (function(t, e, n) {\n            var r = t[0];\n            // Having a sentinel row for a document does not count as containing that document;\n            // For the target cache, containing the document means the document is part of some\n            // target.\n                        t[1];\n            0 !== r && (i++, n.done());\n        })).next((function() {\n            return i > 0;\n        }));\n    }, \n    /**\n     * Looks up a TargetData entry by target ID.\n     *\n     * @param targetId - The target ID of the TargetData entry to look up.\n     * @returns The cached TargetData entry, or null if the cache has no entry for\n     * the target.\n     */\n    // PORTING NOTE: Multi-tab only.\n    t.prototype.Sn = function(t, e) {\n        return xi(t).get(e).next((function(t) {\n            return t ? oi(t) : null;\n        }));\n    }, t;\n}();\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Helper to get a typed SimpleDbStore for the queries object store.\n */\nfunction xi(t) {\n    return Kr(t, qr.store);\n}\n\n/**\n * Helper to get a typed SimpleDbStore for the target globals object store.\n */ function ki(t) {\n    return Kr(t, jr.store);\n}\n\n/**\n * Helper to get a typed SimpleDbStore for the document target object store.\n */ function Oi(t) {\n    return Kr(t, Fr.store);\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ function Pi(t, e) {\n    var n = t[0], r = t[1], i = e[0], o = e[1], u = C(n, i);\n    return 0 === u ? C(r, o) : u;\n}\n\n/**\n * Used to calculate the nth sequence number. Keeps a rolling buffer of the\n * lowest n values passed to `addElement`, and finally reports the largest of\n * them in `maxValue`.\n */ var Vi = /** @class */ function() {\n    function t(t) {\n        this.cr = t, this.buffer = new sn(Pi), this.ar = 0;\n    }\n    return t.prototype.ur = function() {\n        return ++this.ar;\n    }, t.prototype.hr = function(t) {\n        var e = [ t, this.ur() ];\n        if (this.buffer.size < this.cr) this.buffer = this.buffer.add(e); else {\n            var n = this.buffer.last();\n            Pi(e, n) < 0 && (this.buffer = this.buffer.delete(n).add(e));\n        }\n    }, Object.defineProperty(t.prototype, \"maxValue\", {\n        get: function() {\n            // Guaranteed to be non-empty. If we decide we are not collecting any\n            // sequence numbers, nthSequenceNumber below short-circuits. If we have\n            // decided that we are collecting n sequence numbers, it's because n is some\n            // percentage of the existing sequence numbers. That means we should never\n            // be in a situation where we are collecting sequence numbers but don't\n            // actually have any.\n            return this.buffer.last()[0];\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t;\n}(), Ci = /** @class */ function() {\n    function t(t, e) {\n        this.lr = t, this._s = e, this._r = !1, this.dr = null;\n    }\n    return t.prototype.start = function(t) {\n        -1 !== this.lr.params.zs && this.wr(t);\n    }, t.prototype.stop = function() {\n        this.dr && (this.dr.cancel(), this.dr = null);\n    }, Object.defineProperty(t.prototype, \"Er\", {\n        get: function() {\n            return null !== this.dr;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.wr = function(t) {\n        var e = this, n = this._r ? 3e5 : 6e4;\n        N(\"LruGarbageCollector\", \"Garbage collection scheduled in \" + n + \"ms\"), this.dr = this._s.Tr(\"lru_garbage_collection\" /* LruGarbageCollection */ , n, (function() {\n            return g(e, void 0, void 0, (function() {\n                var e;\n                return w(this, (function(n) {\n                    switch (n.label) {\n                      case 0:\n                        this.dr = null, this._r = !0, n.label = 1;\n\n                      case 1:\n                        return n.trys.push([ 1, 3, , 7 ]), [ 4 /*yield*/ , t.Ir(this.lr) ];\n\n                      case 2:\n                        return n.sent(), [ 3 /*break*/ , 7 ];\n\n                      case 3:\n                        return mr(e = n.sent()) ? (N(\"LruGarbageCollector\", \"Ignoring IndexedDB error during garbage collection: \", e), \n                        [ 3 /*break*/ , 6 ]) : [ 3 /*break*/ , 4 ];\n\n                      case 4:\n                        return [ 4 /*yield*/ , mi(e) ];\n\n                      case 5:\n                        n.sent(), n.label = 6;\n\n                      case 6:\n                        return [ 3 /*break*/ , 7 ];\n\n                      case 7:\n                        return [ 4 /*yield*/ , this.wr(t) ];\n\n                      case 8:\n                        return n.sent(), [ 2 /*return*/ ];\n                    }\n                }));\n            }));\n        }));\n    }, t;\n}(), Li = /** @class */ function() {\n    function t(t, e) {\n        this.mr = t, this.params = e;\n    }\n    return t.prototype.Ar = function(t, e) {\n        return this.mr.Rr(t).next((function(t) {\n            return Math.floor(e / 100 * t);\n        }));\n    }, t.prototype.Pr = function(t, e) {\n        var n = this;\n        if (0 === e) return lr.resolve(H.q);\n        var r = new Vi(e);\n        return this.mr.In(t, (function(t) {\n            return r.hr(t.sequenceNumber);\n        })).next((function() {\n            return n.mr.yr(t, (function(t) {\n                return r.hr(t);\n            }));\n        })).next((function() {\n            return r.maxValue;\n        }));\n    }, t.prototype.Xi = function(t, e, n) {\n        return this.mr.Xi(t, e, n);\n    }, t.prototype.gr = function(t, e) {\n        return this.mr.gr(t, e);\n    }, t.prototype.Vr = function(t, e) {\n        var n = this;\n        return -1 === this.params.zs ? (N(\"LruGarbageCollector\", \"Garbage collection skipped; disabled\"), \n        lr.resolve(vi)) : this.pr(t).next((function(r) {\n            return r < n.params.zs ? (N(\"LruGarbageCollector\", \"Garbage collection skipped; Cache size \" + r + \" is lower than threshold \" + n.params.zs), \n            vi) : n.br(t, e);\n        }));\n    }, t.prototype.pr = function(t) {\n        return this.mr.pr(t);\n    }, t.prototype.br = function(t, n) {\n        var r, i, o, u, s, a, c, h = this, f = Date.now();\n        return this.Ar(t, this.params.Hs).next((function(e) {\n            // Cap at the configured max\n            return e > h.params.Js ? (N(\"LruGarbageCollector\", \"Capping sequence numbers to collect down to the maximum of \" + h.params.Js + \" from \" + e), \n            i = h.params.Js) : i = e, u = Date.now(), h.Pr(t, i);\n        })).next((function(e) {\n            return r = e, s = Date.now(), h.Xi(t, r, n);\n        })).next((function(e) {\n            return o = e, a = Date.now(), h.gr(t, r);\n        })).next((function(t) {\n            return c = Date.now(), T() <= e.DEBUG && N(\"LruGarbageCollector\", \"LRU Garbage Collection\\n\\tCounted targets in \" + (u - f) + \"ms\\n\\tDetermined least recently used \" + i + \" in \" + (s - u) + \"ms\\n\\tRemoved \" + o + \" targets in \" + (a - s) + \"ms\\n\\tRemoved \" + t + \" documents in \" + (c - a) + \"ms\\nTotal Duration: \" + (c - f) + \"ms\"), \n            lr.resolve({\n                Ks: !0,\n                Ws: i,\n                js: o,\n                Gs: t\n            });\n        }));\n    }, t;\n}(), Ri = /** @class */ function() {\n    function t(t, e) {\n        this.db = t, this.lr = function(t, e) {\n            return new Li(t, e);\n        }(this, e);\n    }\n    return t.prototype.Rr = function(t) {\n        var e = this.vr(t);\n        return this.db.Sr().Zi(t).next((function(t) {\n            return e.next((function(e) {\n                return t + e;\n            }));\n        }));\n    }, t.prototype.vr = function(t) {\n        var e = 0;\n        return this.yr(t, (function(t) {\n            e++;\n        })).next((function() {\n            return e;\n        }));\n    }, t.prototype.In = function(t, e) {\n        return this.db.Sr().In(t, e);\n    }, t.prototype.yr = function(t, e) {\n        return this.Dr(t, (function(t, n) {\n            return e(n);\n        }));\n    }, t.prototype.nr = function(t, e, n) {\n        return Ui(t, n);\n    }, t.prototype.ir = function(t, e, n) {\n        return Ui(t, n);\n    }, t.prototype.Xi = function(t, e, n) {\n        return this.db.Sr().Xi(t, e, n);\n    }, t.prototype.Ni = function(t, e) {\n        return Ui(t, e);\n    }, \n    /**\n     * Returns true if anything would prevent this document from being garbage\n     * collected, given that the document in question is not present in any\n     * targets and has a sequence number less than or equal to the upper bound for\n     * the collection run.\n     */\n    t.prototype.Cr = function(t, e) {\n        return function(t, e) {\n            var n = !1;\n            return Ai(t).ls((function(r) {\n                return Ei(t, r, e).next((function(t) {\n                    return t && (n = !0), lr.resolve(!t);\n                }));\n            })).next((function() {\n                return n;\n            }));\n        }(t, e);\n    }, t.prototype.gr = function(t, e) {\n        var n = this, r = this.db.$r().Nr(), i = [], o = 0;\n        return this.Dr(t, (function(u, s) {\n            if (s <= e) {\n                var a = n.Cr(t, u).next((function(e) {\n                    if (!e) \n                    // Our size accounting requires us to read all documents before\n                    // removing them.\n                    return o++, r._i(t, u).next((function() {\n                        return r.li(u), Oi(t).delete([ 0, Ar(u.path) ]);\n                    }));\n                }));\n                i.push(a);\n            }\n        })).next((function() {\n            return lr.Mn(i);\n        })).next((function() {\n            return r.apply(t);\n        })).next((function() {\n            return o;\n        }));\n    }, t.prototype.removeTarget = function(t, e) {\n        var n = e.kt(t.bs);\n        return this.db.Sr().Hi(t, n);\n    }, t.prototype.Fr = function(t, e) {\n        return Ui(t, e);\n    }, \n    /**\n     * Call provided function for each document in the cache that is 'orphaned'. Orphaned\n     * means not a part of any target, so the only entry in the target-document index for\n     * that document will be the sentinel row (targetId 0), which will also have the sequence\n     * number for the last time the document was accessed.\n     */\n    t.prototype.Dr = function(t, e) {\n        var n, r = Oi(t), i = H.q;\n        return r.hs({\n            index: Fr.documentTargetsIndex\n        }, (function(t, r) {\n            var o = t[0], u = (t[1], r.path), s = r.sequenceNumber;\n            0 === o ? (\n            // if nextToReport is valid, report it, this is a new key so the\n            // last one must not be a member of any targets.\n            i !== H.q && e(new tt(xr(n)), i), \n            // set nextToReport to be this sequence number. It's the next one we\n            // might report, if we don't find any targets for this document.\n            // Note that the sequence number must be defined when the targetId\n            // is 0.\n            i = s, n = u) : \n            // set nextToReport to be invalid, we know we don't need to report\n            // this one since we found a target for it.\n            i = H.q;\n        })).next((function() {\n            // Since we report sequence numbers after getting to the next key, we\n            // need to check if the last key we iterated over was an orphaned\n            // document and report it.\n            i !== H.q && e(new tt(xr(n)), i);\n        }));\n    }, t.prototype.pr = function(t) {\n        return this.db.$r().Or(t);\n    }, t;\n}();\n\n/**\n * This class is responsible for the scheduling of LRU garbage collection. It handles checking\n * whether or not GC is enabled, as well as which delay to use before the next run.\n */ function Ui(t, e) {\n    return Oi(t).put(\n    /**\n * @returns A value suitable for writing a sentinel row in the target-document\n * store.\n */\n    function(t, e) {\n        return new Fr(0, Ar(t.path), e);\n    }(e, t.bs));\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * The RemoteDocumentCache for IndexedDb. To construct, invoke\n * `newIndexedDbRemoteDocumentCache()`.\n */ var Mi = /** @class */ function() {\n    /**\n     * @param serializer - The document serializer.\n     * @param indexManager - The query indexes that need to be maintained.\n     */\n    function t(t, e) {\n        this.Qt = t, this.Ei = e\n        /**\n     * Adds the supplied entries to the cache.\n     *\n     * All calls of `addEntry` are required to go through the RemoteDocumentChangeBuffer\n     * returned by `newChangeBuffer()` to ensure proper accounting of metadata.\n     */;\n    }\n    return t.prototype.ai = function(t, e, n) {\n        return ji(t).put(zi(e), n);\n    }, \n    /**\n     * Removes a document from the cache.\n     *\n     * All calls of `removeEntry`  are required to go through the RemoteDocumentChangeBuffer\n     * returned by `newChangeBuffer()` to ensure proper accounting of metadata.\n     */\n    t.prototype.li = function(t, e) {\n        var n = ji(t), r = zi(e);\n        return n.delete(r);\n    }, \n    /**\n     * Updates the current cache size.\n     *\n     * Callers to `addEntry()` and `removeEntry()` *must* call this afterwards to update the\n     * cache's metadata.\n     */\n    t.prototype.updateMetadata = function(t, e) {\n        var n = this;\n        return this.getMetadata(t).next((function(r) {\n            return r.byteSize += e, n.kr(t, r);\n        }));\n    }, t.prototype._i = function(t, e) {\n        var n = this;\n        return ji(t).get(zi(e)).next((function(t) {\n            return n.Mr(t);\n        }));\n    }, \n    /**\n     * Looks up an entry in the cache.\n     *\n     * @param documentKey - The key of the entry to look up.\n     * @returns The cached MaybeDocument entry and its size, or null if we have\n     * nothing cached.\n     */\n    t.prototype.Lr = function(t, e) {\n        var n = this;\n        return ji(t).get(zi(e)).next((function(t) {\n            var e = n.Mr(t);\n            return e ? {\n                hi: e,\n                size: _i(t)\n            } : null;\n        }));\n    }, t.prototype.getEntries = function(t, e) {\n        var n = this, r = fn();\n        return this.Br(t, e, (function(t, e) {\n            var i = n.Mr(e);\n            r = r.zt(t, i);\n        })).next((function() {\n            return r;\n        }));\n    }, \n    /**\n     * Looks up several entries in the cache.\n     *\n     * @param documentKeys - The set of keys entries to look up.\n     * @returns A map of MaybeDocuments indexed by key (if a document cannot be\n     *     found, the key will be mapped to null) and a map of sizes indexed by\n     *     key (zero if the key cannot be found).\n     */\n    t.prototype.qr = function(t, e) {\n        var n = this, r = fn(), i = new rn(tt.H);\n        return this.Br(t, e, (function(t, e) {\n            var o = n.Mr(e);\n            o ? (r = r.zt(t, o), i = i.zt(t, _i(e))) : (r = r.zt(t, null), i = i.zt(t, 0));\n        })).next((function() {\n            return {\n                Ur: r,\n                Qr: i\n            };\n        }));\n    }, t.prototype.Br = function(t, e, n) {\n        if (e.et()) return lr.resolve();\n        var r = IDBKeyRange.bound(e.first().path.it(), e.last().path.it()), i = e.te(), o = i.oe();\n        return ji(t).hs({\n            range: r\n        }, (function(t, e, r) {\n            // Go through keys not found in cache.\n            for (var u = tt.Et(t); o && tt.H(o, u) < 0; ) n(o, null), o = i.oe();\n            o && o.isEqual(u) && (\n            // Key found in cache.\n            n(o, e), o = i.ce() ? i.oe() : null), \n            // Skip to the next key (if there is one).\n            o ? r.ss(o.path.it()) : r.done();\n        })).next((function() {\n            // The rest of the keys are not in the cache. One case where `iterate`\n            // above won't go through them is when the cache is empty.\n            for (;o; ) n(o, null), o = i.ce() ? i.oe() : null;\n        }));\n    }, t.prototype.Kr = function(t, e, n) {\n        var r = this, i = pn(), o = e.path.length + 1, u = {};\n        if (n.isEqual(X.min())) {\n            // Documents are ordered by key, so we can use a prefix scan to narrow\n            // down the documents we need to match the query against.\n            var s = e.path.it();\n            u.range = IDBKeyRange.lowerBound(s);\n        } else {\n            // Execute an index-free query and filter by read time. This is safe\n            // since all document changes to queries that have a\n            // lastLimboFreeSnapshotVersion (`sinceReadTime`) have a read time set.\n            var a = e.path.it(), c = ti(n);\n            u.range = IDBKeyRange.lowerBound([ a, c ], \n            /* open= */ !0), u.index = Ur.collectionReadTimeIndex;\n        }\n        return ji(t).hs(u, (function(t, n, u) {\n            // The query is actually returning any path that starts with the query\n            // path prefix which may include documents in subcollections. For\n            // example, a query on 'rooms' will return rooms/abc/messages/xyx but we\n            // shouldn't match it. Fix this by discarding rows with document keys\n            // more than one segment longer than the query path.\n            if (t.length === o) {\n                var s = Jr(r.Qt, n);\n                e.path.nt(s.key.path) ? s instanceof Pt && ve(e, s) && (i = i.zt(s.key, s)) : u.done();\n            }\n        })).next((function() {\n            return i;\n        }));\n    }, t.prototype.Nr = function(t) {\n        return new qi(this, !!t && t.Wr);\n    }, t.prototype.Or = function(t) {\n        return this.getMetadata(t).next((function(t) {\n            return t.byteSize;\n        }));\n    }, t.prototype.getMetadata = function(t) {\n        return Fi(t).get(Mr.key).next((function(t) {\n            return k(!!t), t;\n        }));\n    }, t.prototype.kr = function(t, e) {\n        return Fi(t).put(Mr.key, e);\n    }, \n    /**\n     * Decodes `remoteDoc` and returns the document (or null, if the document\n     * corresponds to the format used for sentinel deletes).\n     */\n    t.prototype.Mr = function(t) {\n        if (t) {\n            var e = Jr(this.Qt, t);\n            return e instanceof Vt && e.version.isEqual(X.min()) ? null : e;\n        }\n        return null;\n    }, t;\n}(), qi = /** @class */ function(t) {\n    /**\n     * @param documentCache - The IndexedDbRemoteDocumentCache to apply the changes to.\n     * @param trackRemovals - Whether to create sentinel deletes that can be tracked by\n     * `getNewDocumentChanges()`.\n     */\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this) || this).jr = e, r.Wr = n, \n        // A map of document sizes prior to applying the changes in this buffer.\n        r.Gr = new gi((function(t) {\n            return t.toString();\n        }), (function(t, e) {\n            return t.isEqual(e);\n        })), r;\n    }\n    return m(e, t), e.prototype.wi = function(t) {\n        var e = this, n = [], r = 0, i = new sn((function(t, e) {\n            return C(t.rt(), e.rt());\n        }));\n        return this.ri.forEach((function(o, u) {\n            var s = e.Gr.get(o);\n            if (u.hi) {\n                var a = $r(e.jr.Qt, u.hi, e.ci(o));\n                i = i.add(o.path.X());\n                var c = _i(a);\n                r += c - s, n.push(e.jr.ai(t, o, a));\n            } else if (r -= s, e.Wr) {\n                // In order to track removals, we store a \"sentinel delete\" in the\n                // RemoteDocumentCache. This entry is represented by a NoDocument\n                // with a version of 0 and ignored by `maybeDecodeDocument()` but\n                // preserved in `getNewDocumentChanges()`.\n                var h = $r(e.jr.Qt, new Vt(o, X.min()), e.ci(o));\n                n.push(e.jr.ai(t, o, h));\n            } else n.push(e.jr.li(t, o));\n        })), i.forEach((function(r) {\n            n.push(e.jr.Ei.qs(t, r));\n        })), n.push(this.jr.updateMetadata(t, r)), lr.Mn(n);\n    }, e.prototype.fi = function(t, e) {\n        var n = this;\n        // Record the size of everything we load from the cache so we can compute a delta later.\n                return this.jr.Lr(t, e).next((function(t) {\n            return null === t ? (n.Gr.set(e, 0), null) : (n.Gr.set(e, t.size), t.hi);\n        }));\n    }, e.prototype.di = function(t, e) {\n        var n = this;\n        // Record the size of everything we load from the cache so we can compute\n        // a delta later.\n                return this.jr.qr(t, e).next((function(t) {\n            var e = t.Ur;\n            // Note: `getAllFromCache` returns two maps instead of a single map from\n            // keys to `DocumentSizeEntry`s. This is to allow returning the\n            // `NullableMaybeDocumentMap` directly, without a conversion.\n            return t.Qr.forEach((function(t, e) {\n                n.Gr.set(t, e);\n            })), e;\n        }));\n    }, e;\n}(wi);\n\n/**\n * Creates a new IndexedDbRemoteDocumentCache.\n *\n * @param serializer - The document serializer.\n * @param indexManager - The query indexes that need to be maintained.\n */\n/**\n * Handles the details of adding and updating documents in the IndexedDbRemoteDocumentCache.\n *\n * Unlike the MemoryRemoteDocumentChangeBuffer, the IndexedDb implementation computes the size\n * delta for all submitted changes. This avoids having to re-read all documents from IndexedDb\n * when we apply the changes.\n */ function Fi(t) {\n    return Kr(t, Mr.store);\n}\n\n/**\n * Helper to get a typed SimpleDbStore for the remoteDocuments object store.\n */ function ji(t) {\n    return Kr(t, Ur.store);\n}\n\nfunction zi(t) {\n    return t.path.it();\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/** Performs database creation and schema upgrades. */ var Gi = /** @class */ function() {\n    function t(t) {\n        this.Qt = t;\n    }\n    /**\n     * Performs database creation and schema upgrades.\n     *\n     * Note that in production, this method is only ever used to upgrade the schema\n     * to SCHEMA_VERSION. Different values of toVersion are only used for testing\n     * and local feature development.\n     */    return t.prototype.Jn = function(t, e, n, r) {\n        var i = this;\n        k(n < r && n >= 0 && r <= 11);\n        var o = new pr(\"createOrUpgrade\", e);\n        n < 1 && r >= 1 && (function(t) {\n            t.createObjectStore(Or.store);\n        }(t), function(t) {\n            t.createObjectStore(Pr.store, {\n                keyPath: Pr.keyPath\n            }), t.createObjectStore(Vr.store, {\n                keyPath: Vr.keyPath,\n                autoIncrement: !0\n            }).createIndex(Vr.userMutationsIndex, Vr.userMutationsKeyPath, {\n                unique: !0\n            }), t.createObjectStore(Cr.store);\n        }(t), Bi(t), function(t) {\n            t.createObjectStore(Ur.store);\n        }(t));\n        // Migration 2 to populate the targetGlobal object no longer needed since\n        // migration 3 unconditionally clears it.\n        var u = lr.resolve();\n        return n < 3 && r >= 3 && (\n        // Brand new clients don't need to drop and recreate--only clients that\n        // potentially have corrupt data.\n        0 !== n && (function(t) {\n            t.deleteObjectStore(Fr.store), t.deleteObjectStore(qr.store), t.deleteObjectStore(jr.store);\n        }(t), Bi(t)), u = u.next((function() {\n            /**\n     * Creates the target global singleton row.\n     *\n     * @param txn - The version upgrade transaction for indexeddb\n     */\n            return function(t) {\n                var e = t.store(jr.store), n = new jr(\n                /*highestTargetId=*/ 0, \n                /*lastListenSequenceNumber=*/ 0, X.min().j(), \n                /*targetCount=*/ 0);\n                return e.put(jr.key, n);\n            }(o);\n        }))), n < 4 && r >= 4 && (0 !== n && (\n        // Schema version 3 uses auto-generated keys to generate globally unique\n        // mutation batch IDs (this was previously ensured internally by the\n        // client). To migrate to the new schema, we have to read all mutations\n        // and write them back out. We preserve the existing batch IDs to guarantee\n        // consistency with other object stores. Any further mutation batch IDs will\n        // be auto-generated.\n        u = u.next((function() {\n            return function(t, e) {\n                return e.store(Vr.store).rs().next((function(n) {\n                    t.deleteObjectStore(Vr.store), t.createObjectStore(Vr.store, {\n                        keyPath: Vr.keyPath,\n                        autoIncrement: !0\n                    }).createIndex(Vr.userMutationsIndex, Vr.userMutationsKeyPath, {\n                        unique: !0\n                    });\n                    var r = e.store(Vr.store), i = n.map((function(t) {\n                        return r.put(t);\n                    }));\n                    return lr.Mn(i);\n                }));\n            }(t, o);\n        }))), u = u.next((function() {\n            !function(t) {\n                t.createObjectStore(Gr.store, {\n                    keyPath: Gr.keyPath\n                });\n            }(t);\n        }))), n < 5 && r >= 5 && (u = u.next((function() {\n            return i.zr(o);\n        }))), n < 6 && r >= 6 && (u = u.next((function() {\n            return function(t) {\n                t.createObjectStore(Mr.store);\n            }(t), i.Hr(o);\n        }))), n < 7 && r >= 7 && (u = u.next((function() {\n            return i.Jr(o);\n        }))), n < 8 && r >= 8 && (u = u.next((function() {\n            return i.Yr(t, o);\n        }))), n < 9 && r >= 9 && (u = u.next((function() {\n            // Multi-Tab used to manage its own changelog, but this has been moved\n            // to the DbRemoteDocument object store itself. Since the previous change\n            // log only contained transient data, we can drop its object store.\n            !function(t) {\n                t.objectStoreNames.contains(\"remoteDocumentChanges\") && t.deleteObjectStore(\"remoteDocumentChanges\");\n            }(t), function(t) {\n                var e = t.objectStore(Ur.store);\n                e.createIndex(Ur.readTimeIndex, Ur.readTimeIndexPath, {\n                    unique: !1\n                }), e.createIndex(Ur.collectionReadTimeIndex, Ur.collectionReadTimeIndexPath, {\n                    unique: !1\n                });\n            }(e);\n        }))), n < 10 && r >= 10 && (u = u.next((function() {\n            return i.Xr(o);\n        }))), n < 11 && r >= 11 && (u = u.next((function() {\n            !function(t) {\n                t.createObjectStore(Br.store, {\n                    keyPath: Br.keyPath\n                });\n            }(t), function(t) {\n                t.createObjectStore(Qr.store, {\n                    keyPath: Qr.keyPath\n                });\n            }(t);\n        }))), u;\n    }, t.prototype.Hr = function(t) {\n        var e = 0;\n        return t.store(Ur.store).hs((function(t, n) {\n            e += _i(n);\n        })).next((function() {\n            var n = new Mr(e);\n            return t.store(Mr.store).put(Mr.key, n);\n        }));\n    }, t.prototype.zr = function(t) {\n        var e = this, n = t.store(Pr.store), r = t.store(Vr.store);\n        return n.rs().next((function(n) {\n            return lr.forEach(n, (function(n) {\n                var i = IDBKeyRange.bound([ n.userId, -1 ], [ n.userId, n.lastAcknowledgedBatchId ]);\n                return r.rs(Vr.userMutationsIndex, i).next((function(r) {\n                    return lr.forEach(r, (function(r) {\n                        k(r.userId === n.userId);\n                        var i = ii(e.Qt, r);\n                        return bi(t, n.userId, i).next((function() {}));\n                    }));\n                }));\n            }));\n        }));\n    }, \n    /**\n     * Ensures that every document in the remote document cache has a corresponding sentinel row\n     * with a sequence number. Missing rows are given the most recently used sequence number.\n     */\n    t.prototype.Jr = function(t) {\n        var e = t.store(Fr.store), n = t.store(Ur.store);\n        return t.store(jr.store).get(jr.key).next((function(t) {\n            var r = [];\n            return n.hs((function(n, i) {\n                var o = new Z(n), u = function(t) {\n                    return [ 0, Ar(t) ];\n                }(o);\n                r.push(e.get(u).next((function(n) {\n                    return n ? lr.resolve() : function(n) {\n                        return e.put(new Fr(0, Ar(n), t.highestListenSequenceNumber));\n                    }(o);\n                })));\n            })).next((function() {\n                return lr.Mn(r);\n            }));\n        }));\n    }, t.prototype.Yr = function(t, e) {\n        // Create the index.\n        t.createObjectStore(zr.store, {\n            keyPath: zr.keyPath\n        });\n        var n = e.store(zr.store), r = new li, i = function(t) {\n            if (r.add(t)) {\n                var e = t.tt(), i = t.X();\n                return n.put({\n                    collectionId: e,\n                    parent: Ar(i)\n                });\n            }\n        };\n        // Helper to add an index entry iff we haven't already written it.\n        // Index existing remote documents.\n                return e.store(Ur.store).hs({\n            us: !0\n        }, (function(t, e) {\n            var n = new Z(t);\n            return i(n.X());\n        })).next((function() {\n            return e.store(Cr.store).hs({\n                us: !0\n            }, (function(t, e) {\n                t[0];\n                var n = t[1], r = (t[2], xr(n));\n                return i(r.X());\n            }));\n        }));\n    }, t.prototype.Xr = function(t) {\n        var e = this, n = t.store(qr.store);\n        return n.hs((function(t, r) {\n            var i = oi(r), o = ui(e.Qt, i);\n            return n.put(o);\n        }));\n    }, t;\n}();\n\nfunction Bi(t) {\n    t.createObjectStore(Fr.store, {\n        keyPath: Fr.keyPath\n    }).createIndex(Fr.documentTargetsIndex, Fr.documentTargetsKeyPath, {\n        unique: !0\n    }), \n    // NOTE: This is unique only because the TargetId is the suffix.\n    t.createObjectStore(qr.store, {\n        keyPath: qr.keyPath\n    }).createIndex(qr.queryTargetsIndexName, qr.queryTargetsKeyPath, {\n        unique: !0\n    }), t.createObjectStore(jr.store);\n}\n\nvar Qi = \"Failed to obtain exclusive access to the persistence layer. To allow shared access, multi-tab synchronization has to be enabled in all tabs. If you are using `experimentalForceOwningTab:true`, make sure that only one tab has persistence enabled at any given time.\", Yi = /** @class */ function() {\n    function t(\n    /**\n     * Whether to synchronize the in-memory state of multiple tabs and share\n     * access to local persistence.\n     */\n    e, n, r, i, o, u, s, a, c, \n    /**\n     * If set to true, forcefully obtains database access. Existing tabs will\n     * no longer be able to access IndexedDB.\n     */\n    h) {\n        if (this.allowTabSynchronization = e, this.persistenceKey = n, this.clientId = r, \n        this.Zr = o, this.window = u, this.document = s, this.eo = c, this.no = h, this.so = null, \n        this.io = !1, this.isPrimary = !1, this.networkEnabled = !0, \n        /** Our window.unload handler, if registered. */\n        this.ro = null, this.inForeground = !1, \n        /** Our 'visibilitychange' listener if registered. */\n        this.oo = null, \n        /** The client metadata refresh task. */\n        this.co = null, \n        /** The last time we garbage collected the client metadata object store. */\n        this.ao = Number.NEGATIVE_INFINITY, \n        /** A listener to notify on primary state changes. */\n        this.uo = function(t) {\n            return Promise.resolve();\n        }, !t.Kn()) throw new q(M.UNIMPLEMENTED, \"This platform is either missing IndexedDB or is known to have an incomplete implementation. Offline persistence has been disabled.\");\n        this.Ti = new Ri(this, i), this.ho = n + \"main\", this.Qt = new Zr(a), this.lo = new dr(this.ho, 11, new Gi(this.Qt)), \n        this._o = new Si(this.Ti, this.Qt), this.Ei = new pi, this.fo = function(t, e) {\n            return new Mi(t, e);\n        }(this.Qt, this.Ei), this.wo = new ai, this.window && this.window.localStorage ? this.Eo = this.window.localStorage : (this.Eo = null, \n        !1 === h && A(\"IndexedDbPersistence\", \"LocalStorage is unavailable. As a result, persistence may not work reliably. In particular enablePersistence() could fail immediately after refreshing the page.\"));\n    }\n    /**\n     * Attempt to start IndexedDb persistence.\n     *\n     * @returns Whether persistence was enabled.\n     */    return t.prototype.start = function() {\n        var t = this;\n        // NOTE: This is expected to fail sometimes (in the case of another tab\n        // already having the persistence lock), so it's the first thing we should\n        // do.\n                return this.To().then((function() {\n            if (!t.isPrimary && !t.allowTabSynchronization) \n            // Fail `start()` if `synchronizeTabs` is disabled and we cannot\n            // obtain the primary lease.\n            throw new q(M.FAILED_PRECONDITION, Qi);\n            return t.Io(), t.mo(), t.Ao(), t.runTransaction(\"getHighestListenSequenceNumber\", \"readonly\", (function(e) {\n                return t._o.Ki(e);\n            }));\n        })).then((function(e) {\n            t.so = new H(e, t.eo);\n        })).then((function() {\n            t.io = !0;\n        })).catch((function(e) {\n            return t.lo && t.lo.close(), Promise.reject(e);\n        }));\n    }, \n    /**\n     * Registers a listener that gets called when the primary state of the\n     * instance changes. Upon registering, this listener is invoked immediately\n     * with the current primary state.\n     *\n     * PORTING NOTE: This is only used for Web multi-tab.\n     */\n    t.prototype.Ro = function(t) {\n        var e = this;\n        return this.uo = function(n) {\n            return g(e, void 0, void 0, (function() {\n                return w(this, (function(e) {\n                    return this.Er ? [ 2 /*return*/ , t(n) ] : [ 2 /*return*/ ];\n                }));\n            }));\n        }, t(this.isPrimary);\n    }, \n    /**\n     * Registers a listener that gets called when the database receives a\n     * version change event indicating that it has deleted.\n     *\n     * PORTING NOTE: This is only used for Web multi-tab.\n     */\n    t.prototype.Po = function(t) {\n        var e = this;\n        this.lo.Xn((function(n) {\n            return g(e, void 0, void 0, (function() {\n                return w(this, (function(e) {\n                    switch (e.label) {\n                      case 0:\n                        return null === n.newVersion ? [ 4 /*yield*/ , t() ] : [ 3 /*break*/ , 2 ];\n\n                      case 1:\n                        e.sent(), e.label = 2;\n\n                      case 2:\n                        return [ 2 /*return*/ ];\n                    }\n                }));\n            }));\n        }));\n    }, \n    /**\n     * Adjusts the current network state in the client's metadata, potentially\n     * affecting the primary lease.\n     *\n     * PORTING NOTE: This is only used for Web multi-tab.\n     */\n    t.prototype.yo = function(t) {\n        var e = this;\n        this.networkEnabled !== t && (this.networkEnabled = t, \n        // Schedule a primary lease refresh for immediate execution. The eventual\n        // lease update will be propagated via `primaryStateListener`.\n        this.Zr.Ps((function() {\n            return g(e, void 0, void 0, (function() {\n                return w(this, (function(t) {\n                    switch (t.label) {\n                      case 0:\n                        return this.Er ? [ 4 /*yield*/ , this.To() ] : [ 3 /*break*/ , 2 ];\n\n                      case 1:\n                        t.sent(), t.label = 2;\n\n                      case 2:\n                        return [ 2 /*return*/ ];\n                    }\n                }));\n            }));\n        })));\n    }, \n    /**\n     * Updates the client metadata in IndexedDb and attempts to either obtain or\n     * extend the primary lease for the local client. Asynchronously notifies the\n     * primary state listener if the client either newly obtained or released its\n     * primary lease.\n     */\n    t.prototype.To = function() {\n        var t = this;\n        return this.runTransaction(\"updateClientMetadataAndTryBecomePrimary\", \"readwrite\", (function(e) {\n            return Ki(e).put(new Gr(t.clientId, Date.now(), t.networkEnabled, t.inForeground)).next((function() {\n                if (t.isPrimary) return t.Vo(e).next((function(e) {\n                    e || (t.isPrimary = !1, t.Zr.po((function() {\n                        return t.uo(!1);\n                    })));\n                }));\n            })).next((function() {\n                return t.bo(e);\n            })).next((function(n) {\n                return t.isPrimary && !n ? t.vo(e).next((function() {\n                    return !1;\n                })) : !!n && t.So(e).next((function() {\n                    return !0;\n                }));\n            }));\n        })).catch((function(e) {\n            if (mr(e)) \n            // Proceed with the existing state. Any subsequent access to\n            // IndexedDB will verify the lease.\n            return N(\"IndexedDbPersistence\", \"Failed to extend owner lease: \", e), t.isPrimary;\n            if (!t.allowTabSynchronization) throw e;\n            return N(\"IndexedDbPersistence\", \"Releasing owner lease after error during lease refresh\", e), \n            /* isPrimary= */ !1;\n        })).then((function(e) {\n            t.isPrimary !== e && t.Zr.po((function() {\n                return t.uo(e);\n            })), t.isPrimary = e;\n        }));\n    }, t.prototype.Vo = function(t) {\n        var e = this;\n        return Hi(t).get(Or.key).next((function(t) {\n            return lr.resolve(e.Do(t));\n        }));\n    }, t.prototype.Co = function(t) {\n        return Ki(t).delete(this.clientId);\n    }, \n    /**\n     * If the garbage collection threshold has passed, prunes the\n     * RemoteDocumentChanges and the ClientMetadata store based on the last update\n     * time of all clients.\n     */\n    t.prototype.xo = function() {\n        return g(this, void 0, void 0, (function() {\n            var t, e, n, r, i = this;\n            return w(this, (function(o) {\n                switch (o.label) {\n                  case 0:\n                    return !this.isPrimary || this.No(this.ao, 18e5) ? [ 3 /*break*/ , 2 ] : (this.ao = Date.now(), \n                    [ 4 /*yield*/ , this.runTransaction(\"maybeGarbageCollectMultiClientState\", \"readwrite-primary\", (function(t) {\n                        var e = Kr(t, Gr.store);\n                        return e.rs().next((function(t) {\n                            var n = i.$o(t, 18e5), r = t.filter((function(t) {\n                                return -1 === n.indexOf(t);\n                            }));\n                            // Delete metadata for clients that are no longer considered active.\n                                                        return lr.forEach(r, (function(t) {\n                                return e.delete(t.clientId);\n                            })).next((function() {\n                                return r;\n                            }));\n                        }));\n                    })).catch((function() {\n                        return [];\n                    })) ]);\n\n                  case 1:\n                    // Delete potential leftover entries that may continue to mark the\n                    // inactive clients as zombied in LocalStorage.\n                    // Ideally we'd delete the IndexedDb and LocalStorage zombie entries for\n                    // the client atomically, but we can't. So we opt to delete the IndexedDb\n                    // entries first to avoid potentially reviving a zombied client.\n                    if (t = o.sent(), this.Eo) for (e = 0, n = t; e < n.length; e++) r = n[e], this.Eo.removeItem(this.Fo(r.clientId));\n                    o.label = 2;\n\n                  case 2:\n                    return [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, \n    /**\n     * Schedules a recurring timer to update the client metadata and to either\n     * extend or acquire the primary lease if the client is eligible.\n     */\n    t.prototype.Ao = function() {\n        var t = this;\n        this.co = this.Zr.Tr(\"client_metadata_refresh\" /* ClientMetadataRefresh */ , 4e3, (function() {\n            return t.To().then((function() {\n                return t.xo();\n            })).then((function() {\n                return t.Ao();\n            }));\n        }));\n    }, \n    /** Checks whether `client` is the local client. */ t.prototype.Do = function(t) {\n        return !!t && t.ownerId === this.clientId;\n    }, \n    /**\n     * Evaluate the state of all active clients and determine whether the local\n     * client is or can act as the holder of the primary lease. Returns whether\n     * the client is eligible for the lease, but does not actually acquire it.\n     * May return 'false' even if there is no active leaseholder and another\n     * (foreground) client should become leaseholder instead.\n     */\n    t.prototype.bo = function(t) {\n        var e = this;\n        return this.no ? lr.resolve(!0) : Hi(t).get(Or.key).next((function(n) {\n            // A client is eligible for the primary lease if:\n            // - its network is enabled and the client's tab is in the foreground.\n            // - its network is enabled and no other client's tab is in the\n            //   foreground.\n            // - every clients network is disabled and the client's tab is in the\n            //   foreground.\n            // - every clients network is disabled and no other client's tab is in\n            //   the foreground.\n            // - the `forceOwningTab` setting was passed in.\n            if (null !== n && e.No(n.leaseTimestampMs, 5e3) && !e.Oo(n.ownerId)) {\n                if (e.Do(n) && e.networkEnabled) return !0;\n                if (!e.Do(n)) {\n                    if (!n.allowTabSynchronization) \n                    // Fail the `canActAsPrimary` check if the current leaseholder has\n                    // not opted into multi-tab synchronization. If this happens at\n                    // client startup, we reject the Promise returned by\n                    // `enablePersistence()` and the user can continue to use Firestore\n                    // with in-memory persistence.\n                    // If this fails during a lease refresh, we will instead block the\n                    // AsyncQueue from executing further operations. Note that this is\n                    // acceptable since mixing & matching different `synchronizeTabs`\n                    // settings is not supported.\n                    // TODO(b/114226234): Remove this check when `synchronizeTabs` can\n                    // no longer be turned off.\n                    throw new q(M.FAILED_PRECONDITION, Qi);\n                    return !1;\n                }\n            }\n            return !(!e.networkEnabled || !e.inForeground) || Ki(t).rs().next((function(t) {\n                return void 0 === e.$o(t, 5e3).find((function(t) {\n                    if (e.clientId !== t.clientId) {\n                        var n = !e.networkEnabled && t.networkEnabled, r = !e.inForeground && t.inForeground, i = e.networkEnabled === t.networkEnabled;\n                        if (n || r && i) return !0;\n                    }\n                    return !1;\n                }));\n            }));\n        })).next((function(t) {\n            return e.isPrimary !== t && N(\"IndexedDbPersistence\", \"Client \" + (t ? \"is\" : \"is not\") + \" eligible for a primary lease.\"), \n            t;\n        }));\n    }, t.prototype.ko = function() {\n        return g(this, void 0, void 0, (function() {\n            var t = this;\n            return w(this, (function(e) {\n                switch (e.label) {\n                  case 0:\n                    // Use `SimpleDb.runTransaction` directly to avoid failing if another tab\n                    // has obtained the primary lease.\n                    // The shutdown() operations are idempotent and can be called even when\n                    // start() aborted (e.g. because it couldn't acquire the persistence lease).\n                    return this.io = !1, this.Mo(), this.co && (this.co.cancel(), this.co = null), this.Lo(), \n                    this.Bo(), [ 4 /*yield*/ , this.lo.runTransaction(\"shutdown\", \"readwrite\", [ Or.store, Gr.store ], (function(e) {\n                        var n = new Hr(e, H.q);\n                        return t.vo(n).next((function() {\n                            return t.Co(n);\n                        }));\n                    })) ];\n\n                  case 1:\n                    // The shutdown() operations are idempotent and can be called even when\n                    // start() aborted (e.g. because it couldn't acquire the persistence lease).\n                    // Use `SimpleDb.runTransaction` directly to avoid failing if another tab\n                    // has obtained the primary lease.\n                    return e.sent(), this.lo.close(), \n                    // Remove the entry marking the client as zombied from LocalStorage since\n                    // we successfully deleted its metadata from IndexedDb.\n                    this.qo(), [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, \n    /**\n     * Returns clients that are not zombied and have an updateTime within the\n     * provided threshold.\n     */\n    t.prototype.$o = function(t, e) {\n        var n = this;\n        return t.filter((function(t) {\n            return n.No(t.updateTimeMs, e) && !n.Oo(t.clientId);\n        }));\n    }, \n    /**\n     * Returns the IDs of the clients that are currently active. If multi-tab\n     * is not supported, returns an array that only contains the local client's\n     * ID.\n     *\n     * PORTING NOTE: This is only used for Web multi-tab.\n     */\n    t.prototype.Uo = function() {\n        var t = this;\n        return this.runTransaction(\"getActiveClients\", \"readonly\", (function(e) {\n            return Ki(e).rs().next((function(e) {\n                return t.$o(e, 18e5).map((function(t) {\n                    return t.clientId;\n                }));\n            }));\n        }));\n    }, Object.defineProperty(t.prototype, \"Er\", {\n        get: function() {\n            return this.io;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.Qo = function(t) {\n        return Ii.mi(t, this.Qt, this.Ei, this.Ti);\n    }, t.prototype.Sr = function() {\n        return this._o;\n    }, t.prototype.$r = function() {\n        return this.fo;\n    }, t.prototype.Ko = function() {\n        return this.Ei;\n    }, t.prototype.Wo = function() {\n        return this.wo;\n    }, t.prototype.runTransaction = function(t, e, n) {\n        var r = this;\n        N(\"IndexedDbPersistence\", \"Starting transaction:\", t);\n        var i, o = \"readonly\" === e ? \"readonly\" : \"readwrite\";\n        // Do all transactions as readwrite against all object stores, since we\n        // are the only reader/writer.\n        return this.lo.runTransaction(t, o, Yr, (function(o) {\n            return i = new Hr(o, r.so ? r.so.next() : H.q), \"readwrite-primary\" === e ? r.Vo(i).next((function(t) {\n                return !!t || r.bo(i);\n            })).next((function(e) {\n                if (!e) throw A(\"Failed to obtain primary lease for action '\" + t + \"'.\"), r.isPrimary = !1, \n                r.Zr.po((function() {\n                    return r.uo(!1);\n                })), new q(M.FAILED_PRECONDITION, Tr);\n                return n(i);\n            })).next((function(t) {\n                return r.So(i).next((function() {\n                    return t;\n                }));\n            })) : r.jo(i).next((function() {\n                return n(i);\n            }));\n        })).then((function(t) {\n            return i.Vs(), t;\n        }));\n    }, \n    /**\n     * Verifies that the current tab is the primary leaseholder or alternatively\n     * that the leaseholder has opted into multi-tab synchronization.\n     */\n    // TODO(b/114226234): Remove this check when `synchronizeTabs` can no longer\n    // be turned off.\n    t.prototype.jo = function(t) {\n        var e = this;\n        return Hi(t).get(Or.key).next((function(t) {\n            if (null !== t && e.No(t.leaseTimestampMs, 5e3) && !e.Oo(t.ownerId) && !e.Do(t) && !(e.no || e.allowTabSynchronization && t.allowTabSynchronization)) throw new q(M.FAILED_PRECONDITION, Qi);\n        }));\n    }, \n    /**\n     * Obtains or extends the new primary lease for the local client. This\n     * method does not verify that the client is eligible for this lease.\n     */\n    t.prototype.So = function(t) {\n        var e = new Or(this.clientId, this.allowTabSynchronization, Date.now());\n        return Hi(t).put(Or.key, e);\n    }, t.Kn = function() {\n        return dr.Kn();\n    }, \n    /** Checks the primary lease and removes it if we are the current primary. */ t.prototype.vo = function(t) {\n        var e = this, n = Hi(t);\n        return n.get(Or.key).next((function(t) {\n            return e.Do(t) ? (N(\"IndexedDbPersistence\", \"Releasing primary lease.\"), n.delete(Or.key)) : lr.resolve();\n        }));\n    }, \n    /** Verifies that `updateTimeMs` is within `maxAgeMs`. */ t.prototype.No = function(t, e) {\n        var n = Date.now();\n        return !(t < n - e || t > n && (A(\"Detected an update time that is in the future: \" + t + \" > \" + n), \n        1));\n    }, t.prototype.Io = function() {\n        var t = this;\n        null !== this.document && \"function\" == typeof this.document.addEventListener && (this.oo = function() {\n            t.Zr.Ps((function() {\n                return t.inForeground = \"visible\" === t.document.visibilityState, t.To();\n            }));\n        }, this.document.addEventListener(\"visibilitychange\", this.oo), this.inForeground = \"visible\" === this.document.visibilityState);\n    }, t.prototype.Lo = function() {\n        this.oo && (this.document.removeEventListener(\"visibilitychange\", this.oo), this.oo = null);\n    }, \n    /**\n     * Attaches a window.unload handler that will synchronously write our\n     * clientId to a \"zombie client id\" location in LocalStorage. This can be used\n     * by tabs trying to acquire the primary lease to determine that the lease\n     * is no longer valid even if the timestamp is recent. This is particularly\n     * important for the refresh case (so the tab correctly re-acquires the\n     * primary lease). LocalStorage is used for this rather than IndexedDb because\n     * it is a synchronous API and so can be used reliably from  an unload\n     * handler.\n     */\n    t.prototype.mo = function() {\n        var t, e = this;\n        \"function\" == typeof (null === (t = this.window) || void 0 === t ? void 0 : t.addEventListener) && (this.ro = function() {\n            // Note: In theory, this should be scheduled on the AsyncQueue since it\n            // accesses internal state. We execute this code directly during shutdown\n            // to make sure it gets a chance to run.\n            e.Mo(), e.Zr.Ps((function() {\n                return e.ko();\n            }));\n        }, this.window.addEventListener(\"unload\", this.ro));\n    }, t.prototype.Bo = function() {\n        this.ro && (this.window.removeEventListener(\"unload\", this.ro), this.ro = null);\n    }, \n    /**\n     * Returns whether a client is \"zombied\" based on its LocalStorage entry.\n     * Clients become zombied when their tab closes without running all of the\n     * cleanup logic in `shutdown()`.\n     */\n    t.prototype.Oo = function(t) {\n        var e;\n        try {\n            var n = null !== (null === (e = this.Eo) || void 0 === e ? void 0 : e.getItem(this.Fo(t)));\n            return N(\"IndexedDbPersistence\", \"Client '\" + t + \"' \" + (n ? \"is\" : \"is not\") + \" zombied in LocalStorage\"), \n            n;\n        } catch (t) {\n            // Gracefully handle if LocalStorage isn't working.\n            return A(\"IndexedDbPersistence\", \"Failed to get zombied client id.\", t), !1;\n        }\n    }, \n    /**\n     * Record client as zombied (a client that had its tab closed). Zombied\n     * clients are ignored during primary tab selection.\n     */\n    t.prototype.Mo = function() {\n        if (this.Eo) try {\n            this.Eo.setItem(this.Fo(this.clientId), String(Date.now()));\n        } catch (t) {\n            // Gracefully handle if LocalStorage isn't available / working.\n            A(\"Failed to set zombie client id.\", t);\n        }\n    }, \n    /** Removes the zombied client entry if it exists. */ t.prototype.qo = function() {\n        if (this.Eo) try {\n            this.Eo.removeItem(this.Fo(this.clientId));\n        } catch (t) {\n            // Ignore\n        }\n    }, t.prototype.Fo = function(t) {\n        return \"firestore_zombie_\" + this.persistenceKey + \"_\" + t;\n    }, t;\n}();\n\n/**\n * Oldest acceptable age in milliseconds for client metadata before the client\n * is considered inactive and its associated data is garbage collected.\n */\n/**\n * An IndexedDB-backed instance of Persistence. Data is stored persistently\n * across sessions.\n *\n * On Web only, the Firestore SDKs support shared access to its persistence\n * layer. This allows multiple browser tabs to read and write to IndexedDb and\n * to synchronize state even without network connectivity. Shared access is\n * currently optional and not enabled unless all clients invoke\n * `enablePersistence()` with `{synchronizeTabs:true}`.\n *\n * In multi-tab mode, if multiple clients are active at the same time, the SDK\n * will designate one client as the “primary client”. An effort is made to pick\n * a visible, network-connected and active client, and this client is\n * responsible for letting other clients know about its presence. The primary\n * client writes a unique client-generated identifier (the client ID) to\n * IndexedDb’s “owner” store every 4 seconds. If the primary client fails to\n * update this entry, another client can acquire the lease and take over as\n * primary.\n *\n * Some persistence operations in the SDK are designated as primary-client only\n * operations. This includes the acknowledgment of mutations and all updates of\n * remote documents. The effects of these operations are written to persistence\n * and then broadcast to other tabs via LocalStorage (see\n * `WebStorageSharedClientState`), which then refresh their state from\n * persistence.\n *\n * Similarly, the primary client listens to notifications sent by secondary\n * clients to discover persistence changes written by secondary clients, such as\n * the addition of new mutations and query targets.\n *\n * If multi-tab is not enabled and another tab already obtained the primary\n * lease, IndexedDbPersistence enters a failed state and all subsequent\n * operations will automatically fail.\n *\n * Additionally, there is an optimization so that when a tab is closed, the\n * primary lease is released immediately (this is especially important to make\n * sure that a refreshed tab is able to immediately re-acquire the primary\n * lease). Unfortunately, IndexedDB cannot be reliably used in window.unload\n * since it is an asynchronous API. So in addition to attempting to give up the\n * lease, the leaseholder writes its client ID to a \"zombiedClient\" entry in\n * LocalStorage which acts as an indicator that another tab should go ahead and\n * take the primary lease immediately regardless of the current lease timestamp.\n *\n * TODO(b/114226234): Remove `synchronizeTabs` section when multi-tab is no\n * longer optional.\n */\n/**\n * Helper to get a typed SimpleDbStore for the primary client object store.\n */\nfunction Hi(t) {\n    return Kr(t, Or.store);\n}\n\n/**\n * Helper to get a typed SimpleDbStore for the client metadata object store.\n */ function Ki(t) {\n    return Kr(t, Gr.store);\n}\n\n/**\n * Generates a string used as a prefix when storing data in IndexedDB and\n * LocalStorage.\n */ function Xi(t, e) {\n    // Use two different prefix formats:\n    //   * firestore / persistenceKey / projectID . databaseID / ...\n    //   * firestore / persistenceKey / projectID / ...\n    // projectIDs are DNS-compatible names and cannot contain dots\n    // so there's no danger of collisions.\n    var n = t.projectId;\n    return t.o || (n += \".\" + t.database), \"firestore/\" + e + \"/\" + n + \"/\"\n    /**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */;\n}\n\nvar Wi = function(t, e) {\n    this.progress = t, this.Go = e;\n}, Zi = /** @class */ function() {\n    function t(t, e, n) {\n        this.fo = t, this.zo = e, this.Ei = n\n        /**\n     * Get the local view of the document identified by `key`.\n     *\n     * @returns Local view of the document or null if we don't have any cached\n     * state for it.\n     */;\n    }\n    return t.prototype.Ho = function(t, e) {\n        var n = this;\n        return this.zo.bi(t, e).next((function(r) {\n            return n.Jo(t, e, r);\n        }));\n    }, \n    /** Internal version of `getDocument` that allows reusing batches. */ t.prototype.Jo = function(t, e, n) {\n        return this.fo._i(t, e).next((function(t) {\n            for (var r = 0, i = n; r < i.length; r++) {\n                t = i[r].Cs(e, t);\n            }\n            return t;\n        }));\n    }, \n    // Returns the view of the given `docs` as they would appear after applying\n    // all mutations in the given `batches`.\n    t.prototype.Yo = function(t, e, n) {\n        var r = fn();\n        return e.forEach((function(t, e) {\n            for (var i = 0, o = n; i < o.length; i++) {\n                e = o[i].Cs(t, e);\n            }\n            r = r.zt(t, e);\n        })), r;\n    }, \n    /**\n     * Gets the local view of the documents identified by `keys`.\n     *\n     * If we don't have cached state for a document in `keys`, a NoDocument will\n     * be stored for that key in the resulting set.\n     */\n    t.prototype.Xo = function(t, e) {\n        var n = this;\n        return this.fo.getEntries(t, e).next((function(e) {\n            return n.Zo(t, e);\n        }));\n    }, \n    /**\n     * Similar to `getDocuments`, but creates the local view from the given\n     * `baseDocs` without retrieving documents from the local store.\n     */\n    t.prototype.Zo = function(t, e) {\n        var n = this;\n        return this.zo.vi(t, e).next((function(r) {\n            var i = n.Yo(t, e, r), o = hn();\n            return i.forEach((function(t, e) {\n                // TODO(http://b/32275378): Don't conflate missing / deleted.\n                e || (e = new Vt(t, X.min())), o = o.zt(t, e);\n            })), o;\n        }));\n    }, \n    /**\n     * Performs a query against the local view of all documents.\n     *\n     * @param transaction - The persistence transaction.\n     * @param query - The query to match documents against.\n     * @param sinceReadTime - If not set to SnapshotVersion.min(), return only\n     *     documents that have been read since this snapshot version (exclusive).\n     */\n    t.prototype.Kr = function(t, e, n) {\n        /**\n * Returns whether the query matches a single document by path (rather than a\n * collection).\n */\n        return function(t) {\n            return tt.wt(t.path) && null === t.collectionGroup && 0 === t.filters.length;\n        }(e) ? this.tc(t, e.path) : ae(e) ? this.ec(t, e, n) : this.nc(t, e, n);\n    }, t.prototype.tc = function(t, e) {\n        // Just do a simple document lookup.\n        return this.Ho(t, new tt(e)).next((function(t) {\n            var e = pn();\n            return t instanceof Pt && (e = e.zt(t.key, t)), e;\n        }));\n    }, t.prototype.ec = function(t, e, n) {\n        var r = this, i = e.collectionGroup, o = pn();\n        return this.Ei.Us(t, i).next((function(u) {\n            return lr.forEach(u, (function(u) {\n                var s = function(t, e) {\n                    return new ee(e, \n                    /*collectionGroup=*/ null, t.xt.slice(), t.filters.slice(), t.limit, t.limitType, t.startAt, t.endAt);\n                }(e, u.child(i));\n                return r.nc(t, s, n).next((function(t) {\n                    t.forEach((function(t, e) {\n                        o = o.zt(t, e);\n                    }));\n                }));\n            })).next((function() {\n                return o;\n            }));\n        }));\n    }, t.prototype.nc = function(t, e, n) {\n        var r, i, o = this;\n        // Query the remote documents and overlay mutations.\n                return this.fo.Kr(t, e, n).next((function(n) {\n            return r = n, o.zo.Di(t, e);\n        })).next((function(e) {\n            return i = e, o.sc(t, i, r).next((function(t) {\n                r = t;\n                for (var e = 0, n = i; e < n.length; e++) for (var o = n[e], u = 0, s = o.mutations; u < s.length; u++) {\n                    var a = s[u], c = a.key, h = Fe(a, r.get(c), o.vs);\n                    r = h instanceof Pt ? r.zt(c, h) : r.remove(c);\n                }\n            }));\n        })).next((function() {\n            // Finally, filter out any documents that don't actually match\n            // the query.\n            return r.forEach((function(t, n) {\n                ve(e, n) || (r = r.remove(t));\n            })), r;\n        }));\n    }, t.prototype.sc = function(t, e, n) {\n        for (var r = mn(), i = 0, o = e; i < o.length; i++) for (var u = 0, s = o[i].mutations; u < s.length; u++) {\n            var a = s[u];\n            a instanceof Qe && null === n.get(a.key) && (r = r.add(a.key));\n        }\n        var c = n;\n        return this.fo.getEntries(t, r).next((function(t) {\n            return t.forEach((function(t, e) {\n                null !== e && e instanceof Pt && (c = c.zt(t, e));\n            })), c;\n        }));\n    }, t;\n}(), Ji = /** @class */ function() {\n    function t(t, e, n, r) {\n        this.targetId = t, this.fromCache = e, this.ic = n, this.rc = r;\n    }\n    return t.oc = function(e, n) {\n        for (var r = mn(), i = mn(), o = 0, u = n.docChanges; o < u.length; o++) {\n            var s = u[o];\n            switch (s.type) {\n              case 0 /* Added */ :\n                r = r.add(s.doc.key);\n                break;\n\n              case 1 /* Removed */ :\n                i = i.add(s.doc.key);\n                // do nothing\n                        }\n        }\n        return new t(e, n.fromCache, r, i);\n    }, t;\n}(), $i = /** @class */ function() {\n    function t() {}\n    /** Sets the document view to query against. */    return t.prototype.cc = function(t) {\n        this.ac = t;\n    }, \n    /** Returns all local documents matching the specified query. */ t.prototype.Kr = function(t, n, r, i) {\n        var o = this;\n        // Queries that match all documents don't benefit from using\n        // key-based lookups. It is more efficient to scan all documents in a\n        // collection, rather than to perform individual lookups.\n                return function(t) {\n            return 0 === t.filters.length && null === t.limit && null == t.startAt && null == t.endAt && (0 === t.xt.length || 1 === t.xt.length && t.xt[0].field.ut());\n        }(n) || r.isEqual(X.min()) ? this.uc(t, n) : this.ac.Xo(t, i).next((function(u) {\n            var s = o.hc(n, u);\n            return (ie(n) || oe(n)) && o.lc(n.limitType, s, i, r) ? o.uc(t, n) : (T() <= e.DEBUG && N(\"QueryEngine\", \"Re-using previous result from %s to execute query: %s\", r.toString(), de(n)), \n            o.ac.Kr(t, n, r).next((function(t) {\n                // We merge `previousResults` into `updateResults`, since\n                // `updateResults` is already a DocumentMap. If a document is\n                // contained in both lists, then its contents are the same.\n                return s.forEach((function(e) {\n                    t = t.zt(e.key, e);\n                })), t;\n            })));\n        }));\n        // Queries that have never seen a snapshot without limbo free documents\n        // should also be run as a full collection scan.\n        }, \n    /** Applies the query filter and sorting to the provided documents.  */ t.prototype.hc = function(t, e) {\n        // Sort the documents and re-apply the query filter since previously\n        // matching documents do not necessarily still match the query.\n        var n = new sn(ye(t));\n        return e.forEach((function(e, r) {\n            r instanceof Pt && ve(t, r) && (n = n.add(r));\n        })), n;\n    }, \n    /**\n     * Determines if a limit query needs to be refilled from cache, making it\n     * ineligible for index-free execution.\n     *\n     * @param sortedPreviousResults - The documents that matched the query when it\n     * was last synchronized, sorted by the query's comparator.\n     * @param remoteKeys - The document keys that matched the query at the last\n     * snapshot.\n     * @param limboFreeSnapshotVersion - The version of the snapshot when the\n     * query was last synchronized.\n     */\n    t.prototype.lc = function(t, e, n, r) {\n        // The query needs to be refilled if a previously matching document no\n        // longer matches.\n        if (n.size !== e.size) return !0;\n        // Limit queries are not eligible for index-free query execution if there is\n        // a potential that an older document from cache now sorts before a document\n        // that was previously part of the limit. This, however, can only happen if\n        // the document at the edge of the limit goes out of limit.\n        // If a document that is not the limit boundary sorts differently,\n        // the boundary of the limit itself did not change and documents from cache\n        // will continue to be \"rejected\" by this boundary. Therefore, we can ignore\n        // any modifications that don't affect the last document.\n                var i = \"F\" /* First */ === t ? e.last() : e.first();\n        return !!i && (i.hasPendingWrites || i.version._(r) > 0);\n    }, t.prototype.uc = function(t, n) {\n        return T() <= e.DEBUG && N(\"QueryEngine\", \"Using full collection scan to execute query:\", de(n)), \n        this.ac.Kr(t, n, X.min());\n    }, t;\n}(), to = /** @class */ function() {\n    function t(\n    /** Manages our in-memory or durable persistence. */\n    t, e, n, r) {\n        this.persistence = t, this._c = e, this.Qt = r, \n        /**\n             * Maps a targetID to data about its target.\n             *\n             * PORTING NOTE: We are using an immutable data structure on Web to make re-runs\n             * of `applyRemoteEvent()` idempotent.\n             */\n        this.fc = new rn(C), \n        /** Maps a target to its targetID. */\n        // TODO(wuandy): Evaluate if TargetId can be part of Target.\n        this.dc = new gi((function(t) {\n            return Ut(t);\n        }), Mt), \n        /**\n             * The read time of the last entry processed by `getNewDocumentChanges()`.\n             *\n             * PORTING NOTE: This is only used for multi-tab synchronization.\n             */\n        this.wc = X.min(), this.zo = t.Qo(n), this.Ec = t.$r(), this._o = t.Sr(), this.Tc = new Zi(this.Ec, this.zo, this.persistence.Ko()), \n        this.wo = t.Wo(), this._c.cc(this.Tc);\n    }\n    return t.prototype.Ir = function(t) {\n        var e = this;\n        return this.persistence.runTransaction(\"Collect garbage\", \"readwrite-primary\", (function(n) {\n            return t.Vr(n, e.fc);\n        }));\n    }, t;\n}();\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A readonly view of the local state of all documents we're tracking (i.e. we\n * have a cached version in remoteDocumentCache or local mutations for the\n * document). The view is computed by applying the mutations in the\n * MutationQueue to the RemoteDocumentCache.\n */ function eo(\n/** Manages our in-memory or durable persistence. */\nt, e, n, r) {\n    return new to(t, e, n, r);\n}\n\n/**\n * Tells the LocalStore that the currently authenticated user has changed.\n *\n * In response the local store switches the mutation queue to the new user and\n * returns any resulting document changes.\n */\n// PORTING NOTE: Android and iOS only return the documents affected by the\n// change.\nfunction no(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r, i, o;\n        return w(this, (function(u) {\n            switch (u.label) {\n              case 0:\n                return n = O(t), r = n.zo, i = n.Tc, [ 4 /*yield*/ , n.persistence.runTransaction(\"Handle user change\", \"readonly\", (function(t) {\n                    // Swap out the mutation queue, grabbing the pending mutation batches\n                    // before and after.\n                    var o;\n                    return n.zo.pi(t).next((function(u) {\n                        return o = u, r = n.persistence.Qo(e), \n                        // Recreate our LocalDocumentsView using the new\n                        // MutationQueue.\n                        i = new Zi(n.Ec, r, n.persistence.Ko()), r.pi(t);\n                    })).next((function(e) {\n                        for (var n = [], r = [], u = mn(), s = 0, a = o\n                        // Union the old/new changed keys.\n                        ; s < a.length; s++) {\n                            var c = a[s];\n                            n.push(c.batchId);\n                            for (var h = 0, f = c.mutations; h < f.length; h++) {\n                                var l = f[h];\n                                u = u.add(l.key);\n                            }\n                        }\n                        for (var p = 0, d = e; p < d.length; p++) {\n                            var v = d[p];\n                            r.push(v.batchId);\n                            for (var y = 0, m = v.mutations; y < m.length; y++) {\n                                var g = m[y];\n                                u = u.add(g.key);\n                            }\n                        }\n                        // Return the set of all (potentially) changed documents and the list\n                        // of mutation batch IDs that were affected by change.\n                                                return i.Xo(t, u).next((function(t) {\n                            return {\n                                Ic: t,\n                                mc: n,\n                                Ac: r\n                            };\n                        }));\n                    }));\n                })) ];\n\n              case 1:\n                return o = u.sent(), [ 2 /*return*/ , (n.zo = r, n.Tc = i, n._c.cc(n.Tc), o) ];\n            }\n        }));\n    }));\n}\n\n/* Accepts locally generated Mutations and commit them to storage. */\n/**\n * Acknowledges the given batch.\n *\n * On the happy path when a batch is acknowledged, the local store will\n *\n *  + remove the batch from the mutation queue;\n *  + apply the changes to the remote document cache;\n *  + recalculate the latency compensated view implied by those changes (there\n *    may be mutations in the queue that affect the documents but haven't been\n *    acknowledged yet); and\n *  + give the changed documents back the sync engine\n *\n * @returns The resulting (modified) documents.\n */ function ro(t, e) {\n    var n = O(t);\n    return n.persistence.runTransaction(\"Acknowledge batch\", \"readwrite-primary\", (function(t) {\n        var r = e.batch.keys(), i = n.Ec.Nr({\n            Wr: !0\n        });\n        return function(t, e, n, r) {\n            var i = n.batch, o = i.keys(), u = lr.resolve();\n            return o.forEach((function(t) {\n                u = u.next((function() {\n                    return r._i(e, t);\n                })).next((function(e) {\n                    var o = e, u = n.$s.get(t);\n                    k(null !== u), (!o || o.version._(u) < 0) && ((o = i.Ss(t, o, n)) && \n                    // We use the commitVersion as the readTime rather than the\n                    // document's updateTime since the updateTime is not advanced\n                    // for updates that do not modify the underlying document.\n                    r.ai(o, n.Ns));\n                }));\n            })), u.next((function() {\n                return t.zo.Ci(e, i);\n            }));\n        }(n, t, e, i).next((function() {\n            return i.apply(t);\n        })).next((function() {\n            return n.zo.$i(t);\n        })).next((function() {\n            return n.Tc.Xo(t, r);\n        }));\n    }));\n}\n\n/**\n * Removes mutations from the MutationQueue for the specified batch;\n * LocalDocuments will be recalculated.\n *\n * @returns The resulting modified documents.\n */\n/**\n * Returns the last consistent snapshot processed (used by the RemoteStore to\n * determine whether to buffer incoming snapshots from the backend).\n */ function io(t) {\n    var e = O(t);\n    return e.persistence.runTransaction(\"Get last remote snapshot version\", \"readonly\", (function(t) {\n        return e._o.Qi(t);\n    }));\n}\n\n/**\n * Updates the \"ground-state\" (remote) documents. We assume that the remote\n * event reflects any write batches that have been acknowledged or rejected\n * (i.e. we do not re-apply local mutations to updates from this event).\n *\n * LocalDocuments are re-calculated if there are remaining mutations in the\n * queue.\n */ function oo(t, e) {\n    var n = O(t), r = e.Ot, i = n.fc;\n    return n.persistence.runTransaction(\"Apply remote event\", \"readwrite-primary\", (function(t) {\n        var o = n.Ec.Nr({\n            Wr: !0\n        });\n        // Reset newTargetDataByTargetMap in case this transaction gets re-run.\n                i = n.fc;\n        var u = [];\n        e.$e.forEach((function(e, o) {\n            var s = i.get(o);\n            if (s) {\n                // Only update the remote keys if the target is still active. This\n                // ensures that we can persist the updated target data along with\n                // the updated assignment.\n                u.push(n._o.sr(t, e.Qe, o).next((function() {\n                    return n._o.er(t, e.qe, o);\n                })));\n                var a = e.resumeToken;\n                // Update the resume token if the change includes one.\n                                if (a.l() > 0) {\n                    var c = s.Mt(a, r).kt(t.bs);\n                    i = i.zt(o, c), \n                    // Update the target data if there are target changes (or if\n                    // sufficient time has passed since the last update).\n                    /**\n     * Returns true if the newTargetData should be persisted during an update of\n     * an active target. TargetData should always be persisted when a target is\n     * being released and should not call this function.\n     *\n     * While the target is active, TargetData updates can be omitted when nothing\n     * about the target has changed except metadata like the resume token or\n     * snapshot version. Occasionally it's worth the extra write to prevent these\n     * values from getting too stale after a crash, but this doesn't have to be\n     * too frequent.\n     */\n                    function(t, e, n) {\n                        // Always persist target data if we don't already have a resume token.\n                        return k(e.resumeToken.l() > 0), 0 === t.resumeToken.l() || (\n                        // Don't allow resume token changes to be buffered indefinitely. This\n                        // allows us to be reasonably up-to-date after a crash and avoids needing\n                        // to loop over all active queries on shutdown. Especially in the browser\n                        // we may not get time to do anything interesting while the current tab is\n                        // closing.\n                        e.Ot.W() - t.Ot.W() >= 3e8 || n.qe.size + n.Ue.size + n.Qe.size > 0);\n                    }(s, c, e) && u.push(n._o.Hi(t, c));\n                }\n            }\n        }));\n        var s = hn();\n        // HACK: The only reason we allow a null snapshot version is so that we\n        // can synthesize remote events when we get permission denied errors while\n        // trying to resolve the state of a locally cached document that is in\n        // limbo.\n                if (e.Oe.forEach((function(r, i) {\n            e.ke.has(r) && u.push(n.persistence.Ti.Fr(t, r));\n        })), \n        // Each loop iteration only affects its \"own\" doc, so it's safe to get all the remote\n        // documents in advance in a single call.\n        u.push(uo(t, o, e.Oe, r, void 0).next((function(t) {\n            s = t;\n        }))), !r.isEqual(X.min())) {\n            var a = n._o.Qi(t).next((function(e) {\n                return n._o.Wi(t, t.bs, r);\n            }));\n            u.push(a);\n        }\n        return lr.Mn(u).next((function() {\n            return o.apply(t);\n        })).next((function() {\n            return n.Tc.Zo(t, s);\n        }));\n    })).then((function(t) {\n        return n.fc = i, t;\n    }));\n}\n\n/**\n * Populates document change buffer with documents from backend or a bundle.\n * Returns the document changes resulting from applying those documents.\n *\n * @param txn - Transaction to use to read existing documents from storage.\n * @param documentBuffer - Document buffer to collect the resulted changes to be\n *        applied to storage.\n * @param documents - Documents to be applied.\n * @param globalVersion - A `SnapshotVersion` representing the read time if all\n *        documents have the same read time.\n * @param documentVersions - A DocumentKey-to-SnapshotVersion map if documents\n *        have their own read time.\n *\n * Note: this function will use `documentVersions` if it is defined;\n * when it is not defined, resorts to `globalVersion`.\n */ function uo(t, e, n, r, \n// TODO(wuandy): We could add `readTime` to MaybeDocument instead to remove\n// this parameter.\ni) {\n    var o = mn();\n    return n.forEach((function(t) {\n        return o = o.add(t);\n    })), e.getEntries(t, o).next((function(t) {\n        var o = hn();\n        return n.forEach((function(n, u) {\n            var s = t.get(n), a = (null == i ? void 0 : i.get(n)) || r;\n            // Note: The order of the steps below is important, since we want\n            // to ensure that rejected limbo resolutions (which fabricate\n            // NoDocuments with SnapshotVersion.min()) never add documents to\n            // cache.\n                        u instanceof Vt && u.version.isEqual(X.min()) ? (\n            // NoDocuments with SnapshotVersion.min() are used in manufactured\n            // events. We remove these documents from cache since we lost\n            // access.\n            e.li(n, a), o = o.zt(n, u)) : null == s || u.version._(s.version) > 0 || 0 === u.version._(s.version) && s.hasPendingWrites ? (e.ai(u, a), \n            o = o.zt(n, u)) : N(\"LocalStore\", \"Ignoring outdated watch update for \", n, \". Current version:\", s.version, \" Watch version:\", u.version);\n        })), o;\n    }))\n    /**\n * Gets the mutation batch after the passed in batchId in the mutation queue\n * or null if empty.\n * @param afterBatchId - If provided, the batch to search after.\n * @returns The next mutation or null if there wasn't one.\n */;\n}\n\nfunction so(t, e) {\n    var n = O(t);\n    return n.persistence.runTransaction(\"Get next mutation batch\", \"readonly\", (function(t) {\n        return void 0 === e && (e = -1), n.zo.gi(t, e);\n    }));\n}\n\n/**\n * Reads the current value of a Document with a given key or null if not\n * found - used for testing.\n */\n/**\n * Assigns the given target an internal ID so that its results can be pinned so\n * they don't get GC'd. A target must be allocated in the local store before\n * the store can be used to manage its view.\n *\n * Allocating an already allocated `Target` will return the existing `TargetData`\n * for that `Target`.\n */ function ao(t, e) {\n    var n = O(t);\n    return n.persistence.runTransaction(\"Allocate target\", \"readwrite\", (function(t) {\n        var r;\n        return n._o.tr(t, e).next((function(i) {\n            return i ? (\n            // This target has been listened to previously, so reuse the\n            // previous targetID.\n            // TODO(mcg): freshen last accessed date?\n            r = i, lr.resolve(r)) : n._o.Bi(t).next((function(i) {\n                return r = new ge(e, i, 0 /* Listen */ , t.bs), n._o.ji(t, r).next((function() {\n                    return r;\n                }));\n            }));\n        }));\n    })).then((function(t) {\n        // If Multi-Tab is enabled, the existing target data may be newer than\n        // the in-memory data\n        var r = n.fc.get(t.targetId);\n        return (null === r || t.Ot._(r.Ot) > 0) && (n.fc = n.fc.zt(t.targetId, t), n.dc.set(e, t.targetId)), \n        t;\n    }));\n}\n\n/**\n * Returns the TargetData as seen by the LocalStore, including updates that may\n * have not yet been persisted to the TargetCache.\n */\n// Visible for testing.\n/**\n * Unpins all the documents associated with the given target. If\n * `keepPersistedTargetData` is set to false and Eager GC enabled, the method\n * directly removes the associated target data from the target cache.\n *\n * Releasing a non-existing `Target` is a no-op.\n */\n// PORTING NOTE: `keepPersistedTargetData` is multi-tab only.\nfunction co(t, e, n) {\n    return g(this, void 0, void 0, (function() {\n        var r, i, o, u;\n        return w(this, (function(s) {\n            switch (s.label) {\n              case 0:\n                r = O(t), i = r.fc.get(e), o = n ? \"readwrite\" : \"readwrite-primary\", s.label = 1;\n\n              case 1:\n                return s.trys.push([ 1, 4, , 5 ]), n ? [ 3 /*break*/ , 3 ] : [ 4 /*yield*/ , r.persistence.runTransaction(\"Release target\", o, (function(t) {\n                    return r.persistence.Ti.removeTarget(t, i);\n                })) ];\n\n              case 2:\n                s.sent(), s.label = 3;\n\n              case 3:\n                return [ 3 /*break*/ , 5 ];\n\n              case 4:\n                if (!mr(u = s.sent())) throw u;\n                // All `releaseTarget` does is record the final metadata state for the\n                // target, but we've been recording this periodically during target\n                // activity. If we lose this write this could cause a very slight\n                // difference in the order of target deletion during GC, but we\n                // don't define exact LRU semantics so this is acceptable.\n                                return N(\"LocalStore\", \"Failed to update sequence numbers for target \" + e + \": \" + u), \n                [ 3 /*break*/ , 5 ];\n\n              case 5:\n                return r.fc = r.fc.remove(e), r.dc.delete(i.target), [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * Runs the specified query against the local store and returns the results,\n * potentially taking advantage of query data from previous executions (such\n * as the set of remote keys).\n *\n * @param usePreviousResults - Whether results from previous executions can\n * be used to optimize this query execution.\n */ function ho(t, e, n) {\n    var r = O(t), i = X.min(), o = mn();\n    return r.persistence.runTransaction(\"Execute query\", \"readonly\", (function(t) {\n        return function(t, e, n) {\n            var r = O(t), i = r.dc.get(n);\n            return void 0 !== i ? lr.resolve(r.fc.get(i)) : r._o.tr(e, n);\n        }(r, t, he(e)).next((function(e) {\n            if (e) return i = e.lastLimboFreeSnapshotVersion, r._o.rr(t, e.targetId).next((function(t) {\n                o = t;\n            }));\n        })).next((function() {\n            return r._c.Kr(t, e, n ? i : X.min(), n ? o : mn());\n        })).next((function(t) {\n            return {\n                documents: t,\n                Rc: o\n            };\n        }));\n    }));\n}\n\n// PORTING NOTE: Multi-Tab only.\nfunction fo(t, e) {\n    var n = O(t), r = O(n._o), i = n.fc.get(e);\n    return i ? Promise.resolve(i.target) : n.persistence.runTransaction(\"Get target data\", \"readonly\", (function(t) {\n        return r.Sn(t, e).next((function(t) {\n            return t ? t.target : null;\n        }));\n    }));\n}\n\n/**\n * Returns the set of documents that have been updated since the last call.\n * If this is the first call, returns the set of changes since client\n * initialization. Further invocations will return document that have changed\n * since the prior call.\n */\n// PORTING NOTE: Multi-Tab only.\nfunction lo(t) {\n    var e = O(t);\n    return e.persistence.runTransaction(\"Get new document changes\", \"readonly\", (function(t) {\n        return function(t, e, n) {\n            var r = O(t), i = hn(), o = ti(n), u = ji(e), s = IDBKeyRange.lowerBound(o, !0);\n            return u.hs({\n                index: Ur.readTimeIndex,\n                range: s\n            }, (function(t, e) {\n                // Unlike `getEntry()` and others, `getNewDocumentChanges()` parses\n                // the documents directly since we want to keep sentinel deletes.\n                var n = Jr(r.Qt, e);\n                i = i.zt(n.key, n), o = e.readTime;\n            })).next((function() {\n                return {\n                    Go: i,\n                    readTime: ei(o)\n                };\n            }));\n        }(e.Ec, t, e.wc);\n    })).then((function(t) {\n        var n = t.Go, r = t.readTime;\n        return e.wc = r, n;\n    }));\n}\n\n/**\n * Reads the newest document change from persistence and moves the internal\n * synchronization marker forward so that calls to `getNewDocumentChanges()`\n * only return changes that happened after client initialization.\n */\n// PORTING NOTE: Multi-Tab only.\nfunction po(t) {\n    return g(this, void 0, void 0, (function() {\n        var e;\n        return w(this, (function(n) {\n            return [ 2 /*return*/ , (e = O(t)).persistence.runTransaction(\"Synchronize last document change read time\", \"readonly\", (function(t) {\n                return function(t) {\n                    var e = ji(t), n = X.min();\n                    // If there are no existing entries, we return SnapshotVersion.min().\n                                        return e.hs({\n                        index: Ur.readTimeIndex,\n                        reverse: !0\n                    }, (function(t, e, r) {\n                        e.readTime && (n = ei(e.readTime)), r.done();\n                    })).next((function() {\n                        return n;\n                    }));\n                }(t);\n            })).then((function(t) {\n                e.wc = t;\n            })) ];\n        }));\n    }));\n}\n\n/**\n * Creates a new target using the given bundle name, which will be used to\n * hold the keys of all documents from the bundle in query-document mappings.\n * This ensures that the loaded documents do not get garbage collected\n * right away.\n */\n/**\n * Applies the documents from a bundle to the \"ground-state\" (remote)\n * documents.\n *\n * LocalDocuments are re-calculated if there are remaining mutations in the\n * queue.\n */ function vo(t, e, n, r) {\n    return g(this, void 0, void 0, (function() {\n        var i, o, u, s, a, c, h, f, l, p;\n        return w(this, (function(d) {\n            switch (d.label) {\n              case 0:\n                for (i = O(t), o = mn(), u = hn(), s = vn(), a = 0, c = n; a < c.length; a++) h = c[a], \n                f = e.Pc(h.metadata.name), h.document && (o = o.add(f)), u = u.zt(f, e.yc(h)), s = s.zt(f, e.gc(h.metadata.readTime));\n                return l = i.Ec.Nr({\n                    Wr: !0\n                }), [ 4 /*yield*/ , ao(i, function(t) {\n                    // It is OK that the path used for the query is not valid, because this will\n                    // not be read and queried.\n                    return he(re(Z.ot(\"__bundle__/docs/\" + t)));\n                }(r)) ];\n\n              case 1:\n                // Allocates a target to hold all document keys from the bundle, such that\n                // they will not get garbage collected right away.\n                return p = d.sent(), [ 2 /*return*/ , i.persistence.runTransaction(\"Apply bundle documents\", \"readwrite\", (function(t) {\n                    return uo(t, l, u, X.min(), s).next((function(e) {\n                        return l.apply(t), e;\n                    })).next((function(e) {\n                        return i._o.Yi(t, p.targetId).next((function() {\n                            return i._o.er(t, o, p.targetId);\n                        })).next((function() {\n                            return i.Tc.Zo(t, e);\n                        }));\n                    }));\n                })) ];\n            }\n        }));\n    }));\n}\n\n/**\n * Returns a promise of a boolean to indicate if the given bundle has already\n * been loaded and the create time is newer than the current loading bundle.\n */\n/**\n * Saves the given `NamedQuery` to local persistence.\n */ function yo(t, e, n) {\n    return void 0 === n && (n = mn()), g(this, void 0, void 0, (function() {\n        var r, i;\n        return w(this, (function(o) {\n            switch (o.label) {\n              case 0:\n                return [ 4 /*yield*/ , ao(t, he(si(e.bundledQuery))) ];\n\n              case 1:\n                return r = o.sent(), [ 2 /*return*/ , (i = O(t)).persistence.runTransaction(\"Save named query\", \"readwrite\", (function(t) {\n                    var o = Mn(e.readTime);\n                    // Simply save the query itself if it is older than what the SDK already\n                    // has.\n                                        if (r.Ot._(o) >= 0) return i.wo.Ls(t, e);\n                    // Update existing target data because the query from the bundle is newer.\n                                        var u = r.Mt(U.T, o);\n                    return i.fc = i.fc.zt(u.targetId, u), i._o.Hi(t, u).next((function() {\n                        return i._o.Yi(t, r.targetId);\n                    })).next((function() {\n                        return i._o.er(t, n, r.targetId);\n                    })).next((function() {\n                        return i.wo.Ls(t, e);\n                    }));\n                })) ];\n            }\n        }));\n    }));\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ var mo = /** @class */ function() {\n    function t(t) {\n        this.Qt = t, this.Vc = new Map, this.bc = new Map;\n    }\n    return t.prototype.Os = function(t, e) {\n        return lr.resolve(this.Vc.get(e));\n    }, t.prototype.ks = function(t, e) {\n        /** Decodes a BundleMetadata proto into a BundleMetadata object. */\n        var n;\n        return this.Vc.set(e.id, {\n            id: (n = e).id,\n            version: n.version,\n            createTime: Mn(n.createTime)\n        }), lr.resolve();\n    }, t.prototype.Ms = function(t, e) {\n        return lr.resolve(this.bc.get(e));\n    }, t.prototype.Ls = function(t, e) {\n        return this.bc.set(e.name, function(t) {\n            return {\n                name: t.name,\n                query: si(t.bundledQuery),\n                readTime: Mn(t.readTime)\n            };\n        }(e)), lr.resolve();\n    }, t;\n}(), go = /** @class */ function() {\n    function t() {\n        // A set of outstanding references to a document sorted by key.\n        this.vc = new sn(wo.Sc), \n        // A set of outstanding references to a document sorted by target id.\n        this.Dc = new sn(wo.Cc)\n        /** Returns true if the reference set contains no references. */;\n    }\n    return t.prototype.et = function() {\n        return this.vc.et();\n    }, \n    /** Adds a reference to the given document key for the given ID. */ t.prototype.nr = function(t, e) {\n        var n = new wo(t, e);\n        this.vc = this.vc.add(n), this.Dc = this.Dc.add(n);\n    }, \n    /** Add references to the given document keys for the given ID. */ t.prototype.xc = function(t, e) {\n        var n = this;\n        t.forEach((function(t) {\n            return n.nr(t, e);\n        }));\n    }, \n    /**\n     * Removes a reference to the given document key for the given\n     * ID.\n     */\n    t.prototype.ir = function(t, e) {\n        this.Nc(new wo(t, e));\n    }, t.prototype.$c = function(t, e) {\n        var n = this;\n        t.forEach((function(t) {\n            return n.ir(t, e);\n        }));\n    }, \n    /**\n     * Clears all references with a given ID. Calls removeRef() for each key\n     * removed.\n     */\n    t.prototype.Fc = function(t) {\n        var e = this, n = new tt(new Z([])), r = new wo(n, t), i = new wo(n, t + 1), o = [];\n        return this.Dc.me([ r, i ], (function(t) {\n            e.Nc(t), o.push(t.key);\n        })), o;\n    }, t.prototype.Oc = function() {\n        var t = this;\n        this.vc.forEach((function(e) {\n            return t.Nc(e);\n        }));\n    }, t.prototype.Nc = function(t) {\n        this.vc = this.vc.delete(t), this.Dc = this.Dc.delete(t);\n    }, t.prototype.kc = function(t) {\n        var e = new tt(new Z([])), n = new wo(e, t), r = new wo(e, t + 1), i = mn();\n        return this.Dc.me([ n, r ], (function(t) {\n            i = i.add(t.key);\n        })), i;\n    }, t.prototype.Fi = function(t) {\n        var e = new wo(t, 0), n = this.vc.Re(e);\n        return null !== n && t.isEqual(n.key);\n    }, t;\n}(), wo = /** @class */ function() {\n    function t(t, e) {\n        this.key = t, this.Mc = e\n        /** Compare by key then by ID */;\n    }\n    return t.Sc = function(t, e) {\n        return tt.H(t.key, e.key) || C(t.Mc, e.Mc);\n    }, \n    /** Compare by ID then by key */ t.Cc = function(t, e) {\n        return C(t.Mc, e.Mc) || tt.H(t.key, e.key);\n    }, t;\n}(), bo = /** @class */ function() {\n    function t(t, e) {\n        this.Ei = t, this.Ti = e, \n        /**\n             * The set of all mutations that have been sent but not yet been applied to\n             * the backend.\n             */\n        this.zo = [], \n        /** Next value to use when assigning sequential IDs to each mutation batch. */\n        this.Lc = 1, \n        /** An ordered mapping between documents and the mutations batch IDs. */\n        this.Bc = new sn(wo.Sc);\n    }\n    return t.prototype.Ai = function(t) {\n        return lr.resolve(0 === this.zo.length);\n    }, t.prototype.Ri = function(t, e, n, r) {\n        var i = this.Lc;\n        this.Lc++, this.zo.length > 0 && this.zo[this.zo.length - 1];\n        var o = new Xr(i, e, n, r);\n        this.zo.push(o);\n        // Track references by document key and index collection parents.\n        for (var u = 0, s = r; u < s.length; u++) {\n            var a = s[u];\n            this.Bc = this.Bc.add(new wo(a.key, i)), this.Ei.qs(t, a.key.path.X());\n        }\n        return lr.resolve(o);\n    }, t.prototype.Pi = function(t, e) {\n        return lr.resolve(this.qc(e));\n    }, t.prototype.gi = function(t, e) {\n        var n = e + 1, r = this.Uc(n), i = r < 0 ? 0 : r;\n        // The requested batchId may still be out of range so normalize it to the\n        // start of the queue.\n                return lr.resolve(this.zo.length > i ? this.zo[i] : null);\n    }, t.prototype.Vi = function() {\n        return lr.resolve(0 === this.zo.length ? -1 : this.Lc - 1);\n    }, t.prototype.pi = function(t) {\n        return lr.resolve(this.zo.slice());\n    }, t.prototype.bi = function(t, e) {\n        var n = this, r = new wo(e, 0), i = new wo(e, Number.POSITIVE_INFINITY), o = [];\n        return this.Bc.me([ r, i ], (function(t) {\n            var e = n.qc(t.Mc);\n            o.push(e);\n        })), lr.resolve(o);\n    }, t.prototype.vi = function(t, e) {\n        var n = this, r = new sn(C);\n        return e.forEach((function(t) {\n            var e = new wo(t, 0), i = new wo(t, Number.POSITIVE_INFINITY);\n            n.Bc.me([ e, i ], (function(t) {\n                r = r.add(t.Mc);\n            }));\n        })), lr.resolve(this.Qc(r));\n    }, t.prototype.Di = function(t, e) {\n        // Use the query path as a prefix for testing if a document matches the\n        // query.\n        var n = e.path, r = n.length + 1, i = n;\n        // Construct a document reference for actually scanning the index. Unlike\n        // the prefix the document key in this reference must have an even number of\n        // segments. The empty segment can be used a suffix of the query path\n        // because it precedes all other segments in an ordered traversal.\n                tt.wt(i) || (i = i.child(\"\"));\n        var o = new wo(new tt(i), 0), u = new sn(C);\n        // Find unique batchIDs referenced by all documents potentially matching the\n        // query.\n                return this.Bc.Ae((function(t) {\n            var e = t.key.path;\n            return !!n.nt(e) && (\n            // Rows with document keys more than one segment longer than the query\n            // path can't be matches. For example, a query on 'rooms' can't match\n            // the document /rooms/abc/messages/xyx.\n            // TODO(mcg): we'll need a different scanner when we implement\n            // ancestor queries.\n            e.length === r && (u = u.add(t.Mc)), !0);\n        }), o), lr.resolve(this.Qc(u));\n    }, t.prototype.Qc = function(t) {\n        var e = this, n = [];\n        // Construct an array of matching batches, sorted by batchID to ensure that\n        // multiple mutations affecting the same document key are applied in order.\n                return t.forEach((function(t) {\n            var r = e.qc(t);\n            null !== r && n.push(r);\n        })), n;\n    }, t.prototype.Ci = function(t, e) {\n        var n = this;\n        k(0 === this.Kc(e.batchId, \"removed\")), this.zo.shift();\n        var r = this.Bc;\n        return lr.forEach(e.mutations, (function(i) {\n            var o = new wo(i.key, e.batchId);\n            return r = r.delete(o), n.Ti.Ni(t, i.key);\n        })).next((function() {\n            n.Bc = r;\n        }));\n    }, t.prototype.xi = function(t) {\n        // No-op since the memory mutation queue does not maintain a separate cache.\n    }, t.prototype.Fi = function(t, e) {\n        var n = new wo(e, 0), r = this.Bc.Re(n);\n        return lr.resolve(e.isEqual(r && r.key));\n    }, t.prototype.$i = function(t) {\n        return this.zo.length, lr.resolve();\n    }, \n    /**\n     * Finds the index of the given batchId in the mutation queue and asserts that\n     * the resulting index is within the bounds of the queue.\n     *\n     * @param batchId - The batchId to search for\n     * @param action - A description of what the caller is doing, phrased in passive\n     * form (e.g. \"acknowledged\" in a routine that acknowledges batches).\n     */\n    t.prototype.Kc = function(t, e) {\n        return this.Uc(t);\n    }, \n    /**\n     * Finds the index of the given batchId in the mutation queue. This operation\n     * is O(1).\n     *\n     * @returns The computed index of the batch with the given batchId, based on\n     * the state of the queue. Note this index can be negative if the requested\n     * batchId has already been remvoed from the queue or past the end of the\n     * queue if the batchId is larger than the last added batch.\n     */\n    t.prototype.Uc = function(t) {\n        return 0 === this.zo.length ? 0 : t - this.zo[0].batchId;\n        // Examine the front of the queue to figure out the difference between the\n        // batchId and indexes in the array. Note that since the queue is ordered\n        // by batchId, if the first batch has a larger batchId then the requested\n        // batchId doesn't exist in the queue.\n        }, \n    /**\n     * A version of lookupMutationBatch that doesn't return a promise, this makes\n     * other functions that uses this code easier to read and more efficent.\n     */\n    t.prototype.qc = function(t) {\n        var e = this.Uc(t);\n        return e < 0 || e >= this.zo.length ? null : this.zo[e];\n    }, t;\n}(), _o = /** @class */ function() {\n    /**\n     * @param sizer - Used to assess the size of a document. For eager GC, this is\n     * expected to just return 0 to avoid unnecessarily doing the work of\n     * calculating the size.\n     */\n    function t(t, e) {\n        this.Ei = t, this.Wc = e, \n        /** Underlying cache of documents and their read times. */\n        this.docs = new rn(tt.H), \n        /** Size of all cached documents. */\n        this.size = 0\n        /**\n     * Adds the supplied entry to the cache and updates the cache size as appropriate.\n     *\n     * All calls of `addEntry`  are required to go through the RemoteDocumentChangeBuffer\n     * returned by `newChangeBuffer()`.\n     */;\n    }\n    return t.prototype.ai = function(t, e, n) {\n        var r = e.key, i = this.docs.get(r), o = i ? i.size : 0, u = this.Wc(e);\n        return this.docs = this.docs.zt(r, {\n            hi: e,\n            size: u,\n            readTime: n\n        }), this.size += u - o, this.Ei.qs(t, r.path.X());\n    }, \n    /**\n     * Removes the specified entry from the cache and updates the cache size as appropriate.\n     *\n     * All calls of `removeEntry` are required to go through the RemoteDocumentChangeBuffer\n     * returned by `newChangeBuffer()`.\n     */\n    t.prototype.li = function(t) {\n        var e = this.docs.get(t);\n        e && (this.docs = this.docs.remove(t), this.size -= e.size);\n    }, t.prototype._i = function(t, e) {\n        var n = this.docs.get(e);\n        return lr.resolve(n ? n.hi : null);\n    }, t.prototype.getEntries = function(t, e) {\n        var n = this, r = fn();\n        return e.forEach((function(t) {\n            var e = n.docs.get(t);\n            r = r.zt(t, e ? e.hi : null);\n        })), lr.resolve(r);\n    }, t.prototype.Kr = function(t, e, n) {\n        for (var r = pn(), i = new tt(e.path.child(\"\")), o = this.docs.ee(i)\n        // Documents are ordered by key, so we can use a prefix scan to narrow down\n        // the documents we need to match the query against.\n        ; o.ce(); ) {\n            var u = o.oe(), s = u.key, a = u.value, c = a.hi, h = a.readTime;\n            if (!e.path.nt(s.path)) break;\n            h._(n) <= 0 || c instanceof Pt && ve(e, c) && (r = r.zt(c.key, c));\n        }\n        return lr.resolve(r);\n    }, t.prototype.jc = function(t, e) {\n        return lr.forEach(this.docs, (function(t) {\n            return e(t);\n        }));\n    }, t.prototype.Nr = function(t) {\n        // `trackRemovals` is ignores since the MemoryRemoteDocumentCache keeps\n        // a separate changelog and does not need special handling for removals.\n        return new Io(this);\n    }, t.prototype.Or = function(t) {\n        return lr.resolve(this.size);\n    }, t;\n}(), Io = /** @class */ function(t) {\n    function e(e) {\n        var n = this;\n        return (n = t.call(this) || this).jr = e, n;\n    }\n    return m(e, t), e.prototype.wi = function(t) {\n        var e = this, n = [];\n        return this.ri.forEach((function(r, i) {\n            i && i.hi ? n.push(e.jr.ai(t, i.hi, e.ci(r))) : e.jr.li(r);\n        })), lr.Mn(n);\n    }, e.prototype.fi = function(t, e) {\n        return this.jr._i(t, e);\n    }, e.prototype.di = function(t, e) {\n        return this.jr.getEntries(t, e);\n    }, e;\n}(wi), Eo = /** @class */ function() {\n    function t(t) {\n        this.persistence = t, \n        /**\n             * Maps a target to the data about that target\n             */\n        this.Gc = new gi((function(t) {\n            return Ut(t);\n        }), Mt), \n        /** The last received snapshot version. */\n        this.lastRemoteSnapshotVersion = X.min(), \n        /** The highest numbered target ID encountered. */\n        this.highestTargetId = 0, \n        /** The highest sequence number encountered. */\n        this.zc = 0, \n        /**\n             * A ordered bidirectional mapping between documents and the remote target\n             * IDs.\n             */\n        this.Hc = new go, this.targetCount = 0, this.Jc = Di.Mi();\n    }\n    return t.prototype.In = function(t, e) {\n        return this.Gc.forEach((function(t, n) {\n            return e(n);\n        })), lr.resolve();\n    }, t.prototype.Qi = function(t) {\n        return lr.resolve(this.lastRemoteSnapshotVersion);\n    }, t.prototype.Ki = function(t) {\n        return lr.resolve(this.zc);\n    }, t.prototype.Bi = function(t) {\n        return this.highestTargetId = this.Jc.next(), lr.resolve(this.highestTargetId);\n    }, t.prototype.Wi = function(t, e, n) {\n        return n && (this.lastRemoteSnapshotVersion = n), e > this.zc && (this.zc = e), \n        lr.resolve();\n    }, t.prototype.Gi = function(t) {\n        this.Gc.set(t.target, t);\n        var e = t.targetId;\n        e > this.highestTargetId && (this.Jc = new Di(e), this.highestTargetId = e), t.sequenceNumber > this.zc && (this.zc = t.sequenceNumber);\n    }, t.prototype.ji = function(t, e) {\n        return this.Gi(e), this.targetCount += 1, lr.resolve();\n    }, t.prototype.Hi = function(t, e) {\n        return this.Gi(e), lr.resolve();\n    }, t.prototype.Ji = function(t, e) {\n        return this.Gc.delete(e.target), this.Hc.Fc(e.targetId), this.targetCount -= 1, \n        lr.resolve();\n    }, t.prototype.Xi = function(t, e, n) {\n        var r = this, i = 0, o = [];\n        return this.Gc.forEach((function(u, s) {\n            s.sequenceNumber <= e && null === n.get(s.targetId) && (r.Gc.delete(u), o.push(r.Yi(t, s.targetId)), \n            i++);\n        })), lr.Mn(o).next((function() {\n            return i;\n        }));\n    }, t.prototype.Zi = function(t) {\n        return lr.resolve(this.targetCount);\n    }, t.prototype.tr = function(t, e) {\n        var n = this.Gc.get(e) || null;\n        return lr.resolve(n);\n    }, t.prototype.er = function(t, e, n) {\n        return this.Hc.xc(e, n), lr.resolve();\n    }, t.prototype.sr = function(t, e, n) {\n        this.Hc.$c(e, n);\n        var r = this.persistence.Ti, i = [];\n        return r && e.forEach((function(e) {\n            i.push(r.Ni(t, e));\n        })), lr.Mn(i);\n    }, t.prototype.Yi = function(t, e) {\n        return this.Hc.Fc(e), lr.resolve();\n    }, t.prototype.rr = function(t, e) {\n        var n = this.Hc.kc(e);\n        return lr.resolve(n);\n    }, t.prototype.Fi = function(t, e) {\n        return lr.resolve(this.Hc.Fi(e));\n    }, t;\n}(), To = /** @class */ function() {\n    /**\n     * The constructor accepts a factory for creating a reference delegate. This\n     * allows both the delegate and this instance to have strong references to\n     * each other without having nullable fields that would then need to be\n     * checked or asserted on every access.\n     */\n    function t(t, e) {\n        var n = this;\n        this.Yc = {}, this.so = new H(0), this.io = !1, this.io = !0, this.Ti = t(this), \n        this._o = new Eo(this), this.Ei = new fi, this.fo = function(t, e) {\n            return new _o(t, (function(t) {\n                return n.Ti.Xc(t);\n            }));\n        }(this.Ei), this.Qt = new Zr(e), this.wo = new mo(this.Qt);\n    }\n    return t.prototype.start = function() {\n        return Promise.resolve();\n    }, t.prototype.ko = function() {\n        // No durable state to ensure is closed on shutdown.\n        return this.io = !1, Promise.resolve();\n    }, Object.defineProperty(t.prototype, \"Er\", {\n        get: function() {\n            return this.io;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.Po = function() {\n        // No op.\n    }, t.prototype.yo = function() {\n        // No op.\n    }, t.prototype.Ko = function() {\n        return this.Ei;\n    }, t.prototype.Qo = function(t) {\n        var e = this.Yc[t.A()];\n        return e || (e = new bo(this.Ei, this.Ti), this.Yc[t.A()] = e), e;\n    }, t.prototype.Sr = function() {\n        return this._o;\n    }, t.prototype.$r = function() {\n        return this.fo;\n    }, t.prototype.Wo = function() {\n        return this.wo;\n    }, t.prototype.runTransaction = function(t, e, n) {\n        var r = this;\n        N(\"MemoryPersistence\", \"Starting transaction:\", t);\n        var i = new No(this.so.next());\n        return this.Ti.Zc(), n(i).next((function(t) {\n            return r.Ti.ta(i).next((function() {\n                return t;\n            }));\n        })).On().then((function(t) {\n            return i.Vs(), t;\n        }));\n    }, t.prototype.ea = function(t, e) {\n        return lr.Ln(Object.values(this.Yc).map((function(n) {\n            return function() {\n                return n.Fi(t, e);\n            };\n        })));\n    }, t;\n}(), No = /** @class */ function(t) {\n    function e(e) {\n        var n = this;\n        return (n = t.call(this) || this).bs = e, n;\n    }\n    return m(e, t), e;\n}(Nr), Ao = /** @class */ function() {\n    function t(t) {\n        this.persistence = t, \n        /** Tracks all documents that are active in Query views. */\n        this.na = new go, \n        /** The list of documents that are potentially GCed after each transaction. */\n        this.sa = null;\n    }\n    return t.ia = function(e) {\n        return new t(e);\n    }, Object.defineProperty(t.prototype, \"ra\", {\n        get: function() {\n            if (this.sa) return this.sa;\n            throw x();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.nr = function(t, e, n) {\n        return this.na.nr(n, e), this.ra.delete(n.toString()), lr.resolve();\n    }, t.prototype.ir = function(t, e, n) {\n        return this.na.ir(n, e), this.ra.add(n.toString()), lr.resolve();\n    }, t.prototype.Ni = function(t, e) {\n        return this.ra.add(e.toString()), lr.resolve();\n    }, t.prototype.removeTarget = function(t, e) {\n        var n = this;\n        this.na.Fc(e.targetId).forEach((function(t) {\n            return n.ra.add(t.toString());\n        }));\n        var r = this.persistence.Sr();\n        return r.rr(t, e.targetId).next((function(t) {\n            t.forEach((function(t) {\n                return n.ra.add(t.toString());\n            }));\n        })).next((function() {\n            return r.Ji(t, e);\n        }));\n    }, t.prototype.Zc = function() {\n        this.sa = new Set;\n    }, t.prototype.ta = function(t) {\n        var e = this, n = this.persistence.$r().Nr();\n        // Remove newly orphaned documents.\n                return lr.forEach(this.ra, (function(r) {\n            var i = tt._t(r);\n            return e.oa(t, i).next((function(t) {\n                t || n.li(i);\n            }));\n        })).next((function() {\n            return e.sa = null, n.apply(t);\n        }));\n    }, t.prototype.Fr = function(t, e) {\n        var n = this;\n        return this.oa(t, e).next((function(t) {\n            t ? n.ra.delete(e.toString()) : n.ra.add(e.toString());\n        }));\n    }, t.prototype.Xc = function(t) {\n        // For eager GC, we don't care about the document size, there are no size thresholds.\n        return 0;\n    }, t.prototype.oa = function(t, e) {\n        var n = this;\n        return lr.Ln([ function() {\n            return lr.resolve(n.na.Fi(e));\n        }, function() {\n            return n.persistence.Sr().Fi(t, e);\n        }, function() {\n            return n.persistence.ea(t, e);\n        } ]);\n    }, t;\n}();\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A collection of references to a document from some kind of numbered entity\n * (either a target ID or batch ID). As references are added to or removed from\n * the set corresponding events are emitted to a registered garbage collector.\n *\n * Each reference is represented by a DocumentReference object. Each of them\n * contains enough information to uniquely identify the reference. They are all\n * stored primarily in a set sorted by key. A document is considered garbage if\n * there's no references in that set (this can be efficiently checked thanks to\n * sorting by key).\n *\n * ReferenceSet also keeps a secondary set that contains references sorted by\n * IDs. This one is used to efficiently implement removal of all references by\n * some target ID.\n */\n/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n// The format of the LocalStorage key that stores the client state is:\n//     firestore_clients_<persistence_prefix>_<instance_key>\n/** Assembles the key for a client state in WebStorage */\nfunction Do(t, e) {\n    return \"firestore_clients_\" + t + \"_\" + e;\n}\n\n// The format of the WebStorage key that stores the mutation state is:\n//     firestore_mutations_<persistence_prefix>_<batch_id>\n//     (for unauthenticated users)\n// or: firestore_mutations_<persistence_prefix>_<batch_id>_<user_uid>\n// 'user_uid' is last to avoid needing to escape '_' characters that it might\n// contain.\n/** Assembles the key for a mutation batch in WebStorage */ function So(t, e, n) {\n    var r = \"firestore_mutations_\" + t + \"_\" + n;\n    return e.m() && (r += \"_\" + e.uid), r;\n}\n\n// The format of the WebStorage key that stores a query target's metadata is:\n//     firestore_targets_<persistence_prefix>_<target_id>\n/** Assembles the key for a query state in WebStorage */ function xo(t, e) {\n    return \"firestore_targets_\" + t + \"_\" + e;\n}\n\n// The WebStorage prefix that stores the primary tab's online state. The\n// format of the key is:\n//     firestore_online_state_<persistence_prefix>\n/**\n * Holds the state of a mutation batch, including its user ID, batch ID and\n * whether the batch is 'pending', 'acknowledged' or 'rejected'.\n */\n// Visible for testing\nvar ko = /** @class */ function() {\n    function t(t, e, n, r) {\n        this.user = t, this.batchId = e, this.state = n, this.error = r\n        /**\n     * Parses a MutationMetadata from its JSON representation in WebStorage.\n     * Logs a warning and returns null if the format of the data is not valid.\n     */;\n    }\n    return t.ca = function(e, n, r) {\n        var i, o = JSON.parse(r), u = \"object\" == typeof o && -1 !== [ \"pending\", \"acknowledged\", \"rejected\" ].indexOf(o.state) && (void 0 === o.error || \"object\" == typeof o.error);\n        return u && o.error && ((u = \"string\" == typeof o.error.message && \"string\" == typeof o.error.code) && (i = new q(o.error.code, o.error.message))), \n        u ? new t(e, n, o.state, i) : (A(\"SharedClientState\", \"Failed to parse mutation state for ID '\" + n + \"': \" + r), \n        null);\n    }, t.prototype.aa = function() {\n        var t = {\n            state: this.state,\n            updateTimeMs: Date.now()\n        };\n        return this.error && (t.error = {\n            code: this.error.code,\n            message: this.error.message\n        }), JSON.stringify(t);\n    }, t;\n}(), Oo = /** @class */ function() {\n    function t(t, e, n) {\n        this.targetId = t, this.state = e, this.error = n\n        /**\n     * Parses a QueryTargetMetadata from its JSON representation in WebStorage.\n     * Logs a warning and returns null if the format of the data is not valid.\n     */;\n    }\n    return t.ca = function(e, n) {\n        var r, i = JSON.parse(n), o = \"object\" == typeof i && -1 !== [ \"not-current\", \"current\", \"rejected\" ].indexOf(i.state) && (void 0 === i.error || \"object\" == typeof i.error);\n        return o && i.error && ((o = \"string\" == typeof i.error.message && \"string\" == typeof i.error.code) && (r = new q(i.error.code, i.error.message))), \n        o ? new t(e, i.state, r) : (A(\"SharedClientState\", \"Failed to parse target state for ID '\" + e + \"': \" + n), \n        null);\n    }, t.prototype.aa = function() {\n        var t = {\n            state: this.state,\n            updateTimeMs: Date.now()\n        };\n        return this.error && (t.error = {\n            code: this.error.code,\n            message: this.error.message\n        }), JSON.stringify(t);\n    }, t;\n}(), Po = /** @class */ function() {\n    function t(t, e) {\n        this.clientId = t, this.activeTargetIds = e\n        /**\n     * Parses a RemoteClientState from the JSON representation in WebStorage.\n     * Logs a warning and returns null if the format of the data is not valid.\n     */;\n    }\n    return t.ca = function(e, n) {\n        for (var r = JSON.parse(n), i = \"object\" == typeof r && r.activeTargetIds instanceof Array, o = wn(), u = 0; i && u < r.activeTargetIds.length; ++u) i = dt(r.activeTargetIds[u]), \n        o = o.add(r.activeTargetIds[u]);\n        return i ? new t(e, o) : (A(\"SharedClientState\", \"Failed to parse client data for instance '\" + e + \"': \" + n), \n        null);\n    }, t;\n}(), Vo = /** @class */ function() {\n    function t(t, e) {\n        this.clientId = t, this.onlineState = e\n        /**\n     * Parses a SharedOnlineState from its JSON representation in WebStorage.\n     * Logs a warning and returns null if the format of the data is not valid.\n     */;\n    }\n    return t.ca = function(e) {\n        var n = JSON.parse(e);\n        return \"object\" == typeof n && -1 !== [ \"Unknown\", \"Online\", \"Offline\" ].indexOf(n.onlineState) && \"string\" == typeof n.clientId ? new t(n.clientId, n.onlineState) : (A(\"SharedClientState\", \"Failed to parse online state: \" + e), \n        null);\n    }, t;\n}(), Co = /** @class */ function() {\n    function t() {\n        this.activeTargetIds = wn();\n    }\n    return t.prototype.ua = function(t) {\n        this.activeTargetIds = this.activeTargetIds.add(t);\n    }, t.prototype.ha = function(t) {\n        this.activeTargetIds = this.activeTargetIds.delete(t);\n    }, \n    /**\n     * Converts this entry into a JSON-encoded format we can use for WebStorage.\n     * Does not encode `clientId` as it is part of the key in WebStorage.\n     */\n    t.prototype.aa = function() {\n        var t = {\n            activeTargetIds: this.activeTargetIds.it(),\n            updateTimeMs: Date.now()\n        };\n        return JSON.stringify(t);\n    }, t;\n}(), Lo = /** @class */ function() {\n    function t(t, e, n, r, i) {\n        this.window = t, this.Zr = e, this.persistenceKey = n, this.la = r, this._a = null, \n        this.fa = null, this.k = null, this.da = this.wa.bind(this), this.Ea = new rn(C), \n        this.Er = !1, \n        /**\n             * Captures WebStorage events that occur before `start()` is called. These\n             * events are replayed once `WebStorageSharedClientState` is started.\n             */\n        this.Ta = [];\n        // Escape the special characters mentioned here:\n        // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions\n        var o = n.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n        this.storage = this.window.localStorage, this.currentUser = i, this.Ia = Do(this.persistenceKey, this.la), \n        this.ma = \n        /** Assembles the key for the current sequence number. */\n        function(t) {\n            return \"firestore_sequence_number_\" + t;\n        }(this.persistenceKey), this.Ea = this.Ea.zt(this.la, new Co), this.Aa = new RegExp(\"^firestore_clients_\" + o + \"_([^_]*)$\"), \n        this.Ra = new RegExp(\"^firestore_mutations_\" + o + \"_(\\\\d+)(?:_(.*))?$\"), this.Pa = new RegExp(\"^firestore_targets_\" + o + \"_(\\\\d+)$\"), \n        this.ya = \n        /** Assembles the key for the online state of the primary tab. */\n        function(t) {\n            return \"firestore_online_state_\" + t;\n        }(this.persistenceKey), this.ga = function(t) {\n            return \"firestore_bundle_loaded_\" + t;\n        }(this.persistenceKey), \n        // Rather than adding the storage observer during start(), we add the\n        // storage observer during initialization. This ensures that we collect\n        // events before other components populate their initial state (during their\n        // respective start() calls). Otherwise, we might for example miss a\n        // mutation that is added after LocalStore's start() processed the existing\n        // mutations but before we observe WebStorage events.\n        this.window.addEventListener(\"storage\", this.da);\n    }\n    /** Returns 'true' if WebStorage is available in the current environment. */    return t.Kn = function(t) {\n        return !(!t || !t.localStorage);\n    }, t.prototype.start = function() {\n        return g(this, void 0, void 0, (function() {\n            var t, e, n, r, i, o, u, s, a, c, h, f = this;\n            return w(this, (function(l) {\n                switch (l.label) {\n                  case 0:\n                    return [ 4 /*yield*/ , this._a.Uo() ];\n\n                  case 1:\n                    for (t = l.sent(), e = 0, n = t; e < n.length; e++) (r = n[e]) !== this.la && (i = this.getItem(Do(this.persistenceKey, r))) && (o = Po.ca(r, i)) && (this.Ea = this.Ea.zt(o.clientId, o));\n                    for (this.Va(), (u = this.storage.getItem(this.ya)) && (s = this.pa(u)) && this.ba(s), \n                    a = 0, c = this.Ta; a < c.length; a++) h = c[a], this.wa(h);\n                    return this.Ta = [], \n                    // Register a window unload hook to remove the client metadata entry from\n                    // WebStorage even if `shutdown()` was not called.\n                    this.window.addEventListener(\"unload\", (function() {\n                        return f.ko();\n                    })), this.Er = !0, [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, t.prototype.B = function(t) {\n        this.setItem(this.ma, JSON.stringify(t));\n    }, t.prototype.va = function() {\n        return this.Sa(this.Ea);\n    }, t.prototype.Da = function(t) {\n        var e = !1;\n        return this.Ea.forEach((function(n, r) {\n            r.activeTargetIds.has(t) && (e = !0);\n        })), e;\n    }, t.prototype.Ca = function(t) {\n        this.xa(t, \"pending\");\n    }, t.prototype.Na = function(t, e, n) {\n        this.xa(t, e, n), \n        // Once a final mutation result is observed by other clients, they no longer\n        // access the mutation's metadata entry. Since WebStorage replays events\n        // in order, it is safe to delete the entry right after updating it.\n        this.$a(t);\n    }, t.prototype.Fa = function(t) {\n        var e = \"not-current\";\n        // Lookup an existing query state if the target ID was already registered\n        // by another tab\n                if (this.Da(t)) {\n            var n = this.storage.getItem(xo(this.persistenceKey, t));\n            if (n) {\n                var r = Oo.ca(t, n);\n                r && (e = r.state);\n            }\n        }\n        return this.Oa.ua(t), this.Va(), e;\n    }, t.prototype.ka = function(t) {\n        this.Oa.ha(t), this.Va();\n    }, t.prototype.Ma = function(t) {\n        return this.Oa.activeTargetIds.has(t);\n    }, t.prototype.La = function(t) {\n        this.removeItem(xo(this.persistenceKey, t));\n    }, t.prototype.Ba = function(t, e, n) {\n        this.qa(t, e, n);\n    }, t.prototype.Ua = function(t, e, n) {\n        var r = this;\n        e.forEach((function(t) {\n            r.$a(t);\n        })), this.currentUser = t, n.forEach((function(t) {\n            r.Ca(t);\n        }));\n    }, t.prototype.Qa = function(t) {\n        this.Ka(t);\n    }, t.prototype.Wa = function() {\n        this.ja();\n    }, t.prototype.ko = function() {\n        this.Er && (this.window.removeEventListener(\"storage\", this.da), this.removeItem(this.Ia), \n        this.Er = !1);\n    }, t.prototype.getItem = function(t) {\n        var e = this.storage.getItem(t);\n        return N(\"SharedClientState\", \"READ\", t, e), e;\n    }, t.prototype.setItem = function(t, e) {\n        N(\"SharedClientState\", \"SET\", t, e), this.storage.setItem(t, e);\n    }, t.prototype.removeItem = function(t) {\n        N(\"SharedClientState\", \"REMOVE\", t), this.storage.removeItem(t);\n    }, t.prototype.wa = function(t) {\n        var e = this, n = t;\n        // Note: The function is typed to take Event to be interface-compatible with\n        // `Window.addEventListener`.\n                if (n.storageArea === this.storage) {\n            if (N(\"SharedClientState\", \"EVENT\", n.key, n.newValue), n.key === this.Ia) return void A(\"Received WebStorage notification for local change. Another client might have garbage-collected our state\");\n            this.Zr.po((function() {\n                return g(e, void 0, void 0, (function() {\n                    var t, e, r, i, o, u;\n                    return w(this, (function(s) {\n                        if (this.Er) {\n                            if (null !== n.key) if (this.Aa.test(n.key)) {\n                                if (null == n.newValue) return t = this.Ga(n.key), [ 2 /*return*/ , this.za(t, null) ];\n                                if (e = this.Ha(n.key, n.newValue)) return [ 2 /*return*/ , this.za(e.clientId, e) ];\n                            } else if (this.Ra.test(n.key)) {\n                                if (null !== n.newValue && (r = this.Ja(n.key, n.newValue))) return [ 2 /*return*/ , this.Ya(r) ];\n                            } else if (this.Pa.test(n.key)) {\n                                if (null !== n.newValue && (i = this.Xa(n.key, n.newValue))) return [ 2 /*return*/ , this.Za(i) ];\n                            } else if (n.key === this.ya) {\n                                if (null !== n.newValue && (o = this.pa(n.newValue))) return [ 2 /*return*/ , this.ba(o) ];\n                            } else if (n.key === this.ma) (u = function(t) {\n                                var e = H.q;\n                                if (null != t) try {\n                                    var n = JSON.parse(t);\n                                    k(\"number\" == typeof n), e = n;\n                                } catch (t) {\n                                    A(\"SharedClientState\", \"Failed to read sequence number from WebStorage\", t);\n                                }\n                                return e;\n                            }(n.newValue)) !== H.q && this.k(u); else if (n.key === this.ga) return [ 2 /*return*/ , this._a.tu() ];\n                        } else this.Ta.push(n);\n                        return [ 2 /*return*/ ];\n                    }));\n                }));\n            }));\n        }\n    }, Object.defineProperty(t.prototype, \"Oa\", {\n        get: function() {\n            return this.Ea.get(this.la);\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.Va = function() {\n        this.setItem(this.Ia, this.Oa.aa());\n    }, t.prototype.xa = function(t, e, n) {\n        var r = new ko(this.currentUser, t, e, n), i = So(this.persistenceKey, this.currentUser, t);\n        this.setItem(i, r.aa());\n    }, t.prototype.$a = function(t) {\n        var e = So(this.persistenceKey, this.currentUser, t);\n        this.removeItem(e);\n    }, t.prototype.Ka = function(t) {\n        var e = {\n            clientId: this.la,\n            onlineState: t\n        };\n        this.storage.setItem(this.ya, JSON.stringify(e));\n    }, t.prototype.qa = function(t, e, n) {\n        var r = xo(this.persistenceKey, t), i = new Oo(t, e, n);\n        this.setItem(r, i.aa());\n    }, t.prototype.ja = function() {\n        this.setItem(this.ga, \"value-not-used\");\n    }, \n    /**\n     * Parses a client state key in WebStorage. Returns null if the key does not\n     * match the expected key format.\n     */\n    t.prototype.Ga = function(t) {\n        var e = this.Aa.exec(t);\n        return e ? e[1] : null;\n    }, \n    /**\n     * Parses a client state in WebStorage. Returns 'null' if the value could not\n     * be parsed.\n     */\n    t.prototype.Ha = function(t, e) {\n        var n = this.Ga(t);\n        return Po.ca(n, e);\n    }, \n    /**\n     * Parses a mutation batch state in WebStorage. Returns 'null' if the value\n     * could not be parsed.\n     */\n    t.prototype.Ja = function(t, e) {\n        var n = this.Ra.exec(t), r = Number(n[1]), i = void 0 !== n[2] ? n[2] : null;\n        return ko.ca(new j(i), r, e);\n    }, \n    /**\n     * Parses a query target state from WebStorage. Returns 'null' if the value\n     * could not be parsed.\n     */\n    t.prototype.Xa = function(t, e) {\n        var n = this.Pa.exec(t), r = Number(n[1]);\n        return Oo.ca(r, e);\n    }, \n    /**\n     * Parses an online state from WebStorage. Returns 'null' if the value\n     * could not be parsed.\n     */\n    t.prototype.pa = function(t) {\n        return Vo.ca(t);\n    }, t.prototype.Ya = function(t) {\n        return g(this, void 0, void 0, (function() {\n            return w(this, (function(e) {\n                return t.user.uid === this.currentUser.uid ? [ 2 /*return*/ , this._a.eu(t.batchId, t.state, t.error) ] : (N(\"SharedClientState\", \"Ignoring mutation for non-active user \" + t.user.uid), \n                [ 2 /*return*/ ]);\n            }));\n        }));\n    }, t.prototype.Za = function(t) {\n        return this._a.nu(t.targetId, t.state, t.error);\n    }, t.prototype.za = function(t, e) {\n        var n = this, r = e ? this.Ea.zt(t, e) : this.Ea.remove(t), i = this.Sa(this.Ea), o = this.Sa(r), u = [], s = [];\n        return o.forEach((function(t) {\n            i.has(t) || u.push(t);\n        })), i.forEach((function(t) {\n            o.has(t) || s.push(t);\n        })), this._a.su(u, s).then((function() {\n            n.Ea = r;\n        }));\n    }, t.prototype.ba = function(t) {\n        // We check whether the client that wrote this online state is still active\n        // by comparing its client ID to the list of clients kept active in\n        // IndexedDb. If a client does not update their IndexedDb client state\n        // within 5 seconds, it is considered inactive and we don't emit an online\n        // state event.\n        this.Ea.get(t.clientId) && this.fa(t.onlineState);\n    }, t.prototype.Sa = function(t) {\n        var e = wn();\n        return t.forEach((function(t, n) {\n            e = e.Pe(n.activeTargetIds);\n        })), e;\n    }, t;\n}(), Ro = /** @class */ function() {\n    function t() {\n        this.iu = new Co, this.ru = {}, this.fa = null, this.k = null;\n    }\n    return t.prototype.Ca = function(t) {\n        // No op.\n    }, t.prototype.Na = function(t, e, n) {\n        // No op.\n    }, t.prototype.Fa = function(t) {\n        return this.iu.ua(t), this.ru[t] || \"not-current\";\n    }, t.prototype.Ba = function(t, e, n) {\n        this.ru[t] = e;\n    }, t.prototype.ka = function(t) {\n        this.iu.ha(t);\n    }, t.prototype.Ma = function(t) {\n        return this.iu.activeTargetIds.has(t);\n    }, t.prototype.La = function(t) {\n        delete this.ru[t];\n    }, t.prototype.va = function() {\n        return this.iu.activeTargetIds;\n    }, t.prototype.Da = function(t) {\n        return this.iu.activeTargetIds.has(t);\n    }, t.prototype.start = function() {\n        return this.iu = new Co, Promise.resolve();\n    }, t.prototype.Ua = function(t, e, n) {\n        // No op.\n    }, t.prototype.Qa = function(t) {\n        // No op.\n    }, t.prototype.ko = function() {}, t.prototype.B = function(t) {}, t.prototype.Wa = function() {\n        // No op.\n    }, t;\n}(), Uo = /** @class */ function() {\n    function t() {}\n    return t.prototype.ou = function(t) {\n        // No-op.\n    }, t.prototype.ko = function() {\n        // No-op.\n    }, t;\n}(), Mo = /** @class */ function() {\n    function t() {\n        var t = this;\n        this.cu = function() {\n            return t.au();\n        }, this.uu = function() {\n            return t.hu();\n        }, this.lu = [], this._u();\n    }\n    return t.prototype.ou = function(t) {\n        this.lu.push(t);\n    }, t.prototype.ko = function() {\n        window.removeEventListener(\"online\", this.cu), window.removeEventListener(\"offline\", this.uu);\n    }, t.prototype._u = function() {\n        window.addEventListener(\"online\", this.cu), window.addEventListener(\"offline\", this.uu);\n    }, t.prototype.au = function() {\n        N(\"ConnectivityMonitor\", \"Network connectivity changed: AVAILABLE\");\n        for (var t = 0, e = this.lu; t < e.length; t++) {\n            (0, e[t])(0 /* AVAILABLE */);\n        }\n    }, t.prototype.hu = function() {\n        N(\"ConnectivityMonitor\", \"Network connectivity changed: UNAVAILABLE\");\n        for (var t = 0, e = this.lu; t < e.length; t++) {\n            (0, e[t])(1 /* UNAVAILABLE */);\n        }\n    }, \n    // TODO(chenbrian): Consider passing in window either into this component or\n    // here for testing via FakeWindow.\n    /** Checks that all used attributes of window are available. */\n    t.Kn = function() {\n        return \"undefined\" != typeof window && void 0 !== window.addEventListener && void 0 !== window.removeEventListener;\n    }, t;\n}(), qo = {\n    BatchGetDocuments: \"batchGet\",\n    Commit: \"commit\",\n    RunQuery: \"runQuery\"\n}, Fo = /** @class */ function() {\n    function t(t) {\n        this.fu = t.fu, this.du = t.du;\n    }\n    return t.prototype.wu = function(t) {\n        this.Eu = t;\n    }, t.prototype.Tu = function(t) {\n        this.Iu = t;\n    }, t.prototype.onMessage = function(t) {\n        this.mu = t;\n    }, t.prototype.close = function() {\n        this.du();\n    }, t.prototype.send = function(t) {\n        this.fu(t);\n    }, t.prototype.Au = function() {\n        this.Eu();\n    }, t.prototype.Ru = function(t) {\n        this.Iu(t);\n    }, t.prototype.Pu = function(t) {\n        this.mu(t);\n    }, t;\n}(), jo = /** @class */ function(t) {\n    function e(e) {\n        var n = this;\n        return (n = t.call(this, e) || this).forceLongPolling = e.forceLongPolling, n.i = e.i, \n        n;\n    }\n    /**\n     * Base class for all Rest-based connections to the backend (WebChannel and\n     * HTTP).\n     */\n    return m(e, t), e.prototype.Su = function(t, e, n, r) {\n        return new Promise((function(i, o) {\n            var u = new c;\n            u.listenOnce(h.COMPLETE, (function() {\n                try {\n                    switch (u.getLastErrorCode()) {\n                      case f.NO_ERROR:\n                        var e = u.getResponseJson();\n                        N(\"Connection\", \"XHR received:\", JSON.stringify(e)), i(e);\n                        break;\n\n                      case f.TIMEOUT:\n                        N(\"Connection\", 'RPC \"' + t + '\" timed out'), o(new q(M.DEADLINE_EXCEEDED, \"Request time out\"));\n                        break;\n\n                      case f.HTTP_ERROR:\n                        var n = u.getStatus();\n                        if (N(\"Connection\", 'RPC \"' + t + '\" failed with status:', n, \"response text:\", u.getResponseText()), \n                        n > 0) {\n                            var r = u.getResponseJson().error;\n                            if (r && r.status && r.message) {\n                                var s = function(t) {\n                                    var e = t.toLowerCase().replace(/_/g, \"-\");\n                                    return Object.values(M).indexOf(e) >= 0 ? e : M.UNKNOWN;\n                                }(r.status);\n                                o(new q(s, r.message));\n                            } else o(new q(M.UNKNOWN, \"Server responded with status \" + u.getStatus()));\n                        } else \n                        // If we received an HTTP_ERROR but there's no status code,\n                        // it's most probably a connection issue\n                        o(new q(M.UNAVAILABLE, \"Connection failed.\"));\n                        break;\n\n                      default:\n                        x();\n                    }\n                } finally {\n                    N(\"Connection\", 'RPC \"' + t + '\" completed.');\n                }\n            }));\n            var s = JSON.stringify(r);\n            u.send(e, \"POST\", s, n, 15);\n        }));\n    }, e.prototype.Cu = function(t, e) {\n        var n = [ this.gu, \"/\", \"google.firestore.v1.Firestore\", \"/\", t, \"/channel\" ], c = l(), h = p(), f = {\n            // Required for backend stickiness, routing behavior is based on this\n            // parameter.\n            httpSessionIdParam: \"gsessionid\",\n            initMessageHeaders: {},\n            messageUrlParams: {\n                // This param is used to improve routing and project isolation by the\n                // backend and must be included in every request.\n                database: \"projects/\" + this.t.projectId + \"/databases/\" + this.t.database\n            },\n            sendRawJson: !0,\n            supportsCrossDomainXhr: !0,\n            internalChannelParams: {\n                // Override the default timeout (randomized between 10-20 seconds) since\n                // a large write batch on a slow internet connection may take a long\n                // time to send to the backend. Rather than have WebChannel impose a\n                // tight timeout which could lead to infinite timeouts and retries, we\n                // set it very large (5-10 minutes) and rely on the browser's builtin\n                // timeouts to kick in if the request isn't working.\n                forwardChannelRequestTimeoutMs: 6e5\n            },\n            forceLongPolling: this.forceLongPolling,\n            detectBufferingProxy: this.i\n        };\n        this.vu(f.initMessageHeaders, e), \n        // Sending the custom headers we just added to request.initMessageHeaders\n        // (Authorization, etc.) will trigger the browser to make a CORS preflight\n        // request because the XHR will no longer meet the criteria for a \"simple\"\n        // CORS request:\n        // https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS#Simple_requests\n        // Therefore to avoid the CORS preflight request (an extra network\n        // roundtrip), we use the httpHeadersOverwriteParam option to specify that\n        // the headers should instead be encoded into a special \"$httpHeaders\" query\n        // parameter, which is recognized by the webchannel backend. This is\n        // formally defined here:\n        // https://github.com/google/closure-library/blob/b0e1815b13fb92a46d7c9b3c30de5d6a396a3245/closure/goog/net/rpc/httpcors.js#L32\n        // TODO(b/145624756): There is a backend bug where $httpHeaders isn't respected if the request\n        // doesn't have an Origin header. So we have to exclude a few browser environments that are\n        // known to (sometimes) not include an Origin. See\n        // https://github.com/firebase/firebase-js-sdk/issues/1491.\n        r() || i() || o() || u() || s() || a() || (f.httpHeadersOverwriteParam = \"$httpHeaders\");\n        var m = n.join(\"\");\n        N(\"Connection\", \"Creating WebChannel: \" + m, f);\n        var g = c.createWebChannel(m, f), w = !1, b = !1, _ = new Fo({\n            fu: function(t) {\n                b ? N(\"Connection\", \"Not sending because WebChannel is closed:\", t) : (w || (N(\"Connection\", \"Opening WebChannel transport.\"), \n                g.open(), w = !0), N(\"Connection\", \"WebChannel sending:\", t), g.send(t));\n            },\n            du: function() {\n                return g.close();\n            }\n        }), I = function(t, e, n) {\n            // TODO(dimond): closure typing seems broken because WebChannel does\n            // not implement goog.events.Listenable\n            t.listen(e, (function(t) {\n                try {\n                    n(t);\n                } catch (t) {\n                    setTimeout((function() {\n                        throw t;\n                    }), 0);\n                }\n            }));\n        };\n        // WebChannel supports sending the first message with the handshake - saving\n        // a network round trip. However, it will have to call send in the same\n        // JS event loop as open. In order to enforce this, we delay actually\n        // opening the WebChannel until send is called. Whether we have called\n        // open is tracked with this variable.\n                // Closure events are guarded and exceptions are swallowed, so catch any\n        // exception and rethrow using a setTimeout so they become visible again.\n        // Note that eventually this function could go away if we are confident\n        // enough the code is exception free.\n        return I(g, d.EventType.OPEN, (function() {\n            b || N(\"Connection\", \"WebChannel transport opened.\");\n        })), I(g, d.EventType.CLOSE, (function() {\n            b || (b = !0, N(\"Connection\", \"WebChannel transport closed\"), _.Ru());\n        })), I(g, d.EventType.ERROR, (function(t) {\n            b || (b = !0, D(\"Connection\", \"WebChannel transport errored:\", t), _.Ru(new q(M.UNAVAILABLE, \"The operation could not be completed\")));\n        })), I(g, d.EventType.MESSAGE, (function(t) {\n            var e;\n            if (!b) {\n                var n = t.data[0];\n                k(!!n);\n                // TODO(b/35143891): There is a bug in One Platform that caused errors\n                // (and only errors) to be wrapped in an extra array. To be forward\n                // compatible with the bug we need to check either condition. The latter\n                // can be removed once the fix has been rolled out.\n                // Use any because msgData.error is not typed.\n                var r = n, i = r.error || (null === (e = r[0]) || void 0 === e ? void 0 : e.error);\n                if (i) {\n                    N(\"Connection\", \"WebChannel received error:\", i);\n                    // error.status will be a string like 'OK' or 'NOT_FOUND'.\n                    var o = i.status, u = \n                    /**\n * Maps an error Code from a GRPC status identifier like 'NOT_FOUND'.\n *\n * @returns The Code equivalent to the given status string or undefined if\n *     there is no match.\n */\n                    function(t) {\n                        // lookup by string\n                        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n                        var e = We[t];\n                        if (void 0 !== e) return nn(e);\n                    }(o), s = i.message;\n                    void 0 === u && (u = M.INTERNAL, s = \"Unknown error status: \" + o + \" with message \" + i.message), \n                    // Mark closed so no further events are propagated\n                    b = !0, _.Ru(new q(u, s)), g.close();\n                } else N(\"Connection\", \"WebChannel received:\", n), _.Pu(n);\n            }\n        })), I(h, v.STAT_EVENT, (function(t) {\n            t.stat === y.PROXY ? N(\"Connection\", \"Detected buffering proxy\") : t.stat === y.NOPROXY && N(\"Connection\", \"Detected no buffering proxy\");\n        })), setTimeout((function() {\n            // Technically we could/should wait for the WebChannel opened event,\n            // but because we want to send the first message with the WebChannel\n            // handshake we pretend the channel opened here (asynchronously), and\n            // then delay the actual open until the first message is sent.\n            _.Au();\n        }), 0), _;\n    }, e;\n}(/** @class */ function() {\n    function t(t) {\n        this.yu = t, this.t = t.t;\n        var e = t.ssl ? \"https\" : \"http\";\n        this.gu = e + \"://\" + t.host, this.Vu = \"projects/\" + this.t.projectId + \"/databases/\" + this.t.database + \"/documents\";\n    }\n    return t.prototype.pu = function(t, e, n, r) {\n        var i = this.bu(t, e);\n        N(\"RestConnection\", \"Sending: \", i, n);\n        var o = {};\n        return this.vu(o, r), this.Su(t, i, o, n).then((function(t) {\n            return N(\"RestConnection\", \"Received: \", t), t;\n        }), (function(e) {\n            throw D(\"RestConnection\", t + \" failed with error: \", e, \"url: \", i, \"request:\", n), \n            e;\n        }));\n    }, t.prototype.Du = function(t, e, n, r) {\n        // The REST API automatically aggregates all of the streamed results, so we\n        // can just use the normal invoke() method.\n        return this.pu(t, e, n, r);\n    }, \n    /**\n     * Modifies the headers for a request, adding any authorization token if\n     * present and any additional headers for the request.\n     */\n    t.prototype.vu = function(t, e) {\n        if (t[\"X-Goog-Api-Client\"] = \"gl-js/ fire/8.3.0\", \n        // Content-Type: text/plain will avoid preflight requests which might\n        // mess with CORS and redirects by proxies. If we add custom headers\n        // we will need to change this code to potentially use the $httpOverwrite\n        // parameter supported by ESF to avoid triggering preflight requests.\n        t[\"Content-Type\"] = \"text/plain\", e) for (var n in e.g) e.g.hasOwnProperty(n) && (t[n] = e.g[n]);\n    }, t.prototype.bu = function(t, e) {\n        var n = qo[t];\n        return this.gu + \"/v1/\" + e + \":\" + n;\n    }, t;\n}());\n\n/**\n * Holds the state of a query target, including its target ID and whether the\n * target is 'not-current', 'current' or 'rejected'.\n */\n// Visible for testing\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/** Initializes the WebChannelConnection for the browser. */\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/** The Platform's 'window' implementation or null if not available. */\nfunction zo() {\n    // `window` is not always available, e.g. in ReactNative and WebWorkers.\n    // eslint-disable-next-line no-restricted-globals\n    return \"undefined\" != typeof window ? window : null;\n}\n\n/** The Platform's 'document' implementation or null if not available. */ function Go() {\n    // `document` is not always available, e.g. in ReactNative and WebWorkers.\n    // eslint-disable-next-line no-restricted-globals\n    return \"undefined\" != typeof document ? document : null;\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ function Bo(t) {\n    return new Cn(t, /* useProto3Json= */ !0);\n}\n\n/**\n * An instance of the Platform's 'TextEncoder' implementation.\n */\n/**\n * A helper for running delayed tasks following an exponential backoff curve\n * between attempts.\n *\n * Each delay is made up of a \"base\" delay which follows the exponential\n * backoff curve, and a +/- 50% \"jitter\" that is calculated and added to the\n * base delay. This prevents clients from accidentally synchronizing their\n * delays causing spikes of load to the backend.\n */ var Qo = /** @class */ function() {\n    function t(\n    /**\n     * The AsyncQueue to run backoff operations on.\n     */\n    t, \n    /**\n     * The ID to use when scheduling backoff operations on the AsyncQueue.\n     */\n    e, \n    /**\n     * The initial delay (used as the base delay on the first retry attempt).\n     * Note that jitter will still be applied, so the actual delay could be as\n     * little as 0.5*initialDelayMs.\n     */\n    n\n    /**\n     * The multiplier to use to determine the extended base delay after each\n     * attempt.\n     */ , r\n    /**\n     * The maximum base delay after which no further backoff is performed.\n     * Note that jitter will still be applied, so the actual delay could be as\n     * much as 1.5*maxDelayMs.\n     */ , i) {\n        void 0 === n && (n = 1e3), void 0 === r && (r = 1.5), void 0 === i && (i = 6e4), \n        this.Zr = t, this.fs = e, this.xu = n, this.Nu = r, this.$u = i, this.Fu = 0, this.Ou = null, \n        /** The last backoff attempt, as epoch milliseconds. */\n        this.ku = Date.now(), this.reset();\n    }\n    /**\n     * Resets the backoff delay.\n     *\n     * The very next backoffAndWait() will have no delay. If it is called again\n     * (i.e. due to an error), initialDelayMs (plus jitter) will be used, and\n     * subsequent ones will increase according to the backoffFactor.\n     */    return t.prototype.reset = function() {\n        this.Fu = 0;\n    }, \n    /**\n     * Resets the backoff delay to the maximum delay (e.g. for use after a\n     * RESOURCE_EXHAUSTED error).\n     */\n    t.prototype.Mu = function() {\n        this.Fu = this.$u;\n    }, \n    /**\n     * Returns a promise that resolves after currentDelayMs, and increases the\n     * delay for any subsequent attempts. If there was a pending backoff operation\n     * already, it will be canceled.\n     */\n    t.prototype.Lu = function(t) {\n        var e = this;\n        // Cancel any pending backoff operation.\n                this.cancel();\n        // First schedule using the current base (which may be 0 and should be\n        // honored as such).\n        var n = Math.floor(this.Fu + this.Bu()), r = Math.max(0, Date.now() - this.ku), i = Math.max(0, n - r);\n        // Guard against lastAttemptTime being in the future due to a clock change.\n                i > 0 && N(\"ExponentialBackoff\", \"Backing off for \" + i + \" ms (base delay: \" + this.Fu + \" ms, delay with jitter: \" + n + \" ms, last attempt: \" + r + \" ms ago)\"), \n        this.Ou = this.Zr.Tr(this.fs, i, (function() {\n            return e.ku = Date.now(), t();\n        })), \n        // Apply backoff factor to determine next delay and ensure it is within\n        // bounds.\n        this.Fu *= this.Nu, this.Fu < this.xu && (this.Fu = this.xu), this.Fu > this.$u && (this.Fu = this.$u);\n    }, t.prototype.qu = function() {\n        null !== this.Ou && (this.Ou.Rs(), this.Ou = null);\n    }, t.prototype.cancel = function() {\n        null !== this.Ou && (this.Ou.cancel(), this.Ou = null);\n    }, \n    /** Returns a random value in the range [-currentBaseMs/2, currentBaseMs/2] */ t.prototype.Bu = function() {\n        return (Math.random() - .5) * this.Fu;\n    }, t;\n}(), Yo = /** @class */ function() {\n    function t(t, e, n, r, i, o) {\n        this.Zr = t, this.Uu = n, this.Qu = r, this.Ku = i, this.listener = o, this.state = 0 /* Initial */ , \n        /**\n             * A close count that's incremented every time the stream is closed; used by\n             * getCloseGuardedDispatcher() to invalidate callbacks that happen after\n             * close.\n             */\n        this.Wu = 0, this.ju = null, this.stream = null, this.Gu = new Qo(t, e)\n        /**\n     * Returns true if start() has been called and no error has occurred. True\n     * indicates the stream is open or in the process of opening (which\n     * encompasses respecting backoff, getting auth tokens, and starting the\n     * actual RPC). Use isOpen() to determine if the stream is open and ready for\n     * outbound requests.\n     */;\n    }\n    return t.prototype.zu = function() {\n        return 1 /* Starting */ === this.state || 2 /* Open */ === this.state || 4 /* Backoff */ === this.state;\n    }, \n    /**\n     * Returns true if the underlying RPC is open (the onOpen() listener has been\n     * called) and the stream is ready for outbound requests.\n     */\n    t.prototype.Hu = function() {\n        return 2 /* Open */ === this.state;\n    }, \n    /**\n     * Starts the RPC. Only allowed if isStarted() returns false. The stream is\n     * not immediately ready for use: onOpen() will be invoked when the RPC is\n     * ready for outbound requests, at which point isOpen() will return true.\n     *\n     * When start returns, isStarted() will return true.\n     */\n    t.prototype.start = function() {\n        3 /* Error */ !== this.state ? this.auth() : this.Ju();\n    }, \n    /**\n     * Stops the RPC. This call is idempotent and allowed regardless of the\n     * current isStarted() state.\n     *\n     * When stop returns, isStarted() and isOpen() will both return false.\n     */\n    t.prototype.stop = function() {\n        return g(this, void 0, void 0, (function() {\n            return w(this, (function(t) {\n                switch (t.label) {\n                  case 0:\n                    return this.zu() ? [ 4 /*yield*/ , this.close(0 /* Initial */) ] : [ 3 /*break*/ , 2 ];\n\n                  case 1:\n                    t.sent(), t.label = 2;\n\n                  case 2:\n                    return [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, \n    /**\n     * After an error the stream will usually back off on the next attempt to\n     * start it. If the error warrants an immediate restart of the stream, the\n     * sender can use this to indicate that the receiver should not back off.\n     *\n     * Each error will call the onClose() listener. That function can decide to\n     * inhibit backoff if required.\n     */\n    t.prototype.Yu = function() {\n        this.state = 0 /* Initial */ , this.Gu.reset();\n    }, \n    /**\n     * Marks this stream as idle. If no further actions are performed on the\n     * stream for one minute, the stream will automatically close itself and\n     * notify the stream's onClose() handler with Status.OK. The stream will then\n     * be in a !isStarted() state, requiring the caller to start the stream again\n     * before further use.\n     *\n     * Only streams that are in state 'Open' can be marked idle, as all other\n     * states imply pending network operations.\n     */\n    t.prototype.Xu = function() {\n        var t = this;\n        // Starts the idle time if we are in state 'Open' and are not yet already\n        // running a timer (in which case the previous idle timeout still applies).\n                this.Hu() && null === this.ju && (this.ju = this.Zr.Tr(this.Uu, 6e4, (function() {\n            return t.Zu();\n        })));\n    }, \n    /** Sends a message to the underlying stream. */ t.prototype.th = function(t) {\n        this.eh(), this.stream.send(t);\n    }, \n    /** Called by the idle timer when the stream should close due to inactivity. */ t.prototype.Zu = function() {\n        return g(this, void 0, void 0, (function() {\n            return w(this, (function(t) {\n                return this.Hu() ? [ 2 /*return*/ , this.close(0 /* Initial */) ] : [ 2 /*return*/ ];\n            }));\n        }));\n    }, \n    /** Marks the stream as active again. */ t.prototype.eh = function() {\n        this.ju && (this.ju.cancel(), this.ju = null);\n    }, \n    /**\n     * Closes the stream and cleans up as necessary:\n     *\n     * * closes the underlying GRPC stream;\n     * * calls the onClose handler with the given 'error';\n     * * sets internal stream state to 'finalState';\n     * * adjusts the backoff timer based on the error\n     *\n     * A new stream can be opened by calling start().\n     *\n     * @param finalState - the intended state of the stream after closing.\n     * @param error - the error the connection was closed with.\n     */\n    t.prototype.close = function(t, e) {\n        return g(this, void 0, void 0, (function() {\n            return w(this, (function(n) {\n                switch (n.label) {\n                  case 0:\n                    // Notify the listener that the stream closed.\n                    // Cancel any outstanding timers (they're guaranteed not to execute).\n                    return this.eh(), this.Gu.cancel(), \n                    // Invalidates any stream-related callbacks (e.g. from auth or the\n                    // underlying stream), guaranteeing they won't execute.\n                    this.Wu++, 3 /* Error */ !== t ? \n                    // If this is an intentional close ensure we don't delay our next connection attempt.\n                    this.Gu.reset() : e && e.code === M.RESOURCE_EXHAUSTED ? (\n                    // Log the error. (Probably either 'quota exceeded' or 'max queue length reached'.)\n                    A(e.toString()), A(\"Using maximum backoff delay to prevent overloading the backend.\"), \n                    this.Gu.Mu()) : e && e.code === M.UNAUTHENTICATED && \n                    // \"unauthenticated\" error means the token was rejected. Try force refreshing it in case it\n                    // just expired.\n                    this.Ku.p(), \n                    // Clean up the underlying stream because we are no longer interested in events.\n                    null !== this.stream && (this.nh(), this.stream.close(), this.stream = null), \n                    // This state must be assigned before calling onClose() to allow the callback to\n                    // inhibit backoff or otherwise manipulate the state in its non-started state.\n                    this.state = t, [ 4 /*yield*/ , this.listener.Tu(e) ];\n\n                  case 1:\n                    // Cancel any outstanding timers (they're guaranteed not to execute).\n                    // Notify the listener that the stream closed.\n                    return n.sent(), [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, \n    /**\n     * Can be overridden to perform additional cleanup before the stream is closed.\n     * Calling super.tearDown() is not required.\n     */\n    t.prototype.nh = function() {}, t.prototype.auth = function() {\n        var t = this;\n        this.state = 1 /* Starting */;\n        var e = this.sh(this.Wu), n = this.Wu;\n        // TODO(mikelehen): Just use dispatchIfNotClosed, but see TODO below.\n                this.Ku.getToken().then((function(e) {\n            // Stream can be stopped while waiting for authentication.\n            // TODO(mikelehen): We really should just use dispatchIfNotClosed\n            // and let this dispatch onto the queue, but that opened a spec test can\n            // of worms that I don't want to deal with in this PR.\n            t.Wu === n && \n            // Normally we'd have to schedule the callback on the AsyncQueue.\n            // However, the following calls are safe to be called outside the\n            // AsyncQueue since they don't chain asynchronous calls\n            t.ih(e);\n        }), (function(n) {\n            e((function() {\n                var e = new q(M.UNKNOWN, \"Fetching auth token failed: \" + n.message);\n                return t.rh(e);\n            }));\n        }));\n    }, t.prototype.ih = function(t) {\n        var e = this, n = this.sh(this.Wu);\n        this.stream = this.oh(t), this.stream.wu((function() {\n            n((function() {\n                return e.state = 2 /* Open */ , e.listener.wu();\n            }));\n        })), this.stream.Tu((function(t) {\n            n((function() {\n                return e.rh(t);\n            }));\n        })), this.stream.onMessage((function(t) {\n            n((function() {\n                return e.onMessage(t);\n            }));\n        }));\n    }, t.prototype.Ju = function() {\n        var t = this;\n        this.state = 4 /* Backoff */ , this.Gu.Lu((function() {\n            return g(t, void 0, void 0, (function() {\n                return w(this, (function(t) {\n                    return this.state = 0 /* Initial */ , this.start(), [ 2 /*return*/ ];\n                }));\n            }));\n        }));\n    }, \n    // Visible for tests\n    t.prototype.rh = function(t) {\n        // In theory the stream could close cleanly, however, in our current model\n        // we never expect this to happen because if we stop a stream ourselves,\n        // this callback will never be called. To prevent cases where we retry\n        // without a backoff accidentally, we set the stream to error in all cases.\n        return N(\"PersistentStream\", \"close with error: \" + t), this.stream = null, this.close(3 /* Error */ , t);\n    }, \n    /**\n     * Returns a \"dispatcher\" function that dispatches operations onto the\n     * AsyncQueue but only runs them if closeCount remains unchanged. This allows\n     * us to turn auth / stream callbacks into no-ops if the stream is closed /\n     * re-opened, etc.\n     */\n    t.prototype.sh = function(t) {\n        var e = this;\n        return function(n) {\n            e.Zr.Ps((function() {\n                return e.Wu === t ? n() : (N(\"PersistentStream\", \"stream callback skipped by getCloseGuardedDispatcher.\"), \n                Promise.resolve());\n            }));\n        };\n    }, t;\n}(), Ho = /** @class */ function(t) {\n    function e(e, n, r, i, o) {\n        var u = this;\n        return (u = t.call(this, e, \"listen_stream_connection_backoff\" /* ListenStreamConnectionBackoff */ , \"listen_stream_idle\" /* ListenStreamIdle */ , n, r, o) || this).Qt = i, \n        u;\n    }\n    return m(e, t), e.prototype.oh = function(t) {\n        return this.Qu.Cu(\"Listen\", t);\n    }, e.prototype.onMessage = function(t) {\n        // A successful response means the stream is healthy\n        this.Gu.reset();\n        var e = function(t, e) {\n            var n;\n            if (\"targetChange\" in e) {\n                e.targetChange;\n                // proto3 default value is unset in JSON (undefined), so use 'NO_CHANGE'\n                // if unset\n                var r = function(t) {\n                    return \"NO_CHANGE\" === t ? 0 /* NoChange */ : \"ADD\" === t ? 1 /* Added */ : \"REMOVE\" === t ? 2 /* Removed */ : \"CURRENT\" === t ? 3 /* Current */ : \"RESET\" === t ? 4 /* Reset */ : x();\n                }(e.targetChange.targetChangeType || \"NO_CHANGE\"), i = e.targetChange.targetIds || [], o = function(t, e) {\n                    return t.Bt ? (k(void 0 === e || \"string\" == typeof e), U.fromBase64String(e || \"\")) : (k(void 0 === e || e instanceof Uint8Array), \n                    U.fromUint8Array(e || new Uint8Array));\n                }(t, e.targetChange.resumeToken), u = (s = e.targetChange.cause) && function(t) {\n                    var e = void 0 === t.code ? M.UNKNOWN : nn(t.code);\n                    return new q(e, t.message || \"\");\n                }(s);\n                n = new Dn(r, i, o, u || null);\n            } else if (\"documentChange\" in e) {\n                e.documentChange, (r = e.documentChange).document, r.document.name, r.document.updateTime, \n                i = zn(t, r.document.name), o = Mn(r.document.updateTime);\n                var s = new St({\n                    mapValue: {\n                        fields: r.document.fields\n                    }\n                }), a = (u = new Pt(i, o, s, {}), r.targetIds || []), c = r.removedTargetIds || [];\n                n = new Nn(a, c, u.key, u);\n            } else if (\"documentDelete\" in e) e.documentDelete, (r = e.documentDelete).document, \n            i = zn(t, r.document), o = r.readTime ? Mn(r.readTime) : X.min(), s = new Vt(i, o), \n            u = r.removedTargetIds || [], n = new Nn([], u, s.key, s); else if (\"documentRemove\" in e) e.documentRemove, \n            (r = e.documentRemove).document, i = zn(t, r.document), o = r.removedTargetIds || [], \n            n = new Nn([], o, i, null); else {\n                if (!(\"filter\" in e)) return x();\n                e.filter;\n                var h = e.filter;\n                h.targetId, r = h.count || 0, i = new tn(r), o = h.targetId, n = new An(o, i);\n            }\n            return n;\n        }(this.Qt, t), n = function(t) {\n            // We have only reached a consistent snapshot for the entire stream if there\n            // is a read_time set and it applies to all targets (i.e. the list of\n            // targets is empty). The backend is guaranteed to send such responses.\n            if (!(\"targetChange\" in t)) return X.min();\n            var e = t.targetChange;\n            return e.targetIds && e.targetIds.length ? X.min() : e.readTime ? Mn(e.readTime) : X.min();\n        }(t);\n        return this.listener.ah(e, n);\n    }, \n    /**\n     * Registers interest in the results of the given target. If the target\n     * includes a resumeToken it will be included in the request. Results that\n     * affect the target will be streamed back as WatchChange messages that\n     * reference the targetId.\n     */\n    e.prototype.uh = function(t) {\n        var e = {};\n        e.database = Qn(this.Qt), e.addTarget = function(t, e) {\n            var n, r = e.target;\n            return (n = qt(r) ? {\n                documents: Zn(t, r)\n            } : {\n                query: Jn(t, r)\n            }).targetId = e.targetId, e.resumeToken.l() > 0 ? n.resumeToken = Rn(t, e.resumeToken) : e.Ot._(X.min()) > 0 && (\n            // TODO(wuandy): Consider removing above check because it is most likely true.\n            // Right now, many tests depend on this behaviour though (leaving min() out\n            // of serialization).\n            n.readTime = Ln(t, e.Ot.j())), n;\n        }(this.Qt, t);\n        var n = function(t, e) {\n            var n = function(t, e) {\n                switch (e) {\n                  case 0 /* Listen */ :\n                    return null;\n\n                  case 1 /* ExistenceFilterMismatch */ :\n                    return \"existence-filter-mismatch\";\n\n                  case 2 /* LimboResolution */ :\n                    return \"limbo-document\";\n\n                  default:\n                    return x();\n                }\n            }(0, e.Ft);\n            return null == n ? null : {\n                \"goog-listen-tags\": n\n            };\n        }(this.Qt, t);\n        n && (e.labels = n), this.th(e);\n    }, \n    /**\n     * Unregisters interest in the results of the target associated with the\n     * given targetId.\n     */\n    e.prototype.hh = function(t) {\n        var e = {};\n        e.database = Qn(this.Qt), e.removeTarget = t, this.th(e);\n    }, e;\n}(Yo), Ko = /** @class */ function(t) {\n    function e(e, n, r, i, o) {\n        var u = this;\n        return (u = t.call(this, e, \"write_stream_connection_backoff\" /* WriteStreamConnectionBackoff */ , \"write_stream_idle\" /* WriteStreamIdle */ , n, r, o) || this).Qt = i, \n        u.lh = !1, u;\n    }\n    return m(e, t), Object.defineProperty(e.prototype, \"_h\", {\n        /**\n         * Tracks whether or not a handshake has been successfully exchanged and\n         * the stream is ready to accept mutations.\n         */\n        get: function() {\n            return this.lh;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    // Override of PersistentStream.start\n    e.prototype.start = function() {\n        this.lh = !1, this.lastStreamToken = void 0, t.prototype.start.call(this);\n    }, e.prototype.nh = function() {\n        this.lh && this.fh([]);\n    }, e.prototype.oh = function(t) {\n        return this.Qu.Cu(\"Write\", t);\n    }, e.prototype.onMessage = function(t) {\n        if (\n        // Always capture the last stream token.\n        k(!!t.streamToken), this.lastStreamToken = t.streamToken, this.lh) {\n            // A successful first write response means the stream is healthy,\n            // Note, that we could consider a successful handshake healthy, however,\n            // the write itself might be causing an error we want to back off from.\n            this.Gu.reset();\n            var e = function(t, e) {\n                return t && t.length > 0 ? (k(void 0 !== e), t.map((function(t) {\n                    return function(t, e) {\n                        // NOTE: Deletes don't have an updateTime.\n                        var n = t.updateTime ? Mn(t.updateTime) : Mn(e);\n                        return n.isEqual(X.min()) && (\n                        // The Firestore Emulator currently returns an update time of 0 for\n                        // deletes of non-existing documents (rather than null). This breaks the\n                        // test \"get deleted doc while offline with source=cache\" as NoDocuments\n                        // with version 0 are filtered by IndexedDb's RemoteDocumentCache.\n                        // TODO(#2149): Remove this when Emulator is fixed\n                        n = Mn(e)), new Le(n, t.transformResults || []);\n                    }(t, e);\n                }))) : [];\n            }(t.writeResults, t.commitTime), n = Mn(t.commitTime);\n            return this.listener.dh(n, e);\n        }\n        // The first response is always the handshake response\n                return k(!t.writeResults || 0 === t.writeResults.length), this.lh = !0, \n        this.listener.wh();\n    }, \n    /**\n     * Sends an initial streamToken to the server, performing the handshake\n     * required to make the StreamingWrite RPC work. Subsequent\n     * calls should wait until onHandshakeComplete was called.\n     */\n    e.prototype.Eh = function() {\n        // TODO(dimond): Support stream resumption. We intentionally do not set the\n        // stream token on the handshake, ignoring any stream token we might have.\n        var t = {};\n        t.database = Qn(this.Qt), this.th(t);\n    }, \n    /** Sends a group of mutations to the Firestore backend to apply. */ e.prototype.fh = function(t) {\n        var e = this, n = {\n            streamToken: this.lastStreamToken,\n            writes: t.map((function(t) {\n                return Xn(e.Qt, t);\n            }))\n        };\n        this.th(n);\n    }, e;\n}(Yo), Xo = /** @class */ function(t) {\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this) || this).credentials = e, i.Qu = n, i.Qt = r, i.Th = !1, \n        i;\n    }\n    return m(e, t), e.prototype.Ih = function() {\n        if (this.Th) throw new q(M.FAILED_PRECONDITION, \"The client has already been terminated.\");\n    }, \n    /** Gets an auth token and invokes the provided RPC. */ e.prototype.pu = function(t, e, n) {\n        var r = this;\n        return this.Ih(), this.credentials.getToken().then((function(i) {\n            return r.Qu.pu(t, e, n, i);\n        })).catch((function(t) {\n            throw t.code === M.UNAUTHENTICATED && r.credentials.p(), t;\n        }));\n    }, \n    /** Gets an auth token and invokes the provided RPC with streamed results. */ e.prototype.Du = function(t, e, n) {\n        var r = this;\n        return this.Ih(), this.credentials.getToken().then((function(i) {\n            return r.Qu.Du(t, e, n, i);\n        })).catch((function(t) {\n            throw t.code === M.UNAUTHENTICATED && r.credentials.p(), t;\n        }));\n    }, e.prototype.terminate = function() {\n        this.Th = !1;\n    }, e;\n}((function() {})), Wo = /** @class */ function() {\n    function t(t, e) {\n        this._s = t, this.fa = e, \n        /** The current OnlineState. */\n        this.state = \"Unknown\" /* Unknown */ , \n        /**\n             * A count of consecutive failures to open the stream. If it reaches the\n             * maximum defined by MAX_WATCH_STREAM_FAILURES, we'll set the OnlineState to\n             * Offline.\n             */\n        this.mh = 0, \n        /**\n             * A timer that elapses after ONLINE_STATE_TIMEOUT_MS, at which point we\n             * transition from OnlineState.Unknown to OnlineState.Offline without waiting\n             * for the stream to actually fail (MAX_WATCH_STREAM_FAILURES times).\n             */\n        this.Ah = null, \n        /**\n             * Whether the client should log a warning message if it fails to connect to\n             * the backend (initially true, cleared after a successful stream, or if we've\n             * logged the message already).\n             */\n        this.Rh = !0\n        /**\n     * Called by RemoteStore when a watch stream is started (including on each\n     * backoff attempt).\n     *\n     * If this is the first attempt, it sets the OnlineState to Unknown and starts\n     * the onlineStateTimer.\n     */;\n    }\n    return t.prototype.Ph = function() {\n        var t = this;\n        0 === this.mh && (this.yh(\"Unknown\" /* Unknown */), this.Ah = this._s.Tr(\"online_state_timeout\" /* OnlineStateTimeout */ , 1e4, (function() {\n            return t.Ah = null, t.gh(\"Backend didn't respond within 10 seconds.\"), t.yh(\"Offline\" /* Offline */), \n            Promise.resolve();\n        })));\n    }, \n    /**\n     * Updates our OnlineState as appropriate after the watch stream reports a\n     * failure. The first failure moves us to the 'Unknown' state. We then may\n     * allow multiple failures (based on MAX_WATCH_STREAM_FAILURES) before we\n     * actually transition to the 'Offline' state.\n     */\n    t.prototype.Vh = function(t) {\n        \"Online\" /* Online */ === this.state ? this.yh(\"Unknown\" /* Unknown */) : (this.mh++, \n        this.mh >= 1 && (this.ph(), this.gh(\"Connection failed 1 times. Most recent error: \" + t.toString()), \n        this.yh(\"Offline\" /* Offline */)));\n    }, \n    /**\n     * Explicitly sets the OnlineState to the specified state.\n     *\n     * Note that this resets our timers / failure counters, etc. used by our\n     * Offline heuristics, so must not be used in place of\n     * handleWatchStreamStart() and handleWatchStreamFailure().\n     */\n    t.prototype.set = function(t) {\n        this.ph(), this.mh = 0, \"Online\" /* Online */ === t && (\n        // We've connected to watch at least once. Don't warn the developer\n        // about being offline going forward.\n        this.Rh = !1), this.yh(t);\n    }, t.prototype.yh = function(t) {\n        t !== this.state && (this.state = t, this.fa(t));\n    }, t.prototype.gh = function(t) {\n        var e = \"Could not reach Cloud Firestore backend. \" + t + \"\\nThis typically indicates that your device does not have a healthy Internet connection at the moment. The client will operate in offline mode until it is able to successfully connect to the backend.\";\n        this.Rh ? (A(e), this.Rh = !1) : N(\"OnlineStateTracker\", e);\n    }, t.prototype.ph = function() {\n        null !== this.Ah && (this.Ah.cancel(), this.Ah = null);\n    }, t;\n}(), Zo = function(\n/**\n     * The local store, used to fill the write pipeline with outbound mutations.\n     */\nt, \n/** The client-side proxy for interacting with the backend. */\ne, n, r, i) {\n    var o = this;\n    this.bh = t, this.Sh = e, this._s = n, this.Dh = {}, \n    /**\n             * A list of up to MAX_PENDING_WRITES writes that we have fetched from the\n             * LocalStore via fillWritePipeline() and have or will send to the write\n             * stream.\n             *\n             * Whenever writePipeline.length > 0 the RemoteStore will attempt to start or\n             * restart the write stream. When the stream is established the writes in the\n             * pipeline will be sent in order.\n             *\n             * Writes remain in writePipeline until they are acknowledged by the backend\n             * and thus will automatically be re-sent if the stream is interrupted /\n             * restarted before they're acknowledged.\n             *\n             * Write responses from the backend are linked to their originating request\n             * purely based on order, and so we can just shift() writes from the front of\n             * the writePipeline as we receive responses.\n             */\n    this.Ch = [], \n    /**\n             * A mapping of watched targets that the client cares about tracking and the\n             * user has explicitly called a 'listen' for this target.\n             *\n             * These targets may or may not have been sent to or acknowledged by the\n             * server. On re-establishing the listen stream, these targets should be sent\n             * to the server. The targets removed with unlistens are removed eagerly\n             * without waiting for confirmation from the listen stream.\n             */\n    this.xh = new Map, \n    /**\n             * A set of reasons for why the RemoteStore may be offline. If empty, the\n             * RemoteStore may start its network connections.\n             */\n    this.Nh = new Set, \n    /**\n             * Event handlers that get called when the network is disabled or enabled.\n             *\n             * PORTING NOTE: These functions are used on the Web client to create the\n             * underlying streams (to support tree-shakeable streams). On Android and iOS,\n             * the streams are created during construction of RemoteStore.\n             */\n    this.$h = [], this.Fh = i, this.Fh.ou((function(t) {\n        n.Ps((function() {\n            return g(o, void 0, void 0, (function() {\n                return w(this, (function(t) {\n                    switch (t.label) {\n                      case 0:\n                        return uu(this) ? (N(\"RemoteStore\", \"Restarting streams for network reachability change.\"), \n                        [ 4 /*yield*/ , function(t) {\n                            return g(this, void 0, void 0, (function() {\n                                var e;\n                                return w(this, (function(n) {\n                                    switch (n.label) {\n                                      case 0:\n                                        return (e = O(t)).Nh.add(4 /* ConnectivityChange */), [ 4 /*yield*/ , $o(e) ];\n\n                                      case 1:\n                                        return n.sent(), e.Oh.set(\"Unknown\" /* Unknown */), e.Nh.delete(4 /* ConnectivityChange */), \n                                        [ 4 /*yield*/ , Jo(e) ];\n\n                                      case 2:\n                                        return n.sent(), [ 2 /*return*/ ];\n                                    }\n                                }));\n                            }));\n                        }(this) ]) : [ 3 /*break*/ , 2 ];\n\n                      case 1:\n                        t.sent(), t.label = 2;\n\n                      case 2:\n                        return [ 2 /*return*/ ];\n                    }\n                }));\n            }));\n        }));\n    })), this.Oh = new Wo(n, r);\n};\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A PersistentStream is an abstract base class that represents a streaming RPC\n * to the Firestore backend. It's built on top of the connections own support\n * for streaming RPCs, and adds several critical features for our clients:\n *\n *   - Exponential backoff on failure\n *   - Authentication via CredentialsProvider\n *   - Dispatching all callbacks into the shared worker queue\n *   - Closing idle streams after 60 seconds of inactivity\n *\n * Subclasses of PersistentStream implement serialization of models to and\n * from the JSON representation of the protocol buffers for a specific\n * streaming RPC.\n *\n * ## Starting and Stopping\n *\n * Streaming RPCs are stateful and need to be start()ed before messages can\n * be sent and received. The PersistentStream will call the onOpen() function\n * of the listener once the stream is ready to accept requests.\n *\n * Should a start() fail, PersistentStream will call the registered onClose()\n * listener with a FirestoreError indicating what went wrong.\n *\n * A PersistentStream can be started and stopped repeatedly.\n *\n * Generic types:\n *  SendType: The type of the outgoing message of the underlying\n *    connection stream\n *  ReceiveType: The type of the incoming message of the underlying\n *    connection stream\n *  ListenerType: The type of the listener that will be used for callbacks\n */ function Jo(t) {\n    return g(this, void 0, void 0, (function() {\n        var e, n;\n        return w(this, (function(r) {\n            switch (r.label) {\n              case 0:\n                if (!uu(t)) return [ 3 /*break*/ , 4 ];\n                e = 0, n = t.$h, r.label = 1;\n\n              case 1:\n                return e < n.length ? [ 4 /*yield*/ , (0, n[e])(/* enabled= */ !0) ] : [ 3 /*break*/ , 4 ];\n\n              case 2:\n                r.sent(), r.label = 3;\n\n              case 3:\n                return e++, [ 3 /*break*/ , 1 ];\n\n              case 4:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * Temporarily disables the network. The network can be re-enabled using\n * enableNetwork().\n */ function $o(t) {\n    return g(this, void 0, void 0, (function() {\n        var e, n;\n        return w(this, (function(r) {\n            switch (r.label) {\n              case 0:\n                e = 0, n = t.$h, r.label = 1;\n\n              case 1:\n                return e < n.length ? [ 4 /*yield*/ , (0, n[e])(/* enabled= */ !1) ] : [ 3 /*break*/ , 4 ];\n\n              case 2:\n                r.sent(), r.label = 3;\n\n              case 3:\n                return e++, [ 3 /*break*/ , 1 ];\n\n              case 4:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * Starts new listen for the given target. Uses resume token if provided. It\n * is a no-op if the target of given `TargetData` is already being listened to.\n */ function tu(t, e) {\n    var n = O(t);\n    n.xh.has(e.targetId) || (\n    // Mark this as something the client is currently listening for.\n    n.xh.set(e.targetId, e), ou(n) ? \n    // The listen will be sent in onWatchStreamOpen\n    iu(n) : _u(n).Hu() && nu(n, e));\n}\n\n/**\n * Removes the listen from server. It is a no-op if the given target id is\n * not being listened to.\n */ function eu(t, e) {\n    var n = O(t), r = _u(n);\n    n.xh.delete(e), r.Hu() && ru(n, e), 0 === n.xh.size && (r.Hu() ? r.Xu() : uu(n) && \n    // Revert to OnlineState.Unknown if the watch stream is not open and we\n    // have no listeners, since without any listens to send we cannot\n    // confirm if the stream is healthy and upgrade to OnlineState.Online.\n    n.Oh.set(\"Unknown\" /* Unknown */));\n}\n\n/**\n * We need to increment the the expected number of pending responses we're due\n * from watch so we wait for the ack to process any messages from this target.\n */ function nu(t, e) {\n    t.kh.on(e.targetId), _u(t).uh(e)\n    /**\n * We need to increment the expected number of pending responses we're due\n * from watch so we wait for the removal on the server before we process any\n * messages from this target.\n */;\n}\n\nfunction ru(t, e) {\n    t.kh.on(e), _u(t).hh(e);\n}\n\nfunction iu(t) {\n    t.kh = new xn({\n        vn: function(e) {\n            return t.Dh.vn(e);\n        },\n        Sn: function(e) {\n            return t.xh.get(e) || null;\n        }\n    }), _u(t).start(), t.Oh.Ph()\n    /**\n * Returns whether the watch stream should be started because it's necessary\n * and has not yet been started.\n */;\n}\n\nfunction ou(t) {\n    return uu(t) && !_u(t).zu() && t.xh.size > 0;\n}\n\nfunction uu(t) {\n    return 0 === O(t).Nh.size;\n}\n\nfunction su(t) {\n    t.kh = void 0;\n}\n\nfunction au(t) {\n    return g(this, void 0, void 0, (function() {\n        return w(this, (function(e) {\n            return t.xh.forEach((function(e, n) {\n                nu(t, e);\n            })), [ 2 /*return*/ ];\n        }));\n    }));\n}\n\nfunction cu(t, e) {\n    return g(this, void 0, void 0, (function() {\n        return w(this, (function(n) {\n            return su(t), \n            // If we still need the watch stream, retry the connection.\n            ou(t) ? (t.Oh.Vh(e), iu(t)) : \n            // No need to restart watch stream because there are no active targets.\n            // The online state is set to unknown because there is no active attempt\n            // at establishing a connection\n            t.Oh.set(\"Unknown\" /* Unknown */), [ 2 /*return*/ ];\n        }));\n    }));\n}\n\nfunction hu(t, e, n) {\n    return g(this, void 0, void 0, (function() {\n        var r, i, o;\n        return w(this, (function(u) {\n            switch (u.label) {\n              case 0:\n                if (t.Oh.set(\"Online\" /* Online */), !(e instanceof Dn && 2 /* Removed */ === e.state && e.cause)) \n                // Mark the client as online since we got a message from the server\n                return [ 3 /*break*/ , 6 ];\n                u.label = 1;\n\n              case 1:\n                return u.trys.push([ 1, 3, , 5 ]), [ 4 /*yield*/ , \n                /** Handles an error on a target */\n                function(t, e) {\n                    return g(this, void 0, void 0, (function() {\n                        var n, r, i, o;\n                        return w(this, (function(u) {\n                            switch (u.label) {\n                              case 0:\n                                n = e.cause, r = 0, i = e.targetIds, u.label = 1;\n\n                              case 1:\n                                return r < i.length ? (o = i[r], t.xh.has(o) ? [ 4 /*yield*/ , t.Dh.Mh(o, n) ] : [ 3 /*break*/ , 3 ]) : [ 3 /*break*/ , 5 ];\n\n                              case 2:\n                                u.sent(), t.xh.delete(o), t.kh.removeTarget(o), u.label = 3;\n\n                              case 3:\n                                u.label = 4;\n\n                              case 4:\n                                return r++, [ 3 /*break*/ , 1 ];\n\n                              case 5:\n                                return [ 2 /*return*/ ];\n                            }\n                        }));\n                    }));\n                }(t, e) ];\n\n              case 2:\n                return u.sent(), [ 3 /*break*/ , 5 ];\n\n              case 3:\n                return r = u.sent(), N(\"RemoteStore\", \"Failed to remove targets %s: %s \", e.targetIds.join(\",\"), r), \n                [ 4 /*yield*/ , fu(t, r) ];\n\n              case 4:\n                return u.sent(), [ 3 /*break*/ , 5 ];\n\n              case 5:\n                return [ 3 /*break*/ , 13 ];\n\n              case 6:\n                if (e instanceof Nn ? t.kh.dn(e) : e instanceof An ? t.kh.Pn(e) : t.kh.Tn(e), n.isEqual(X.min())) return [ 3 /*break*/ , 13 ];\n                u.label = 7;\n\n              case 7:\n                return u.trys.push([ 7, 11, , 13 ]), [ 4 /*yield*/ , io(t.bh) ];\n\n              case 8:\n                return i = u.sent(), n._(i) >= 0 ? [ 4 /*yield*/ , \n                /**\n                 * Takes a batch of changes from the Datastore, repackages them as a\n                 * RemoteEvent, and passes that on to the listener, which is typically the\n                 * SyncEngine.\n                 */\n                function(t, e) {\n                    var n = t.kh.Vn(e);\n                    // Update in-memory resume tokens. LocalStore will update the\n                    // persistent view of these when applying the completed RemoteEvent.\n                                        return n.$e.forEach((function(n, r) {\n                        if (n.resumeToken.l() > 0) {\n                            var i = t.xh.get(r);\n                            // A watched target might have been removed already.\n                                                        i && t.xh.set(r, i.Mt(n.resumeToken, e));\n                        }\n                    })), \n                    // Re-establish listens for the targets that have been invalidated by\n                    // existence filter mismatches.\n                    n.Fe.forEach((function(e) {\n                        var n = t.xh.get(e);\n                        if (n) {\n                            // Clear the resume token for the target, since we're in a known mismatch\n                            // state.\n                            t.xh.set(e, n.Mt(U.T, n.Ot)), \n                            // Cause a hard reset by unwatching and rewatching immediately, but\n                            // deliberately don't send a resume token so that we get a full update.\n                            ru(t, e);\n                            // Mark the target we send as being on behalf of an existence filter\n                            // mismatch, but don't actually retain that in listenTargets. This ensures\n                            // that we flag the first re-listen this way without impacting future\n                            // listens of this target (that might happen e.g. on reconnect).\n                            var r = new ge(n.target, e, 1 /* ExistenceFilterMismatch */ , n.sequenceNumber);\n                            nu(t, r);\n                        }\n                    })), t.Dh.Lh(n);\n                }(t, n) ] : [ 3 /*break*/ , 10 ];\n\n                // We have received a target change with a global snapshot if the snapshot\n                // version is not equal to SnapshotVersion.min().\n                              case 9:\n                // We have received a target change with a global snapshot if the snapshot\n                // version is not equal to SnapshotVersion.min().\n                u.sent(), u.label = 10;\n\n              case 10:\n                return [ 3 /*break*/ , 13 ];\n\n              case 11:\n                return N(\"RemoteStore\", \"Failed to raise snapshot:\", o = u.sent()), [ 4 /*yield*/ , fu(t, o) ];\n\n              case 12:\n                return u.sent(), [ 3 /*break*/ , 13 ];\n\n              case 13:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * Recovery logic for IndexedDB errors that takes the network offline until\n * `op` succeeds. Retries are scheduled with backoff using\n * `enqueueRetryable()`. If `op()` is not provided, IndexedDB access is\n * validated via a generic operation.\n *\n * The returned Promise is resolved once the network is disabled and before\n * any retry attempt.\n */ function fu(t, e, n) {\n    return g(this, void 0, void 0, (function() {\n        var r = this;\n        return w(this, (function(i) {\n            switch (i.label) {\n              case 0:\n                if (!mr(e)) throw e;\n                // Disable network and raise offline snapshots\n                return t.Nh.add(1 /* IndexedDbFailed */), [ 4 /*yield*/ , $o(t) ];\n\n              case 1:\n                // Disable network and raise offline snapshots\n                return i.sent(), t.Oh.set(\"Offline\" /* Offline */), n || (\n                // Use a simple read operation to determine if IndexedDB recovered.\n                // Ideally, we would expose a health check directly on SimpleDb, but\n                // RemoteStore only has access to persistence through LocalStore.\n                n = function() {\n                    return io(t.bh);\n                }), \n                // Probe IndexedDB periodically and re-enable network\n                t._s.po((function() {\n                    return g(r, void 0, void 0, (function() {\n                        return w(this, (function(e) {\n                            switch (e.label) {\n                              case 0:\n                                return N(\"RemoteStore\", \"Retrying IndexedDB access\"), [ 4 /*yield*/ , n() ];\n\n                              case 1:\n                                return e.sent(), t.Nh.delete(1 /* IndexedDbFailed */), [ 4 /*yield*/ , Jo(t) ];\n\n                              case 2:\n                                return e.sent(), [ 2 /*return*/ ];\n                            }\n                        }));\n                    }));\n                })), [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * Executes `op`. If `op` fails, takes the network offline until `op`\n * succeeds. Returns after the first attempt.\n */ function lu(t, e) {\n    return e().catch((function(n) {\n        return fu(t, n, e);\n    }));\n}\n\nfunction pu(t) {\n    return g(this, void 0, void 0, (function() {\n        var e, n, r, i, o;\n        return w(this, (function(u) {\n            switch (u.label) {\n              case 0:\n                e = O(t), n = Iu(e), r = e.Ch.length > 0 ? e.Ch[e.Ch.length - 1].batchId : -1, u.label = 1;\n\n              case 1:\n                if (!\n                /**\n * Returns true if we can add to the write pipeline (i.e. the network is\n * enabled and the write pipeline is not full).\n */\n                function(t) {\n                    return uu(t) && t.Ch.length < 10;\n                }\n                /**\n * Queues additional writes to be sent to the write stream, sending them\n * immediately if the write stream is established.\n */ (e)) return [ 3 /*break*/ , 7 ];\n                u.label = 2;\n\n              case 2:\n                return u.trys.push([ 2, 4, , 6 ]), [ 4 /*yield*/ , so(e.bh, r) ];\n\n              case 3:\n                return null === (i = u.sent()) ? (0 === e.Ch.length && n.Xu(), [ 3 /*break*/ , 7 ]) : (r = i.batchId, \n                function(t, e) {\n                    t.Ch.push(e);\n                    var n = Iu(t);\n                    n.Hu() && n._h && n.fh(e.mutations);\n                }(e, i), [ 3 /*break*/ , 6 ]);\n\n              case 4:\n                return o = u.sent(), [ 4 /*yield*/ , fu(e, o) ];\n\n              case 5:\n                return u.sent(), [ 3 /*break*/ , 6 ];\n\n              case 6:\n                return [ 3 /*break*/ , 1 ];\n\n              case 7:\n                return du(e) && vu(e), [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\nfunction du(t) {\n    return uu(t) && !Iu(t).zu() && t.Ch.length > 0;\n}\n\nfunction vu(t) {\n    Iu(t).start();\n}\n\nfunction yu(t) {\n    return g(this, void 0, void 0, (function() {\n        return w(this, (function(e) {\n            return Iu(t).Eh(), [ 2 /*return*/ ];\n        }));\n    }));\n}\n\nfunction mu(t) {\n    return g(this, void 0, void 0, (function() {\n        var e, n, r, i;\n        return w(this, (function(o) {\n            // Send the write pipeline now that the stream is established.\n            for (e = Iu(t), n = 0, r = t.Ch; n < r.length; n++) i = r[n], e.fh(i.mutations);\n            return [ 2 /*return*/ ];\n        }));\n    }));\n}\n\nfunction gu(t, e, n) {\n    return g(this, void 0, void 0, (function() {\n        var r, i;\n        return w(this, (function(o) {\n            switch (o.label) {\n              case 0:\n                return r = t.Ch.shift(), i = Wr.from(r, e, n), [ 4 /*yield*/ , lu(t, (function() {\n                    return t.Dh.Bh(i);\n                })) ];\n\n              case 1:\n                // It's possible that with the completion of this mutation another\n                // slot has freed up.\n                return o.sent(), [ 4 /*yield*/ , pu(t) ];\n\n              case 2:\n                // It's possible that with the completion of this mutation another\n                // slot has freed up.\n                return o.sent(), [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\nfunction wu(t, e) {\n    return g(this, void 0, void 0, (function() {\n        return w(this, (function(n) {\n            switch (n.label) {\n              case 0:\n                return e && Iu(t)._h ? [ 4 /*yield*/ , function(t, e) {\n                    return g(this, void 0, void 0, (function() {\n                        var n, r;\n                        return w(this, (function(i) {\n                            switch (i.label) {\n                              case 0:\n                                return en(r = e.code) && r !== M.ABORTED ? (n = t.Ch.shift(), \n                                // In this case it's also unlikely that the server itself is melting\n                                // down -- this was just a bad request so inhibit backoff on the next\n                                // restart.\n                                Iu(t).Yu(), [ 4 /*yield*/ , lu(t, (function() {\n                                    return t.Dh.qh(n.batchId, e);\n                                })) ]) : [ 3 /*break*/ , 3 ];\n\n                              case 1:\n                                // It's possible that with the completion of this mutation\n                                // another slot has freed up.\n                                return i.sent(), [ 4 /*yield*/ , pu(t) ];\n\n                              case 2:\n                                // In this case it's also unlikely that the server itself is melting\n                                // down -- this was just a bad request so inhibit backoff on the next\n                                // restart.\n                                // It's possible that with the completion of this mutation\n                                // another slot has freed up.\n                                i.sent(), i.label = 3;\n\n                              case 3:\n                                return [ 2 /*return*/ ];\n                            }\n                        }));\n                    }));\n                }(t, e) ] : [ 3 /*break*/ , 2 ];\n\n                // This error affects the actual write.\n                              case 1:\n                // This error affects the actual write.\n                n.sent(), n.label = 2;\n\n              case 2:\n                // If the write stream closed after the write handshake completes, a write\n                // operation failed and we fail the pending operation.\n                // The write stream might have been started by refilling the write\n                // pipeline for failed writes\n                return du(t) && vu(t), [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * Toggles the network state when the client gains or loses its primary lease.\n */ function bu(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r;\n        return w(this, (function(i) {\n            switch (i.label) {\n              case 0:\n                return n = O(t), e ? (n.Nh.delete(2 /* IsSecondary */), [ 4 /*yield*/ , Jo(n) ]) : [ 3 /*break*/ , 2 ];\n\n              case 1:\n                return i.sent(), [ 3 /*break*/ , 5 ];\n\n              case 2:\n                return (r = e) ? [ 3 /*break*/ , 4 ] : (n.Nh.add(2 /* IsSecondary */), [ 4 /*yield*/ , $o(n) ]);\n\n              case 3:\n                i.sent(), r = n.Oh.set(\"Unknown\" /* Unknown */), i.label = 4;\n\n              case 4:\n                r, i.label = 5;\n\n              case 5:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * If not yet initialized, registers the WatchStream and its network state\n * callback with `remoteStoreImpl`. Returns the existing stream if one is\n * already available.\n *\n * PORTING NOTE: On iOS and Android, the WatchStream gets registered on startup.\n * This is not done on Web to allow it to be tree-shaken.\n */ function _u(t) {\n    var e = this;\n    return t.Uh || (\n    // Create stream (but note that it is not started yet).\n    t.Uh = function(t, e, n) {\n        var r = O(t);\n        return r.Ih(), new Ho(e, r.Qu, r.credentials, r.Qt, n);\n    }(t.Sh, t._s, {\n        wu: au.bind(null, t),\n        Tu: cu.bind(null, t),\n        ah: hu.bind(null, t)\n    }), t.$h.push((function(n) {\n        return g(e, void 0, void 0, (function() {\n            return w(this, (function(e) {\n                switch (e.label) {\n                  case 0:\n                    return n ? (t.Uh.Yu(), ou(t) ? iu(t) : t.Oh.set(\"Unknown\" /* Unknown */), [ 3 /*break*/ , 3 ]) : [ 3 /*break*/ , 1 ];\n\n                  case 1:\n                    return [ 4 /*yield*/ , t.Uh.stop() ];\n\n                  case 2:\n                    e.sent(), su(t), e.label = 3;\n\n                  case 3:\n                    return [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }))), t.Uh\n    /**\n * If not yet initialized, registers the WriteStream and its network state\n * callback with `remoteStoreImpl`. Returns the existing stream if one is\n * already available.\n *\n * PORTING NOTE: On iOS and Android, the WriteStream gets registered on startup.\n * This is not done on Web to allow it to be tree-shaken.\n */;\n}\n\nfunction Iu(t) {\n    var e = this;\n    return t.Qh || (\n    // Create stream (but note that it is not started yet).\n    t.Qh = function(t, e, n) {\n        var r = O(t);\n        return r.Ih(), new Ko(e, r.Qu, r.credentials, r.Qt, n);\n    }(t.Sh, t._s, {\n        wu: yu.bind(null, t),\n        Tu: wu.bind(null, t),\n        wh: mu.bind(null, t),\n        dh: gu.bind(null, t)\n    }), t.$h.push((function(n) {\n        return g(e, void 0, void 0, (function() {\n            return w(this, (function(e) {\n                switch (e.label) {\n                  case 0:\n                    return n ? (t.Qh.Yu(), [ 4 /*yield*/ , pu(t) ]) : [ 3 /*break*/ , 2 ];\n\n                  case 1:\n                    // This will start the write stream if necessary.\n                    return e.sent(), [ 3 /*break*/ , 4 ];\n\n                  case 2:\n                    return [ 4 /*yield*/ , t.Qh.stop() ];\n\n                  case 3:\n                    e.sent(), t.Ch.length > 0 && (N(\"RemoteStore\", \"Stopping write stream with \" + t.Ch.length + \" pending writes\"), \n                    t.Ch = []), e.label = 4;\n\n                  case 4:\n                    return [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }))), t.Qh\n    /**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n    /**\n * Holds the listeners and the last received ViewSnapshot for a query being\n * tracked by EventManager.\n */;\n}\n\nvar Eu = function() {\n    this.Kh = void 0, this.listeners = [];\n}, Tu = function() {\n    this.queries = new gi((function(t) {\n        return pe(t);\n    }), le), this.onlineState = \"Unknown\" /* Unknown */ , this.Wh = new Set;\n};\n\nfunction Nu(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r, i, o, u, s, a;\n        return w(this, (function(c) {\n            switch (c.label) {\n              case 0:\n                if (n = O(t), r = e.query, i = !1, (o = n.queries.get(r)) || (i = !0, o = new Eu), \n                !i) return [ 3 /*break*/ , 4 ];\n                c.label = 1;\n\n              case 1:\n                return c.trys.push([ 1, 3, , 4 ]), u = o, [ 4 /*yield*/ , n.jh(r) ];\n\n              case 2:\n                return u.Kh = c.sent(), [ 3 /*break*/ , 4 ];\n\n              case 3:\n                return s = c.sent(), a = Er(s, \"Initialization of query '\" + de(e.query) + \"' failed\"), \n                [ 2 /*return*/ , void e.onError(a) ];\n\n              case 4:\n                return n.queries.set(r, o), o.listeners.push(e), \n                // Run global snapshot listeners if a consistent snapshot has been emitted.\n                e.Gh(n.onlineState), o.Kh && e.zh(o.Kh) && xu(n), [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\nfunction Au(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r, i, o, u;\n        return w(this, (function(s) {\n            return n = O(t), r = e.query, i = !1, (o = n.queries.get(r)) && (u = o.listeners.indexOf(e)) >= 0 && (o.listeners.splice(u, 1), \n            i = 0 === o.listeners.length), i ? [ 2 /*return*/ , (n.queries.delete(r), n.Hh(r)) ] : [ 2 /*return*/ ];\n        }));\n    }));\n}\n\nfunction Du(t, e) {\n    for (var n = O(t), r = !1, i = 0, o = e; i < o.length; i++) {\n        var u = o[i], s = u.query, a = n.queries.get(s);\n        if (a) {\n            for (var c = 0, h = a.listeners; c < h.length; c++) {\n                h[c].zh(u) && (r = !0);\n            }\n            a.Kh = u;\n        }\n    }\n    r && xu(n);\n}\n\nfunction Su(t, e, n) {\n    var r = O(t), i = r.queries.get(e);\n    if (i) for (var o = 0, u = i.listeners; o < u.length; o++) {\n        u[o].onError(n);\n    }\n    // Remove all listeners. NOTE: We don't need to call syncEngine.unlisten()\n    // after an error.\n        r.queries.delete(e);\n}\n\n// Call all global snapshot listeners that have been set.\nfunction xu(t) {\n    t.Wh.forEach((function(t) {\n        t.next();\n    }));\n}\n\n/**\n * QueryListener takes a series of internal view snapshots and determines\n * when to raise the event.\n *\n * It uses an Observer to dispatch events.\n */ var ku = /** @class */ function() {\n    function t(t, e, n) {\n        this.query = t, this.Jh = e, \n        /**\n             * Initial snapshots (e.g. from cache) may not be propagated to the wrapped\n             * observer. This flag is set to true once we've actually raised an event.\n             */\n        this.Yh = !1, this.Xh = null, this.onlineState = \"Unknown\" /* Unknown */ , this.options = n || {}\n        /**\n     * Applies the new ViewSnapshot to this listener, raising a user-facing event\n     * if applicable (depending on what changed, whether the user has opted into\n     * metadata-only changes, etc.). Returns true if a user-facing event was\n     * indeed raised.\n     */;\n    }\n    return t.prototype.zh = function(t) {\n        if (!this.options.includeMetadataChanges) {\n            for (\n            // Remove the metadata only changes.\n            var e = [], n = 0, r = t.docChanges; n < r.length; n++) {\n                var i = r[n];\n                3 /* Metadata */ !== i.type && e.push(i);\n            }\n            t = new In(t.query, t.docs, t.Se, e, t.De, t.fromCache, t.Ce, \n            /* excludesMetadataChanges= */ !0);\n        }\n        var o = !1;\n        return this.Yh ? this.Zh(t) && (this.Jh.next(t), o = !0) : this.tl(t, this.onlineState) && (this.el(t), \n        o = !0), this.Xh = t, o;\n    }, t.prototype.onError = function(t) {\n        this.Jh.error(t);\n    }, \n    /** Returns whether a snapshot was raised. */ t.prototype.Gh = function(t) {\n        this.onlineState = t;\n        var e = !1;\n        return this.Xh && !this.Yh && this.tl(this.Xh, t) && (this.el(this.Xh), e = !0), \n        e;\n    }, t.prototype.tl = function(t, e) {\n        // Always raise the first event when we're synced\n        if (!t.fromCache) return !0;\n        // NOTE: We consider OnlineState.Unknown as online (it should become Offline\n        // or Online if we wait long enough).\n                var n = \"Offline\" /* Offline */ !== e;\n        // Don't raise the event if we're online, aren't synced yet (checked\n        // above) and are waiting for a sync.\n                return !(this.options.nl && n || t.docs.et() && \"Offline\" /* Offline */ !== e);\n        // Raise data from cache if we have any documents or we are offline\n        }, t.prototype.Zh = function(t) {\n        // We don't need to handle includeDocumentMetadataChanges here because\n        // the Metadata only changes have already been stripped out if needed.\n        // At this point the only changes we will see are the ones we should\n        // propagate.\n        if (t.docChanges.length > 0) return !0;\n        var e = this.Xh && this.Xh.hasPendingWrites !== t.hasPendingWrites;\n        return !(!t.Ce && !e) && !0 === this.options.includeMetadataChanges;\n        // Generally we should have hit one of the cases above, but it's possible\n        // to get here if there were only metadata docChanges and they got\n        // stripped out.\n        }, t.prototype.el = function(t) {\n        t = In.Ne(t.query, t.docs, t.De, t.fromCache), this.Yh = !0, this.Jh.next(t);\n    }, t;\n}(), Ou = /** @class */ function() {\n    function t(t, \n    // How many bytes this element takes to store in the bundle.\n    e) {\n        this.payload = t, this.byteLength = e;\n    }\n    return t.prototype.sl = function() {\n        return \"metadata\" in this.payload;\n    }, t;\n}(), Pu = /** @class */ function() {\n    function t(t) {\n        this.Qt = t;\n    }\n    return t.prototype.Pc = function(t) {\n        return zn(this.Qt, t);\n    }, \n    /**\n     * Converts a BundleDocument to a MaybeDocument.\n     */\n    t.prototype.yc = function(t) {\n        return t.metadata.exists ? Kn(this.Qt, t.document, !1) : new Vt(this.Pc(t.metadata.name), this.gc(t.metadata.readTime));\n    }, t.prototype.gc = function(t) {\n        return Mn(t);\n    }, t;\n}(), Vu = /** @class */ function() {\n    function t(t, e, n) {\n        this.il = t, this.bh = e, this.Qt = n, \n        /** Batched queries to be saved into storage */\n        this.queries = [], \n        /** Batched documents to be saved into storage */\n        this.documents = [], this.progress = Cu(t)\n        /**\n     * Adds an element from the bundle to the loader.\n     *\n     * Returns a new progress if adding the element leads to a new progress,\n     * otherwise returns null.\n     */;\n    }\n    return t.prototype.rl = function(t) {\n        this.progress.bytesLoaded += t.byteLength;\n        var e = this.progress.documentsLoaded;\n        return t.payload.namedQuery ? this.queries.push(t.payload.namedQuery) : t.payload.documentMetadata ? (this.documents.push({\n            metadata: t.payload.documentMetadata\n        }), t.payload.documentMetadata.exists || ++e) : t.payload.document && (this.documents[this.documents.length - 1].document = t.payload.document, \n        ++e), e !== this.progress.documentsLoaded ? (this.progress.documentsLoaded = e, \n        Object.assign({}, this.progress)) : null;\n    }, t.prototype.ol = function(t) {\n        for (var e = new Map, n = new Pu(this.Qt), r = 0, i = t; r < i.length; r++) {\n            var o = i[r];\n            if (o.metadata.queries) for (var u = n.Pc(o.metadata.name), s = 0, a = o.metadata.queries; s < a.length; s++) {\n                var c = a[s], h = (e.get(c) || mn()).add(u);\n                e.set(c, h);\n            }\n        }\n        return e;\n    }, \n    /**\n     * Update the progress to 'Success' and return the updated progress.\n     */\n    t.prototype.complete = function() {\n        return g(this, void 0, void 0, (function() {\n            var t, e, n, r, i;\n            return w(this, (function(o) {\n                switch (o.label) {\n                  case 0:\n                    return [ 4 /*yield*/ , vo(this.bh, new Pu(this.Qt), this.documents, this.il.id) ];\n\n                  case 1:\n                    t = o.sent(), e = this.ol(this.documents), n = 0, r = this.queries, o.label = 2;\n\n                  case 2:\n                    return n < r.length ? (i = r[n], [ 4 /*yield*/ , yo(this.bh, i, e.get(i.name)) ]) : [ 3 /*break*/ , 5 ];\n\n                  case 3:\n                    o.sent(), o.label = 4;\n\n                  case 4:\n                    return n++, [ 3 /*break*/ , 2 ];\n\n                  case 5:\n                    return [ 2 /*return*/ , (this.progress.taskState = \"Success\", new Wi(Object.assign({}, this.progress), t)) ];\n                }\n            }));\n        }));\n    }, t;\n}();\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A complete element in the bundle stream, together with the byte length it\n * occupies in the stream.\n */\n/**\n * Returns a `LoadBundleTaskProgress` representing the initial progress of\n * loading a bundle.\n */\nfunction Cu(t) {\n    return {\n        taskState: \"Running\",\n        documentsLoaded: 0,\n        bytesLoaded: 0,\n        totalDocuments: t.totalDocuments,\n        totalBytes: t.totalBytes\n    };\n}\n\n/**\n * Returns a `LoadBundleTaskProgress` representing the progress that the loading\n * has succeeded.\n */\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ var Lu = function(t) {\n    this.key = t;\n}, Ru = function(t) {\n    this.key = t;\n}, Uu = /** @class */ function() {\n    function t(t, \n    /** Documents included in the remote target */\n    e) {\n        this.query = t, this.cl = e, this.al = null, \n        /**\n             * A flag whether the view is current with the backend. A view is considered\n             * current after it has seen the current flag from the backend and did not\n             * lose consistency within the watch stream (e.g. because of an existence\n             * filter mismatch).\n             */\n        this.Be = !1, \n        /** Documents in the view but not in the remote target */\n        this.ul = mn(), \n        /** Document Keys that have local changes */\n        this.De = mn(), this.hl = ye(t), this.ll = new bn(this.hl);\n    }\n    return Object.defineProperty(t.prototype, \"_l\", {\n        /**\n         * The set of remote documents that the server has told us belongs to the target associated with\n         * this view.\n         */\n        get: function() {\n            return this.cl;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    /**\n     * Iterates over a set of doc changes, applies the query limit, and computes\n     * what the new results should be, what the changes were, and whether we may\n     * need to go back to the local cache for more results. Does not make any\n     * changes to the view.\n     * @param docChanges - The doc changes to apply to this view.\n     * @param previousChanges - If this is being called with a refill, then start\n     *        with this set of docs and changes instead of the current view.\n     * @returns a new set of docs, changes, and refill flag.\n     */\n    t.prototype.fl = function(t, e) {\n        var n = this, r = e ? e.dl : new _n, i = e ? e.ll : this.ll, o = e ? e.De : this.De, u = i, s = !1, a = ie(this.query) && i.size === this.query.limit ? i.last() : null, c = oe(this.query) && i.size === this.query.limit ? i.first() : null;\n        // Drop documents out to meet limit/limitToLast requirement.\n        if (t.Xt((function(t, e) {\n            var h = i.get(t), f = e instanceof Pt ? e : null;\n            f && (f = ve(n.query, f) ? f : null);\n            var l = !!h && n.De.has(h.key), p = !!f && (f.Vt || \n            // We only consider committed mutations for documents that were\n            // mutated during the lifetime of the view.\n            n.De.has(f.key) && f.hasCommittedMutations), d = !1;\n            // Calculate change\n            h && f ? h.data().isEqual(f.data()) ? l !== p && (r.track({\n                type: 3 /* Metadata */ ,\n                doc: f\n            }), d = !0) : n.wl(h, f) || (r.track({\n                type: 2 /* Modified */ ,\n                doc: f\n            }), d = !0, (a && n.hl(f, a) > 0 || c && n.hl(f, c) < 0) && (\n            // This doc moved from inside the limit to outside the limit.\n            // That means there may be some other doc in the local cache\n            // that should be included instead.\n            s = !0)) : !h && f ? (r.track({\n                type: 0 /* Added */ ,\n                doc: f\n            }), d = !0) : h && !f && (r.track({\n                type: 1 /* Removed */ ,\n                doc: h\n            }), d = !0, (a || c) && (\n            // A doc was removed from a full limit query. We'll need to\n            // requery from the local cache to see if we know about some other\n            // doc that should be in the results.\n            s = !0)), d && (f ? (u = u.add(f), o = p ? o.add(t) : o.delete(t)) : (u = u.delete(t), \n            o = o.delete(t)));\n        })), ie(this.query) || oe(this.query)) for (;u.size > this.query.limit; ) {\n            var h = ie(this.query) ? u.last() : u.first();\n            u = u.delete(h.key), o = o.delete(h.key), r.track({\n                type: 1 /* Removed */ ,\n                doc: h\n            });\n        }\n        return {\n            ll: u,\n            dl: r,\n            lc: s,\n            De: o\n        };\n    }, t.prototype.wl = function(t, e) {\n        // We suppress the initial change event for documents that were modified as\n        // part of a write acknowledgment (e.g. when the value of a server transform\n        // is applied) as Watch will send us the same document again.\n        // By suppressing the event, we only raise two user visible events (one with\n        // `hasPendingWrites` and the final state of the document) instead of three\n        // (one with `hasPendingWrites`, the modified document with\n        // `hasPendingWrites` and the final state of the document).\n        return t.Vt && e.hasCommittedMutations && !e.Vt;\n    }, \n    /**\n     * Updates the view with the given ViewDocumentChanges and optionally updates\n     * limbo docs and sync state from the provided target change.\n     * @param docChanges - The set of changes to make to the view's docs.\n     * @param updateLimboDocuments - Whether to update limbo documents based on\n     *        this change.\n     * @param targetChange - A target change to apply for computing limbo docs and\n     *        sync state.\n     * @returns A new ViewChange with the given docs, changes, and sync state.\n     */\n    // PORTING NOTE: The iOS/Android clients always compute limbo document changes.\n    t.prototype.wi = function(t, e, n) {\n        var r = this, i = this.ll;\n        this.ll = t.ll, this.De = t.De;\n        // Sort changes based on type and query comparator\n        var o = t.dl.ve();\n        o.sort((function(t, e) {\n            return function(t, e) {\n                var n = function(t) {\n                    switch (t) {\n                      case 0 /* Added */ :\n                        return 1;\n\n                      case 2 /* Modified */ :\n                      case 3 /* Metadata */ :\n                        // A metadata change is converted to a modified change at the public\n                        // api layer.  Since we sort by document key and then change type,\n                        // metadata and modified changes must be sorted equivalently.\n                        return 2;\n\n                      case 1 /* Removed */ :\n                        return 0;\n\n                      default:\n                        return x();\n                    }\n                };\n                return n(t) - n(e);\n            }(t.type, e.type) || r.hl(t.doc, e.doc);\n        })), this.El(n);\n        var u = e ? this.Tl() : [], s = 0 === this.ul.size && this.Be ? 1 /* Synced */ : 0 /* Local */ , a = s !== this.al;\n        return this.al = s, 0 !== o.length || a ? {\n            snapshot: new In(this.query, t.ll, i, o, t.De, 0 /* Local */ === s, a, \n            /* excludesMetadataChanges= */ !1),\n            Il: u\n        } : {\n            Il: u\n        };\n        // no changes\n        }, \n    /**\n     * Applies an OnlineState change to the view, potentially generating a\n     * ViewChange if the view's syncState changes as a result.\n     */\n    t.prototype.Gh = function(t) {\n        return this.Be && \"Offline\" /* Offline */ === t ? (\n        // If we're offline, set `current` to false and then call applyChanges()\n        // to refresh our syncState and generate a ViewChange as appropriate. We\n        // are guaranteed to get a new TargetChange that sets `current` back to\n        // true once the client is back online.\n        this.Be = !1, this.wi({\n            ll: this.ll,\n            dl: new _n,\n            De: this.De,\n            lc: !1\n        }, \n        /* updateLimboDocuments= */ !1)) : {\n            Il: []\n        };\n    }, \n    /**\n     * Returns whether the doc for the given key should be in limbo.\n     */\n    t.prototype.ml = function(t) {\n        // If the remote end says it's part of this query, it's not in limbo.\n        return !this.cl.has(t) && \n        // The local store doesn't think it's a result, so it shouldn't be in limbo.\n        !!this.ll.has(t) && !this.ll.get(t).Vt;\n    }, \n    /**\n     * Updates syncedDocuments, current, and limbo docs based on the given change.\n     * Returns the list of changes to which docs are in limbo.\n     */\n    t.prototype.El = function(t) {\n        var e = this;\n        t && (t.qe.forEach((function(t) {\n            return e.cl = e.cl.add(t);\n        })), t.Ue.forEach((function(t) {})), t.Qe.forEach((function(t) {\n            return e.cl = e.cl.delete(t);\n        })), this.Be = t.Be);\n    }, t.prototype.Tl = function() {\n        var t = this;\n        // We can only determine limbo documents when we're in-sync with the server.\n                if (!this.Be) return [];\n        // TODO(klimt): Do this incrementally so that it's not quadratic when\n        // updating many documents.\n                var e = this.ul;\n        this.ul = mn(), this.ll.forEach((function(e) {\n            t.ml(e.key) && (t.ul = t.ul.add(e.key));\n        }));\n        // Diff the new limbo docs with the old limbo docs.\n        var n = [];\n        return e.forEach((function(e) {\n            t.ul.has(e) || n.push(new Ru(e));\n        })), this.ul.forEach((function(t) {\n            e.has(t) || n.push(new Lu(t));\n        })), n;\n    }, \n    /**\n     * Update the in-memory state of the current view with the state read from\n     * persistence.\n     *\n     * We update the query view whenever a client's primary status changes:\n     * - When a client transitions from primary to secondary, it can miss\n     *   LocalStorage updates and its query views may temporarily not be\n     *   synchronized with the state on disk.\n     * - For secondary to primary transitions, the client needs to update the list\n     *   of `syncedDocuments` since secondary clients update their query views\n     *   based purely on synthesized RemoteEvents.\n     *\n     * @param queryResult.documents - The documents that match the query according\n     * to the LocalStore.\n     * @param queryResult.remoteKeys - The keys of the documents that match the\n     * query according to the backend.\n     *\n     * @returns The ViewChange that resulted from this synchronization.\n     */\n    // PORTING NOTE: Multi-tab only.\n    t.prototype.Al = function(t) {\n        this.cl = t.Rc, this.ul = mn();\n        var e = this.fl(t.documents);\n        return this.wi(e, /*updateLimboDocuments=*/ !0);\n    }, \n    /**\n     * Returns a view snapshot as if this query was just listened to. Contains\n     * a document add for every existing document and the `fromCache` and\n     * `hasPendingWrites` status of the already established view.\n     */\n    // PORTING NOTE: Multi-tab only.\n    t.prototype.Rl = function() {\n        return In.Ne(this.query, this.ll, this.De, 0 /* Local */ === this.al);\n    }, t;\n}(), Mu = function(\n/**\n     * The query itself.\n     */\nt, \n/**\n     * The target number created by the client that is used in the watch\n     * stream to identify this query.\n     */\ne, \n/**\n     * The view is responsible for computing the final merged truth of what\n     * docs are in the query. It gets notified of local and remote changes,\n     * and applies the query filters and limits to determine the most correct\n     * possible results.\n     */\nn) {\n    this.query = t, this.targetId = e, this.view = n;\n}, qu = function(t) {\n    this.key = t, \n    /**\n             * Set to true once we've received a document. This is used in\n             * getRemoteKeysForTarget() and ultimately used by WatchChangeAggregator to\n             * decide whether it needs to manufacture a delete event for the target once\n             * the target is CURRENT.\n             */\n    this.Pl = !1;\n}, Fu = /** @class */ function() {\n    function t(t, e, n, \n    // PORTING NOTE: Manages state synchronization in multi-tab environments.\n    r, i, o) {\n        this.bh = t, this.yl = e, this.gl = n, this.Vl = r, this.currentUser = i, this.pl = o, \n        this.bl = {}, this.vl = new gi((function(t) {\n            return pe(t);\n        }), le), this.Sl = new Map, \n        /**\n             * The keys of documents that are in limbo for which we haven't yet started a\n             * limbo resolution query. The strings in this set are the result of calling\n             * `key.path.canonicalString()` where `key` is a `DocumentKey` object.\n             *\n             * The `Set` type was chosen because it provides efficient lookup and removal\n             * of arbitrary elements and it also maintains insertion order, providing the\n             * desired queue-like FIFO semantics.\n             */\n        this.Dl = new Set, \n        /**\n             * Keeps track of the target ID for each document that is in limbo with an\n             * active target.\n             */\n        this.Cl = new rn(tt.H), \n        /**\n             * Keeps track of the information about an active limbo resolution for each\n             * active target ID that was started for the purpose of limbo resolution.\n             */\n        this.xl = new Map, this.Nl = new go, \n        /** Stores user completion handlers, indexed by User and BatchId. */\n        this.$l = {}, \n        /** Stores user callbacks waiting for all pending writes to be acknowledged. */\n        this.Fl = new Map, this.Ol = Di.Li(), this.onlineState = \"Unknown\" /* Unknown */ , \n        // The primary state is set to `true` or `false` immediately after Firestore\n        // startup. In the interim, a client should only be considered primary if\n        // `isPrimary` is true.\n        this.kl = void 0;\n    }\n    return Object.defineProperty(t.prototype, \"Ml\", {\n        get: function() {\n            return !0 === this.kl;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t;\n}();\n\n/**\n * Initiates the new listen, resolves promise when listen enqueued to the\n * server. All the subsequent view snapshots or errors are sent to the\n * subscribed handlers. Returns the initial snapshot.\n */\nfunction ju(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r, i, o, u, s;\n        return w(this, (function(a) {\n            switch (a.label) {\n              case 0:\n                return n = ys(t), (o = n.vl.get(e)) ? (\n                // PORTING NOTE: With Multi-Tab Web, it is possible that a query view\n                // already exists when EventManager calls us for the first time. This\n                // happens when the primary tab is already listening to this query on\n                // behalf of another tab and the user of the primary also starts listening\n                // to the query. EventManager will not have an assigned target ID in this\n                // case and calls `listen` to obtain this ID.\n                r = o.targetId, n.Vl.Fa(r), i = o.view.Rl(), [ 3 /*break*/ , 4 ]) : [ 3 /*break*/ , 1 ];\n\n              case 1:\n                return [ 4 /*yield*/ , ao(n.bh, he(e)) ];\n\n              case 2:\n                return u = a.sent(), s = n.Vl.Fa(u.targetId), r = u.targetId, [ 4 /*yield*/ , zu(n, e, r, \"current\" === s) ];\n\n              case 3:\n                i = a.sent(), n.Ml && tu(n.yl, u), a.label = 4;\n\n              case 4:\n                return [ 2 /*return*/ , i ];\n            }\n        }));\n    }));\n}\n\n/**\n * Registers a view for a previously unknown query and computes its initial\n * snapshot.\n */ function zu(t, e, n, r) {\n    return g(this, void 0, void 0, (function() {\n        var i, o, u, s, a, c;\n        return w(this, (function(h) {\n            switch (h.label) {\n              case 0:\n                // PORTING NOTE: On Web only, we inject the code that registers new Limbo\n                // targets based on view changes. This allows us to only depend on Limbo\n                // changes when user code includes queries.\n                return t.Ll = function(e, n, r) {\n                    return function(t, e, n, r) {\n                        return g(this, void 0, void 0, (function() {\n                            var i, o, u;\n                            return w(this, (function(s) {\n                                switch (s.label) {\n                                  case 0:\n                                    return i = e.view.fl(n), i.lc ? [ 4 /*yield*/ , ho(t.bh, e.query, \n                                    /* usePreviousResults= */ !1).then((function(t) {\n                                        var n = t.documents;\n                                        return e.view.fl(n, i);\n                                    })) ] : [ 3 /*break*/ , 2 ];\n\n                                  case 1:\n                                    // The query has a limit and some docs were removed, so we need\n                                    // to re-run the query against the local store to make sure we\n                                    // didn't lose any good docs that had been past the limit.\n                                    i = s.sent(), s.label = 2;\n\n                                  case 2:\n                                    return o = r && r.$e.get(e.targetId), u = e.view.wi(i, \n                                    /* updateLimboDocuments= */ t.Ml, o), [ 2 /*return*/ , (es(t, e.targetId, u.Il), \n                                    u.snapshot) ];\n                                }\n                            }));\n                        }));\n                    }(t, e, n, r);\n                }, [ 4 /*yield*/ , ho(t.bh, e, \n                /* usePreviousResults= */ !0) ];\n\n              case 1:\n                return i = h.sent(), o = new Uu(e, i.Rc), u = o.fl(i.documents), s = Tn.Le(n, r && \"Offline\" /* Offline */ !== t.onlineState), \n                a = o.wi(u, \n                /* updateLimboDocuments= */ t.Ml, s), es(t, n, a.Il), c = new Mu(e, n, o), [ 2 /*return*/ , (t.vl.set(e, c), \n                t.Sl.has(n) ? t.Sl.get(n).push(e) : t.Sl.set(n, [ e ]), a.snapshot) ];\n            }\n        }));\n    }));\n}\n\n/** Stops listening to the query. */ function Gu(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r, i;\n        return w(this, (function(o) {\n            switch (o.label) {\n              case 0:\n                return n = O(t), r = n.vl.get(e), (i = n.Sl.get(r.targetId)).length > 1 ? [ 2 /*return*/ , (n.Sl.set(r.targetId, i.filter((function(t) {\n                    return !le(t, e);\n                }))), void n.vl.delete(e)) ] : n.Ml ? (\n                // We need to remove the local query target first to allow us to verify\n                // whether any other client is still interested in this target.\n                n.Vl.ka(r.targetId), n.Vl.Da(r.targetId) ? [ 3 /*break*/ , 2 ] : [ 4 /*yield*/ , co(n.bh, r.targetId, \n                /*keepPersistedTargetData=*/ !1).then((function() {\n                    n.Vl.La(r.targetId), eu(n.yl, r.targetId), $u(n, r.targetId);\n                })).catch(mi) ]) : [ 3 /*break*/ , 3 ];\n\n              case 1:\n                o.sent(), o.label = 2;\n\n              case 2:\n                return [ 3 /*break*/ , 5 ];\n\n              case 3:\n                return $u(n, r.targetId), [ 4 /*yield*/ , co(n.bh, r.targetId, \n                /*keepPersistedTargetData=*/ !0) ];\n\n              case 4:\n                o.sent(), o.label = 5;\n\n              case 5:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * Initiates the write of local mutation batch which involves adding the\n * writes to the mutation queue, notifying the remote store about new\n * mutations and raising events for any changes this write caused.\n *\n * The promise returned by this call is resolved when the above steps\n * have completed, *not* when the write was acked by the backend. The\n * userCallback is resolved once the write was acked/rejected by the\n * backend (or failed locally for any other reason).\n */ function Bu(t, e, n) {\n    return g(this, void 0, void 0, (function() {\n        var r, i, o, u;\n        return w(this, (function(s) {\n            switch (s.label) {\n              case 0:\n                r = ms(t), s.label = 1;\n\n              case 1:\n                return s.trys.push([ 1, 5, , 6 ]), [ 4 /*yield*/ , function(t, e) {\n                    var n, r = O(t), i = K.now(), o = e.reduce((function(t, e) {\n                        return t.add(e.key);\n                    }), mn());\n                    return r.persistence.runTransaction(\"Locally write mutations\", \"readwrite\", (function(t) {\n                        return r.Tc.Xo(t, o).next((function(o) {\n                            n = o;\n                            for (\n                            // For non-idempotent mutations (such as `FieldValue.increment()`),\n                            // we record the base state in a separate patch mutation. This is\n                            // later used to guarantee consistent values and prevents flicker\n                            // even if the backend sends us an update that already includes our\n                            // transform.\n                            var u = [], s = 0, a = e; s < a.length; s++) {\n                                var c = a[s], h = je(c, n.get(c.key));\n                                null != h && \n                                // NOTE: The base state should only be applied if there's some\n                                // existing document to override, so use a Precondition of\n                                // exists=true\n                                u.push(new Qe(c.key, h, kt(h.proto.mapValue), Re.exists(!0)));\n                            }\n                            return r.zo.Ri(t, i, u, e);\n                        }));\n                    })).then((function(t) {\n                        var e = t.xs(n);\n                        return {\n                            batchId: t.batchId,\n                            ri: e\n                        };\n                    }));\n                }(r.bh, e) ];\n\n              case 2:\n                return i = s.sent(), r.Vl.Ca(i.batchId), function(t, e, n) {\n                    var r = t.$l[t.currentUser.A()];\n                    r || (r = new rn(C)), r = r.zt(e, n), t.$l[t.currentUser.A()] = r;\n                }(r, i.batchId, n), [ 4 /*yield*/ , is(r, i.ri) ];\n\n              case 3:\n                return s.sent(), [ 4 /*yield*/ , pu(r.yl) ];\n\n              case 4:\n                return s.sent(), [ 3 /*break*/ , 6 ];\n\n              case 5:\n                return o = s.sent(), u = Er(o, \"Failed to persist write\"), n.reject(u), [ 3 /*break*/ , 6 ];\n\n              case 6:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * Applies one remote event to the sync engine, notifying any views of the\n * changes, and releasing any pending mutation batches that would become\n * visible because of the snapshot version the remote event contains.\n */ function Qu(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r;\n        return w(this, (function(i) {\n            switch (i.label) {\n              case 0:\n                n = O(t), i.label = 1;\n\n              case 1:\n                return i.trys.push([ 1, 4, , 6 ]), [ 4 /*yield*/ , oo(n.bh, e) ];\n\n              case 2:\n                return r = i.sent(), \n                // Update `receivedDocument` as appropriate for any limbo targets.\n                e.$e.forEach((function(t, e) {\n                    var r = n.xl.get(e);\n                    r && (\n                    // Since this is a limbo resolution lookup, it's for a single document\n                    // and it could be added, modified, or removed, but not a combination.\n                    k(t.qe.size + t.Ue.size + t.Qe.size <= 1), t.qe.size > 0 ? r.Pl = !0 : t.Ue.size > 0 ? k(r.Pl) : t.Qe.size > 0 && (k(r.Pl), \n                    r.Pl = !1));\n                })), [ 4 /*yield*/ , is(n, r, e) ];\n\n              case 3:\n                // Update `receivedDocument` as appropriate for any limbo targets.\n                return i.sent(), [ 3 /*break*/ , 6 ];\n\n              case 4:\n                return [ 4 /*yield*/ , mi(i.sent()) ];\n\n              case 5:\n                return i.sent(), [ 3 /*break*/ , 6 ];\n\n              case 6:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * Applies an OnlineState change to the sync engine and notifies any views of\n * the change.\n */ function Yu(t, e, n) {\n    var r = O(t);\n    // If we are the secondary client, we explicitly ignore the remote store's\n    // online state (the local client may go offline, even though the primary\n    // tab remains online) and only apply the primary tab's online state from\n    // SharedClientState.\n        if (r.Ml && 0 /* RemoteStore */ === n || !r.Ml && 1 /* SharedClientState */ === n) {\n        var i = [];\n        r.vl.forEach((function(t, n) {\n            var r = n.view.Gh(e);\n            r.snapshot && i.push(r.snapshot);\n        })), function(t, e) {\n            var n = O(t);\n            n.onlineState = e;\n            var r = !1;\n            n.queries.forEach((function(t, n) {\n                for (var i = 0, o = n.listeners; i < o.length; i++) {\n                    // Run global snapshot listeners if a consistent snapshot has been emitted.\n                    o[i].Gh(e) && (r = !0);\n                }\n            })), r && xu(n);\n        }(r.gl, e), i.length && r.bl.ah(i), r.onlineState = e, r.Ml && r.Vl.Qa(e);\n    }\n}\n\n/**\n * Rejects the listen for the given targetID. This can be triggered by the\n * backend for any active target.\n *\n * @param syncEngine - The sync engine implementation.\n * @param targetId - The targetID corresponds to one previously initiated by the\n * user as part of TargetData passed to listen() on RemoteStore.\n * @param err - A description of the condition that has forced the rejection.\n * Nearly always this will be an indication that the user is no longer\n * authorized to see the data matching the target.\n */ function Hu(t, e, n) {\n    return g(this, void 0, void 0, (function() {\n        var r, i, o, u, s, a;\n        return w(this, (function(c) {\n            switch (c.label) {\n              case 0:\n                // PORTING NOTE: Multi-tab only.\n                return (r = O(t)).Vl.Ba(e, \"rejected\", n), i = r.xl.get(e), (o = i && i.key) ? (u = (u = new rn(tt.H)).zt(o, new Vt(o, X.min())), \n                s = mn().add(o), a = new En(X.min(), \n                /* targetChanges= */ new Map, \n                /* targetMismatches= */ new sn(C), u, s), [ 4 /*yield*/ , Qu(r, a) ]) : [ 3 /*break*/ , 2 ];\n\n              case 1:\n                return c.sent(), \n                // Since this query failed, we won't want to manually unlisten to it.\n                // We only remove it from bookkeeping after we successfully applied the\n                // RemoteEvent. If `applyRemoteEvent()` throws, we want to re-listen to\n                // this query when the RemoteStore restarts the Watch stream, which should\n                // re-trigger the target failure.\n                r.Cl = r.Cl.remove(o), r.xl.delete(e), rs(r), [ 3 /*break*/ , 4 ];\n\n              case 2:\n                return [ 4 /*yield*/ , co(r.bh, e, \n                /* keepPersistedTargetData */ !1).then((function() {\n                    return $u(r, e, n);\n                })).catch(mi) ];\n\n              case 3:\n                c.sent(), c.label = 4;\n\n              case 4:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\nfunction Ku(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r, i;\n        return w(this, (function(o) {\n            switch (o.label) {\n              case 0:\n                n = O(t), r = e.batch.batchId, o.label = 1;\n\n              case 1:\n                return o.trys.push([ 1, 4, , 6 ]), [ 4 /*yield*/ , ro(n.bh, e) ];\n\n              case 2:\n                return i = o.sent(), \n                // The local store may or may not be able to apply the write result and\n                // raise events immediately (depending on whether the watcher is caught\n                // up), so we raise user callbacks first so that they consistently happen\n                // before listen events.\n                Ju(n, r, /*error=*/ null), Zu(n, r), n.Vl.Na(r, \"acknowledged\"), [ 4 /*yield*/ , is(n, i) ];\n\n              case 3:\n                // The local store may or may not be able to apply the write result and\n                // raise events immediately (depending on whether the watcher is caught\n                // up), so we raise user callbacks first so that they consistently happen\n                // before listen events.\n                return o.sent(), [ 3 /*break*/ , 6 ];\n\n              case 4:\n                return [ 4 /*yield*/ , mi(o.sent()) ];\n\n              case 5:\n                return o.sent(), [ 3 /*break*/ , 6 ];\n\n              case 6:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\nfunction Xu(t, e, n) {\n    return g(this, void 0, void 0, (function() {\n        var r, i;\n        return w(this, (function(o) {\n            switch (o.label) {\n              case 0:\n                r = O(t), o.label = 1;\n\n              case 1:\n                return o.trys.push([ 1, 4, , 6 ]), [ 4 /*yield*/ , function(t, e) {\n                    var n = O(t);\n                    return n.persistence.runTransaction(\"Reject batch\", \"readwrite-primary\", (function(t) {\n                        var r;\n                        return n.zo.Pi(t, e).next((function(e) {\n                            return k(null !== e), r = e.keys(), n.zo.Ci(t, e);\n                        })).next((function() {\n                            return n.zo.$i(t);\n                        })).next((function() {\n                            return n.Tc.Xo(t, r);\n                        }));\n                    }));\n                }(r.bh, e) ];\n\n              case 2:\n                return i = o.sent(), \n                // The local store may or may not be able to apply the write result and\n                // raise events immediately (depending on whether the watcher is caught up),\n                // so we raise user callbacks first so that they consistently happen before\n                // listen events.\n                Ju(r, e, n), Zu(r, e), r.Vl.Na(e, \"rejected\", n), [ 4 /*yield*/ , is(r, i) ];\n\n              case 3:\n                // The local store may or may not be able to apply the write result and\n                // raise events immediately (depending on whether the watcher is caught up),\n                // so we raise user callbacks first so that they consistently happen before\n                // listen events.\n                return o.sent(), [ 3 /*break*/ , 6 ];\n\n              case 4:\n                return [ 4 /*yield*/ , mi(o.sent()) ];\n\n              case 5:\n                return o.sent(), [ 3 /*break*/ , 6 ];\n\n              case 6:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * Registers a user callback that resolves when all pending mutations at the moment of calling\n * are acknowledged .\n */ function Wu(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r, i, o, u;\n        return w(this, (function(s) {\n            switch (s.label) {\n              case 0:\n                uu((n = O(t)).yl) || N(\"SyncEngine\", \"The network is disabled. The task returned by 'awaitPendingWrites()' will not complete until the network is enabled.\"), \n                s.label = 1;\n\n              case 1:\n                return s.trys.push([ 1, 3, , 4 ]), [ 4 /*yield*/ , function(t) {\n                    var e = O(t);\n                    return e.persistence.runTransaction(\"Get highest unacknowledged batch id\", \"readonly\", (function(t) {\n                        return e.zo.Vi(t);\n                    }));\n                }(n.bh) ];\n\n              case 2:\n                return -1 === (r = s.sent()) ? [ 2 /*return*/ , void e.resolve() ] : ((i = n.Fl.get(r) || []).push(e), \n                n.Fl.set(r, i), [ 3 /*break*/ , 4 ]);\n\n              case 3:\n                return o = s.sent(), u = Er(o, \"Initialization of waitForPendingWrites() operation failed\"), \n                e.reject(u), [ 3 /*break*/ , 4 ];\n\n              case 4:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/**\n * Triggers the callbacks that are waiting for this batch id to get acknowledged by server,\n * if there are any.\n */ function Zu(t, e) {\n    (t.Fl.get(e) || []).forEach((function(t) {\n        t.resolve();\n    })), t.Fl.delete(e)\n    /** Reject all outstanding callbacks waiting for pending writes to complete. */;\n}\n\nfunction Ju(t, e, n) {\n    var r = O(t), i = r.$l[r.currentUser.A()];\n    // NOTE: Mutations restored from persistence won't have callbacks, so it's\n    // okay for there to be no callback for this ID.\n    if (i) {\n        var o = i.get(e);\n        o && (n ? o.reject(n) : o.resolve(), i = i.remove(e)), r.$l[r.currentUser.A()] = i;\n    }\n}\n\nfunction $u(t, e, n) {\n    void 0 === n && (n = null), t.Vl.ka(e);\n    for (var r = 0, i = t.Sl.get(e); r < i.length; r++) {\n        var o = i[r];\n        t.vl.delete(o), n && t.bl.Bl(o, n);\n    }\n    t.Sl.delete(e), t.Ml && t.Nl.Fc(e).forEach((function(e) {\n        t.Nl.Fi(e) || \n        // We removed the last reference for this key\n        ts(t, e);\n    }));\n}\n\nfunction ts(t, e) {\n    t.Dl.delete(e.path.rt());\n    // It's possible that the target already got removed because the query failed. In that case,\n    // the key won't exist in `limboTargetsByKey`. Only do the cleanup if we still have the target.\n    var n = t.Cl.get(e);\n    null !== n && (eu(t.yl, n), t.Cl = t.Cl.remove(e), t.xl.delete(n), rs(t));\n}\n\nfunction es(t, e, n) {\n    for (var r = 0, i = n; r < i.length; r++) {\n        var o = i[r];\n        o instanceof Lu ? (t.Nl.nr(o.key, e), ns(t, o)) : o instanceof Ru ? (N(\"SyncEngine\", \"Document no longer in limbo: \" + o.key), \n        t.Nl.ir(o.key, e), t.Nl.Fi(o.key) || \n        // We removed the last reference for this key\n        ts(t, o.key)) : x();\n    }\n}\n\nfunction ns(t, e) {\n    var n = e.key, r = n.path.rt();\n    t.Cl.get(n) || t.Dl.has(r) || (N(\"SyncEngine\", \"New document in limbo: \" + n), t.Dl.add(r), \n    rs(t));\n}\n\n/**\n * Starts listens for documents in limbo that are enqueued for resolution,\n * subject to a maximum number of concurrent resolutions.\n *\n * Without bounding the number of concurrent resolutions, the server can fail\n * with \"resource exhausted\" errors which can lead to pathological client\n * behavior as seen in https://github.com/firebase/firebase-js-sdk/issues/2683.\n */ function rs(t) {\n    for (;t.Dl.size > 0 && t.Cl.size < t.pl; ) {\n        var e = t.Dl.values().next().value;\n        t.Dl.delete(e);\n        var n = new tt(Z.ot(e)), r = t.Ol.next();\n        t.xl.set(r, new qu(n)), t.Cl = t.Cl.zt(n, r), tu(t.yl, new ge(he(re(n.path)), r, 2 /* LimboResolution */ , H.q));\n    }\n}\n\nfunction is(t, e, n) {\n    return g(this, void 0, void 0, (function() {\n        var r, i, o, u;\n        return w(this, (function(s) {\n            switch (s.label) {\n              case 0:\n                return r = O(t), i = [], o = [], u = [], r.vl.et() ? [ 3 /*break*/ , 3 ] : (r.vl.forEach((function(t, s) {\n                    u.push(r.Ll(s, e, n).then((function(t) {\n                        if (t) {\n                            r.Ml && r.Vl.Ba(s.targetId, t.fromCache ? \"not-current\" : \"current\"), i.push(t);\n                            var e = Ji.oc(s.targetId, t);\n                            o.push(e);\n                        }\n                    })));\n                })), [ 4 /*yield*/ , Promise.all(u) ]);\n\n              case 1:\n                return s.sent(), r.bl.ah(i), [ 4 /*yield*/ , function(t, e) {\n                    return g(this, void 0, void 0, (function() {\n                        var n, r, i, o, u, s, a, c, h;\n                        return w(this, (function(f) {\n                            switch (f.label) {\n                              case 0:\n                                n = O(t), f.label = 1;\n\n                              case 1:\n                                return f.trys.push([ 1, 3, , 4 ]), [ 4 /*yield*/ , n.persistence.runTransaction(\"notifyLocalViewChanges\", \"readwrite\", (function(t) {\n                                    return lr.forEach(e, (function(e) {\n                                        return lr.forEach(e.ic, (function(r) {\n                                            return n.persistence.Ti.nr(t, e.targetId, r);\n                                        })).next((function() {\n                                            return lr.forEach(e.rc, (function(r) {\n                                                return n.persistence.Ti.ir(t, e.targetId, r);\n                                            }));\n                                        }));\n                                    }));\n                                })) ];\n\n                              case 2:\n                                return f.sent(), [ 3 /*break*/ , 4 ];\n\n                              case 3:\n                                if (!mr(r = f.sent())) throw r;\n                                // If `notifyLocalViewChanges` fails, we did not advance the sequence\n                                // number for the documents that were included in this transaction.\n                                // This might trigger them to be deleted earlier than they otherwise\n                                // would have, but it should not invalidate the integrity of the data.\n                                                                return N(\"LocalStore\", \"Failed to update sequence numbers: \" + r), \n                                [ 3 /*break*/ , 4 ];\n\n                              case 4:\n                                for (i = 0, o = e; i < o.length; i++) u = o[i], s = u.targetId, u.fromCache || (a = n.fc.get(s), \n                                c = a.Ot, h = a.Lt(c), \n                                // Advance the last limbo free snapshot version\n                                n.fc = n.fc.zt(s, h));\n                                return [ 2 /*return*/ ];\n                            }\n                        }));\n                    }));\n                }(r.bh, o) ];\n\n              case 2:\n                s.sent(), s.label = 3;\n\n              case 3:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\nfunction os(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r;\n        return w(this, (function(i) {\n            switch (i.label) {\n              case 0:\n                return (n = O(t)).currentUser.isEqual(e) ? [ 3 /*break*/ , 3 ] : (N(\"SyncEngine\", \"User change. New user:\", e.A()), \n                [ 4 /*yield*/ , no(n.bh, e) ]);\n\n              case 1:\n                return r = i.sent(), n.currentUser = e, \n                // Fails tasks waiting for pending writes requested by previous user.\n                function(t, e) {\n                    t.Fl.forEach((function(t) {\n                        t.forEach((function(t) {\n                            t.reject(new q(M.CANCELLED, \"'waitForPendingWrites' promise is rejected due to a user change.\"));\n                        }));\n                    })), t.Fl.clear();\n                }(n), \n                // TODO(b/114226417): Consider calling this only in the primary tab.\n                n.Vl.Ua(e, r.mc, r.Ac), [ 4 /*yield*/ , is(n, r.Ic) ];\n\n              case 2:\n                i.sent(), i.label = 3;\n\n              case 3:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\nfunction us(t, e) {\n    var n = O(t), r = n.xl.get(e);\n    if (r && r.Pl) return mn().add(r.key);\n    var i = mn(), o = n.Sl.get(e);\n    if (!o) return i;\n    for (var u = 0, s = o; u < s.length; u++) {\n        var a = s[u], c = n.vl.get(a);\n        i = i.Pe(c.view._l);\n    }\n    return i;\n}\n\n/**\n * Reconcile the list of synced documents in an existing view with those\n * from persistence.\n */ function ss(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r, i;\n        return w(this, (function(o) {\n            switch (o.label) {\n              case 0:\n                return [ 4 /*yield*/ , ho((n = O(t)).bh, e.query, \n                /* usePreviousResults= */ !0) ];\n\n              case 1:\n                return r = o.sent(), i = e.view.Al(r), [ 2 /*return*/ , (n.Ml && es(n, e.targetId, i.Il), \n                i) ];\n            }\n        }));\n    }));\n}\n\n/**\n * Retrieves newly changed documents from remote document cache and raises\n * snapshots if needed.\n */\n// PORTING NOTE: Multi-Tab only.\nfunction as(t) {\n    return g(this, void 0, void 0, (function() {\n        var e;\n        return w(this, (function(n) {\n            return [ 2 /*return*/ , lo((e = O(t)).bh).then((function(t) {\n                return is(e, t);\n            })) ];\n        }));\n    }));\n}\n\n/** Applies a mutation state to an existing batch.  */\n// PORTING NOTE: Multi-Tab only.\nfunction cs(t, e, n, r) {\n    return g(this, void 0, void 0, (function() {\n        var i, o;\n        return w(this, (function(u) {\n            switch (u.label) {\n              case 0:\n                return [ 4 /*yield*/ , function(t, e) {\n                    var n = O(t), r = O(n.zo);\n                    return n.persistence.runTransaction(\"Lookup mutation documents\", \"readonly\", (function(t) {\n                        return r.yi(t, e).next((function(e) {\n                            return e ? n.Tc.Xo(t, e) : lr.resolve(null);\n                        }));\n                    }));\n                }((i = O(t)).bh, e) ];\n\n              case 1:\n                return null === (o = u.sent()) ? [ 3 /*break*/ , 6 ] : \"pending\" !== n ? [ 3 /*break*/ , 3 ] : [ 4 /*yield*/ , pu(i.yl) ];\n\n              case 2:\n                // If we are the primary client, we need to send this write to the\n                // backend. Secondary clients will ignore these writes since their remote\n                // connection is disabled.\n                return u.sent(), [ 3 /*break*/ , 4 ];\n\n              case 3:\n                \"acknowledged\" === n || \"rejected\" === n ? (\n                // NOTE: Both these methods are no-ops for batches that originated from\n                // other clients.\n                Ju(i, e, r || null), Zu(i, e), function(t, e) {\n                    O(O(t).zo).xi(e);\n                }(i.bh, e)) : x(), u.label = 4;\n\n              case 4:\n                return [ 4 /*yield*/ , is(i, o) ];\n\n              case 5:\n                return u.sent(), [ 3 /*break*/ , 7 ];\n\n              case 6:\n                // A throttled tab may not have seen the mutation before it was completed\n                // and removed from the mutation queue, in which case we won't have cached\n                // the affected documents. In this case we can safely ignore the update\n                // since that means we didn't apply the mutation locally at all (if we\n                // had, we would have cached the affected documents), and so we will just\n                // see any resulting document changes via normal remote document updates\n                // as applicable.\n                N(\"SyncEngine\", \"Cannot apply mutation batch with id: \" + e), u.label = 7;\n\n              case 7:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/** Applies a query target change from a different tab. */\n// PORTING NOTE: Multi-Tab only.\nfunction hs(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r, i, o, u, s, a, c;\n        return w(this, (function(h) {\n            switch (h.label) {\n              case 0:\n                return ys(n = O(t)), ms(n), !0 !== e || !0 === n.kl ? [ 3 /*break*/ , 3 ] : (r = n.Vl.va(), \n                [ 4 /*yield*/ , fs(n, r.it()) ]);\n\n              case 1:\n                return i = h.sent(), n.kl = !0, [ 4 /*yield*/ , bu(n.yl, !0) ];\n\n              case 2:\n                for (h.sent(), o = 0, u = i; o < u.length; o++) s = u[o], tu(n.yl, s);\n                return [ 3 /*break*/ , 7 ];\n\n              case 3:\n                return !1 !== e || !1 === n.kl ? [ 3 /*break*/ , 7 ] : (a = [], c = Promise.resolve(), \n                n.Sl.forEach((function(t, e) {\n                    n.Vl.Ma(e) ? a.push(e) : c = c.then((function() {\n                        return $u(n, e), co(n.bh, e, \n                        /*keepPersistedTargetData=*/ !0);\n                    })), eu(n.yl, e);\n                })), [ 4 /*yield*/ , c ]);\n\n              case 4:\n                return h.sent(), [ 4 /*yield*/ , fs(n, a) ];\n\n              case 5:\n                return h.sent(), \n                // PORTING NOTE: Multi-Tab only.\n                function(t) {\n                    var e = O(t);\n                    e.xl.forEach((function(t, n) {\n                        eu(e.yl, n);\n                    })), e.Nl.Oc(), e.xl = new Map, e.Cl = new rn(tt.H);\n                }(n), n.kl = !1, [ 4 /*yield*/ , bu(n.yl, !1) ];\n\n              case 6:\n                h.sent(), h.label = 7;\n\n              case 7:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\nfunction fs(t, e, n) {\n    return g(this, void 0, void 0, (function() {\n        var n, r, i, o, u, s, a, c, h, f, l, p, d, v;\n        return w(this, (function(y) {\n            switch (y.label) {\n              case 0:\n                n = O(t), r = [], i = [], o = 0, u = e, y.label = 1;\n\n              case 1:\n                return o < u.length ? (s = u[o], a = void 0, (c = n.Sl.get(s)) && 0 !== c.length ? [ 4 /*yield*/ , ao(n.bh, he(c[0])) ] : [ 3 /*break*/ , 7 ]) : [ 3 /*break*/ , 13 ];\n\n              case 2:\n                // For queries that have a local View, we fetch their current state\n                // from LocalStore (as the resume token and the snapshot version\n                // might have changed) and reconcile their views with the persisted\n                // state (the list of syncedDocuments may have gotten out of sync).\n                a = y.sent(), h = 0, f = c, y.label = 3;\n\n              case 3:\n                return h < f.length ? (l = f[h], p = n.vl.get(l), [ 4 /*yield*/ , ss(n, p) ]) : [ 3 /*break*/ , 6 ];\n\n              case 4:\n                (d = y.sent()).snapshot && i.push(d.snapshot), y.label = 5;\n\n              case 5:\n                return h++, [ 3 /*break*/ , 3 ];\n\n              case 6:\n                return [ 3 /*break*/ , 11 ];\n\n              case 7:\n                return [ 4 /*yield*/ , fo(n.bh, s) ];\n\n              case 8:\n                return v = y.sent(), [ 4 /*yield*/ , ao(n.bh, v) ];\n\n              case 9:\n                return a = y.sent(), [ 4 /*yield*/ , zu(n, ls(v), s, \n                /*current=*/ !1) ];\n\n              case 10:\n                y.sent(), y.label = 11;\n\n              case 11:\n                r.push(a), y.label = 12;\n\n              case 12:\n                return o++, [ 3 /*break*/ , 1 ];\n\n              case 13:\n                return [ 2 /*return*/ , (n.bl.ah(i), r) ];\n            }\n        }));\n    }));\n}\n\n/**\n * Creates a `Query` object from the specified `Target`. There is no way to\n * obtain the original `Query`, so we synthesize a `Query` from the `Target`\n * object.\n *\n * The synthesized result might be different from the original `Query`, but\n * since the synthesized `Query` should return the same results as the\n * original one (only the presentation of results might differ), the potential\n * difference will not cause issues.\n */\n// PORTING NOTE: Multi-Tab only.\nfunction ls(t) {\n    return ne(t.path, t.collectionGroup, t.orderBy, t.filters, t.limit, \"F\" /* First */ , t.startAt, t.endAt);\n}\n\n/** Returns the IDs of the clients that are currently active. */\n// PORTING NOTE: Multi-Tab only.\nfunction ps(t) {\n    var e = O(t);\n    return O(O(e.bh).persistence).Uo();\n}\n\n/** Applies a query target change from a different tab. */\n// PORTING NOTE: Multi-Tab only.\nfunction ds(t, e, n, r) {\n    return g(this, void 0, void 0, (function() {\n        var i, o, u;\n        return w(this, (function(s) {\n            switch (s.label) {\n              case 0:\n                return (i = O(t)).kl ? (\n                // If we receive a target state notification via WebStorage, we are\n                // either already secondary or another tab has taken the primary lease.\n                N(\"SyncEngine\", \"Ignoring unexpected query state notification.\"), [ 3 /*break*/ , 8 ]) : [ 3 /*break*/ , 1 ];\n\n              case 1:\n                if (!i.Sl.has(e)) return [ 3 /*break*/ , 8 ];\n                switch (n) {\n                  case \"current\":\n                  case \"not-current\":\n                    return [ 3 /*break*/ , 2 ];\n\n                  case \"rejected\":\n                    return [ 3 /*break*/ , 5 ];\n                }\n                return [ 3 /*break*/ , 7 ];\n\n              case 2:\n                return [ 4 /*yield*/ , lo(i.bh) ];\n\n              case 3:\n                return o = s.sent(), u = En.Me(e, \"current\" === n), [ 4 /*yield*/ , is(i, o, u) ];\n\n              case 4:\n                return s.sent(), [ 3 /*break*/ , 8 ];\n\n              case 5:\n                return [ 4 /*yield*/ , co(i.bh, e, \n                /* keepPersistedTargetData */ !0) ];\n\n              case 6:\n                return s.sent(), $u(i, e, r), [ 3 /*break*/ , 8 ];\n\n              case 7:\n                x(), s.label = 8;\n\n              case 8:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\n/** Adds or removes Watch targets for queries from different tabs. */ function vs(t, e, n) {\n    return g(this, void 0, void 0, (function() {\n        var r, i, o, u, s, a, c, h, f, l;\n        return w(this, (function(p) {\n            switch (p.label) {\n              case 0:\n                if (!(r = ys(t)).kl) return [ 3 /*break*/ , 10 ];\n                i = 0, o = e, p.label = 1;\n\n              case 1:\n                return i < o.length ? (u = o[i], r.Sl.has(u) ? (\n                // A target might have been added in a previous attempt\n                N(\"SyncEngine\", \"Adding an already active target \" + u), [ 3 /*break*/ , 5 ]) : [ 4 /*yield*/ , fo(r.bh, u) ]) : [ 3 /*break*/ , 6 ];\n\n              case 2:\n                return s = p.sent(), [ 4 /*yield*/ , ao(r.bh, s) ];\n\n              case 3:\n                return a = p.sent(), [ 4 /*yield*/ , zu(r, ls(s), a.targetId, \n                /*current=*/ !1) ];\n\n              case 4:\n                p.sent(), tu(r.yl, a), p.label = 5;\n\n              case 5:\n                return i++, [ 3 /*break*/ , 1 ];\n\n              case 6:\n                c = function(t) {\n                    return w(this, (function(e) {\n                        switch (e.label) {\n                          case 0:\n                            return r.Sl.has(t) ? [ 4 /*yield*/ , co(r.bh, t, \n                            /* keepPersistedTargetData */ !1).then((function() {\n                                eu(r.yl, t), $u(r, t);\n                            })).catch(mi) ] : [ 3 /*break*/ , 2 ];\n\n                            // Release queries that are still active.\n                                                      case 1:\n                            // Release queries that are still active.\n                            e.sent(), e.label = 2;\n\n                          case 2:\n                            return [ 2 /*return*/ ];\n                        }\n                    }));\n                }, h = 0, f = n, p.label = 7;\n\n              case 7:\n                return h < f.length ? (l = f[h], [ 5 /*yield**/ , c(l) ]) : [ 3 /*break*/ , 10 ];\n\n              case 8:\n                p.sent(), p.label = 9;\n\n              case 9:\n                return h++, [ 3 /*break*/ , 7 ];\n\n              case 10:\n                return [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\nfunction ys(t) {\n    var e = O(t);\n    return e.yl.Dh.Lh = Qu.bind(null, e), e.yl.Dh.vn = us.bind(null, e), e.yl.Dh.Mh = Hu.bind(null, e), \n    e.bl.ah = Du.bind(null, e.gl), e.bl.Bl = Su.bind(null, e.gl), e;\n}\n\nfunction ms(t) {\n    var e = O(t);\n    return e.yl.Dh.Bh = Ku.bind(null, e), e.yl.Dh.qh = Xu.bind(null, e), e\n    /**\n * Loads a Firestore bundle into the SDK. The returned promise resolves when\n * the bundle finished loading.\n *\n * @param syncEngine - SyncEngine to use.\n * @param bundleReader - Bundle to load into the SDK.\n * @param task - LoadBundleTask used to update the loading progress to public API.\n */;\n}\n\nfunction gs(t, e, n) {\n    var r = O(t);\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        (function(t, e, n) {\n        return g(this, void 0, void 0, (function() {\n            var r, i, o, u, s, a;\n            return w(this, (function(c) {\n                switch (c.label) {\n                  case 0:\n                    return c.trys.push([ 0, 14, , 15 ]), [ 4 /*yield*/ , e.getMetadata() ];\n\n                  case 1:\n                    return r = c.sent(), [ 4 /*yield*/ , function(t, e) {\n                        var n = O(t), r = Mn(e.createTime);\n                        return n.persistence.runTransaction(\"hasNewerBundle\", \"readonly\", (function(t) {\n                            return n.wo.Os(t, e.id);\n                        })).then((function(t) {\n                            return !!t && t.createTime._(r) >= 0;\n                        }));\n                    }(t.bh, r) ];\n\n                  case 2:\n                    return c.sent() ? [ 4 /*yield*/ , e.close() ] : [ 3 /*break*/ , 4 ];\n\n                  case 3:\n                    return [ 2 /*return*/ , (c.sent(), void n.ql(function(t) {\n                        return {\n                            taskState: \"Success\",\n                            documentsLoaded: t.totalDocuments,\n                            bytesLoaded: t.totalBytes,\n                            totalDocuments: t.totalDocuments,\n                            totalBytes: t.totalBytes\n                        };\n                    }(r))) ];\n\n                  case 4:\n                    return n.Ul(Cu(r)), i = new Vu(r, t.bh, e.Qt), [ 4 /*yield*/ , e.Ql() ];\n\n                  case 5:\n                    o = c.sent(), c.label = 6;\n\n                  case 6:\n                    return o ? [ 4 /*yield*/ , i.rl(o) ] : [ 3 /*break*/ , 10 ];\n\n                  case 7:\n                    return (u = c.sent()) && n.Ul(u), [ 4 /*yield*/ , e.Ql() ];\n\n                  case 8:\n                    o = c.sent(), c.label = 9;\n\n                  case 9:\n                    return [ 3 /*break*/ , 6 ];\n\n                  case 10:\n                    return [ 4 /*yield*/ , i.complete() ];\n\n                  case 11:\n                    // TODO(b/160876443): This currently raises snapshots with\n                    // `fromCache=false` if users already listen to some queries and bundles\n                    // has newer version.\n                    return s = c.sent(), [ 4 /*yield*/ , is(t, s.Go, \n                    /* remoteEvent */ void 0) ];\n\n                  case 12:\n                    // Save metadata, so loading the same bundle will skip.\n                    // TODO(b/160876443): This currently raises snapshots with\n                    // `fromCache=false` if users already listen to some queries and bundles\n                    // has newer version.\n                    return c.sent(), [ 4 /*yield*/ , function(t, e) {\n                        var n = O(t);\n                        return n.persistence.runTransaction(\"Save bundle\", \"readwrite\", (function(t) {\n                            return n.wo.ks(t, e);\n                        }));\n                    }(t.bh, r) ];\n\n                  case 13:\n                    // TODO(b/160876443): This currently raises snapshots with\n                    // `fromCache=false` if users already listen to some queries and bundles\n                    // has newer version.\n                    // Save metadata, so loading the same bundle will skip.\n                    return c.sent(), n.ql(s.progress), [ 3 /*break*/ , 15 ];\n\n                  case 14:\n                    return D(\"SyncEngine\", \"Loading bundle failed with \" + (a = c.sent())), n.Kl(a), \n                    [ 3 /*break*/ , 15 ];\n\n                  case 15:\n                    return [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }\n    /**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n    /**\n * Provides all components needed for Firestore with in-memory persistence.\n * Uses EagerGC garbage collection.\n */)(r, e, n).then((function() {\n        r.Vl.Wa();\n    }));\n}\n\nvar ws = /** @class */ function() {\n    function t() {\n        this.synchronizeTabs = !1;\n    }\n    return t.prototype.initialize = function(t) {\n        return g(this, void 0, void 0, (function() {\n            return w(this, (function(e) {\n                switch (e.label) {\n                  case 0:\n                    return this.Qt = Bo(t.yu.t), this.Vl = this.Wl(t), this.persistence = this.jl(t), \n                    [ 4 /*yield*/ , this.persistence.start() ];\n\n                  case 1:\n                    return e.sent(), this.Gl = this.zl(t), this.bh = this.Hl(t), [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, t.prototype.zl = function(t) {\n        return null;\n    }, t.prototype.Hl = function(t) {\n        return eo(this.persistence, new $i, t.Jl, this.Qt);\n    }, t.prototype.jl = function(t) {\n        return new To(Ao.ia, this.Qt);\n    }, t.prototype.Wl = function(t) {\n        return new Ro;\n    }, t.prototype.terminate = function() {\n        return g(this, void 0, void 0, (function() {\n            return w(this, (function(t) {\n                switch (t.label) {\n                  case 0:\n                    return this.Gl && this.Gl.stop(), [ 4 /*yield*/ , this.Vl.ko() ];\n\n                  case 1:\n                    return t.sent(), [ 4 /*yield*/ , this.persistence.ko() ];\n\n                  case 2:\n                    return t.sent(), [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, t;\n}(), bs = /** @class */ function(t) {\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this) || this).Yl = e, i.cacheSizeBytes = n, i.forceOwnership = r, \n        i.synchronizeTabs = !1, i;\n    }\n    return m(e, t), e.prototype.initialize = function(e) {\n        return g(this, void 0, void 0, (function() {\n            return w(this, (function(n) {\n                switch (n.label) {\n                  case 0:\n                    return [ 4 /*yield*/ , t.prototype.initialize.call(this, e) ];\n\n                  case 1:\n                    return n.sent(), [ 4 /*yield*/ , po(this.bh) ];\n\n                  case 2:\n                    return n.sent(), [ 4 /*yield*/ , this.Yl.initialize(this, e) ];\n\n                  case 3:\n                    // Enqueue writes from a previous session\n                    return n.sent(), [ 4 /*yield*/ , ms(this.Yl._a) ];\n\n                  case 4:\n                    // Enqueue writes from a previous session\n                    return n.sent(), [ 4 /*yield*/ , pu(this.Yl.yl) ];\n\n                  case 5:\n                    return n.sent(), [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, e.prototype.Hl = function(t) {\n        return eo(this.persistence, new $i, t.Jl, this.Qt);\n    }, e.prototype.zl = function(t) {\n        var e = this.persistence.Ti.lr;\n        return new Ci(e, t._s);\n    }, e.prototype.jl = function(t) {\n        var e = Xi(t.yu.t, t.yu.persistenceKey), n = void 0 !== this.cacheSizeBytes ? yi.Ys(this.cacheSizeBytes) : yi.ti;\n        return new Yi(this.synchronizeTabs, e, t.clientId, n, t._s, zo(), Go(), this.Qt, this.Vl, !!this.forceOwnership);\n    }, e.prototype.Wl = function(t) {\n        return new Ro;\n    }, e;\n}(ws), _s = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, e, n, /* forceOwnership= */ !1) || this).Yl = e, r.cacheSizeBytes = n, \n        r.synchronizeTabs = !0, r;\n    }\n    return m(e, t), e.prototype.initialize = function(e) {\n        return g(this, void 0, void 0, (function() {\n            var n, r = this;\n            return w(this, (function(i) {\n                switch (i.label) {\n                  case 0:\n                    return [ 4 /*yield*/ , t.prototype.initialize.call(this, e) ];\n\n                  case 1:\n                    return i.sent(), n = this.Yl._a, this.Vl instanceof Lo ? (this.Vl._a = {\n                        eu: cs.bind(null, n),\n                        nu: ds.bind(null, n),\n                        su: vs.bind(null, n),\n                        Uo: ps.bind(null, n),\n                        tu: as.bind(null, n)\n                    }, [ 4 /*yield*/ , this.Vl.start() ]) : [ 3 /*break*/ , 3 ];\n\n                  case 2:\n                    i.sent(), i.label = 3;\n\n                  case 3:\n                    // NOTE: This will immediately call the listener, so we make sure to\n                    // set it after localStore / remoteStore are started.\n                    return [ 4 /*yield*/ , this.persistence.Ro((function(t) {\n                        return g(r, void 0, void 0, (function() {\n                            return w(this, (function(e) {\n                                switch (e.label) {\n                                  case 0:\n                                    return [ 4 /*yield*/ , hs(this.Yl._a, t) ];\n\n                                  case 1:\n                                    return e.sent(), this.Gl && (t && !this.Gl.Er ? this.Gl.start(this.bh) : t || this.Gl.stop()), \n                                    [ 2 /*return*/ ];\n                                }\n                            }));\n                        }));\n                    })) ];\n\n                  case 4:\n                    // NOTE: This will immediately call the listener, so we make sure to\n                    // set it after localStore / remoteStore are started.\n                    return i.sent(), [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, e.prototype.Wl = function(t) {\n        var e = zo();\n        if (!Lo.Kn(e)) throw new q(M.UNIMPLEMENTED, \"IndexedDB persistence is only available on platforms that support LocalStorage.\");\n        var n = Xi(t.yu.t, t.yu.persistenceKey);\n        return new Lo(e, t._s, n, t.clientId, t.Jl);\n    }, e;\n}(bs), Is = /** @class */ function() {\n    function t() {}\n    return t.prototype.initialize = function(t, e) {\n        return g(this, void 0, void 0, (function() {\n            var n = this;\n            return w(this, (function(r) {\n                switch (r.label) {\n                  case 0:\n                    return this.bh ? [ 3 /*break*/ , 2 ] : (this.bh = t.bh, this.Vl = t.Vl, this.Sh = this.Xl(e), \n                    this.yl = this.Zl(e), this.gl = this.t_(e), this._a = this.e_(e, \n                    /* startAsPrimary=*/ !t.synchronizeTabs), this.Vl.fa = function(t) {\n                        return Yu(n._a, t, 1 /* SharedClientState */);\n                    }, this.yl.Dh.n_ = os.bind(null, this._a), [ 4 /*yield*/ , bu(this.yl, this._a.Ml) ]);\n\n                  case 1:\n                    r.sent(), r.label = 2;\n\n                  case 2:\n                    return [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, t.prototype.t_ = function(t) {\n        return new Tu;\n    }, t.prototype.Xl = function(t) {\n        var e, n = Bo(t.yu.t), r = (e = t.yu, new jo(e));\n        /** Return the Platform-specific connectivity monitor. */ return function(t, e, n) {\n            return new Xo(t, e, n);\n        }(t.credentials, r, n);\n    }, t.prototype.Zl = function(t) {\n        var e, n, r, i, o, u = this;\n        return e = this.bh, n = this.Sh, r = t._s, i = function(t) {\n            return Yu(u._a, t, 0 /* RemoteStore */);\n        }, o = Mo.Kn() ? new Mo : new Uo, new Zo(e, n, r, i, o);\n    }, t.prototype.e_ = function(t, e) {\n        return function(t, e, n, \n        // PORTING NOTE: Manages state synchronization in multi-tab environments.\n        r, i, o, u) {\n            var s = new Fu(t, e, n, r, i, o);\n            return u && (s.kl = !0), s;\n        }(this.bh, this.yl, this.gl, this.Vl, t.Jl, t.pl, e);\n    }, t.prototype.terminate = function() {\n        return function(t) {\n            return g(this, void 0, void 0, (function() {\n                var e;\n                return w(this, (function(n) {\n                    switch (n.label) {\n                      case 0:\n                        return e = O(t), N(\"RemoteStore\", \"RemoteStore shutting down.\"), e.Nh.add(5 /* Shutdown */), \n                        [ 4 /*yield*/ , $o(e) ];\n\n                      case 1:\n                        return n.sent(), e.Fh.ko(), \n                        // Set the OnlineState to Unknown (rather than Offline) to avoid potentially\n                        // triggering spurious listener events with cached data, etc.\n                        e.Oh.set(\"Unknown\" /* Unknown */), [ 2 /*return*/ ];\n                    }\n                }));\n            }));\n        }(this.yl);\n    }, t;\n}();\n\n/**\n * Provides all components needed for Firestore with IndexedDB persistence.\n */\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * How many bytes to read each time when `ReadableStreamReader.read()` is\n * called. Only applicable for byte streams that we control (e.g. those backed\n * by an UInt8Array).\n */\n/**\n * Builds a `ByteStreamReader` from a UInt8Array.\n * @param source - The data source to use.\n * @param bytesPerRead - How many bytes each `read()` from the returned reader\n *        will read.\n */\nfunction Es(t, e) {\n    void 0 === e && (e = 10240);\n    var n = 0;\n    return {\n        read: function() {\n            return g(this, void 0, void 0, (function() {\n                var r;\n                return w(this, (function(i) {\n                    return n < t.byteLength ? (r = {\n                        value: t.slice(n, n + e),\n                        done: !1\n                    }, [ 2 /*return*/ , (n += e, r) ]) : [ 2 /*return*/ , {\n                        done: !0\n                    } ];\n                }));\n            }));\n        },\n        cancel: function() {\n            return g(this, void 0, void 0, (function() {\n                return w(this, (function(t) {\n                    return [ 2 /*return*/ ];\n                }));\n            }));\n        },\n        releaseLock: function() {},\n        closed: Promise.reject(\"unimplemented\")\n    };\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * On web, a `ReadableStream` is wrapped around by a `ByteStreamReader`.\n */\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/*\n * A wrapper implementation of Observer<T> that will dispatch events\n * asynchronously. To allow immediate silencing, a mute call is added which\n * causes events scheduled to no longer be raised.\n */ var Ts = /** @class */ function() {\n    function t(t) {\n        this.observer = t, \n        /**\n             * When set to true, will not raise future events. Necessary to deal with\n             * async detachment of listener.\n             */\n        this.muted = !1;\n    }\n    return t.prototype.next = function(t) {\n        this.observer.next && this.s_(this.observer.next, t);\n    }, t.prototype.error = function(t) {\n        this.observer.error ? this.s_(this.observer.error, t) : console.error(\"Uncaught Error in snapshot listener:\", t);\n    }, t.prototype.i_ = function() {\n        this.muted = !0;\n    }, t.prototype.s_ = function(t, e) {\n        var n = this;\n        this.muted || setTimeout((function() {\n            n.muted || t(e);\n        }), 0);\n    }, t;\n}(), Ns = /** @class */ function() {\n    function t(\n    /** The reader to read from underlying binary bundle data source. */\n    t, e) {\n        var n = this;\n        this.r_ = t, this.Qt = e, \n        /** Cached bundle metadata. */\n        this.metadata = new fr, \n        /**\n             * Internal buffer to hold bundle content, accumulating incomplete element\n             * content.\n             */\n        this.buffer = new Uint8Array, this.o_ = new TextDecoder(\"utf-8\"), \n        // Read the metadata (which is the first element).\n        this.c_().then((function(t) {\n            t && t.sl() ? n.metadata.resolve(t.payload.metadata) : n.metadata.reject(new Error(\"The first element of the bundle is not a metadata, it is\\n             \" + JSON.stringify(null == t ? void 0 : t.payload)));\n        }), (function(t) {\n            return n.metadata.reject(t);\n        }));\n    }\n    return t.prototype.close = function() {\n        return this.r_.cancel();\n    }, t.prototype.getMetadata = function() {\n        return g(this, void 0, void 0, (function() {\n            return w(this, (function(t) {\n                return [ 2 /*return*/ , this.metadata.promise ];\n            }));\n        }));\n    }, t.prototype.Ql = function() {\n        return g(this, void 0, void 0, (function() {\n            return w(this, (function(t) {\n                switch (t.label) {\n                  case 0:\n                    return [ 4 /*yield*/ , this.getMetadata() ];\n\n                  case 1:\n                    // Makes sure metadata is read before proceeding.\n                    return [ 2 /*return*/ , (t.sent(), this.c_()) ];\n                }\n            }));\n        }));\n    }, \n    /**\n     * Reads from the head of internal buffer, and pulling more data from\n     * underlying stream if a complete element cannot be found, until an\n     * element(including the prefixed length and the JSON string) is found.\n     *\n     * Once a complete element is read, it is dropped from internal buffer.\n     *\n     * Returns either the bundled element, or null if we have reached the end of\n     * the stream.\n     */\n    t.prototype.c_ = function() {\n        return g(this, void 0, void 0, (function() {\n            var t, e, n, r;\n            return w(this, (function(i) {\n                switch (i.label) {\n                  case 0:\n                    return [ 4 /*yield*/ , this.a_() ];\n\n                  case 1:\n                    return null === (t = i.sent()) ? [ 2 /*return*/ , null ] : (e = this.o_.decode(t), \n                    n = Number(e), isNaN(n) && this.u_(\"length string (\" + e + \") is not valid number\"), \n                    [ 4 /*yield*/ , this.h_(n) ]);\n\n                  case 2:\n                    return r = i.sent(), [ 2 /*return*/ , new Ou(JSON.parse(r), t.length + n) ];\n                }\n            }));\n        }));\n    }, \n    /** First index of '{' from the underlying buffer. */ t.prototype.l_ = function() {\n        return this.buffer.findIndex((function(t) {\n            return t === \"{\".charCodeAt(0);\n        }));\n    }, \n    /**\n     * Reads from the beginning of the internal buffer, until the first '{', and\n     * return the content.\n     *\n     * If reached end of the stream, returns a null.\n     */\n    t.prototype.a_ = function() {\n        return g(this, void 0, void 0, (function() {\n            var t, e;\n            return w(this, (function(n) {\n                switch (n.label) {\n                  case 0:\n                    return this.l_() < 0 ? [ 4 /*yield*/ , this.__() ] : [ 3 /*break*/ , 3 ];\n\n                  case 1:\n                    if (n.sent()) return [ 3 /*break*/ , 3 ];\n                    n.label = 2;\n\n                  case 2:\n                    return [ 3 /*break*/ , 0 ];\n\n                  case 3:\n                    // Broke out of the loop because underlying stream is closed, and there\n                    // happens to be no more data to process.\n                    return 0 === this.buffer.length ? [ 2 /*return*/ , null ] : (\n                    // Broke out of the loop because underlying stream is closed, but still\n                    // cannot find an open bracket.\n                    (t = this.l_()) < 0 && this.u_(\"Reached the end of bundle when a length string is expected.\"), \n                    e = this.buffer.slice(0, t), [ 2 /*return*/ , (this.buffer = this.buffer.slice(t), \n                    e) ]);\n                }\n            }));\n        }));\n    }, \n    /**\n     * Reads from a specified position from the internal buffer, for a specified\n     * number of bytes, pulling more data from the underlying stream if needed.\n     *\n     * Returns a string decoded from the read bytes.\n     */\n    t.prototype.h_ = function(t) {\n        return g(this, void 0, void 0, (function() {\n            var e;\n            return w(this, (function(n) {\n                switch (n.label) {\n                  case 0:\n                    return this.buffer.length < t ? [ 4 /*yield*/ , this.__() ] : [ 3 /*break*/ , 3 ];\n\n                  case 1:\n                    n.sent() && this.u_(\"Reached the end of bundle when more is expected.\"), n.label = 2;\n\n                  case 2:\n                    return [ 3 /*break*/ , 0 ];\n\n                  case 3:\n                    // Update the internal buffer to drop the read json string.\n                    return e = this.o_.decode(this.buffer.slice(0, t)), [ 2 /*return*/ , (this.buffer = this.buffer.slice(t), \n                    e) ];\n                }\n            }));\n        }));\n    }, t.prototype.u_ = function(t) {\n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        throw this.r_.cancel(), new Error(\"Invalid bundle format: \" + t);\n    }, \n    /**\n     * Pulls more data from underlying stream to internal buffer.\n     * Returns a boolean indicating whether the stream is finished.\n     */\n    t.prototype.__ = function() {\n        return g(this, void 0, void 0, (function() {\n            var t, e;\n            return w(this, (function(n) {\n                switch (n.label) {\n                  case 0:\n                    return [ 4 /*yield*/ , this.r_.read() ];\n\n                  case 1:\n                    return (t = n.sent()).done || ((e = new Uint8Array(this.buffer.length + t.value.length)).set(this.buffer), \n                    e.set(t.value, this.buffer.length), this.buffer = e), [ 2 /*return*/ , t.done ];\n                }\n            }));\n        }));\n    }, t;\n}(), As = /** @class */ function() {\n    /**\n     * Creates a FieldPath from the provided field names. If more than one field\n     * name is provided, the path will point to a nested field in a document.\n     *\n     * @param fieldNames - A list of field names.\n     */\n    function t() {\n        for (var t = [], e = 0; e < arguments.length; e++) t[e] = arguments[e];\n        for (var n = 0; n < t.length; ++n) if (0 === t[n].length) throw new q(M.INVALID_ARGUMENT, \"Invalid field name at argument $(i + 1). Field names must not be empty.\");\n        this.f_ = new $(t);\n    }\n    /**\n     * Returns true if this `FieldPath` is equal to the provided one.\n     *\n     * @param other - The `FieldPath` to compare against.\n     * @returns true if this `FieldPath` is equal to the provided one.\n     */    return t.prototype.isEqual = function(t) {\n        return this.f_.isEqual(t.f_);\n    }, t;\n}(), Ds = \n/**\n     * @param _methodName - The public API endpoint that returns this class.\n     */\nfunction(t) {\n    this._methodName = t;\n}, Ss = function(t) {\n    this.d_ = t;\n};\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A class representing a bundle.\n *\n * Takes a bundle stream or buffer, and presents abstractions to read bundled\n * elements out of the underlying content.\n */\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nfunction xs(t, e, n) {\n    if (!n) throw new q(M.INVALID_ARGUMENT, \"Function \" + t + \"() cannot be called with an empty \" + e + \".\");\n}\n\nfunction ks(t, e) {\n    if (void 0 === e) return {\n        merge: !1\n    };\n    if (void 0 !== e.mergeFields && void 0 !== e.merge) throw new q(M.INVALID_ARGUMENT, \"Invalid options passed to function \" + t + '(): You cannot specify both \"merge\" and \"mergeFields\".');\n    return e;\n}\n\n/**\n * Validates that two boolean options are not set at the same time.\n */ function Os(t, e, n, r) {\n    if (!0 === e && !0 === r) throw new q(M.INVALID_ARGUMENT, t + \" and \" + n + \" cannot be used together.\");\n}\n\n/**\n * Validates that `path` refers to a document (indicated by the fact it contains\n * an even numbers of segments).\n */ function Ps(t) {\n    if (!tt.wt(t)) throw new q(M.INVALID_ARGUMENT, \"Invalid document reference. Document references must have an even number of segments, but \" + t + \" has \" + t.length + \".\");\n}\n\n/**\n * Validates that `path` refers to a collection (indicated by the fact it\n * contains an odd numbers of segments).\n */ function Vs(t) {\n    if (tt.wt(t)) throw new q(M.INVALID_ARGUMENT, \"Invalid collection reference. Collection references must have an odd number of segments, but \" + t + \" has \" + t.length + \".\");\n}\n\n/**\n * Returns true if it's a non-null object without a custom prototype\n * (i.e. excludes Array, Date, etc.).\n */\n/** Returns a string describing the type / value of the provided input. */ function Cs(t) {\n    if (void 0 === t) return \"undefined\";\n    if (null === t) return \"null\";\n    if (\"string\" == typeof t) return t.length > 20 && (t = t.substring(0, 20) + \"...\"), \n    JSON.stringify(t);\n    if (\"number\" == typeof t || \"boolean\" == typeof t) return \"\" + t;\n    if (\"object\" == typeof t) {\n        if (t instanceof Array) return \"an array\";\n        var e = \n        /** Hacky method to try to get the constructor name for an object. */\n        function(t) {\n            if (t.constructor) {\n                var e = /function\\s+([^\\s(]+)\\s*\\(/.exec(t.constructor.toString());\n                if (e && e.length > 1) return e[1];\n            }\n            return null;\n        }(t);\n        return e ? \"a custom \" + e + \" object\" : \"an object\";\n    }\n    return \"function\" == typeof t ? \"a function\" : x();\n}\n\nfunction Ls(t, \n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ne) {\n    if (\"_delegate\" in t && (\n    // Unwrap Compat types\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    t = t.d_), !(t instanceof e)) {\n        if (e.name === t.constructor.name) throw new q(M.INVALID_ARGUMENT, \"Type does not match the expected instance. Did you pass a reference from a different Firestore SDK?\");\n        var n = Cs(t);\n        throw new q(M.INVALID_ARGUMENT, \"Expected type '\" + e.name + \"', but it was: \" + n);\n    }\n    return t;\n}\n\nfunction Rs(t, e) {\n    if (e <= 0) throw new q(M.INVALID_ARGUMENT, \"Function \" + t + \"() requires a positive number, but it was: \" + e + \".\");\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n// settings() defaults:\n/**\n * A concrete type describing all the values that can be applied via a\n * user-supplied firestore.Settings object. This is a separate type so that\n * defaults can be supplied and the value can be checked for equality.\n */ var Us = /** @class */ function() {\n    function t(t) {\n        var e;\n        if (void 0 === t.host) {\n            if (void 0 !== t.ssl) throw new q(M.INVALID_ARGUMENT, \"Can't provide ssl option if host option is not set\");\n            this.host = \"firestore.googleapis.com\", this.ssl = !0;\n        } else this.host = t.host, this.ssl = null === (e = t.ssl) || void 0 === e || e;\n        if (this.credentials = t.credentials, this.ignoreUndefinedProperties = !!t.ignoreUndefinedProperties, \n        void 0 === t.cacheSizeBytes) this.cacheSizeBytes = 41943040; else {\n            if (-1 !== t.cacheSizeBytes && t.cacheSizeBytes < 1048576) throw new q(M.INVALID_ARGUMENT, \"cacheSizeBytes must be at least 1048576\");\n            this.cacheSizeBytes = t.cacheSizeBytes;\n        }\n        this.experimentalForceLongPolling = !!t.experimentalForceLongPolling, this.experimentalAutoDetectLongPolling = !!t.experimentalAutoDetectLongPolling, \n        Os(\"experimentalForceLongPolling\", t.experimentalForceLongPolling, \"experimentalAutoDetectLongPolling\", t.experimentalAutoDetectLongPolling);\n    }\n    return t.prototype.isEqual = function(t) {\n        return this.host === t.host && this.ssl === t.ssl && this.credentials === t.credentials && this.cacheSizeBytes === t.cacheSizeBytes && this.experimentalForceLongPolling === t.experimentalForceLongPolling && this.experimentalAutoDetectLongPolling === t.experimentalAutoDetectLongPolling && this.ignoreUndefinedProperties === t.ignoreUndefinedProperties;\n    }, t;\n}(), Ms = new Map, qs = /** @class */ function() {\n    /** @hideconstructor */\n    function t(t, e) {\n        this.w_ = \"(lite)\", this.E_ = new Us({}), this.T_ = !1, t instanceof I ? (this.I_ = t, \n        this.m_ = new G) : (this.A_ = t, this.I_ = function(t) {\n            if (!Object.prototype.hasOwnProperty.apply(t.options, [ \"projectId\" ])) throw new q(M.INVALID_ARGUMENT, '\"projectId\" not provided in firebase.initializeApp.');\n            return new I(t.options.projectId);\n        }(t), this.m_ = new B(e));\n    }\n    return Object.defineProperty(t.prototype, \"app\", {\n        /**\n         * The {@link FirebaseApp} associated with this `Firestore` service\n         * instance.\n         */\n        get: function() {\n            if (!this.A_) throw new q(M.FAILED_PRECONDITION, \"Firestore was not initialized using the Firebase SDK. 'app' is not available\");\n            return this.A_;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"R_\", {\n        get: function() {\n            return this.T_;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"P_\", {\n        get: function() {\n            return void 0 !== this.y_;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.g_ = function(t) {\n        if (this.T_) throw new q(M.FAILED_PRECONDITION, \"Firestore has already been started and its settings can no longer be changed. You can only modify settings before calling any other methods on a Firestore object.\");\n        this.E_ = new Us(t), void 0 !== t.credentials && (this.m_ = function(t) {\n            if (!t) return new G;\n            switch (t.type) {\n              case \"gapi\":\n                var e = t.client;\n                // Make sure this really is a Gapi client.\n                                return k(!(\"object\" != typeof e || null === e || !e.auth || !e.auth.getAuthHeaderValueForFirstParty)), \n                new Y(e, t.sessionIndex || \"0\");\n\n              case \"provider\":\n                return t.client;\n\n              default:\n                throw new q(M.INVALID_ARGUMENT, \"makeCredentialsProvider failed due to invalid credential type\");\n            }\n        }(t.credentials));\n    }, t.prototype.V_ = function() {\n        return this.E_;\n    }, t.prototype.p_ = function() {\n        return this.T_ = !0, this.E_;\n    }, t.prototype._delete = function() {\n        return this.y_ || (this.y_ = this.b_()), this.y_;\n    }, t.prototype.toJSON = function() {\n        return {\n            app: this.A_,\n            t: this.I_,\n            settings: this.E_\n        };\n    }, \n    /**\n     * Terminates all components used by this client. Subclasses can override\n     * this method to clean up their own dependencies, but must also call this\n     * method.\n     *\n     * Only ever called once.\n     */\n    t.prototype.b_ = function() {\n        /**\n * Removes all components associated with the provided instance. Must be called\n * when the `Firestore` instance is terminated.\n */\n        return t = this, (e = Ms.get(t)) && (N(\"ComponentProvider\", \"Removing Datastore\"), \n        Ms.delete(t), e.terminate()), Promise.resolve();\n        var t, e;\n    }, t;\n}(), Fs = /** @class */ function() {\n    /** @hideconstructor */\n    function t(t, e, n) {\n        this.v_ = e, this.S_ = n, \n        /** The type of this Firestore reference. */\n        this.type = \"document\", this.firestore = t;\n    }\n    return Object.defineProperty(t.prototype, \"D_\", {\n        get: function() {\n            return this.S_.path;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"id\", {\n        /**\n         * The document's identifier within its collection.\n         */\n        get: function() {\n            return this.S_.path.tt();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"path\", {\n        /**\n         * A string representing the path of the referenced document (relative\n         * to the root of the database).\n         */\n        get: function() {\n            return this.S_.path.rt();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"parent\", {\n        /**\n         * The collection this `DocumentReference` belongs to.\n         */\n        get: function() {\n            return new zs(this.firestore, this.v_, this.S_.path.X());\n        },\n        enumerable: !1,\n        configurable: !0\n    }), t.prototype.withConverter = function(e) {\n        return new t(this.firestore, e, this.S_);\n    }, t;\n}(), js = /** @class */ function() {\n    // This is the lite version of the Query class in the main SDK.\n    /** @hideconstructor protected */\n    function t(t, e, n) {\n        this.v_ = e, this.C_ = n, \n        /** The type of this Firestore reference. */\n        this.type = \"query\", this.firestore = t;\n    }\n    return t.prototype.withConverter = function(e) {\n        return new t(this.firestore, e, this.C_);\n    }, t;\n}(), zs = /** @class */ function(t) {\n    /** @hideconstructor */\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this, e, n, re(r)) || this).firestore = e, i.D_ = r, i.type = \"collection\", \n        i;\n    }\n    return m(e, t), Object.defineProperty(e.prototype, \"id\", {\n        /** The collection's identifier. */ get: function() {\n            return this.C_.path.tt();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"path\", {\n        /**\n         * A string representing the path of the referenced collection (relative\n         * to the root of the database).\n         */\n        get: function() {\n            return this.C_.path.rt();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"parent\", {\n        /**\n         * A reference to the containing `DocumentReference` if this is a\n         * subcollection. If this isn't a subcollection, the reference is null.\n         */\n        get: function() {\n            var t = this.D_.X();\n            return t.et() ? null : new Fs(this.firestore, \n            /* converter= */ null, new tt(t));\n        },\n        enumerable: !1,\n        configurable: !0\n    }), e.prototype.withConverter = function(t) {\n        return new e(this.firestore, t, this.D_);\n    }, e;\n}(js);\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ function Gs(t, e) {\n    for (var n, r = [], i = 2; i < arguments.length; i++) r[i - 2] = arguments[i];\n    if (t instanceof Ss && (t = t.d_), xs(\"collection\", \"path\", e), t instanceof qs) return Vs(n = Z.ot.apply(Z, b([ e ], r))), \n    new zs(t, /* converter= */ null, n);\n    if (!(t instanceof Fs || t instanceof zs)) throw new q(M.INVALID_ARGUMENT, \"Expected first argument to collection() to be a CollectionReference, a DocumentReference or FirebaseFirestore\");\n    return Vs(n = Z.ot.apply(Z, b([ t.path ], r)).child(Z.ot(e))), new zs(t.firestore, \n    /* converter= */ null, n);\n}\n\n// TODO(firestorelite): Consider using ErrorFactory -\n// https://github.com/firebase/firebase-js-sdk/blob/0131e1f/packages/util/src/errors.ts#L106\n/**\n * Creates and returns a new `Query` instance that includes all documents in the\n * database that are contained in a collection or subcollection with the\n * given `collectionId`.\n *\n * @param firestore - A reference to the root Firestore instance.\n * @param collectionId - Identifies the collections to query over. Every\n * collection or subcollection with this ID as the last segment of its path\n * will be included. Cannot contain a slash.\n * @returns The created `Query`.\n */ function Bs(t, e) {\n    for (var n, r = [], i = 2; i < arguments.length; i++) r[i - 2] = arguments[i];\n    if (t instanceof Ss && (t = t.d_), \n    // We allow omission of 'pathString' but explicitly prohibit passing in both\n    // 'undefined' and 'null'.\n    1 === arguments.length && (e = V.u()), xs(\"doc\", \"path\", e), t instanceof qs) return Ps(n = Z.ot.apply(Z, b([ e ], r))), \n    new Fs(t, \n    /* converter= */ null, new tt(n));\n    if (!(t instanceof Fs || t instanceof zs)) throw new q(M.INVALID_ARGUMENT, \"Expected first argument to collection() to be a CollectionReference, a DocumentReference or FirebaseFirestore\");\n    return Ps(n = t.D_.child(Z.ot.apply(Z, b([ e ], r)))), new Fs(t.firestore, t instanceof zs ? t.v_ : null, new tt(n));\n}\n\n/**\n * Returns true if the provided references are equal.\n *\n * @param left - A reference to compare.\n * @param right - A reference to compare.\n * @returns true if the references point to the same location in the same\n * Firestore database.\n */ function Qs(t, e) {\n    return t instanceof Ss && (t = t.d_), e instanceof Ss && (e = e.d_), (t instanceof Fs || t instanceof zs) && (e instanceof Fs || e instanceof zs) && t.firestore === e.firestore && t.path === e.path && t.v_ === e.v_\n    /**\n * Returns true if the provided queries point to the same collection and apply\n * the same constraints.\n *\n * @param left - A `Query` to compare.\n * @param right - A `Query` to compare.\n * @returns true if the references point to the same location in the same\n * Firestore database.\n */;\n}\n\nfunction Ys(t, e) {\n    return t instanceof Ss && (t = t.d_), e instanceof Ss && (e = e.d_), t instanceof js && e instanceof js && t.firestore === e.firestore && le(t.C_, e.C_) && t.v_ === e.v_\n    /**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n    /**\n * An immutable object representing a geographic location in Firestore. The\n * location is represented as latitude/longitude pair.\n *\n * Latitude values are in the range of [-90, 90].\n * Longitude values are in the range of [-180, 180].\n */;\n}\n\nvar Hs = /** @class */ function() {\n    /**\n     * Creates a new immutable `GeoPoint` object with the provided latitude and\n     * longitude values.\n     * @param latitude - The latitude as number between -90 and 90.\n     * @param longitude - The longitude as number between -180 and 180.\n     */\n    function t(t, e) {\n        if (!isFinite(t) || t < -90 || t > 90) throw new q(M.INVALID_ARGUMENT, \"Latitude must be a number between -90 and 90, but was: \" + t);\n        if (!isFinite(e) || e < -180 || e > 180) throw new q(M.INVALID_ARGUMENT, \"Longitude must be a number between -180 and 180, but was: \" + e);\n        this.x_ = t, this.N_ = e;\n    }\n    return Object.defineProperty(t.prototype, \"latitude\", {\n        /**\n         * The latitude of this `GeoPoint` instance.\n         */\n        get: function() {\n            return this.x_;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"longitude\", {\n        /**\n         * The longitude of this `GeoPoint` instance.\n         */\n        get: function() {\n            return this.N_;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    /**\n     * Returns true if this `GeoPoint` is equal to the provided one.\n     *\n     * @param other - The `GeoPoint` to compare against.\n     * @returns true if this `GeoPoint` is equal to the provided one.\n     */\n    t.prototype.isEqual = function(t) {\n        return this.x_ === t.x_ && this.N_ === t.N_;\n    }, t.prototype.toJSON = function() {\n        return {\n            latitude: this.x_,\n            longitude: this.N_\n        };\n    }, \n    /**\n     * Actually private to JS consumers of our API, so this function is prefixed\n     * with an underscore.\n     */\n    t.prototype.U = function(t) {\n        return C(this.x_, t.x_) || C(this.N_, t.N_);\n    }, t;\n}(), Ks = /^__.*__$/, Xs = /** @class */ function() {\n    function t(t, e, n) {\n        this.data = t, this.Gt = e, this.fieldTransforms = n;\n    }\n    return t.prototype.F_ = function(t, e) {\n        return null !== this.Gt ? new Qe(t, this.data, this.Gt, e, this.fieldTransforms) : new Be(t, this.data, e, this.fieldTransforms);\n    }, t;\n}(), Ws = /** @class */ function() {\n    function t(t, \n    // The fieldMask does not include document transforms.\n    e, n) {\n        this.data = t, this.Gt = e, this.fieldTransforms = n;\n    }\n    return t.prototype.F_ = function(t, e) {\n        return new Qe(t, this.data, this.Gt, e, this.fieldTransforms);\n    }, t;\n}();\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ function Zs(t) {\n    switch (t) {\n      case 0 /* Set */ :\n // fall through\n              case 2 /* MergeSet */ :\n // fall through\n              case 1 /* Update */ :\n        return !0;\n\n      case 3 /* Argument */ :\n      case 4 /* ArrayArgument */ :\n        return !1;\n\n      default:\n        throw x();\n    }\n}\n\n/** A \"context\" object passed around while parsing user data. */ var Js = /** @class */ function() {\n    /**\n     * Initializes a ParseContext with the given source and path.\n     *\n     * @param settings - The settings for the parser.\n     * @param databaseId - The database ID of the Firestore instance.\n     * @param serializer - The serializer to use to generate the Value proto.\n     * @param ignoreUndefinedProperties - Whether to ignore undefined properties\n     * rather than throw.\n     * @param fieldTransforms - A mutable list of field transforms encountered\n     * while parsing the data.\n     * @param fieldMask - A mutable list of field paths encountered while parsing\n     * the data.\n     *\n     * TODO(b/34871131): We don't support array paths right now, so path can be\n     * null to indicate the context represents any location within an array (in\n     * which case certain features will not work and errors will be somewhat\n     * compromised).\n     */\n    function t(t, e, n, r, i, o) {\n        this.settings = t, this.t = e, this.Qt = n, this.ignoreUndefinedProperties = r, \n        // Minor hack: If fieldTransforms is undefined, we assume this is an\n        // external call and we need to validate the entire path.\n        void 0 === i && this.O_(), this.fieldTransforms = i || [], this.Gt = o || [];\n    }\n    return Object.defineProperty(t.prototype, \"path\", {\n        get: function() {\n            return this.settings.path;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"k_\", {\n        get: function() {\n            return this.settings.k_;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    /** Returns a new context with the specified settings overwritten. */ t.prototype.M_ = function(e) {\n        return new t(Object.assign(Object.assign({}, this.settings), e), this.t, this.Qt, this.ignoreUndefinedProperties, this.fieldTransforms, this.Gt);\n    }, t.prototype.L_ = function(t) {\n        var e, n = null === (e = this.path) || void 0 === e ? void 0 : e.child(t), r = this.M_({\n            path: n,\n            B_: !1\n        });\n        return r.q_(t), r;\n    }, t.prototype.U_ = function(t) {\n        var e, n = null === (e = this.path) || void 0 === e ? void 0 : e.child(t), r = this.M_({\n            path: n,\n            B_: !1\n        });\n        return r.O_(), r;\n    }, t.prototype.Q_ = function(t) {\n        // TODO(b/34871131): We don't support array paths right now; so make path\n        // undefined.\n        return this.M_({\n            path: void 0,\n            B_: !0\n        });\n    }, t.prototype.K_ = function(t) {\n        return ga(t, this.settings.methodName, this.settings.W_ || !1, this.path, this.settings.j_);\n    }, \n    /** Returns 'true' if 'fieldPath' was traversed when creating this context. */ t.prototype.contains = function(t) {\n        return void 0 !== this.Gt.find((function(e) {\n            return t.nt(e);\n        })) || void 0 !== this.fieldTransforms.find((function(e) {\n            return t.nt(e.field);\n        }));\n    }, t.prototype.O_ = function() {\n        // TODO(b/34871131): Remove null check once we have proper paths for fields\n        // within arrays.\n        if (this.path) for (var t = 0; t < this.path.length; t++) this.q_(this.path.get(t));\n    }, t.prototype.q_ = function(t) {\n        if (0 === t.length) throw this.K_(\"Document fields must not be empty\");\n        if (Zs(this.k_) && Ks.test(t)) throw this.K_('Document fields cannot begin and end with \"__\"');\n    }, t;\n}(), $s = /** @class */ function() {\n    function t(t, e, n) {\n        this.t = t, this.ignoreUndefinedProperties = e, this.Qt = n || Bo(t)\n        /** Creates a new top-level parse context. */;\n    }\n    return t.prototype.G_ = function(t, e, n, r) {\n        return void 0 === r && (r = !1), new Js({\n            k_: t,\n            methodName: e,\n            j_: n,\n            path: $.ct(),\n            B_: !1,\n            W_: r\n        }, this.t, this.Qt, this.ignoreUndefinedProperties);\n    }, t;\n}();\n\n/**\n * Helper for parsing raw user input (provided via the API) into internal model\n * classes.\n */ function ta(t) {\n    var e = t.p_(), n = Bo(t.I_);\n    return new $s(t.I_, !!e.ignoreUndefinedProperties, n);\n}\n\n/** Parse document data from a set() call. */ function ea(t, e, n, r, i, o) {\n    void 0 === o && (o = {});\n    var u = t.G_(o.merge || o.mergeFields ? 2 /* MergeSet */ : 0 /* Set */ , e, n, i);\n    da(\"Data must be an object, but it was:\", u, r);\n    var s, a, c = la(r, u);\n    if (o.merge) s = new it(u.Gt), a = u.fieldTransforms; else if (o.mergeFields) {\n        for (var h = [], f = 0, l = o.mergeFields; f < l.length; f++) {\n            var p = va(e, l[f], n);\n            if (!u.contains(p)) throw new q(M.INVALID_ARGUMENT, \"Field '\" + p + \"' is specified in your field mask but missing from your input data.\");\n            wa(h, p) || h.push(p);\n        }\n        s = new it(h), a = u.fieldTransforms.filter((function(t) {\n            return s.Tt(t.field);\n        }));\n    } else s = null, a = u.fieldTransforms;\n    return new Xs(new St(c), s, a);\n}\n\nvar na = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    return m(e, t), e.prototype.z_ = function(t) {\n        if (2 /* MergeSet */ !== t.k_) throw 1 /* Update */ === t.k_ ? t.K_(this._methodName + \"() can only appear at the top level of your update data\") : t.K_(this._methodName + \"() cannot be used with set() unless you pass {merge:true}\");\n        // No transform to add for a delete, but we need to add it to our\n        // fieldMask so it gets deleted.\n                return t.Gt.push(t.path), null;\n    }, e.prototype.isEqual = function(t) {\n        return t instanceof e;\n    }, e;\n}(Ds);\n\n/**\n * Creates a child context for parsing SerializableFieldValues.\n *\n * This is different than calling `ParseContext.contextWith` because it keeps\n * the fieldTransforms and fieldMask separate.\n *\n * The created context has its `dataSource` set to `UserDataSource.Argument`.\n * Although these values are used with writes, any elements in these FieldValues\n * are not considered writes since they cannot contain any FieldValue sentinels,\n * etc.\n *\n * @param fieldValue - The sentinel FieldValue for which to create a child\n *     context.\n * @param context - The parent context.\n * @param arrayElement - Whether or not the FieldValue has an array.\n */ function ra(t, e, n) {\n    return new Js({\n        k_: 3 /* Argument */ ,\n        j_: e.settings.j_,\n        methodName: t._methodName,\n        B_: n\n    }, e.t, e.Qt, e.ignoreUndefinedProperties);\n}\n\nvar ia = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    return m(e, t), e.prototype.z_ = function(t) {\n        return new Ce(t.path, new Ae);\n    }, e.prototype.isEqual = function(t) {\n        return t instanceof e;\n    }, e;\n}(Ds), oa = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, e) || this).H_ = n, r;\n    }\n    return m(e, t), e.prototype.z_ = function(t) {\n        var e = ra(this, t, \n        /*array=*/ !0), n = this.H_.map((function(t) {\n            return fa(t, e);\n        })), r = new De(n);\n        return new Ce(t.path, r);\n    }, e.prototype.isEqual = function(t) {\n        // TODO(mrschmidt): Implement isEquals\n        return this === t;\n    }, e;\n}(Ds), ua = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, e) || this).H_ = n, r;\n    }\n    return m(e, t), e.prototype.z_ = function(t) {\n        var e = ra(this, t, \n        /*array=*/ !0), n = this.H_.map((function(t) {\n            return fa(t, e);\n        })), r = new xe(n);\n        return new Ce(t.path, r);\n    }, e.prototype.isEqual = function(t) {\n        // TODO(mrschmidt): Implement isEquals\n        return this === t;\n    }, e;\n}(Ds), sa = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, e) || this).J_ = n, r;\n    }\n    return m(e, t), e.prototype.z_ = function(t) {\n        var e = new Oe(t.Qt, _e(t.Qt, this.J_));\n        return new Ce(t.path, e);\n    }, e.prototype.isEqual = function(t) {\n        // TODO(mrschmidt): Implement isEquals\n        return this === t;\n    }, e;\n}(Ds);\n\n/** Parse update data from an update() call. */ function aa(t, e, n, r) {\n    var i = t.G_(1 /* Update */ , e, n);\n    da(\"Data must be an object, but it was:\", i, r);\n    var o = [], u = new xt;\n    nt(r, (function(t, r) {\n        var s = ma(e, t, n);\n        // For Compat types, we have to \"extract\" the underlying types before\n        // performing validation.\n                r instanceof Ss && (r = r.d_);\n        var a = i.U_(s);\n        if (r instanceof na) \n        // Add it to the field mask, but don't add anything to updateData.\n        o.push(s); else {\n            var c = fa(r, a);\n            null != c && (o.push(s), u.set(s, c));\n        }\n    }));\n    var s = new it(o);\n    return new Ws(u.Pt(), s, i.fieldTransforms);\n}\n\n/** Parse update data from a list of field/value arguments. */ function ca(t, e, n, r, i, o) {\n    var u = t.G_(1 /* Update */ , e, n), s = [ va(e, r, n) ], a = [ i ];\n    if (o.length % 2 != 0) throw new q(M.INVALID_ARGUMENT, \"Function \" + e + \"() needs to be called with an even number of arguments that alternate between field names and values.\");\n    for (var c = 0; c < o.length; c += 2) s.push(va(e, o[c])), a.push(o[c + 1]);\n    // We iterate in reverse order to pick the last value for a field if the\n    // user specified the field multiple times.\n    for (var h = [], f = new xt, l = s.length - 1; l >= 0; --l) if (!wa(h, s[l])) {\n        var p = s[l], d = a[l];\n        // For Compat types, we have to \"extract\" the underlying types before\n        // performing validation.\n        d instanceof Ss && (d = d.d_);\n        var v = u.U_(p);\n        if (d instanceof na) \n        // Add it to the field mask, but don't add anything to updateData.\n        h.push(p); else {\n            var y = fa(d, v);\n            null != y && (h.push(p), f.set(p, y));\n        }\n    }\n    var m = new it(h);\n    return new Ws(f.Pt(), m, u.fieldTransforms);\n}\n\n/**\n * Parse a \"query value\" (e.g. value in a where filter or a value in a cursor\n * bound).\n *\n * @param allowArrays - Whether the query value is an array that may directly\n * contain additional arrays (e.g. the operand of an `in` query).\n */ function ha(t, e, n, r) {\n    return void 0 === r && (r = !1), fa(n, t.G_(r ? 4 /* ArrayArgument */ : 3 /* Argument */ , e));\n}\n\n/**\n * Parses user data to Protobuf Values.\n *\n * @param input - Data to be parsed.\n * @param context - A context object representing the current path being parsed,\n * the source of the data being parsed, etc.\n * @returns The parsed value, or null if the value was a FieldValue sentinel\n * that should not be included in the resulting parsed data.\n */ function fa(t, e) {\n    if (\n    // Unwrap the API type from the Compat SDK. This will return the API type\n    // from firestore-exp.\n    t instanceof Ss && (t = t.d_), pa(t)) return da(\"Unsupported field value:\", e, t), \n    la(t, e);\n    if (t instanceof Ds) \n    // FieldValues usually parse into transforms (except FieldValue.delete())\n    // in which case we do not want to include this field in our parsed data\n    // (as doing so will overwrite the field directly prior to the transform\n    // trying to transform it). So we don't add this location to\n    // context.fieldMask and we return null as our parsing result.\n    /**\n     * \"Parses\" the provided FieldValueImpl, adding any necessary transforms to\n     * context.fieldTransforms.\n     */\n    return function(t, e) {\n        // Sentinels are only supported with writes, and not within arrays.\n        if (!Zs(e.k_)) throw e.K_(t._methodName + \"() can only be used with update() and set()\");\n        if (!e.path) throw e.K_(t._methodName + \"() is not currently supported inside arrays\");\n        var n = t.z_(e);\n        n && e.fieldTransforms.push(n);\n    }(t, e), null;\n    if (void 0 === t && e.ignoreUndefinedProperties) \n    // If the input is undefined it can never participate in the fieldMask, so\n    // don't handle this below. If `ignoreUndefinedProperties` is false,\n    // `parseScalarValue` will reject an undefined value.\n    return null;\n    if (\n    // If context.path is null we are inside an array and we don't support\n    // field mask paths more granular than the top-level array.\n    e.path && e.Gt.push(e.path), t instanceof Array) {\n        // TODO(b/34871131): Include the path containing the array in the error\n        // message.\n        // In the case of IN queries, the parsed data is an array (representing\n        // the set of values to be included for the IN query) that may directly\n        // contain additional arrays (each representing an individual field\n        // value), so we disable this validation.\n        if (e.settings.B_ && 4 /* ArrayArgument */ !== e.k_) throw e.K_(\"Nested arrays are not supported\");\n        return function(t, e) {\n            for (var n = [], r = 0, i = 0, o = t; i < o.length; i++) {\n                var u = fa(o[i], e.Q_(r));\n                null == u && (\n                // Just include nulls in the array for fields being replaced with a\n                // sentinel.\n                u = {\n                    nullValue: \"NULL_VALUE\"\n                }), n.push(u), r++;\n            }\n            return {\n                arrayValue: {\n                    values: n\n                }\n            };\n        }(t, e);\n    }\n    return function(t, e) {\n        if (t instanceof Ss && (t = t.d_), null === t) return {\n            nullValue: \"NULL_VALUE\"\n        };\n        if (\"number\" == typeof t) return _e(e.Qt, t);\n        if (\"boolean\" == typeof t) return {\n            booleanValue: t\n        };\n        if (\"string\" == typeof t) return {\n            stringValue: t\n        };\n        if (t instanceof Date) {\n            var n = K.fromDate(t);\n            return {\n                timestampValue: Ln(e.Qt, n)\n            };\n        }\n        if (t instanceof K) {\n            // Firestore backend truncates precision down to microseconds. To ensure\n            // offline mode works the same with regards to truncation, perform the\n            // truncation immediately without waiting for the backend to do that.\n            n = new K(t.seconds, 1e3 * Math.floor(t.nanoseconds / 1e3));\n            return {\n                timestampValue: Ln(e.Qt, n)\n            };\n        }\n        if (t instanceof Hs) return {\n            geoPointValue: {\n                latitude: t.latitude,\n                longitude: t.longitude\n            }\n        };\n        if (t instanceof F) return {\n            bytesValue: Rn(e.Qt, t.I)\n        };\n        if (t instanceof Fs) {\n            n = e.t;\n            var r = t.firestore.I_;\n            if (!r.isEqual(n)) throw e.K_(\"Document reference is for database \" + r.projectId + \"/\" + r.database + \" but should be for database \" + n.projectId + \"/\" + n.database);\n            return {\n                referenceValue: qn(t.firestore.I_ || e.t, t.S_.path)\n            };\n        }\n        throw e.K_(\"Unsupported field value: \" + Cs(t));\n    }(t, e);\n}\n\nfunction la(t, e) {\n    var n = {};\n    return rt(t) ? \n    // If we encounter an empty object, we explicitly add it to the update\n    // mask to ensure that the server creates a map entry.\n    e.path && e.path.length > 0 && e.Gt.push(e.path) : nt(t, (function(t, r) {\n        var i = fa(r, e.L_(t));\n        null != i && (n[t] = i);\n    })), {\n        mapValue: {\n            fields: n\n        }\n    };\n}\n\nfunction pa(t) {\n    return !(\"object\" != typeof t || null === t || t instanceof Array || t instanceof Date || t instanceof K || t instanceof Hs || t instanceof F || t instanceof Fs || t instanceof Ds);\n}\n\nfunction da(t, e, n) {\n    if (!pa(n) || !function(t) {\n        return \"object\" == typeof t && null !== t && (Object.getPrototypeOf(t) === Object.prototype || null === Object.getPrototypeOf(t));\n    }(n)) {\n        var r = Cs(n);\n        throw \"an object\" === r ? e.K_(t + \" a custom object\") : e.K_(t + \" \" + r);\n    }\n}\n\n/**\n * Helper that calls fromDotSeparatedString() but wraps any error thrown.\n */ function va(t, e, n) {\n    if (\n    // If required, replace the FieldPath Compat class with with the firestore-exp\n    // FieldPath.\n    e instanceof Ss && (e = e.d_), e instanceof As) return e.f_;\n    if (\"string\" == typeof e) return ma(t, e);\n    throw ga(\"Field path arguments must be of type string or FieldPath.\", t, \n    /* hasConverter= */ !1, \n    /* path= */ void 0, n);\n}\n\n/**\n * Matches any characters in a field path string that are reserved.\n */ var ya = new RegExp(\"[~\\\\*/\\\\[\\\\]]\");\n\n/**\n * Wraps fromDotSeparatedString with an error message about the method that\n * was thrown.\n * @param methodName - The publicly visible method name\n * @param path - The dot-separated string form of a field path which will be\n * split on dots.\n * @param targetDoc - The document against which the field path will be\n * evaluated.\n */ function ma(t, e, n) {\n    if (e.search(ya) >= 0) throw ga(\"Invalid field path (\" + e + \"). Paths must not contain '~', '*', '/', '[', or ']'\", t, \n    /* hasConverter= */ !1, \n    /* path= */ void 0, n);\n    try {\n        return (new (As.bind.apply(As, b([ void 0 ], e.split(\".\"))))).f_;\n    } catch (r) {\n        throw ga(\"Invalid field path (\" + e + \"). Paths must not be empty, begin with '.', end with '.', or contain '..'\", t, \n        /* hasConverter= */ !1, \n        /* path= */ void 0, n);\n    }\n}\n\nfunction ga(t, e, n, r, i) {\n    var o = r && !r.et(), u = void 0 !== i, s = \"Function \" + e + \"() called with invalid data\";\n    n && (s += \" (via `toFirestore()`)\");\n    var a = \"\";\n    return (o || u) && (a += \" (found\", o && (a += \" in field \" + r), u && (a += \" in document \" + i), \n    a += \")\"), new q(M.INVALID_ARGUMENT, (s += \". \") + t + a)\n    /** Checks `haystack` if FieldPath `needle` is present. Runs in O(n). */;\n}\n\nfunction wa(t, e) {\n    return t.some((function(t) {\n        return t.isEqual(e);\n    }));\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Internal transaction object responsible for accumulating the mutations to\n * perform and the base versions for any documents read.\n */ var ba = /** @class */ function() {\n    function t(t) {\n        this.Sh = t, \n        // The version of each document that was read during this transaction.\n        this.Y_ = new Map, this.mutations = [], this.X_ = !1, \n        /**\n             * A deferred usage error that occurred previously in this transaction that\n             * will cause the transaction to fail once it actually commits.\n             */\n        this.Z_ = null, \n        /**\n             * Set of documents that have been written in the transaction.\n             *\n             * When there's more than one write to the same key in a transaction, any\n             * writes after the first are handled differently.\n             */\n        this.tf = new Set;\n    }\n    return t.prototype.ef = function(t) {\n        return g(this, void 0, void 0, (function() {\n            var e, n = this;\n            return w(this, (function(r) {\n                switch (r.label) {\n                  case 0:\n                    if (this.nf(), this.mutations.length > 0) throw new q(M.INVALID_ARGUMENT, \"Firestore transactions require all reads to be executed before all writes.\");\n                    return [ 4 /*yield*/ , function(t, e) {\n                        return g(this, void 0, void 0, (function() {\n                            var n, r, i, o, u, s;\n                            return w(this, (function(a) {\n                                switch (a.label) {\n                                  case 0:\n                                    return n = O(t), r = Qn(n.Qt) + \"/documents\", i = {\n                                        documents: e.map((function(t) {\n                                            return jn(n.Qt, t);\n                                        }))\n                                    }, [ 4 /*yield*/ , n.Du(\"BatchGetDocuments\", r, i) ];\n\n                                  case 1:\n                                    return o = a.sent(), u = new Map, o.forEach((function(t) {\n                                        var e = function(t, e) {\n                                            return \"found\" in e ? function(t, e) {\n                                                k(!!e.found), e.found.name, e.found.updateTime;\n                                                var n = zn(t, e.found.name), r = Mn(e.found.updateTime), i = new St({\n                                                    mapValue: {\n                                                        fields: e.found.fields\n                                                    }\n                                                });\n                                                return new Pt(n, r, i, {});\n                                            }(t, e) : \"missing\" in e ? function(t, e) {\n                                                k(!!e.missing), k(!!e.readTime);\n                                                var n = zn(t, e.missing), r = Mn(e.readTime);\n                                                return new Vt(n, r);\n                                            }(t, e) : x();\n                                        }(n.Qt, t);\n                                        u.set(e.key.toString(), e);\n                                    })), s = [], [ 2 /*return*/ , (e.forEach((function(t) {\n                                        var e = u.get(t.toString());\n                                        k(!!e), s.push(e);\n                                    })), s) ];\n                                }\n                            }));\n                        }));\n                    }(this.Sh, t) ];\n\n                  case 1:\n                    return [ 2 /*return*/ , ((e = r.sent()).forEach((function(t) {\n                        t instanceof Vt || t instanceof Pt ? n.sf(t) : x();\n                    })), e) ];\n                }\n            }));\n        }));\n    }, t.prototype.set = function(t, e) {\n        this.write(e.F_(t, this.jt(t))), this.tf.add(t.toString());\n    }, t.prototype.update = function(t, e) {\n        try {\n            this.write(e.F_(t, this.rf(t)));\n        } catch (t) {\n            this.Z_ = t;\n        }\n        this.tf.add(t.toString());\n    }, t.prototype.delete = function(t) {\n        this.write(new Je(t, this.jt(t))), this.tf.add(t.toString());\n    }, t.prototype.commit = function() {\n        return g(this, void 0, void 0, (function() {\n            var t, e = this;\n            return w(this, (function(n) {\n                switch (n.label) {\n                  case 0:\n                    if (this.nf(), this.Z_) throw this.Z_;\n                    return t = this.Y_, \n                    // For each mutation, note that the doc was written.\n                    this.mutations.forEach((function(e) {\n                        t.delete(e.key.toString());\n                    })), \n                    // For each document that was read but not written to, we want to perform\n                    // a `verify` operation.\n                    t.forEach((function(t, n) {\n                        var r = tt._t(n);\n                        e.mutations.push(new $e(r, e.jt(r)));\n                    })), [ 4 /*yield*/ , function(t, e) {\n                        return g(this, void 0, void 0, (function() {\n                            var n, r, i;\n                            return w(this, (function(o) {\n                                switch (o.label) {\n                                  case 0:\n                                    return n = O(t), r = Qn(n.Qt) + \"/documents\", i = {\n                                        writes: e.map((function(t) {\n                                            return Xn(n.Qt, t);\n                                        }))\n                                    }, [ 4 /*yield*/ , n.pu(\"Commit\", r, i) ];\n\n                                  case 1:\n                                    return o.sent(), [ 2 /*return*/ ];\n                                }\n                            }));\n                        }));\n                    }(this.Sh, this.mutations) ];\n\n                  case 1:\n                    // For each mutation, note that the doc was written.\n                    return n.sent(), this.X_ = !0, [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, t.prototype.sf = function(t) {\n        var e;\n        if (t instanceof Pt) e = t.version; else {\n            if (!(t instanceof Vt)) throw x();\n            // For deleted docs, we must use baseVersion 0 when we overwrite them.\n                        e = X.min();\n        }\n        var n = this.Y_.get(t.key.toString());\n        if (n) {\n            if (!e.isEqual(n)) \n            // This transaction will fail no matter what.\n            throw new q(M.ABORTED, \"Document version changed between two reads.\");\n        } else this.Y_.set(t.key.toString(), e);\n    }, \n    /**\n     * Returns the version of this document when it was read in this transaction,\n     * as a precondition, or no precondition if it was not read.\n     */\n    t.prototype.jt = function(t) {\n        var e = this.Y_.get(t.toString());\n        return !this.tf.has(t.toString()) && e ? Re.updateTime(e) : Re.Kt();\n    }, \n    /**\n     * Returns the precondition for a document if the operation is an update.\n     */\n    t.prototype.rf = function(t) {\n        var e = this.Y_.get(t.toString());\n        // The first time a document is written, we want to take into account the\n        // read time and existence\n                if (!this.tf.has(t.toString()) && e) {\n            if (e.isEqual(X.min())) \n            // The document doesn't exist, so fail the transaction.\n            // This has to be validated locally because you can't send a\n            // precondition that a document does not exist without changing the\n            // semantics of the backend write to be an insert. This is the reverse\n            // of what we want, since we want to assert that the document doesn't\n            // exist but then send the update and have it fail. Since we can't\n            // express that to the backend, we have to validate locally.\n            // Note: this can change once we can send separate verify writes in the\n            // transaction.\n            throw new q(M.INVALID_ARGUMENT, \"Can't update a document that doesn't exist.\");\n            // Document exists, base precondition on document update time.\n                        return Re.updateTime(e);\n        }\n        // Document was not read, so we just use the preconditions for a blind\n        // update.\n                return Re.exists(!0);\n    }, t.prototype.write = function(t) {\n        this.nf(), this.mutations.push(t);\n    }, t.prototype.nf = function() {}, t;\n}(), _a = /** @class */ function() {\n    function t(t, e, n, r) {\n        this._s = t, this.Sh = e, this.updateFunction = n, this.Es = r, this.cf = 5, this.Gu = new Qo(this._s, \"transaction_retry\" /* TransactionRetry */)\n        /** Runs the transaction and sets the result on deferred. */;\n    }\n    return t.prototype.run = function() {\n        this.af();\n    }, t.prototype.af = function() {\n        var t = this;\n        this.Gu.Lu((function() {\n            return g(t, void 0, void 0, (function() {\n                var t, e, n = this;\n                return w(this, (function(r) {\n                    return t = new ba(this.Sh), (e = this.uf(t)) && e.then((function(e) {\n                        n._s.Ps((function() {\n                            return t.commit().then((function() {\n                                n.Es.resolve(e);\n                            })).catch((function(t) {\n                                n.hf(t);\n                            }));\n                        }));\n                    })).catch((function(t) {\n                        n.hf(t);\n                    })), [ 2 /*return*/ ];\n                }));\n            }));\n        }));\n    }, t.prototype.uf = function(t) {\n        try {\n            var e = this.updateFunction(t);\n            return !lt(e) && e.catch && e.then ? e : (this.Es.reject(Error(\"Transaction callback must return a Promise\")), \n            null);\n        } catch (t) {\n            // Do not retry errors thrown by user provided updateFunction.\n            return this.Es.reject(t), null;\n        }\n    }, t.prototype.hf = function(t) {\n        var e = this;\n        this.cf > 0 && this.lf(t) ? (this.cf -= 1, this._s.Ps((function() {\n            return e.af(), Promise.resolve();\n        }))) : this.Es.reject(t);\n    }, t.prototype.lf = function(t) {\n        if (\"FirebaseError\" === t.name) {\n            // In transactions, the backend will fail outdated reads with FAILED_PRECONDITION and\n            // non-matching document versions with ABORTED. These errors should be retried.\n            var e = t.code;\n            return \"aborted\" === e || \"failed-precondition\" === e || !en(e);\n        }\n        return !1;\n    }, t;\n}(), Ia = /** @class */ function() {\n    function t(t, \n    /**\n     * Asynchronous queue responsible for all of our internal processing. When\n     * we get incoming work from the user (via public API) or the network\n     * (incoming GRPC messages), we should always schedule onto this queue.\n     * This ensures all of our work is properly serialized (e.g. we don't\n     * start processing a new operation while the previous one is waiting for\n     * an async I/O to complete).\n     */\n    e, n) {\n        var r = this;\n        this.credentials = t, this._s = e, this.yu = n, this.user = j.UNAUTHENTICATED, this.clientId = V.u(), \n        this._f = function() {}, this.C = new fr, this.credentials.v((function(t) {\n            N(\"FirestoreClient\", \"Received user=\", t.uid), r.user = t, r._f(t), r.C.resolve();\n        }));\n    }\n    return t.prototype.getConfiguration = function() {\n        return g(this, void 0, void 0, (function() {\n            return w(this, (function(t) {\n                switch (t.label) {\n                  case 0:\n                    return [ 4 /*yield*/ , this.C.promise ];\n\n                  case 1:\n                    return [ 2 /*return*/ , (t.sent(), {\n                        _s: this._s,\n                        yu: this.yu,\n                        clientId: this.clientId,\n                        credentials: this.credentials,\n                        Jl: this.user,\n                        pl: 100\n                    }) ];\n                }\n            }));\n        }));\n    }, t.prototype.ff = function(t) {\n        var e = this;\n        this._f = t, \n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        this.C.promise.then((function() {\n            return e._f(e.user);\n        }));\n    }, \n    /**\n     * Checks that the client has not been terminated. Ensures that other methods on\n     * this class cannot be called after the client is terminated.\n     */\n    t.prototype.df = function() {\n        if (this._s.wf) throw new q(M.FAILED_PRECONDITION, \"The client has already been terminated.\");\n    }, t.prototype.terminate = function() {\n        var t = this;\n        this._s.Ef();\n        var e = new fr;\n        return this._s.Tf((function() {\n            return g(t, void 0, void 0, (function() {\n                var t, n;\n                return w(this, (function(r) {\n                    switch (r.label) {\n                      case 0:\n                        return r.trys.push([ 0, 5, , 6 ]), this.If ? [ 4 /*yield*/ , this.If.terminate() ] : [ 3 /*break*/ , 2 ];\n\n                      case 1:\n                        r.sent(), r.label = 2;\n\n                      case 2:\n                        return this.mf ? [ 4 /*yield*/ , this.mf.terminate() ] : [ 3 /*break*/ , 4 ];\n\n                      case 3:\n                        r.sent(), r.label = 4;\n\n                      case 4:\n                        // `removeChangeListener` must be called after shutting down the\n                        // RemoteStore as it will prevent the RemoteStore from retrieving\n                        // auth tokens.\n                        return this.credentials.S(), e.resolve(), [ 3 /*break*/ , 6 ];\n\n                      case 5:\n                        return t = r.sent(), n = Er(t, \"Failed to shutdown persistence\"), e.reject(n), [ 3 /*break*/ , 6 ];\n\n                      case 6:\n                        return [ 2 /*return*/ ];\n                    }\n                }));\n            }));\n        })), e.promise;\n    }, t;\n}();\n\n/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * TransactionRunner encapsulates the logic needed to run and retry transactions\n * with backoff.\n */ function Ea(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r, i = this;\n        return w(this, (function(o) {\n            switch (o.label) {\n              case 0:\n                return t._s.Af(), N(\"FirestoreClient\", \"Initializing OfflineComponentProvider\"), \n                [ 4 /*yield*/ , t.getConfiguration() ];\n\n              case 1:\n                return n = o.sent(), [ 4 /*yield*/ , e.initialize(n) ];\n\n              case 2:\n                return o.sent(), r = n.Jl, t.ff((function(n) {\n                    r.isEqual(n) || (r = n, t._s.po((function() {\n                        return g(i, void 0, void 0, (function() {\n                            return w(this, (function(t) {\n                                switch (t.label) {\n                                  case 0:\n                                    return [ 4 /*yield*/ , no(e.bh, n) ];\n\n                                  case 1:\n                                    return t.sent(), [ 2 /*return*/ ];\n                                }\n                            }));\n                        }));\n                    })));\n                })), \n                // When a user calls clearPersistence() in one client, all other clients\n                // need to be terminated to allow the delete to succeed.\n                e.persistence.Po((function() {\n                    return t.terminate();\n                })), t.mf = e, [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\nfunction Ta(t, e) {\n    return g(this, void 0, void 0, (function() {\n        var n, r;\n        return w(this, (function(i) {\n            switch (i.label) {\n              case 0:\n                return t._s.Af(), [ 4 /*yield*/ , Na(t) ];\n\n              case 1:\n                return n = i.sent(), N(\"FirestoreClient\", \"Initializing OnlineComponentProvider\"), \n                [ 4 /*yield*/ , t.getConfiguration() ];\n\n              case 2:\n                return r = i.sent(), [ 4 /*yield*/ , e.initialize(n, r) ];\n\n              case 3:\n                return i.sent(), \n                // The CredentialChangeListener of the online component provider takes\n                // precedence over the offline component provider.\n                t.ff((function(n) {\n                    return t._s.po((function() {\n                        return function(t, e) {\n                            return g(this, void 0, void 0, (function() {\n                                var n, r;\n                                return w(this, (function(i) {\n                                    switch (i.label) {\n                                      case 0:\n                                        return (n = O(t))._s.Af(), N(\"RemoteStore\", \"RemoteStore received new credentials\"), \n                                        r = uu(n), \n                                        // Tear down and re-create our network streams. This will ensure we get a\n                                        // fresh auth token for the new user and re-fill the write pipeline with\n                                        // new mutations from the LocalStore (since mutations are per-user).\n                                        n.Nh.add(3 /* CredentialChange */), [ 4 /*yield*/ , $o(n) ];\n\n                                      case 1:\n                                        return i.sent(), r && \n                                        // Don't set the network status to Unknown if we are offline.\n                                        n.Oh.set(\"Unknown\" /* Unknown */), [ 4 /*yield*/ , n.Dh.n_(e) ];\n\n                                      case 2:\n                                        return i.sent(), n.Nh.delete(3 /* CredentialChange */), [ 4 /*yield*/ , Jo(n) ];\n\n                                      case 3:\n                                        // Tear down and re-create our network streams. This will ensure we get a\n                                        // fresh auth token for the new user and re-fill the write pipeline with\n                                        // new mutations from the LocalStore (since mutations are per-user).\n                                        return i.sent(), [ 2 /*return*/ ];\n                                    }\n                                }));\n                            }));\n                        }(e.yl, n);\n                    }));\n                })), t.If = e, [ 2 /*return*/ ];\n            }\n        }));\n    }));\n}\n\nfunction Na(t) {\n    return g(this, void 0, void 0, (function() {\n        return w(this, (function(e) {\n            switch (e.label) {\n              case 0:\n                return t.mf ? [ 3 /*break*/ , 2 ] : (N(\"FirestoreClient\", \"Using default OfflineComponentProvider\"), \n                [ 4 /*yield*/ , Ea(t, new ws) ]);\n\n              case 1:\n                e.sent(), e.label = 2;\n\n              case 2:\n                return [ 2 /*return*/ , t.mf ];\n            }\n        }));\n    }));\n}\n\nfunction Aa(t) {\n    return g(this, void 0, void 0, (function() {\n        return w(this, (function(e) {\n            switch (e.label) {\n              case 0:\n                return t.If ? [ 3 /*break*/ , 2 ] : (N(\"FirestoreClient\", \"Using default OnlineComponentProvider\"), \n                [ 4 /*yield*/ , Ta(t, new Is) ]);\n\n              case 1:\n                e.sent(), e.label = 2;\n\n              case 2:\n                return [ 2 /*return*/ , t.If ];\n            }\n        }));\n    }));\n}\n\nfunction Da(t) {\n    return Na(t).then((function(t) {\n        return t.persistence;\n    }));\n}\n\nfunction Sa(t) {\n    return Na(t).then((function(t) {\n        return t.bh;\n    }));\n}\n\nfunction xa(t) {\n    return Aa(t).then((function(t) {\n        return t.yl;\n    }));\n}\n\nfunction ka(t) {\n    return Aa(t).then((function(t) {\n        return t._a;\n    }));\n}\n\nfunction Oa(t) {\n    return g(this, void 0, void 0, (function() {\n        var e, n;\n        return w(this, (function(r) {\n            switch (r.label) {\n              case 0:\n                return [ 4 /*yield*/ , Aa(t) ];\n\n              case 1:\n                return e = r.sent(), [ 2 /*return*/ , ((n = e.gl).jh = ju.bind(null, e._a), n.Hh = Gu.bind(null, e._a), \n                n) ];\n            }\n        }));\n    }));\n}\n\n/** Enables the network connection and re-enqueues all pending operations. */ function Pa(t, e, n) {\n    var r = this;\n    void 0 === n && (n = {});\n    var i = new fr;\n    return t._s.Ps((function() {\n        return g(r, void 0, void 0, (function() {\n            var r;\n            return w(this, (function(o) {\n                switch (o.label) {\n                  case 0:\n                    return r = function(t, e, n, r, i) {\n                        var o = new Ts({\n                            next: function(o) {\n                                // Remove query first before passing event to user to avoid\n                                // user actions affecting the now stale query.\n                                e.Ps((function() {\n                                    return Au(t, u);\n                                }));\n                                var s = o.docs.has(n);\n                                !s && o.fromCache ? \n                                // TODO(dimond): If we're online and the document doesn't\n                                // exist then we resolve with a doc.exists set to false. If\n                                // we're offline however, we reject the Promise in this\n                                // case. Two options: 1) Cache the negative response from\n                                // the server so we can deliver that even when you're\n                                // offline 2) Actually reject the Promise in the online case\n                                // if the document doesn't exist.\n                                i.reject(new q(M.UNAVAILABLE, \"Failed to get document because the client is offline.\")) : s && o.fromCache && r && \"server\" === r.source ? i.reject(new q(M.UNAVAILABLE, 'Failed to get document from server. (However, this document does exist in the local cache. Run again without setting source to \"server\" to retrieve the cached document.)')) : i.resolve(o);\n                            },\n                            error: function(t) {\n                                return i.reject(t);\n                            }\n                        }), u = new ku(re(n.path), o, {\n                            includeMetadataChanges: !0,\n                            nl: !0\n                        });\n                        return Nu(t, u);\n                    }, [ 4 /*yield*/ , Oa(t) ];\n\n                  case 1:\n                    return [ 2 /*return*/ , r.apply(void 0, [ o.sent(), t._s, e, n, i ]) ];\n                }\n            }));\n        }));\n    })), i.promise;\n}\n\nfunction Va(t, e, n) {\n    var r = this;\n    void 0 === n && (n = {});\n    var i = new fr;\n    return t._s.Ps((function() {\n        return g(r, void 0, void 0, (function() {\n            var r;\n            return w(this, (function(o) {\n                switch (o.label) {\n                  case 0:\n                    return r = function(t, e, n, r, i) {\n                        var o = new Ts({\n                            next: function(n) {\n                                // Remove query first before passing event to user to avoid\n                                // user actions affecting the now stale query.\n                                e.Ps((function() {\n                                    return Au(t, u);\n                                })), n.fromCache && \"server\" === r.source ? i.reject(new q(M.UNAVAILABLE, 'Failed to get documents from server. (However, these documents may exist in the local cache. Run again without setting source to \"server\" to retrieve the cached documents.)')) : i.resolve(n);\n                            },\n                            error: function(t) {\n                                return i.reject(t);\n                            }\n                        }), u = new ku(n, o, {\n                            includeMetadataChanges: !0,\n                            nl: !0\n                        });\n                        return Nu(t, u);\n                    }, [ 4 /*yield*/ , Oa(t) ];\n\n                  case 1:\n                    return [ 2 /*return*/ , r.apply(void 0, [ o.sent(), t._s, e, n, i ]) ];\n                }\n            }));\n        }));\n    })), i.promise;\n}\n\nvar Ca = /** @class */ function() {\n    function t() {\n        var t = this;\n        // The last promise in the queue.\n                this.Rf = Promise.resolve(), \n        // A list of retryable operations. Retryable operations are run in order and\n        // retried with backoff.\n        this.Pf = [], \n        // Is this AsyncQueue being shut down? Once it is set to true, it will not\n        // be changed again.\n        this.yf = !1, \n        // Operations scheduled to be queued in the future. Operations are\n        // automatically removed after they are run or canceled.\n        this.gf = [], \n        // visible for testing\n        this.Vf = null, \n        // Flag set while there's an outstanding AsyncQueue operation, used for\n        // assertion sanity-checks.\n        this.pf = !1, \n        // List of TimerIds to fast-forward delays for.\n        this.bf = [], \n        // Backoff timer used to schedule retries for retryable operations\n        this.Gu = new Qo(this, \"async_queue_retry\" /* AsyncQueueRetry */), \n        // Visibility handler that triggers an immediate retry of all retryable\n        // operations. Meant to speed up recovery when we regain file system access\n        // after page comes into foreground.\n        this.vf = function() {\n            var e = Go();\n            e && N(\"AsyncQueue\", \"Visibility state changed to \" + e.visibilityState), t.Gu.qu();\n        };\n        var e = Go();\n        e && \"function\" == typeof e.addEventListener && e.addEventListener(\"visibilitychange\", this.vf);\n    }\n    return Object.defineProperty(t.prototype, \"wf\", {\n        get: function() {\n            return this.yf;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    /**\n     * Adds a new operation to the queue without waiting for it to complete (i.e.\n     * we ignore the Promise result).\n     */\n    t.prototype.Ps = function(t) {\n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        this.enqueue(t);\n    }, t.prototype.Tf = function(t) {\n        this.Sf(), \n        // eslint-disable-next-line @typescript-eslint/no-floating-promises\n        this.Df(t);\n    }, t.prototype.Ef = function() {\n        if (!this.yf) {\n            this.yf = !0;\n            var t = Go();\n            t && \"function\" == typeof t.removeEventListener && t.removeEventListener(\"visibilitychange\", this.vf);\n        }\n    }, t.prototype.enqueue = function(t) {\n        return this.Sf(), this.yf ? new Promise((function(t) {})) : this.Df(t);\n    }, t.prototype.po = function(t) {\n        var e = this;\n        this.Ps((function() {\n            return e.Pf.push(t), e.Cf();\n        }));\n    }, \n    /**\n     * Runs the next operation from the retryable queue. If the operation fails,\n     * reschedules with backoff.\n     */\n    t.prototype.Cf = function() {\n        return g(this, void 0, void 0, (function() {\n            var t, e = this;\n            return w(this, (function(n) {\n                switch (n.label) {\n                  case 0:\n                    if (0 === this.Pf.length) return [ 3 /*break*/ , 5 ];\n                    n.label = 1;\n\n                  case 1:\n                    return n.trys.push([ 1, 3, , 4 ]), [ 4 /*yield*/ , this.Pf[0]() ];\n\n                  case 2:\n                    return n.sent(), this.Pf.shift(), this.Gu.reset(), [ 3 /*break*/ , 4 ];\n\n                  case 3:\n                    if (!mr(t = n.sent())) throw t;\n                    // Failure will be handled by AsyncQueue\n                                        return N(\"AsyncQueue\", \"Operation failed with retryable error: \" + t), \n                    [ 3 /*break*/ , 4 ];\n\n                  case 4:\n                    this.Pf.length > 0 && \n                    // If there are additional operations, we re-schedule `retryNextOp()`.\n                    // This is necessary to run retryable operations that failed during\n                    // their initial attempt since we don't know whether they are already\n                    // enqueued. If, for example, `op1`, `op2`, `op3` are enqueued and `op1`\n                    // needs to  be re-run, we will run `op1`, `op1`, `op2` using the\n                    // already enqueued calls to `retryNextOp()`. `op3()` will then run in the\n                    // call scheduled here.\n                    // Since `backoffAndRun()` cancels an existing backoff and schedules a\n                    // new backoff on every call, there is only ever a single additional\n                    // operation in the queue.\n                    this.Gu.Lu((function() {\n                        return e.Cf();\n                    })), n.label = 5;\n\n                  case 5:\n                    return [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, t.prototype.Df = function(t) {\n        var e = this, n = this.Rf.then((function() {\n            return e.pf = !0, t().catch((function(t) {\n                // Re-throw the error so that this.tail becomes a rejected Promise and\n                // all further attempts to chain (via .then) will just short-circuit\n                // and return the rejected Promise.\n                throw e.Vf = t, e.pf = !1, A(\"INTERNAL UNHANDLED ERROR: \", \n                /**\n * Chrome includes Error.message in Error.stack. Other browsers do not.\n * This returns expected output of message + stack when available.\n * @param error - Error or FirestoreError\n */\n                function(t) {\n                    var e = t.message || \"\";\n                    return t.stack && (e = t.stack.includes(t.message) ? t.stack : t.message + \"\\n\" + t.stack), \n                    e;\n                }(t)), t;\n            })).then((function(t) {\n                return e.pf = !1, t;\n            }));\n        }));\n        return this.Rf = n, n;\n    }, t.prototype.Tr = function(t, e, n) {\n        var r = this;\n        this.Sf(), \n        // Fast-forward delays for timerIds that have been overriden.\n        this.bf.indexOf(t) > -1 && (e = 0);\n        var i = Ir.Ts(this, t, e, n, (function(t) {\n            return r.xf(t);\n        }));\n        return this.gf.push(i), i;\n    }, t.prototype.Sf = function() {\n        this.Vf && x();\n    }, t.prototype.Af = function() {}, \n    /**\n     * Waits until all currently queued tasks are finished executing. Delayed\n     * operations are not run.\n     */\n    t.prototype.Nf = function() {\n        return g(this, void 0, void 0, (function() {\n            var t;\n            return w(this, (function(e) {\n                switch (e.label) {\n                  case 0:\n                    return [ 4 /*yield*/ , t = this.Rf ];\n\n                  case 1:\n                    e.sent(), e.label = 2;\n\n                  case 2:\n                    if (t !== this.Rf) return [ 3 /*break*/ , 0 ];\n                    e.label = 3;\n\n                  case 3:\n                    return [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    }, \n    /**\n     * For Tests: Determine if a delayed operation with a particular TimerId\n     * exists.\n     */\n    t.prototype.$f = function(t) {\n        for (var e = 0, n = this.gf; e < n.length; e++) {\n            if (n[e].fs === t) return !0;\n        }\n        return !1;\n    }, \n    /**\n     * For Tests: Runs some or all delayed operations early.\n     *\n     * @param lastTimerId - Delayed operations up to and including this TimerId\n     * will be drained. Pass TimerId.All to run all delayed operations.\n     * @returns a Promise that resolves once all operations have been run.\n     */\n    t.prototype.Ff = function(t) {\n        var e = this;\n        // Note that draining may generate more delayed ops, so we do that first.\n                return this.Nf().then((function() {\n            // Run ops in the same order they'd run if they ran naturally.\n            e.gf.sort((function(t, e) {\n                return t.ds - e.ds;\n            }));\n            for (var n = 0, r = e.gf; n < r.length; n++) {\n                var i = r[n];\n                if (i.Rs(), \"all\" /* All */ !== t && i.fs === t) break;\n            }\n            return e.Nf();\n        }));\n    }, \n    /**\n     * For Tests: Skip all subsequent delays for a timer id.\n     */\n    t.prototype.Of = function(t) {\n        this.bf.push(t);\n    }, \n    /** Called once a DelayedOperation is run or canceled. */ t.prototype.xf = function(t) {\n        // NOTE: indexOf / slice are O(n), but delayedOperations is expected to be small.\n        var e = this.gf.indexOf(t);\n        this.gf.splice(e, 1);\n    }, t;\n}();\n\nfunction La(t) {\n    /**\n * Returns true if obj is an object and contains at least one of the specified\n * methods.\n */\n    return function(t, e) {\n        if (\"object\" != typeof t || null === t) return !1;\n        for (var n = t, r = 0, i = [ \"next\", \"error\", \"complete\" ]; r < i.length; r++) {\n            var o = i[r];\n            if (o in n && \"function\" == typeof n[o]) return !0;\n        }\n        return !1;\n    }(t);\n}\n\nvar Ra = /** @class */ function() {\n    function t() {\n        this.kf = {}, this.Mf = new fr, this.Lf = {\n            taskState: \"Running\",\n            totalBytes: 0,\n            totalDocuments: 0,\n            bytesLoaded: 0,\n            documentsLoaded: 0\n        }\n        /**\n     * Registers functions to listen to bundle loading progress events.\n     * @param next - Called when there is a progress update from bundle loading. Typically `next` calls occur\n     *   each time a Firestore document is loaded from the bundle.\n     * @param error - Called when an error occurs during bundle loading. The task aborts after reporting the\n     *   error, and there should be no more updates after this.\n     * @param complete - Called when the loading task is complete.\n     */;\n    }\n    return t.prototype.onProgress = function(t, e, n) {\n        this.kf = {\n            next: t,\n            error: e,\n            complete: n\n        };\n    }, \n    /**\n     * Implements the `Promise<LoadBundleTaskProgress>.catch` interface.\n     *\n     * @param onRejected - Called when an error occurs during bundle loading.\n     */\n    t.prototype.catch = function(t) {\n        return this.Mf.promise.catch(t);\n    }, \n    /**\n     * Implements the `Promise<LoadBundleTaskProgress>.then` interface.\n     *\n     * @param onFulfilled - Called on the completion of the loading task with a final `LoadBundleTaskProgress` update.\n     *   The update will always have its `taskState` set to `\"Success\"`.\n     * @param onRejected - Called when an error occurs during bundle loading.\n     */\n    t.prototype.then = function(t, e) {\n        return this.Mf.promise.then(t, e);\n    }, \n    /**\n     * Notifies all observers that bundle loading has completed, with a provided\n     * `LoadBundleTaskProgress` object.\n     *\n     * @private\n     */\n    t.prototype.ql = function(t) {\n        this.Ul(t), this.kf.complete && this.kf.complete(), this.Mf.resolve(t);\n    }, \n    /**\n     * Notifies all observers that bundle loading has failed, with a provided\n     * `Error` as the reason.\n     *\n     * @private\n     */\n    t.prototype.Kl = function(t) {\n        this.Lf.taskState = \"Error\", this.kf.next && this.kf.next(this.Lf), this.kf.error && this.kf.error(t), \n        this.Mf.reject(t);\n    }, \n    /**\n     * Notifies a progress update of loading a bundle.\n     * @param progress - The new progress.\n     *\n     * @private\n     */\n    t.prototype.Ul = function(t) {\n        this.Lf = t, this.kf.next && this.kf.next(t);\n    }, t;\n}(), Ua = -1, Ma = /** @class */ function(t) {\n    /** @hideconstructor */\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, e, n) || this).Bf = new Ca, r.w_ = \"name\" in e ? e.name : \"[DEFAULT]\", \n        r;\n    }\n    return m(e, t), e.prototype.b_ = function() {\n        return this.qf || \n        // The client must be initialized to ensure that all subsequent API\n        // usage throws an exception.\n        Fa(this), this.qf.terminate();\n    }, e;\n}(qs);\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/** DOMException error code constants. */ function qa(t) {\n    return t.qf || Fa(t), t.qf.df(), t.qf;\n}\n\nfunction Fa(t) {\n    var e = t.p_(), n = function(t, e, n) {\n        return new _(t, e, n.host, n.ssl, n.experimentalForceLongPolling, n.experimentalAutoDetectLongPolling);\n    }(t.I_, t.w_, e);\n    t.qf = new Ia(t.m_, t.Bf, n);\n}\n\n/**\n * Attempts to enable persistent storage, if possible.\n *\n * Must be called before any other functions (other than\n * {@link initializeFirestore}, {@link getFirestore} or\n * {@link clearIndexedDbPersistence}.\n *\n * If this fails, `enableIndexedDbPersistence()` will reject the promise it\n * returns. Note that even after this failure, the `Firestore` instance will\n * remain usable, however offline persistence will be disabled.\n *\n * There are several reasons why this can fail, which can be identified by\n * the `code` on the error.\n *\n *   * failed-precondition: The app is already open in another browser tab.\n *   * unimplemented: The browser is incompatible with the offline\n *     persistence implementation.\n *\n * @param firestore - The `Firestore` instance to enable persistence for.\n * @param persistenceSettings - Optional settings object to configure\n * persistence.\n * @returns A promise that represents successfully enabling persistent storage.\n */\n/**\n * Registers both the `OfflineComponentProvider` and `OnlineComponentProvider`.\n * If the operation fails with a recoverable error (see\n * `canRecoverFromIndexedDbError()` below), the returned Promise is rejected\n * but the client remains usable.\n */ function ja(t, e, n) {\n    var r = this, i = new fr;\n    return t._s.enqueue((function() {\n        return g(r, void 0, void 0, (function() {\n            var r;\n            return w(this, (function(o) {\n                switch (o.label) {\n                  case 0:\n                    return o.trys.push([ 0, 3, , 4 ]), [ 4 /*yield*/ , Ea(t, n) ];\n\n                  case 1:\n                    return o.sent(), [ 4 /*yield*/ , Ta(t, e) ];\n\n                  case 2:\n                    return o.sent(), i.resolve(), [ 3 /*break*/ , 4 ];\n\n                  case 3:\n                    if (!\n                    /**\n         * Decides whether the provided error allows us to gracefully disable\n         * persistence (as opposed to crashing the client).\n         */\n                    function(t) {\n                        return \"FirebaseError\" === t.name ? t.code === M.FAILED_PRECONDITION || t.code === M.UNIMPLEMENTED : !(\"undefined\" != typeof DOMException && t instanceof DOMException) || (22 === t.code || 20 === t.code || \n                        // Firefox Private Browsing mode disables IndexedDb and returns\n                        // INVALID_STATE for any usage.\n                        11 === t.code);\n                    }(r = o.sent())) throw r;\n                    return console.warn(\"Error enabling offline persistence. Falling back to persistence disabled: \" + r), \n                    i.reject(r), [ 3 /*break*/ , 4 ];\n\n                  case 4:\n                    return [ 2 /*return*/ ];\n                }\n            }));\n        }));\n    })).then((function() {\n        return i.promise;\n    }));\n}\n\n/**\n * Re-enables use of the network for this Firestore instance after a prior\n * call to {@link disableNetwork}.\n *\n * @returns A promise that is resolved once the network has been enabled.\n */\nfunction za(t) {\n    if (t.R_ || t.P_) throw new q(M.FAILED_PRECONDITION, \"Firestore has already been started and persistence can no longer be enabled. You can only enable persistence before calling any other methods on a Firestore object.\");\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Converts Firestore's internal types to the JavaScript types that we expose\n * to the user.\n */ var Ga = /** @class */ function() {\n    function t() {}\n    return t.prototype.Uf = function(t, e) {\n        switch (void 0 === e && (e = \"none\"), vt(t)) {\n          case 0 /* NullValue */ :\n            return null;\n\n          case 1 /* BooleanValue */ :\n            return t.booleanValue;\n\n          case 2 /* NumberValue */ :\n            return st(t.integerValue || t.doubleValue);\n\n          case 3 /* TimestampValue */ :\n            return this.Qf(t.timestampValue);\n\n          case 4 /* ServerTimestampValue */ :\n            return this.Kf(t, e);\n\n          case 5 /* StringValue */ :\n            return t.stringValue;\n\n          case 6 /* BlobValue */ :\n            return this.Wf(at(t.bytesValue));\n\n          case 7 /* RefValue */ :\n            return this.jf(t.referenceValue);\n\n          case 8 /* GeoPointValue */ :\n            return this.Gf(t.geoPointValue);\n\n          case 9 /* ArrayValue */ :\n            return this.zf(t.arrayValue, e);\n\n          case 10 /* ObjectValue */ :\n            return this.Hf(t.mapValue, e);\n\n          default:\n            throw x();\n        }\n    }, t.prototype.Hf = function(t, e) {\n        var n = this, r = {};\n        return nt(t.fields || {}, (function(t, i) {\n            r[t] = n.Uf(i, e);\n        })), r;\n    }, t.prototype.Gf = function(t) {\n        return new Hs(st(t.latitude), st(t.longitude));\n    }, t.prototype.zf = function(t, e) {\n        var n = this;\n        return (t.values || []).map((function(t) {\n            return n.Uf(t, e);\n        }));\n    }, t.prototype.Kf = function(t, e) {\n        switch (e) {\n          case \"previous\":\n            var n = ht(t);\n            return null == n ? null : this.Uf(n, e);\n\n          case \"estimate\":\n            return this.Qf(ft(t));\n\n          default:\n            return null;\n        }\n    }, t.prototype.Qf = function(t) {\n        var e = ut(t);\n        return new K(e.seconds, e.nanos);\n    }, t.prototype.Jf = function(t, e) {\n        var n = Z.ot(t);\n        k(hr(n));\n        var r = new I(n.get(1), n.get(3)), i = new tt(n.Y(5));\n        return r.isEqual(e) || \n        // TODO(b/64130202): Somehow support foreign references.\n        A(\"Document \" + i + \" contains a document reference within a different database (\" + r.projectId + \"/\" + r.database + \") which is not supported. It will be treated as a reference in the current database (\" + e.projectId + \"/\" + e.database + \") instead.\"), \n        i;\n    }, t;\n}(), Ba = /** @class */ function() {\n    // Note: This class is stripped down version of the DocumentSnapshot in\n    // the legacy SDK. The changes are:\n    // - No support for SnapshotMetadata.\n    // - No support for SnapshotOptions.\n    /** @hideconstructor protected */\n    function t(t, e, n, r, i) {\n        this.Yf = t, this.Xf = e, this.S_ = n, this.Zf = r, this.v_ = i;\n    }\n    return Object.defineProperty(t.prototype, \"id\", {\n        /** Property of the `DocumentSnapshot` that provides the document's ID. */ get: function() {\n            return this.S_.path.tt();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"ref\", {\n        /**\n         * The `DocumentReference` for the document included in the `DocumentSnapshot`.\n         */\n        get: function() {\n            return new Fs(this.Yf, this.v_, this.S_);\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    /**\n     * Signals whether or not the document at the snapshot's location exists.\n     *\n     * @returns true if the document exists.\n     */\n    t.prototype.exists = function() {\n        return null !== this.Zf;\n    }, \n    /**\n     * Retrieves all fields in the document as an `Object`. Returns `undefined` if\n     * the document doesn't exist.\n     *\n     * @returns An `Object` containing all fields in the document or `undefined`\n     * if the document doesn't exist.\n     */\n    t.prototype.data = function() {\n        if (this.Zf) {\n            if (this.v_) {\n                // We only want to use the converter and create a new DocumentSnapshot\n                // if a converter has been provided.\n                var t = new Qa(this.Yf, this.Xf, this.S_, this.Zf, \n                /* converter= */ null);\n                return this.v_.fromFirestore(t);\n            }\n            return this.Xf.Uf(this.Zf.bt());\n        }\n    }, \n    /**\n     * Retrieves the field specified by `fieldPath`. Returns `undefined` if the\n     * document or field doesn't exist.\n     *\n     * @param fieldPath - The path (for example 'foo' or 'foo.bar') to a specific\n     * field.\n     * @returns The data at the specified field location or undefined if no such\n     * field exists in the document.\n     */\n    // We are using `any` here to avoid an explicit cast by our users.\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    t.prototype.get = function(t) {\n        if (this.Zf) {\n            var e = this.Zf.data().field(Ya(\"DocumentSnapshot.get\", t));\n            if (null !== e) return this.Xf.Uf(e);\n        }\n    }, t;\n}(), Qa = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    /**\n     * Retrieves all fields in the document as an `Object`.\n     *\n     * @override\n     * @returns An `Object` containing all fields in the document.\n     */    return m(e, t), e.prototype.data = function() {\n        return t.prototype.data.call(this);\n    }, e;\n}(Ba);\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A `DocumentSnapshot` contains data read from a document in your Firestore\n * database. The data can be extracted with `.data()` or `.get(<field>)` to\n * get a specific field.\n *\n * For a `DocumentSnapshot` that points to a non-existing document, any data\n * access will return 'undefined'. You can use the `exists()` method to\n * explicitly verify a document's existence.\n */\n/**\n * Helper that calls fromDotSeparatedString() but wraps any error thrown.\n */\nfunction Ya(t, e) {\n    return \"string\" == typeof e ? ma(t, e) : e instanceof Ss ? e.d_.f_ : e.f_;\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */ function Ha(t) {\n    if (oe(t) && 0 === t.xt.length) throw new q(M.UNIMPLEMENTED, \"limitToLast() queries require specifying at least one orderBy() clause\");\n}\n\n/**\n * A `QueryConstraint` is used to narrow the set of documents returned by a\n * Firestore query. `QueryConstraint`s are created by invoking {@link where},\n * {@link orderBy}, {@link startAt}, {@link startAfter}, {@link\n * endBefore}, {@link endAt}, {@link limit} or {@link limitToLast} and\n * can then be passed to {@link query} to create a new query instance that\n * also contains this `QueryConstraint`.\n */ var Ka = function() {};\n\n/**\n * Creates a new immutable instance of `query` that is extended to also include\n * additional query constraints.\n *\n * @param query - The query instance to use as a base for the new constraints.\n * @param queryConstraints - The list of `QueryConstraint`s to apply.\n * @throws if any of the provided query constraints cannot be combined with the\n * existing or new constraints.\n */ function Xa(t) {\n    for (var e = [], n = 1; n < arguments.length; n++) e[n - 1] = arguments[n];\n    for (var r = 0, i = e; r < i.length; r++) {\n        var o = i[r];\n        t = o.td(t);\n    }\n    return t;\n}\n\nvar Wa = /** @class */ function(t) {\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this) || this).ed = e, i.nd = n, i.sd = r, i.type = \"where\", \n        i;\n    }\n    return m(e, t), e.prototype.td = function(t) {\n        var e = ta(t.firestore), n = function(t, e, n, r, i, o, u) {\n            var s;\n            if (i.ut()) {\n                if (\"array-contains\" /* ARRAY_CONTAINS */ === o || \"array-contains-any\" /* ARRAY_CONTAINS_ANY */ === o) throw new q(M.INVALID_ARGUMENT, \"Invalid Query. You can't perform '\" + o + \"' queries on FieldPath.documentId().\");\n                if (\"in\" /* IN */ === o || \"not-in\" /* NOT_IN */ === o) {\n                    rc(u, o);\n                    for (var a = [], c = 0, h = u; c < h.length; c++) {\n                        var f = h[c];\n                        a.push(nc(r, t, f));\n                    }\n                    s = {\n                        arrayValue: {\n                            values: a\n                        }\n                    };\n                } else s = nc(r, t, u);\n            } else \"in\" /* IN */ !== o && \"not-in\" /* NOT_IN */ !== o && \"array-contains-any\" /* ARRAY_CONTAINS_ANY */ !== o || rc(u, o), \n            s = ha(n, \"where\", u, \n            /* allowArrays= */ \"in\" /* IN */ === o || \"not-in\" /* NOT_IN */ === o);\n            var l = Ft.create(i, o, s);\n            return function(t, e) {\n                if (e.Ct()) {\n                    var n = se(t);\n                    if (null !== n && !n.isEqual(e.field)) throw new q(M.INVALID_ARGUMENT, \"Invalid query. All where filters with an inequality (<, <=, !=, not-in, >, or >=) must be on the same field. But you have inequality filters on '\" + n.toString() + \"' and '\" + e.field.toString() + \"'\");\n                    var r = ue(t);\n                    null !== r && ic(t, e.field, r);\n                }\n                var i = function(t, e) {\n                    for (var n = 0, r = t.filters; n < r.length; n++) {\n                        var i = r[n];\n                        if (e.indexOf(i.op) >= 0) return i.op;\n                    }\n                    return null;\n                }(t, \n                /**\n * Given an operator, returns the set of operators that cannot be used with it.\n *\n * Operators in a query must adhere to the following set of rules:\n * 1. Only one array operator is allowed.\n * 2. Only one disjunctive operator is allowed.\n * 3. NOT_EQUAL cannot be used with another NOT_EQUAL operator.\n * 4. NOT_IN cannot be used with array, disjunctive, or NOT_EQUAL operators.\n *\n * Array operators: ARRAY_CONTAINS, ARRAY_CONTAINS_ANY\n * Disjunctive operators: IN, ARRAY_CONTAINS_ANY, NOT_IN\n */\n                function(t) {\n                    switch (t) {\n                      case \"!=\" /* NOT_EQUAL */ :\n                        return [ \"!=\" /* NOT_EQUAL */ , \"not-in\" /* NOT_IN */ ];\n\n                      case \"array-contains\" /* ARRAY_CONTAINS */ :\n                        return [ \"array-contains\" /* ARRAY_CONTAINS */ , \"array-contains-any\" /* ARRAY_CONTAINS_ANY */ , \"not-in\" /* NOT_IN */ ];\n\n                      case \"in\" /* IN */ :\n                        return [ \"array-contains-any\" /* ARRAY_CONTAINS_ANY */ , \"in\" /* IN */ , \"not-in\" /* NOT_IN */ ];\n\n                      case \"array-contains-any\" /* ARRAY_CONTAINS_ANY */ :\n                        return [ \"array-contains\" /* ARRAY_CONTAINS */ , \"array-contains-any\" /* ARRAY_CONTAINS_ANY */ , \"in\" /* IN */ , \"not-in\" /* NOT_IN */ ];\n\n                      case \"not-in\" /* NOT_IN */ :\n                        return [ \"array-contains\" /* ARRAY_CONTAINS */ , \"array-contains-any\" /* ARRAY_CONTAINS_ANY */ , \"in\" /* IN */ , \"not-in\" /* NOT_IN */ , \"!=\" /* NOT_EQUAL */ ];\n\n                      default:\n                        return [];\n                    }\n                }(e.op));\n                if (null !== i) \n                // Special case when it's a duplicate op to give a slightly clearer error message.\n                throw i === e.op ? new q(M.INVALID_ARGUMENT, \"Invalid query. You cannot use more than one '\" + e.op.toString() + \"' filter.\") : new q(M.INVALID_ARGUMENT, \"Invalid query. You cannot use '\" + e.op.toString() + \"' filters with '\" + i.toString() + \"' filters.\");\n            }(t, l), l;\n        }(t.C_, 0, e, t.firestore.I_, this.ed, this.nd, this.sd);\n        return new js(t.firestore, t.v_, function(t, e) {\n            var n = t.filters.concat([ e ]);\n            return new ee(t.path, t.collectionGroup, t.xt.slice(), n, t.limit, t.limitType, t.startAt, t.endAt);\n        }(t.C_, n));\n    }, e;\n}(Ka), Za = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this) || this).ed = e, r.rd = n, r.type = \"orderBy\", r;\n    }\n    return m(e, t), e.prototype.td = function(t) {\n        var e = function(t, e, n) {\n            if (null !== t.startAt) throw new q(M.INVALID_ARGUMENT, \"Invalid query. You must not call startAt() or startAfter() before calling orderBy().\");\n            if (null !== t.endAt) throw new q(M.INVALID_ARGUMENT, \"Invalid query. You must not call endAt() or endBefore() before calling orderBy().\");\n            var r = new Zt(e, n);\n            return function(t, e) {\n                if (null === ue(t)) {\n                    // This is the first order by. It must match any inequality.\n                    var n = se(t);\n                    null !== n && ic(t, n, e.field);\n                }\n            }(t, r), r;\n        }(t.C_, this.ed, this.rd);\n        return new js(t.firestore, t.v_, function(t, e) {\n            // TODO(dimond): validate that orderBy does not list the same key twice.\n            var n = t.xt.concat([ e ]);\n            return new ee(t.path, t.collectionGroup, n, t.filters.slice(), t.limit, t.limitType, t.startAt, t.endAt);\n        }(t.C_, e));\n    }, e;\n}(Ka), Ja = /** @class */ function(t) {\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this) || this).type = e, i.od = n, i.ad = r, i;\n    }\n    return m(e, t), e.prototype.td = function(t) {\n        return new js(t.firestore, t.v_, fe(t.C_, this.od, this.ad));\n    }, e;\n}(Ka), $a = /** @class */ function(t) {\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this) || this).type = e, i.ud = n, i.hd = r, i;\n    }\n    return m(e, t), e.prototype.td = function(t) {\n        var e = ec(t, this.type, this.ud, this.hd);\n        return new js(t.firestore, t.v_, function(t, e) {\n            return new ee(t.path, t.collectionGroup, t.xt.slice(), t.filters.slice(), t.limit, t.limitType, e, t.endAt);\n        }(t.C_, e));\n    }, e;\n}(Ka), tc = /** @class */ function(t) {\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this) || this).type = e, i.ud = n, i.hd = r, i;\n    }\n    return m(e, t), e.prototype.td = function(t) {\n        var e = ec(t, this.type, this.ud, this.hd);\n        return new js(t.firestore, t.v_, function(t, e) {\n            return new ee(t.path, t.collectionGroup, t.xt.slice(), t.filters.slice(), t.limit, t.limitType, t.startAt, e);\n        }(t.C_, e));\n    }, e;\n}(Ka);\n\n/**\n * Creates a `QueryConstraint` that enforces that documents must contain the\n * specified field and that the value should satisfy the relation constraint\n * provided.\n *\n * @param fieldPath - The path to compare\n * @param opStr - The operation string (e.g \"&lt;\", \"&lt;=\", \"==\", \"&lt;\",\n *   \"&lt;=\", \"!=\").\n * @param value - The value for comparison\n * @returns The created `Query`.\n */\n/** Helper function to create a bound from a document or fields */\nfunction ec(t, e, n, r) {\n    if (n[0] instanceof Ss && (n[0] = n[0].d_), n[0] instanceof Ba) return function(t, e, n, r, i) {\n        if (!r) throw new q(M.NOT_FOUND, \"Can't use a DocumentSnapshot that doesn't exist for \" + n + \"().\");\n        // Because people expect to continue/end a query at the exact document\n        // provided, we need to use the implicit sort order rather than the explicit\n        // sort order, because it's guaranteed to contain the document key. That way\n        // the position becomes unambiguous and the query continues/ends exactly at\n        // the provided document. Without the key (by using the explicit sort\n        // orders), multiple documents could match the position, yielding duplicate\n        // results.\n        for (var o = [], u = 0, s = ce(t); u < s.length; u++) {\n            var a = s[u];\n            if (a.field.ut()) o.push(It(e, r.key)); else {\n                var c = r.field(a.field);\n                if (ct(c)) throw new q(M.INVALID_ARGUMENT, 'Invalid query. You are trying to start or end a query using a document for which the field \"' + a.field + '\" is an uncommitted server timestamp. (Since the value of this field is unknown, you cannot start/end a query with it.)');\n                if (null === c) {\n                    var h = a.field.rt();\n                    throw new q(M.INVALID_ARGUMENT, \"Invalid query. You are trying to start or end a query using a document for which the field '\" + h + \"' (used as the orderBy) does not exist.\");\n                }\n                o.push(c);\n            }\n        }\n        return new Xt(o, i);\n    }(t.C_, t.firestore.I_, e, n[0].Zf, r);\n    var i = ta(t.firestore);\n    return function(t, e, n, r, i, o) {\n        // Use explicit order by's because it has to match the query the user made\n        var u = t.xt;\n        if (i.length > u.length) throw new q(M.INVALID_ARGUMENT, \"Too many arguments provided to \" + r + \"(). The number of arguments must be less than or equal to the number of orderBy() clauses\");\n        for (var s = [], a = 0; a < i.length; a++) {\n            var c = i[a];\n            if (u[a].field.ut()) {\n                if (\"string\" != typeof c) throw new q(M.INVALID_ARGUMENT, \"Invalid query. Expected a string for document ID in \" + r + \"(), but got a \" + typeof c);\n                if (!ae(t) && -1 !== c.indexOf(\"/\")) throw new q(M.INVALID_ARGUMENT, \"Invalid query. When querying a collection and ordering by FieldPath.documentId(), the value passed to \" + r + \"() must be a plain document ID, but '\" + c + \"' contains a slash.\");\n                var h = t.path.child(Z.ot(c));\n                if (!tt.wt(h)) throw new q(M.INVALID_ARGUMENT, \"Invalid query. When querying a collection group and ordering by FieldPath.documentId(), the value passed to \" + r + \"() must result in a valid document path, but '\" + h + \"' is not because it contains an odd number of segments.\");\n                var f = new tt(h);\n                s.push(It(e, f));\n            } else {\n                var l = ha(n, r, c);\n                s.push(l);\n            }\n        }\n        return new Xt(s, o);\n    }(t.C_, t.firestore.I_, i, e, n, r);\n}\n\nfunction nc(t, e, n) {\n    if (n instanceof Ss && (n = n.d_), \"string\" == typeof n) {\n        if (\"\" === n) throw new q(M.INVALID_ARGUMENT, \"Invalid query. When querying with FieldPath.documentId(), you must provide a valid document ID, but it was an empty string.\");\n        if (!ae(e) && -1 !== n.indexOf(\"/\")) throw new q(M.INVALID_ARGUMENT, \"Invalid query. When querying a collection by FieldPath.documentId(), you must provide a plain document ID, but '\" + n + \"' contains a '/' character.\");\n        var r = e.path.child(Z.ot(n));\n        if (!tt.wt(r)) throw new q(M.INVALID_ARGUMENT, \"Invalid query. When querying a collection group by FieldPath.documentId(), the value provided must result in a valid document path, but '\" + r + \"' is not because it has an odd number of segments (\" + r.length + \").\");\n        return It(t, new tt(r));\n    }\n    if (n instanceof Fs) return It(t, n.S_);\n    throw new q(M.INVALID_ARGUMENT, \"Invalid query. When querying with FieldPath.documentId(), you must provide a valid string or a DocumentReference, but it was: \" + Cs(n) + \".\");\n}\n\n/**\n * Validates that the value passed into a disjunctive filter satisfies all\n * array requirements.\n */ function rc(t, e) {\n    if (!Array.isArray(t) || 0 === t.length) throw new q(M.INVALID_ARGUMENT, \"Invalid Query. A non-empty array is required for '\" + e.toString() + \"' filters.\");\n    if (t.length > 10) throw new q(M.INVALID_ARGUMENT, \"Invalid Query. '\" + e.toString() + \"' filters support a maximum of 10 elements in the value array.\");\n}\n\nfunction ic(t, e, n) {\n    if (!n.isEqual(e)) throw new q(M.INVALID_ARGUMENT, \"Invalid query. You have a where filter with an inequality (<, <=, !=, not-in, >, or >=) on field '\" + e.toString() + \"' and so you must also use '\" + e.toString() + \"' as your first argument to orderBy(), but your first orderBy() is on field '\" + n.toString() + \"' instead.\");\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Converts custom model object of type T into DocumentData by applying the\n * converter if it exists.\n *\n * This function is used when converting user objects to DocumentData\n * because we want to provide the user with a more specific error message if\n * their set() or fails due to invalid data originating from a toFirestore()\n * call.\n */ function oc(t, e, n) {\n    // Cast to `any` in order to satisfy the union type constraint on\n    // toFirestore().\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return t ? n && (n.merge || n.mergeFields) ? t.toFirestore(e, n) : t.toFirestore(e) : e;\n}\n\nvar uc = /** @class */ function(t) {\n    function e(e) {\n        var n = this;\n        return (n = t.call(this) || this).firestore = e, n;\n    }\n    return m(e, t), e.prototype.Wf = function(t) {\n        return new F(t);\n    }, e.prototype.jf = function(t) {\n        var e = this.Jf(t, this.firestore.I_);\n        return new Fs(this.firestore, /* converter= */ null, e);\n    }, e;\n}(Ga), sc = /** @class */ function() {\n    /** @hideconstructor */\n    function t(t, e) {\n        this.hasPendingWrites = t, this.fromCache = e\n        /**\n     * Returns true if this `SnapshotMetadata` is equal to the provided one.\n     *\n     * @param other - The `SnapshotMetadata` to compare against.\n     * @returns true if this `SnapshotMetadata` is equal to the provided one.\n     */;\n    }\n    return t.prototype.isEqual = function(t) {\n        return this.hasPendingWrites === t.hasPendingWrites && this.fromCache === t.fromCache;\n    }, t;\n}(), ac = /** @class */ function(t) {\n    /** @hideconstructor protected */\n    function e(e, n, r, i, o, u) {\n        var s = this;\n        return (s = t.call(this, e, n, r, i, u) || this).Yf = e, s.ld = e, s.metadata = o, \n        s;\n    }\n    /**\n     * Property of the `DocumentSnapshot` that signals whether or not the data\n     * exists. True if the document exists.\n     */    return m(e, t), e.prototype.exists = function() {\n        return t.prototype.exists.call(this);\n    }, \n    /**\n     * Retrieves all fields in the document as an `Object`. Returns `undefined` if\n     * the document doesn't exist.\n     *\n     * By default, `FieldValue.serverTimestamp()` values that have not yet been\n     * set to their final value will be returned as `null`. You can override\n     * this by passing an options object.\n     *\n     * @param options - An options object to configure how data is retrieved from\n     * the snapshot (for example the desired behavior for server timestamps that\n     * have not yet been set to their final value).\n     * @returns An `Object` containing all fields in the document or `undefined` if\n     * the document doesn't exist.\n     */\n    e.prototype.data = function(t) {\n        if (void 0 === t && (t = {}), this.Zf) {\n            if (this.v_) {\n                // We only want to use the converter and create a new DocumentSnapshot\n                // if a converter has been provided.\n                var e = new cc(this.Yf, this.Xf, this.S_, this.Zf, this.metadata, \n                /* converter= */ null);\n                return this.v_.fromFirestore(e, t);\n            }\n            return this.Xf.Uf(this.Zf.bt(), t.serverTimestamps);\n        }\n    }, \n    /**\n     * Retrieves the field specified by `fieldPath`. Returns `undefined` if the\n     * document or field doesn't exist.\n     *\n     * By default, a `FieldValue.serverTimestamp()` that has not yet been set to\n     * its final value will be returned as `null`. You can override this by\n     * passing an options object.\n     *\n     * @param fieldPath - The path (for example 'foo' or 'foo.bar') to a specific\n     * field.\n     * @param options - An options object to configure how the field is retrieved\n     * from the snapshot (for example the desired behavior for server timestamps\n     * that have not yet been set to their final value).\n     * @returns The data at the specified field location or undefined if no such\n     * field exists in the document.\n     */\n    // We are using `any` here to avoid an explicit cast by our users.\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    e.prototype.get = function(t, e) {\n        if (void 0 === e && (e = {}), this.Zf) {\n            var n = this.Zf.data().field(Ya(\"DocumentSnapshot.get\", t));\n            if (null !== n) return this.Xf.Uf(n, e.serverTimestamps);\n        }\n    }, e;\n}(Ba), cc = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    /**\n     * Retrieves all fields in the document as an `Object`.\n     *\n     * By default, `FieldValue.serverTimestamp()` values that have not yet been\n     * set to their final value will be returned as `null`. You can override\n     * this by passing an options object.\n     *\n     * @override\n     * @param options - An options object to configure how data is retrieved from\n     * the snapshot (for example the desired behavior for server timestamps that\n     * have not yet been set to their final value).\n     * @returns An `Object` containing all fields in the document.\n     */    return m(e, t), e.prototype.data = function(e) {\n        return void 0 === e && (e = {}), t.prototype.data.call(this, e);\n    }, e;\n}(ac), hc = /** @class */ function() {\n    /** @hideconstructor */\n    function t(t, e, n, r) {\n        this.Yf = t, this.Xf = e, this._d = r, this.metadata = new sc(r.hasPendingWrites, r.fromCache), \n        this.query = n;\n    }\n    return Object.defineProperty(t.prototype, \"docs\", {\n        /** An array of all the documents in the `QuerySnapshot`. */ get: function() {\n            var t = [];\n            return this.forEach((function(e) {\n                return t.push(e);\n            })), t;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"size\", {\n        /** The number of documents in the `QuerySnapshot`. */ get: function() {\n            return this._d.docs.size;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(t.prototype, \"empty\", {\n        /** True if there are no documents in the `QuerySnapshot`. */ get: function() {\n            return 0 === this.size;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), \n    /**\n     * Enumerates all of the documents in the `QuerySnapshot`.\n     *\n     * @param callback - A callback to be called with a `QueryDocumentSnapshot` for\n     * each document in the snapshot.\n     * @param thisArg - The `this` binding for the callback.\n     */\n    t.prototype.forEach = function(t, e) {\n        var n = this;\n        this._d.docs.forEach((function(r) {\n            t.call(e, new cc(n.Yf, n.Xf, r.key, r, new sc(n._d.De.has(r.key), n._d.fromCache), n.query.v_));\n        }));\n    }, \n    /**\n     * Returns an array of the documents changes since the last snapshot. If this\n     * is the first snapshot, all documents will be in the list as 'added'\n     * changes.\n     *\n     * @param options - `SnapshotListenOptions` that control whether metadata-only\n     * changes (i.e. only `DocumentSnapshot.metadata` changed) should trigger\n     * snapshot events.\n     */\n    t.prototype.docChanges = function(t) {\n        void 0 === t && (t = {});\n        var e = !!t.includeMetadataChanges;\n        if (e && this._d.xe) throw new q(M.INVALID_ARGUMENT, \"To include metadata changes with your document changes, you must also pass { includeMetadataChanges:true } to onSnapshot().\");\n        return this.fd && this.dd === e || (this.fd = \n        /** Calculates the array of DocumentChanges for a given ViewSnapshot. */\n        function(t, e) {\n            if (t._d.Se.et()) {\n                // Special case the first snapshot because index calculation is easy and\n                // fast\n                var n = 0;\n                return t._d.docChanges.map((function(e) {\n                    var r = new cc(t.Yf, t.Xf, e.doc.key, e.doc, new sc(t._d.De.has(e.doc.key), t._d.fromCache), t.query.v_);\n                    return e.doc, {\n                        type: \"added\",\n                        doc: r,\n                        oldIndex: -1,\n                        newIndex: n++\n                    };\n                }));\n            }\n            // A DocumentSet that is updated incrementally as changes are applied to use\n            // to lookup the index of a document.\n            var r = t._d.Se;\n            return t._d.docChanges.filter((function(t) {\n                return e || 3 /* Metadata */ !== t.type;\n            })).map((function(e) {\n                var n = new cc(t.Yf, t.Xf, e.doc.key, e.doc, new sc(t._d.De.has(e.doc.key), t._d.fromCache), t.query.v_), i = -1, o = -1;\n                return 0 /* Added */ !== e.type && (i = r.indexOf(e.doc.key), r = r.delete(e.doc.key)), \n                1 /* Removed */ !== e.type && (o = (r = r.add(e.doc)).indexOf(e.doc.key)), {\n                    type: fc(e.type),\n                    doc: n,\n                    oldIndex: i,\n                    newIndex: o\n                };\n            }));\n        }(this, e), this.dd = e), this.fd;\n    }, t;\n}();\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Metadata about a snapshot, describing the state of the snapshot.\n */ function fc(t) {\n    switch (t) {\n      case 0 /* Added */ :\n        return \"added\";\n\n      case 2 /* Modified */ :\n      case 3 /* Metadata */ :\n        return \"modified\";\n\n      case 1 /* Removed */ :\n        return \"removed\";\n\n      default:\n        return x();\n    }\n}\n\n// TODO(firestoreexp): Add tests for snapshotEqual with different snapshot\n// metadata\n/**\n * Returns true if the provided snapshots are equal.\n *\n * @param left - A snapshot to compare.\n * @param right - A snapshot to compare.\n * @returns true if the snapshots are equal.\n */ function lc(t, e) {\n    return t instanceof ac && e instanceof ac ? t.Yf === e.Yf && t.S_.isEqual(e.S_) && (null === t.Zf ? null === e.Zf : t.Zf.isEqual(e.Zf)) && t.v_ === e.v_ : t instanceof hc && e instanceof hc && t.Yf === e.Yf && Ys(t.query, e.query) && t.metadata.isEqual(e.metadata) && t._d.isEqual(e._d);\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Reads the document referred to by this `DocumentReference`.\n *\n * Note: `getDoc()` attempts to provide up-to-date data when possible by waiting\n * for data from the server, but it may return cached data or fail if you are\n * offline and the server cannot be reached. To specify this behavior, invoke\n * {@link getDocFromCache} or {@link getDocFromServer}.\n *\n * @param reference - The reference of the document to fetch.\n * @returns A Promise resolved with a `DocumentSnapshot` containing the\n * current document contents.\n */ var pc = /** @class */ function(t) {\n    function e(e) {\n        var n = this;\n        return (n = t.call(this) || this).firestore = e, n;\n    }\n    return m(e, t), e.prototype.Wf = function(t) {\n        return new F(t);\n    }, e.prototype.jf = function(t) {\n        var e = this.Jf(t, this.firestore.I_);\n        return new Fs(this.firestore, /* converter= */ null, e);\n    }, e;\n}(Ga);\n\n/**\n * Reads the document referred to by this `DocumentReference` from cache.\n * Returns an error if the document is not currently cached.\n *\n * @returns A Promise resolved with a `DocumentSnapshot` containing the\n * current document contents.\n */ function dc(t, e, n) {\n    for (var r = [], i = 3; i < arguments.length; i++) r[i - 3] = arguments[i];\n    t = Ls(t, Fs);\n    var o = Ls(t.firestore, Ma), u = ta(o);\n    // For Compat types, we have to \"extract\" the underlying types before\n    // performing validation.\n    return e instanceof Ss && (e = e.d_), yc(o, [ (\"string\" == typeof e || e instanceof As ? ca(u, \"updateDoc\", t.S_, e, n, r) : aa(u, \"updateDoc\", t.S_, e)).F_(t.S_, Re.exists(!0)) ]);\n}\n\n/**\n * Deletes the document referred to by the specified `DocumentReference`.\n *\n * @param reference - A reference to the document to delete.\n * @returns A Promise resolved once the document has been successfully\n * deleted from the backend (note that it won't resolve while you're offline).\n */ function vc(t) {\n    for (var e, n, r, i = [], o = 1; o < arguments.length; o++) i[o - 1] = arguments[o];\n    t instanceof Ss && (t = t.d_);\n    var u = {\n        includeMetadataChanges: !1\n    }, s = 0;\n    \"object\" != typeof i[s] || La(i[s]) || (u = i[s], s++);\n    var a, c, h, f = {\n        includeMetadataChanges: u.includeMetadataChanges\n    };\n    if (La(i[s])) {\n        var l = i[s];\n        i[s] = null === (e = l.next) || void 0 === e ? void 0 : e.bind(l), i[s + 1] = null === (n = l.error) || void 0 === n ? void 0 : n.bind(l), \n        i[s + 2] = null === (r = l.complete) || void 0 === r ? void 0 : r.bind(l);\n    }\n    if (t instanceof Fs) c = Ls(t.firestore, Ma), h = re(t.S_.path), a = {\n        next: function(e) {\n            i[s] && i[s](mc(c, t, e));\n        },\n        error: i[s + 1],\n        complete: i[s + 2]\n    }; else {\n        var p = Ls(t, js);\n        c = Ls(p.firestore, Ma), h = p.C_;\n        var d = new pc(c);\n        a = {\n            next: function(t) {\n                i[s] && i[s](new hc(c, d, p, t));\n            },\n            error: i[s + 1],\n            complete: i[s + 2]\n        }, Ha(t.C_);\n    }\n    return function(t, e, n, r) {\n        var i = this, o = new Ts(r), u = new ku(e, o, n);\n        return t._s.Ps((function() {\n            return g(i, void 0, void 0, (function() {\n                var e;\n                return w(this, (function(n) {\n                    switch (n.label) {\n                      case 0:\n                        return e = Nu, [ 4 /*yield*/ , Oa(t) ];\n\n                      case 1:\n                        return [ 2 /*return*/ , e.apply(void 0, [ n.sent(), u ]) ];\n                    }\n                }));\n            }));\n        })), function() {\n            o.i_(), t._s.Ps((function() {\n                return g(i, void 0, void 0, (function() {\n                    var e;\n                    return w(this, (function(n) {\n                        switch (n.label) {\n                          case 0:\n                            return e = Au, [ 4 /*yield*/ , Oa(t) ];\n\n                          case 1:\n                            return [ 2 /*return*/ , e.apply(void 0, [ n.sent(), u ]) ];\n                        }\n                    }));\n                }));\n            }));\n        };\n    }(qa(c), h, f, a);\n}\n\n/** Locally writes `mutations` on the async queue. */ function yc(t, e) {\n    return function(t, e) {\n        var n = this, r = new fr;\n        return t._s.Ps((function() {\n            return g(n, void 0, void 0, (function() {\n                var n;\n                return w(this, (function(i) {\n                    switch (i.label) {\n                      case 0:\n                        return n = Bu, [ 4 /*yield*/ , ka(t) ];\n\n                      case 1:\n                        return [ 2 /*return*/ , n.apply(void 0, [ i.sent(), e, r ]) ];\n                    }\n                }));\n            }));\n        })), r.promise;\n    }(qa(t), e);\n}\n\n/**\n * Converts a ViewSnapshot that contains the single document specified by `ref`\n * to a DocumentSnapshot.\n */ function mc(t, e, n) {\n    var r = n.docs.get(e.S_), i = new pc(t);\n    return new ac(t, i, e.S_, r, new sc(n.hasPendingWrites, n.fromCache), e.v_);\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A write batch, used to perform multiple writes as a single atomic unit.\n *\n * A `WriteBatch` object can be acquired by calling {@link writeBatch}. It\n * provides methods for adding writes to the write batch. None of the writes\n * will be committed (or visible locally) until {@link WriteBatch#commit} is\n * called.\n */ var gc = /** @class */ function() {\n    /** @hideconstructor */\n    function t(t, e) {\n        this.Yf = t, this.wd = e, this.Ed = [], this.Td = !1, this.Id = ta(t);\n    }\n    return t.prototype.set = function(t, e, n) {\n        this.md();\n        var r = wc(t, this.Yf), i = oc(r.v_, e, n), o = ea(this.Id, \"WriteBatch.set\", r.S_, i, null !== r.v_, n);\n        return this.Ed.push(o.F_(r.S_, Re.Kt())), this;\n    }, t.prototype.update = function(t, e, n) {\n        for (var r = [], i = 3; i < arguments.length; i++) r[i - 3] = arguments[i];\n        this.md();\n        var o, u = wc(t, this.Yf);\n        // For Compat types, we have to \"extract\" the underlying types before\n        // performing validation.\n                return e instanceof Ss && (e = e.d_), o = \"string\" == typeof e || e instanceof As ? ca(this.Id, \"WriteBatch.update\", u.S_, e, n, r) : aa(this.Id, \"WriteBatch.update\", u.S_, e), \n        this.Ed.push(o.F_(u.S_, Re.exists(!0))), this;\n    }, \n    /**\n     * Deletes the document referred to by the provided {@link DocumentReference}.\n     *\n     * @param documentRef - A reference to the document to be deleted.\n     * @returns This `WriteBatch` instance. Used for chaining method calls.\n     */\n    t.prototype.delete = function(t) {\n        this.md();\n        var e = wc(t, this.Yf);\n        return this.Ed = this.Ed.concat(new Je(e.S_, Re.Kt())), this;\n    }, \n    /**\n     * Commits all of the writes in this write batch as a single atomic unit.\n     *\n     * The result of these writes will only be reflected in document reads that\n     * occur after the returned Promise resolves. If the client is offline, the\n     * write fails. If you would like to see local modifications or buffer writes\n     * until the client is online, use the full Firestore SDK.\n     *\n     * @returns A Promise resolved once all of the writes in the batch have been\n     * successfully written to the backend as an atomic unit (note that it won't\n     * resolve while you're offline).\n     */\n    t.prototype.commit = function() {\n        return this.md(), this.Td = !0, this.Ed.length > 0 ? this.wd(this.Ed) : Promise.resolve();\n    }, t.prototype.md = function() {\n        if (this.Td) throw new q(M.FAILED_PRECONDITION, \"A write batch can no longer be used after commit() has been called.\");\n    }, t;\n}();\n\nfunction wc(t, e) {\n    if (t instanceof Ss && (t = t.d_), t.firestore !== e) throw new q(M.INVALID_ARGUMENT, \"Provided document reference is from a different Firestore instance.\");\n    return t;\n}\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n// TODO(mrschmidt) Consider using `BaseTransaction` as the base class in the\n// legacy SDK.\n/**\n * A reference to a transaction.\n *\n * The `Transaction` object passed to a transaction's `updateFunction` provides\n * the methods to read and write data within the transaction context. See\n * {@link runTransaction}.\n */\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * A reference to a transaction.\n *\n * The `Transaction` object passed to a transaction's `updateFunction` provides\n * the methods to read and write data within the transaction context. See\n * {@link runTransaction}.\n */ var bc = /** @class */ function(t) {\n    // This class implements the same logic as the Transaction API in the Lite SDK\n    // but is subclassed in order to return its own DocumentSnapshot types.\n    /** @hideconstructor */\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, e, n) || this).Yf = e, r;\n    }\n    /**\n     * Reads the document referenced by the provided {@link DocumentReference}.\n     *\n     * @param documentRef - A reference to the document to be read.\n     * @returns A `DocumentSnapshot` with the read data.\n     */    return m(e, t), e.prototype.get = function(e) {\n        var n = this, r = wc(e, this.Yf), i = new pc(this.Yf);\n        return t.prototype.get.call(this, e).then((function(t) {\n            return new ac(n.Yf, i, r.S_, t.Zf, new sc(\n            /* hasPendingWrites= */ !1, \n            /* fromCache= */ !1), r.v_);\n        }));\n    }, e;\n}(/** @class */ function() {\n    /** @hideconstructor */\n    function t(t, e) {\n        this.Yf = t, this.Ad = e, this.Id = ta(t)\n        /**\n     * Reads the document referenced by the provided {@link DocumentReference}.\n     *\n     * @param documentRef - A reference to the document to be read.\n     * @returns A `DocumentSnapshot` with the read data.\n     */;\n    }\n    return t.prototype.get = function(t) {\n        var e = this, n = wc(t, this.Yf), r = new uc(this.Yf);\n        return this.Ad.ef([ n.S_ ]).then((function(t) {\n            if (!t || 1 !== t.length) return x();\n            var i = t[0];\n            if (i instanceof Vt) return new Ba(e.Yf, r, n.S_, null, n.v_);\n            if (i instanceof Pt) return new Ba(e.Yf, r, i.key, i, n.v_);\n            throw x();\n        }));\n    }, t.prototype.set = function(t, e, n) {\n        var r = wc(t, this.Yf), i = oc(r.v_, e, n), o = ea(this.Id, \"Transaction.set\", r.S_, i, null !== r.v_, n);\n        return this.Ad.set(r.S_, o), this;\n    }, t.prototype.update = function(t, e, n) {\n        for (var r = [], i = 3; i < arguments.length; i++) r[i - 3] = arguments[i];\n        var o, u = wc(t, this.Yf);\n        // For Compat types, we have to \"extract\" the underlying types before\n        // performing validation.\n                return e instanceof Ss && (e = e.d_), o = \"string\" == typeof e || e instanceof As ? ca(this.Id, \"Transaction.update\", u.S_, e, n, r) : aa(this.Id, \"Transaction.update\", u.S_, e), \n        this.Ad.update(u.S_, o), this;\n    }, \n    /**\n     * Deletes the document referred to by the provided {@link DocumentReference}.\n     *\n     * @param documentRef - A reference to the document to be deleted.\n     * @returns This `Transaction` instance. Used for chaining method calls.\n     */\n    t.prototype.delete = function(t) {\n        var e = wc(t, this.Yf);\n        return this.Ad.delete(e.S_), this;\n    }, t;\n}());\n\n/**\n * Executes the given `updateFunction` and then attempts to commit the changes\n * applied within the transaction. If any document read within the transaction\n * has changed, Cloud Firestore retries the `updateFunction`. If it fails to\n * commit after 5 attempts, the transaction fails.\n *\n * The maximum number of writes allowed in a single transaction is 500.\n *\n * @param firestore - A reference to the Firestore database to run this\n * transaction against.\n * @param updateFunction - The function to execute within the transaction\n * context.\n * @returns If the transaction completed successfully or was explicitly aborted\n * (the `updateFunction` returned a failed promise), the promise returned by the\n * `updateFunction `is returned here. Otherwise, if the transaction failed, a\n * rejected promise with the corresponding failure error is returned.\n */\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/** Helper function to assert Uint8Array is available at runtime. */ function _c() {\n    if (\"undefined\" == typeof Uint8Array) throw new q(M.UNIMPLEMENTED, \"Uint8Arrays are not available in this environment.\");\n}\n\n/** Helper function to assert Base64 functions are available at runtime. */ function Ic() {\n    if (\"undefined\" == typeof atob) throw new q(M.UNIMPLEMENTED, \"Blobs are unavailable in Firestore in this environment.\");\n}\n\n/** Immutable class holding a blob (binary data) */ var Ec = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    return m(e, t), e.fromBase64String = function(t) {\n        return Ic(), new e(F.fromBase64String(t));\n    }, e.fromUint8Array = function(t) {\n        return _c(), new e(F.fromUint8Array(t));\n    }, e.prototype.toBase64 = function() {\n        return Ic(), this.d_.toBase64();\n    }, e.prototype.toUint8Array = function() {\n        return _c(), this.d_.toUint8Array();\n    }, e.prototype.isEqual = function(t) {\n        return this.d_.isEqual(t.d_);\n    }, e.prototype.toString = function() {\n        return \"Blob(base64: \" + this.toBase64() + \")\";\n    }, e;\n}(Ss), Tc = /** @class */ function() {\n    function t() {}\n    return t.prototype.enableIndexedDbPersistence = function(t, e) {\n        return function(t, e) {\n            za(t = Ls(t, Ma));\n            var n = qa(t), r = t.p_(), i = new Is;\n            return ja(n, i, new bs(i, r.cacheSizeBytes, null == e ? void 0 : e.forceOwnership));\n        }(t.d_, {\n            forceOwnership: e\n        });\n    }, t.prototype.enableMultiTabIndexedDbPersistence = function(t) {\n        return function(t) {\n            za(t = Ls(t, Ma));\n            var e = qa(t), n = t.p_(), r = new Is;\n            return ja(e, r, new _s(r, n.cacheSizeBytes));\n        }(t.d_);\n    }, t.prototype.clearIndexedDbPersistence = function(t) {\n        return function(t) {\n            var e = this;\n            if (t.R_ && !t.P_) throw new q(M.FAILED_PRECONDITION, \"Persistence can only be cleared before a Firestore instance is initialized or after it is terminated.\");\n            var n = new fr;\n            return t.Bf.Tf((function() {\n                return g(e, void 0, void 0, (function() {\n                    var e;\n                    return w(this, (function(r) {\n                        switch (r.label) {\n                          case 0:\n                            return r.trys.push([ 0, 2, , 3 ]), [ 4 /*yield*/ , function(t) {\n                                return g(this, void 0, void 0, (function() {\n                                    var e;\n                                    return w(this, (function(n) {\n                                        switch (n.label) {\n                                          case 0:\n                                            return dr.Kn() ? (e = t + \"main\", [ 4 /*yield*/ , dr.delete(e) ]) : [ 2 /*return*/ , Promise.resolve() ];\n\n                                          case 1:\n                                            return n.sent(), [ 2 /*return*/ ];\n                                        }\n                                    }));\n                                }));\n                            }(Xi(t.I_, t.w_)) ];\n\n                          case 1:\n                            return r.sent(), n.resolve(), [ 3 /*break*/ , 3 ];\n\n                          case 2:\n                            return e = r.sent(), n.reject(e), [ 3 /*break*/ , 3 ];\n\n                          case 3:\n                            return [ 2 /*return*/ ];\n                        }\n                    }));\n                }));\n            })), n.promise\n            /**\n * Waits until all currently pending writes for the active user have been\n * acknowledged by the backend.\n *\n * The returned Promise resolves immediately if there are no outstanding writes.\n * Otherwise, the Promise waits for all previously issued writes (including\n * those written in a previous app session), but it does not wait for writes\n * that were added after the function is called. If you want to wait for\n * additional writes, call `waitForPendingWrites()` again.\n *\n * Any outstanding `waitForPendingWrites()` Promises are rejected during user\n * changes.\n *\n * @returns A Promise which resolves when all currently pending writes have been\n * acknowledged by the backend.\n */;\n        }(t.d_);\n    }, t;\n}(), Nc = /** @class */ function(t) {\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this, n) || this).Rd = r, i.INTERNAL = {\n            delete: function() {\n                return i.terminate();\n            }\n        }, e instanceof I || (i.Pd = e), i;\n    }\n    return m(e, t), Object.defineProperty(e.prototype, \"I_\", {\n        get: function() {\n            return this.d_.I_;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), e.prototype.settings = function(t) {\n        t.merge && \n        // Remove the property from the settings once the merge is completed\n        delete (t = Object.assign(Object.assign({}, this.d_.V_()), t)).merge, this.d_.g_(t);\n    }, e.prototype.useEmulator = function(t, e) {\n        !function(t, e, n) {\n            var r = (t = Ls(t, qs)).V_();\n            \"firestore.googleapis.com\" !== r.host && r.host !== e && D(\"Host has been set in both settings() and useEmulator(), emulator host will be used\"), \n            t.g_(Object.assign(Object.assign({}, r), {\n                host: e + \":\" + n,\n                ssl: !1\n            }));\n        }(this.d_, t, e);\n    }, e.prototype.enableNetwork = function() {\n        return function(t) {\n            var e = this;\n            return t._s.enqueue((function() {\n                return g(e, void 0, void 0, (function() {\n                    var e, n;\n                    return w(this, (function(r) {\n                        switch (r.label) {\n                          case 0:\n                            return [ 4 /*yield*/ , Da(t) ];\n\n                          case 1:\n                            return e = r.sent(), [ 4 /*yield*/ , xa(t) ];\n\n                          case 2:\n                            return n = r.sent(), [ 2 /*return*/ , (e.yo(!0), function(t) {\n                                var e = O(t);\n                                return e.Nh.delete(0 /* UserDisabled */), Jo(e);\n                            }(n)) ];\n                        }\n                    }));\n                }));\n            }));\n        }\n        /** Disables the network connection. Pending operations will not complete. */ (qa(Ls(this.d_, Ma)));\n    }, e.prototype.disableNetwork = function() {\n        return function(t) {\n            var e = this;\n            return t._s.enqueue((function() {\n                return g(e, void 0, void 0, (function() {\n                    var e, n;\n                    return w(this, (function(r) {\n                        switch (r.label) {\n                          case 0:\n                            return [ 4 /*yield*/ , Da(t) ];\n\n                          case 1:\n                            return e = r.sent(), [ 4 /*yield*/ , xa(t) ];\n\n                          case 2:\n                            return n = r.sent(), [ 2 /*return*/ , (e.yo(!1), function(t) {\n                                return g(this, void 0, void 0, (function() {\n                                    var e;\n                                    return w(this, (function(n) {\n                                        switch (n.label) {\n                                          case 0:\n                                            return (e = O(t)).Nh.add(0 /* UserDisabled */), [ 4 /*yield*/ , $o(e) ];\n\n                                          case 1:\n                                            return n.sent(), \n                                            // Set the OnlineState to Offline so get()s return from cache, etc.\n                                            e.Oh.set(\"Offline\" /* Offline */), [ 2 /*return*/ ];\n                                        }\n                                    }));\n                                }));\n                            }(n)) ];\n                        }\n                    }));\n                }));\n            }));\n        }\n        /**\n * Returns a Promise that resolves when all writes that were pending at the time\n * this method was called received server acknowledgement. An acknowledgement\n * can be either acceptance or rejection.\n */ (qa(Ls(this.d_, Ma)));\n    }, e.prototype.enablePersistence = function(t) {\n        var e = !1, n = !1;\n        return t && Os(\"synchronizeTabs\", e = !!t.synchronizeTabs, \"experimentalForceOwningTab\", n = !!t.experimentalForceOwningTab), \n        e ? this.Rd.enableMultiTabIndexedDbPersistence(this) : this.Rd.enableIndexedDbPersistence(this, n);\n    }, e.prototype.clearPersistence = function() {\n        return this.Rd.clearIndexedDbPersistence(this);\n    }, e.prototype.terminate = function() {\n        return this.Pd && (this.Pd._removeServiceInstance(\"firestore\"), this.Pd._removeServiceInstance(\"firestore-exp\")), \n        this.d_._delete();\n    }, e.prototype.waitForPendingWrites = function() {\n        return function(t) {\n            var e = this, n = new fr;\n            return t._s.Ps((function() {\n                return g(e, void 0, void 0, (function() {\n                    var e;\n                    return w(this, (function(r) {\n                        switch (r.label) {\n                          case 0:\n                            return e = Wu, [ 4 /*yield*/ , ka(t) ];\n\n                          case 1:\n                            return [ 2 /*return*/ , e.apply(void 0, [ r.sent(), n ]) ];\n                        }\n                    }));\n                }));\n            })), n.promise;\n        }(qa(Ls(this.d_, Ma)));\n    }, e.prototype.onSnapshotsInSync = function(t) {\n        return function(t, e) {\n            return function(t, e) {\n                var n = this, r = new Ts(e);\n                return t._s.Ps((function() {\n                    return g(n, void 0, void 0, (function() {\n                        var e;\n                        return w(this, (function(n) {\n                            switch (n.label) {\n                              case 0:\n                                return e = function(t, e) {\n                                    O(t).Wh.add(e), \n                                    // Immediately fire an initial event, indicating all existing listeners\n                                    // are in-sync.\n                                    e.next();\n                                }, [ 4 /*yield*/ , Oa(t) ];\n\n                              case 1:\n                                return [ 2 /*return*/ , e.apply(void 0, [ n.sent(), r ]) ];\n                            }\n                        }));\n                    }));\n                })), function() {\n                    r.i_(), t._s.Ps((function() {\n                        return g(n, void 0, void 0, (function() {\n                            var e;\n                            return w(this, (function(n) {\n                                switch (n.label) {\n                                  case 0:\n                                    return e = function(t, e) {\n                                        O(t).Wh.delete(e);\n                                    }, [ 4 /*yield*/ , Oa(t) ];\n\n                                  case 1:\n                                    return [ 2 /*return*/ , e.apply(void 0, [ n.sent(), r ]) ];\n                                }\n                            }));\n                        }));\n                    }));\n                }\n                /**\n * Takes an updateFunction in which a set of reads and writes can be performed\n * atomically. In the updateFunction, the client can read and write values\n * using the supplied transaction object. After the updateFunction, all\n * changes will be committed. If a retryable error occurs (ex: some other\n * client has changed any of the data referenced), then the updateFunction\n * will be called again after a backoff. If the updateFunction still fails\n * after all retries, then the transaction will be rejected.\n *\n * The transaction object passed to the updateFunction contains methods for\n * accessing documents and collections. Unlike other datastore access, data\n * accessed with the transaction will not reflect local changes that have not\n * been committed. For this reason, it is required that all reads are\n * performed before any writes. Transactions must be performed while online.\n */;\n            }(qa(t = Ls(t, Ma)), La(e) ? e : {\n                next: e\n            });\n        }(this.d_, t);\n    }, Object.defineProperty(e.prototype, \"app\", {\n        get: function() {\n            if (!this.Pd) throw new q(M.FAILED_PRECONDITION, \"Firestore was not initialized using the Firebase SDK. 'app' is not available\");\n            return this.Pd;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), e.prototype.collection = function(t) {\n        try {\n            return new Fc(this, Gs(this.d_, t));\n        } catch (t) {\n            throw Pc(t, \"collection()\", \"Firestore.collection()\");\n        }\n    }, e.prototype.doc = function(t) {\n        try {\n            return new Oc(this, Bs(this.d_, t));\n        } catch (t) {\n            throw Pc(t, \"doc()\", \"Firestore.doc()\");\n        }\n    }, e.prototype.collectionGroup = function(t) {\n        try {\n            return new Uc(this, function(t, e) {\n                if (t = Ls(t, qs), xs(\"collectionGroup\", \"collection id\", e), e.indexOf(\"/\") >= 0) throw new q(M.INVALID_ARGUMENT, \"Invalid collection ID '\" + e + \"' passed to function collectionGroup(). Collection IDs must not contain '/'.\");\n                return new js(t, \n                /* converter= */ null, \n                /**\n * Creates a new Query for a collection group query that matches all documents\n * within the provided collection group.\n */\n                function(t) {\n                    return new ee(Z.ct(), t);\n                }(e));\n            }(this.d_, t));\n        } catch (t) {\n            throw Pc(t, \"collectionGroup()\", \"Firestore.collectionGroup()\");\n        }\n    }, e.prototype.runTransaction = function(t) {\n        var e = this;\n        return function(t, e) {\n            return function(t, e) {\n                var n = this, r = new fr;\n                return t._s.Ps((function() {\n                    return g(n, void 0, void 0, (function() {\n                        var n;\n                        return w(this, (function(i) {\n                            switch (i.label) {\n                              case 0:\n                                return [ 4 /*yield*/ , function(t) {\n                                    return Aa(t).then((function(t) {\n                                        return t.Sh;\n                                    }));\n                                }(t) ];\n\n                              case 1:\n                                return n = i.sent(), new _a(t._s, n, e, r).run(), [ 2 /*return*/ ];\n                            }\n                        }));\n                    }));\n                })), r.promise;\n            }(qa(t), (function(n) {\n                return e(new bc(t, n));\n            }));\n        }(this.d_, (function(n) {\n            return t(new Sc(e, n));\n        }));\n    }, e.prototype.batch = function() {\n        var t = this;\n        return qa(this.d_), new xc(new gc(this.d_, (function(e) {\n            return yc(t.d_, e);\n        })));\n    }, e.prototype.loadBundle = function(t) {\n        throw new q(M.FAILED_PRECONDITION, '\"loadBundle()\" does not exist, have you imported \"firebase/firestore/bundle\"?');\n    }, e.prototype.namedQuery = function(t) {\n        throw new q(M.FAILED_PRECONDITION, '\"namedQuery()\" does not exist, have you imported \"firebase/firestore/bundle\"?');\n    }, e;\n}(Ss), Ac = /** @class */ function(t) {\n    function e(e) {\n        var n = this;\n        return (n = t.call(this) || this).firestore = e, n;\n    }\n    return m(e, t), e.prototype.Wf = function(t) {\n        return new Ec(new F(t));\n    }, e.prototype.jf = function(t) {\n        var e = this.Jf(t, this.firestore.I_);\n        return Oc.yd(e, this.firestore, /* converter= */ null);\n    }, e;\n}(Ga);\n\n/**\n * The persistence provider included with the full Firestore SDK.\n */ function Dc(t) {\n    var e;\n    e = t, E.setLogLevel(e);\n}\n\n/**\n * A reference to a transaction.\n */ var Sc = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, n) || this).Yf = e, r.Xf = new Ac(e), r;\n    }\n    return m(e, t), e.prototype.get = function(t) {\n        var e = this, n = jc(t);\n        return this.d_.get(n).then((function(t) {\n            return new Lc(e.Yf, new ac(e.Yf.d_, e.Xf, t.S_, t.Zf, t.metadata, n.v_));\n        }));\n    }, e.prototype.set = function(t, e, n) {\n        var r = jc(t);\n        return n ? (ks(\"Transaction.set\", n), this.d_.set(r, e, n)) : this.d_.set(r, e), \n        this;\n    }, e.prototype.update = function(t, e, n) {\n        for (var r, i = [], o = 3; o < arguments.length; o++) i[o - 3] = arguments[o];\n        var u = jc(t);\n        return 2 === arguments.length ? this.d_.update(u, e) : (r = this.d_).update.apply(r, b([ u, e, n ], i)), \n        this;\n    }, e.prototype.delete = function(t) {\n        var e = jc(t);\n        return this.d_.delete(e), this;\n    }, e;\n}(Ss), xc = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    return m(e, t), e.prototype.set = function(t, e, n) {\n        var r = jc(t);\n        return n ? (ks(\"WriteBatch.set\", n), this.d_.set(r, e, n)) : this.d_.set(r, e), \n        this;\n    }, e.prototype.update = function(t, e, n) {\n        for (var r, i = [], o = 3; o < arguments.length; o++) i[o - 3] = arguments[o];\n        var u = jc(t);\n        return 2 === arguments.length ? this.d_.update(u, e) : (r = this.d_).update.apply(r, b([ u, e, n ], i)), \n        this;\n    }, e.prototype.delete = function(t) {\n        var e = jc(t);\n        return this.d_.delete(e), this;\n    }, e.prototype.commit = function() {\n        return this.d_.commit();\n    }, e;\n}(Ss), kc = /** @class */ function(t) {\n    function e(e, n, r) {\n        var i = this;\n        return (i = t.call(this, r) || this).Yf = e, i.Xf = n, i;\n    }\n    return m(e, t), e.prototype.fromFirestore = function(t, e) {\n        var n = new cc(this.Yf.d_, this.Xf, t.S_, t.Zf, t.metadata, \n        /* converter= */ null);\n        return this.d_.fromFirestore(new Rc(this.Yf, n), null != e ? e : {});\n    }, e.prototype.toFirestore = function(t, e) {\n        return e ? this.d_.toFirestore(t, e) : this.d_.toFirestore(t);\n    }, \n    // Use the same instance of `FirestoreDataConverter` for the given instances\n    // of `Firestore` and `PublicFirestoreDataConverter` so that isEqual() will\n    // compare equal for two objects created with the same converter instance.\n    e.gd = function(t, n) {\n        var r = e.Vd, i = r.get(t);\n        i || (i = new WeakMap, r.set(t, i));\n        var o = i.get(n);\n        return o || (o = new e(t, new Ac(t), n), i.set(n, o)), o;\n    }, e;\n}(Ss);\n\nkc.Vd = new WeakMap;\n\n/**\n * A reference to a particular document in a collection in the database.\n */\nvar Oc = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, n) || this).firestore = e, r.Xf = new Ac(e), r;\n    }\n    return m(e, t), e.pd = function(t, n, r) {\n        if (t.length % 2 != 0) throw new q(M.INVALID_ARGUMENT, \"Invalid document reference. Document references must have an even number of segments, but \" + t.rt() + \" has \" + t.length);\n        return new e(n, new Fs(n.d_, r, new tt(t)));\n    }, e.yd = function(t, n, r) {\n        return new e(n, new Fs(n.d_, r, t));\n    }, Object.defineProperty(e.prototype, \"id\", {\n        get: function() {\n            return this.d_.id;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"parent\", {\n        get: function() {\n            return new Fc(this.firestore, this.d_.parent);\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"path\", {\n        get: function() {\n            return this.d_.path;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), e.prototype.collection = function(t) {\n        try {\n            return new Fc(this.firestore, Gs(this.d_, t));\n        } catch (t) {\n            throw Pc(t, \"collection()\", \"DocumentReference.collection()\");\n        }\n    }, e.prototype.isEqual = function(t) {\n        return t instanceof Ss && (t = t.d_), t instanceof Fs && Qs(this.d_, t);\n    }, e.prototype.set = function(t, e) {\n        e = ks(\"DocumentReference.set\", e);\n        try {\n            return function(t, e, n) {\n                t = Ls(t, Fs);\n                var r = Ls(t.firestore, Ma), i = oc(t.v_, e, n);\n                return yc(r, [ ea(ta(r), \"setDoc\", t.S_, i, null !== t.v_, n).F_(t.S_, Re.Kt()) ]);\n            }(this.d_, t, e);\n        } catch (t) {\n            throw Pc(t, \"setDoc()\", \"DocumentReference.set()\");\n        }\n    }, e.prototype.update = function(t, e) {\n        for (var n = [], r = 2; r < arguments.length; r++) n[r - 2] = arguments[r];\n        try {\n            return 1 === arguments.length ? dc(this.d_, t) : dc.apply(void 0, b([ this.d_, t, e ], n));\n        } catch (t) {\n            throw Pc(t, \"updateDoc()\", \"DocumentReference.update()\");\n        }\n    }, e.prototype.delete = function() {\n        return yc(Ls((t = this.d_).firestore, Ma), [ new Je(t.S_, Re.Kt()) ]);\n        var t;\n        /**\n * Add a new document to specified `CollectionReference` with the given data,\n * assigning it a document ID automatically.\n *\n * @param reference - A reference to the collection to add this document to.\n * @param data - An Object containing the data for the new document.\n * @returns A Promise resolved with a `DocumentReference` pointing to the\n * newly created document after it has been written to the backend (Note that it\n * won't resolve while you're offline).\n */    }, e.prototype.onSnapshot = function() {\n        for (var t = this, e = [], n = 0; n < arguments.length; n++) e[n] = arguments[n];\n        var r = Vc(e), i = Cc(e, (function(e) {\n            return new Lc(t.firestore, new ac(t.firestore.d_, t.Xf, e.S_, e.Zf, e.metadata, t.d_.v_));\n        }));\n        return vc(this.d_, r, i);\n    }, e.prototype.get = function(t) {\n        var e = this;\n        return (\"cache\" === (null == t ? void 0 : t.source) ? function(t) {\n            t = Ls(t, Fs);\n            var e = Ls(t.firestore, Ma), n = qa(e), r = new pc(e);\n            return function(t, e) {\n                var n = this, r = new fr;\n                return t._s.Ps((function() {\n                    return g(n, void 0, void 0, (function() {\n                        var n;\n                        return w(this, (function(i) {\n                            switch (i.label) {\n                              case 0:\n                                return n = function(t, e, n) {\n                                    return g(this, void 0, void 0, (function() {\n                                        var r, i;\n                                        return w(this, (function(o) {\n                                            switch (o.label) {\n                                              case 0:\n                                                return o.trys.push([ 0, 2, , 3 ]), [ 4 /*yield*/ , function(t, e) {\n                                                    var n = O(t);\n                                                    return n.persistence.runTransaction(\"read document\", \"readonly\", (function(t) {\n                                                        return n.Tc.Ho(t, e);\n                                                    }));\n                                                }(t, e) ];\n\n                                              case 1:\n                                                return (i = o.sent()) instanceof Pt ? n.resolve(i) : i instanceof Vt ? n.resolve(null) : n.reject(new q(M.UNAVAILABLE, \"Failed to get document from cache. (However, this document may exist on the server. Run again without setting 'source' in the GetOptions to attempt to retrieve the document from the server.)\")), \n                                                [ 3 /*break*/ , 3 ];\n\n                                              case 2:\n                                                return r = o.sent(), i = Er(r, \"Failed to get document '\" + e + \" from cache\"), \n                                                n.reject(i), [ 3 /*break*/ , 3 ];\n\n                                              case 3:\n                                                return [ 2 /*return*/ ];\n                                            }\n                                        }));\n                                    }));\n                                }, [ 4 /*yield*/ , Sa(t) ];\n\n                              case 1:\n                                return [ 2 /*return*/ , n.apply(void 0, [ i.sent(), e, r ]) ];\n                            }\n                        }));\n                    }));\n                })), r.promise;\n            }(n, t.S_).then((function(n) {\n                return new ac(e, r, t.S_, n, new sc(n instanceof Pt && n.Vt, \n                /* fromCache= */ !0), t.v_);\n            }));\n        }(this.d_) : \"server\" === (null == t ? void 0 : t.source) ? function(t) {\n            t = Ls(t, Fs);\n            var e = Ls(t.firestore, Ma);\n            return Pa(qa(e), t.S_, {\n                source: \"server\"\n            }).then((function(n) {\n                return mc(e, t, n);\n            }));\n        }(this.d_) : function(t) {\n            t = Ls(t, Fs);\n            var e = Ls(t.firestore, Ma);\n            return Pa(qa(e), t.S_).then((function(n) {\n                return mc(e, t, n);\n            }));\n        }(this.d_)).then((function(t) {\n            return new Lc(e.firestore, new ac(e.firestore.d_, e.Xf, t.S_, t.Zf, t.metadata, e.d_.v_));\n        }));\n    }, e.prototype.withConverter = function(t) {\n        return new e(this.firestore, t ? this.d_.withConverter(kc.gd(this.firestore, t)) : this.d_.withConverter(null));\n    }, e;\n}(Ss);\n\n/**\n * Replaces the function name in an error thrown by the firestore-exp API\n * with the function names used in the classic API.\n */ function Pc(t, e, n) {\n    return t.message = t.message.replace(e, n), t\n    /**\n * Iterates the list of arguments from an `onSnapshot` call and returns the\n * first argument that may be an `SnapshotListenOptions` object. Returns an\n * empty object if none is found.\n */;\n}\n\nfunction Vc(t) {\n    for (var e = 0, n = t; e < n.length; e++) {\n        var r = n[e];\n        if (\"object\" == typeof r && !La(r)) return r;\n    }\n    return {};\n}\n\n/**\n * Creates an observer that can be passed to the firestore-exp SDK. The\n * observer converts all observed values into the format expected by the classic\n * SDK.\n *\n * @param args - The list of arguments from an `onSnapshot` call.\n * @param wrapper - The function that converts the firestore-exp type into the\n * type used by this shim.\n */ function Cc(t, e) {\n    var n, r, i;\n    return {\n        next: function(t) {\n            i.next && i.next(e(t));\n        },\n        error: null === (n = (i = La(t[0]) ? t[0] : La(t[1]) ? t[1] : \"function\" == typeof t[0] ? {\n            next: t[0],\n            error: t[1],\n            complete: t[2]\n        } : {\n            next: t[1],\n            error: t[2],\n            complete: t[3]\n        }).error) || void 0 === n ? void 0 : n.bind(i),\n        complete: null === (r = i.complete) || void 0 === r ? void 0 : r.bind(i)\n    };\n}\n\nvar Lc = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, n) || this).Yf = e, r;\n    }\n    return m(e, t), Object.defineProperty(e.prototype, \"ref\", {\n        get: function() {\n            return new Oc(this.Yf, this.d_.ref);\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"id\", {\n        get: function() {\n            return this.d_.id;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"metadata\", {\n        get: function() {\n            return this.d_.metadata;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"exists\", {\n        get: function() {\n            return this.d_.exists();\n        },\n        enumerable: !1,\n        configurable: !0\n    }), e.prototype.data = function(t) {\n        return this.d_.data(t);\n    }, e.prototype.get = function(t, e) {\n        return this.d_.get(t, e);\n    }, e.prototype.isEqual = function(t) {\n        return lc(this.d_, t.d_);\n    }, e;\n}(Ss), Rc = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    return m(e, t), e.prototype.data = function(t) {\n        return this.d_.data(t);\n    }, e;\n}(Lc), Uc = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, n) || this).firestore = e, r.Xf = new Ac(e), r;\n    }\n    return m(e, t), e.prototype.where = function(t, n, r) {\n        try {\n            // The \"as string\" cast is a little bit of a hack. `where` accepts the\n            // FieldPath Compat type as input, but is not typed as such in order to\n            // not expose this via our public typings file.\n            return new e(this.firestore, Xa(this.d_, function(t, e, n) {\n                var r = e, i = Ya(\"where\", t);\n                return new Wa(i, r, n);\n            }(t, n, r)));\n        } catch (t) {\n            throw Pc(t, /(orderBy|where)\\(\\)/, \"Query.$1()\");\n        }\n    }, e.prototype.orderBy = function(t, n) {\n        try {\n            // The \"as string\" cast is a little bit of a hack. `orderBy` accepts the\n            // FieldPath Compat type as input, but is not typed as such in order to\n            // not expose this via our public typings file.\n            return new e(this.firestore, Xa(this.d_, function(t, e) {\n                void 0 === e && (e = \"asc\");\n                var n = e, r = Ya(\"orderBy\", t);\n                return new Za(r, n);\n            }(t, n)));\n        } catch (t) {\n            throw Pc(t, /(orderBy|where)\\(\\)/, \"Query.$1()\");\n        }\n    }, e.prototype.limit = function(t) {\n        try {\n            return new e(this.firestore, Xa(this.d_, function(t) {\n                return Rs(\"limit\", t), new Ja(\"limit\", t, \"F\" /* First */);\n            }(t)));\n        } catch (t) {\n            throw Pc(t, \"limit()\", \"Query.limit()\");\n        }\n    }, e.prototype.limitToLast = function(t) {\n        try {\n            return new e(this.firestore, Xa(this.d_, function(t) {\n                return Rs(\"limitToLast\", t), new Ja(\"limitToLast\", t, \"L\" /* Last */);\n            }(t)));\n        } catch (t) {\n            throw Pc(t, \"limitToLast()\", \"Query.limitToLast()\");\n        }\n    }, e.prototype.startAt = function() {\n        for (var t = [], n = 0; n < arguments.length; n++) t[n] = arguments[n];\n        try {\n            return new e(this.firestore, Xa(this.d_, function() {\n                for (var t = [], e = 0; e < arguments.length; e++) t[e] = arguments[e];\n                return new $a(\"startAt\", t, /*before=*/ !0);\n            }.apply(void 0, t)));\n        } catch (t) {\n            throw Pc(t, \"startAt()\", \"Query.startAt()\");\n        }\n    }, e.prototype.startAfter = function() {\n        for (var t = [], n = 0; n < arguments.length; n++) t[n] = arguments[n];\n        try {\n            return new e(this.firestore, Xa(this.d_, function() {\n                for (var t = [], e = 0; e < arguments.length; e++) t[e] = arguments[e];\n                return new $a(\"startAfter\", t, \n                /*before=*/ !1);\n            }.apply(void 0, t)));\n        } catch (t) {\n            throw Pc(t, \"startAfter()\", \"Query.startAfter()\");\n        }\n    }, e.prototype.endBefore = function() {\n        for (var t = [], n = 0; n < arguments.length; n++) t[n] = arguments[n];\n        try {\n            return new e(this.firestore, Xa(this.d_, function() {\n                for (var t = [], e = 0; e < arguments.length; e++) t[e] = arguments[e];\n                return new tc(\"endBefore\", t, /*before=*/ !0);\n            }.apply(void 0, t)));\n        } catch (t) {\n            throw Pc(t, \"endBefore()\", \"Query.endBefore()\");\n        }\n    }, e.prototype.endAt = function() {\n        for (var t = [], n = 0; n < arguments.length; n++) t[n] = arguments[n];\n        try {\n            return new e(this.firestore, Xa(this.d_, function() {\n                for (var t = [], e = 0; e < arguments.length; e++) t[e] = arguments[e];\n                return new tc(\"endAt\", t, /*before=*/ !1);\n            }.apply(void 0, t)));\n        } catch (t) {\n            throw Pc(t, \"endAt()\", \"Query.endAt()\");\n        }\n    }, e.prototype.isEqual = function(t) {\n        return Ys(this.d_, t.d_);\n    }, e.prototype.get = function(t) {\n        var e = this;\n        return (\"cache\" === (null == t ? void 0 : t.source) ? \n        /**\n     * Executes the query and returns the results as a `QuerySnapshot` from cache.\n     * Returns an error if the document is not currently cached.\n     *\n     * @returns A Promise that will be resolved with the results of the query.\n     */\n        function(t) {\n            t = Ls(t, js);\n            var e = Ls(t.firestore, Ma), n = qa(e), r = new pc(e);\n            return function(t, e) {\n                var n = this, r = new fr;\n                return t._s.Ps((function() {\n                    return g(n, void 0, void 0, (function() {\n                        var n;\n                        return w(this, (function(i) {\n                            switch (i.label) {\n                              case 0:\n                                return n = function(t, e, n) {\n                                    return g(this, void 0, void 0, (function() {\n                                        var r, i, o, u, s;\n                                        return w(this, (function(a) {\n                                            switch (a.label) {\n                                              case 0:\n                                                return a.trys.push([ 0, 2, , 3 ]), [ 4 /*yield*/ , ho(t, e, \n                                                /* usePreviousResults= */ !0) ];\n\n                                              case 1:\n                                                return s = a.sent(), r = new Uu(e, s.Rc), i = r.fl(s.documents), o = r.wi(i, \n                                                /* updateLimboDocuments= */ !1), n.resolve(o.snapshot), [ 3 /*break*/ , 3 ];\n\n                                              case 2:\n                                                return u = a.sent(), s = Er(u, \"Failed to execute query '\" + e + \" against cache\"), \n                                                n.reject(s), [ 3 /*break*/ , 3 ];\n\n                                              case 3:\n                                                return [ 2 /*return*/ ];\n                                            }\n                                        }));\n                                    }));\n                                }, [ 4 /*yield*/ , Sa(t) ];\n\n                              case 1:\n                                return [ 2 /*return*/ , n.apply(void 0, [ i.sent(), e, r ]) ];\n                            }\n                        }));\n                    }));\n                })), r.promise;\n            }(n, t.C_).then((function(n) {\n                return new hc(e, r, t, n);\n            }));\n        }(this.d_) : \"server\" === (null == t ? void 0 : t.source) ? function(t) {\n            t = Ls(t, js);\n            var e = Ls(t.firestore, Ma), n = qa(e), r = new pc(e);\n            return Va(n, t.C_, {\n                source: \"server\"\n            }).then((function(n) {\n                return new hc(e, r, t, n);\n            }));\n        }(this.d_) : function(t) {\n            t = Ls(t, js);\n            var e = Ls(t.firestore, Ma), n = qa(e), r = new pc(e);\n            return Ha(t.C_), Va(n, t.C_).then((function(n) {\n                return new hc(e, r, t, n);\n            }));\n        }(this.d_)).then((function(t) {\n            return new qc(e.firestore, new hc(e.firestore.d_, e.Xf, e.d_, t._d));\n        }));\n    }, e.prototype.onSnapshot = function() {\n        for (var t = this, e = [], n = 0; n < arguments.length; n++) e[n] = arguments[n];\n        var r = Vc(e), i = Cc(e, (function(e) {\n            return new qc(t.firestore, new hc(t.firestore.d_, t.Xf, t.d_, e._d));\n        }));\n        return vc(this.d_, r, i);\n    }, e.prototype.withConverter = function(t) {\n        return new e(this.firestore, t ? this.d_.withConverter(kc.gd(this.firestore, t)) : this.d_.withConverter(null));\n    }, e;\n}(Ss), Mc = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, n) || this).Yf = e, r;\n    }\n    return m(e, t), Object.defineProperty(e.prototype, \"type\", {\n        get: function() {\n            return this.d_.type;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"doc\", {\n        get: function() {\n            return new Rc(this.Yf, this.d_.doc);\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"oldIndex\", {\n        get: function() {\n            return this.d_.oldIndex;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"newIndex\", {\n        get: function() {\n            return this.d_.newIndex;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), e;\n}(Ss), qc = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, n) || this).Yf = e, r;\n    }\n    return m(e, t), Object.defineProperty(e.prototype, \"query\", {\n        get: function() {\n            return new Uc(this.Yf, this.d_.query);\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"metadata\", {\n        get: function() {\n            return this.d_.metadata;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"size\", {\n        get: function() {\n            return this.d_.size;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"empty\", {\n        get: function() {\n            return this.d_.empty;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"docs\", {\n        get: function() {\n            var t = this;\n            return this.d_.docs.map((function(e) {\n                return new Rc(t.Yf, e);\n            }));\n        },\n        enumerable: !1,\n        configurable: !0\n    }), e.prototype.docChanges = function(t) {\n        var e = this;\n        return this.d_.docChanges(t).map((function(t) {\n            return new Mc(e.Yf, t);\n        }));\n    }, e.prototype.forEach = function(t, e) {\n        var n = this;\n        this.d_.forEach((function(r) {\n            t.call(e, new Rc(n.Yf, r));\n        }));\n    }, e.prototype.isEqual = function(t) {\n        return lc(this.d_, t.d_);\n    }, e;\n}(Ss), Fc = /** @class */ function(t) {\n    function e(e, n) {\n        var r = this;\n        return (r = t.call(this, e, n) || this).firestore = e, r.d_ = n, r;\n    }\n    return m(e, t), Object.defineProperty(e.prototype, \"id\", {\n        get: function() {\n            return this.d_.id;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"path\", {\n        get: function() {\n            return this.d_.path;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), Object.defineProperty(e.prototype, \"parent\", {\n        get: function() {\n            var t = this.d_.parent;\n            return t ? new Oc(this.firestore, t) : null;\n        },\n        enumerable: !1,\n        configurable: !0\n    }), e.prototype.doc = function(t) {\n        try {\n            return new Oc(this.firestore, void 0 === t ? Bs(this.d_) : Bs(this.d_, t));\n        } catch (t) {\n            throw Pc(t, \"doc()\", \"CollectionReference.doc()\");\n        }\n    }, e.prototype.add = function(t) {\n        var e = this;\n        return function(t, e) {\n            var n = Ls(t.firestore, Ma), r = Bs(t), i = oc(t.v_, e);\n            return yc(n, [ ea(ta(t.firestore), \"addDoc\", r.S_, i, null !== t.v_, {}).F_(r.S_, Re.exists(!1)) ]).then((function() {\n                return r;\n            }));\n        }(this.d_, t).then((function(t) {\n            return new Oc(e.firestore, t);\n        }));\n    }, e.prototype.isEqual = function(t) {\n        return Qs(this.d_, t.d_);\n    }, e.prototype.withConverter = function(t) {\n        return new e(this.firestore, t ? this.d_.withConverter(kc.gd(this.firestore, t)) : this.d_.withConverter(null));\n    }, e;\n}(Uc);\n\nfunction jc(t) {\n    return t instanceof Ss && (t = t.d_), Ls(t, Fs);\n}\n\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n// The objects that are a part of this API are exposed to third-parties as\n// compiled javascript so we want to flag our private members with a leading\n// underscore to discourage their use.\n/**\n * A `FieldPath` refers to a field in a document. The path may consist of a\n * single field name (referring to a top-level field in the document), or a list\n * of field names (referring to a nested field in the document).\n */ var zc = /** @class */ function(t) {\n    /**\n     * Creates a FieldPath from the provided field names. If more than one field\n     * name is provided, the path will point to a nested field in a document.\n     *\n     * @param fieldNames - A list of field names.\n     */\n    function e() {\n        for (var e = [], n = 0; n < arguments.length; n++) e[n] = arguments[n];\n        return t.call(this, new (As.bind.apply(As, b([ void 0 ], e)))) || this;\n    }\n    return m(e, t), e.documentId = function() {\n        /**\n         * Internal Note: The backend doesn't technically support querying by\n         * document ID. Instead it queries by the entire document name (full path\n         * included), but in the cases we currently support documentId(), the net\n         * effect is the same.\n         */\n        return new e($.ht().rt());\n    }, e.prototype.isEqual = function(t) {\n        return t instanceof Ss && (t = t.d_), t instanceof As && this.d_.f_.isEqual(t.f_);\n    }, e;\n}(Ss), Gc = /** @class */ function(t) {\n    function e() {\n        return null !== t && t.apply(this, arguments) || this;\n    }\n    return m(e, t), e.serverTimestamp = function() {\n        var t = new ia(\"serverTimestamp\");\n        return t._methodName = \"FieldValue.serverTimestamp\", new e(t);\n    }, e.delete = function() {\n        var t = new na(\"deleteField\");\n        return t._methodName = \"FieldValue.delete\", new e(t);\n    }, e.arrayUnion = function() {\n        for (var t = [], n = 0; n < arguments.length; n++) t[n] = arguments[n];\n        var r = \n        /**\n * Returns a special value that can be used with {@link setDoc} or {@link\n * updateDoc} that tells the server to union the given elements with any array\n * value that already exists on the server. Each specified element that doesn't\n * already exist in the array will be added to the end. If the field being\n * modified is not already an array it will be overwritten with an array\n * containing exactly the specified elements.\n *\n * @param elements - The elements to union into the array.\n * @returns The `FieldValue` sentinel for use in a call to `setDoc()` or\n * `updateDoc()`.\n */\n        function() {\n            for (var t = [], e = 0; e < arguments.length; e++) t[e] = arguments[e];\n            // NOTE: We don't actually parse the data until it's used in set() or\n            // update() since we'd need the Firestore instance to do this.\n                        return new oa(\"arrayUnion\", t);\n        }.apply(void 0, t);\n        return r._methodName = \"FieldValue.arrayUnion\", new e(r);\n    }, e.arrayRemove = function() {\n        for (var t = [], n = 0; n < arguments.length; n++) t[n] = arguments[n];\n        var r = function() {\n            for (var t = [], e = 0; e < arguments.length; e++) t[e] = arguments[e];\n            // NOTE: We don't actually parse the data until it's used in set() or\n            // update() since we'd need the Firestore instance to do this.\n                        return new ua(\"arrayRemove\", t);\n        }.apply(void 0, t);\n        return r._methodName = \"FieldValue.arrayRemove\", new e(r);\n    }, e.increment = function(t) {\n        var n = function(t) {\n            return new sa(\"increment\", t);\n        }(t);\n        return n._methodName = \"FieldValue.increment\", new e(n);\n    }, e.prototype.isEqual = function(t) {\n        return this.d_.isEqual(t.d_);\n    }, e;\n}(Ss);\n\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * Returns a sentinel for use with {@link updateDoc} or\n * {@link setDoc} with `{merge: true}` to mark a field for deletion.\n */\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nfunction Bc(t) {\n    /**\n * Loads a Firestore bundle into the local cache.\n *\n * @param firestore - The `Firestore` instance to load bundles for for.\n * @param bundleData - An object representing the bundle to be loaded. Valid objects are\n *   `ArrayBuffer`, `ReadableStream<Uint8Array>` or `string`.\n *\n * @return\n *   A `LoadBundleTask` object, which notifies callers with progress updates, and completion\n *   or error events. It can be used as a `Promise<LoadBundleTaskProgress>`.\n */\n    return function(t, e) {\n        var n = qa(t = Ls(t, Ma)), r = new Ra;\n        return function(t, e, n, r) {\n            var i = this, o = function(t, e) {\n                return function(t, e) {\n                    return new Ns(t, e);\n                }(function(t, e) {\n                    if (t instanceof Uint8Array) return Es(t, e);\n                    if (t instanceof ArrayBuffer) return Es(new Uint8Array(t), e);\n                    if (t instanceof ReadableStream) return t.getReader();\n                    throw new Error(\"Source of `toByteStreamReader` has to be a ArrayBuffer or ReadableStream\");\n                }(\"string\" == typeof t ? (new TextEncoder).encode(t) : t), e);\n            }(n, Bo(e));\n            t._s.Ps((function() {\n                return g(i, void 0, void 0, (function() {\n                    var e;\n                    return w(this, (function(n) {\n                        switch (n.label) {\n                          case 0:\n                            return e = gs, [ 4 /*yield*/ , ka(t) ];\n\n                          case 1:\n                            return e.apply(void 0, [ n.sent(), o, r ]), [ 2 /*return*/ ];\n                        }\n                    }));\n                }));\n            }));\n        }(n, t.I_, e, r), r;\n    }(this.d_, t);\n}\n\nfunction Qc(t) {\n    var e, n, r = this;\n    return (e = this.d_, n = t, function(t, e) {\n        var n = this;\n        return t._s.enqueue((function() {\n            return g(n, void 0, void 0, (function() {\n                var n;\n                return w(this, (function(r) {\n                    switch (r.label) {\n                      case 0:\n                        return n = function(t, e) {\n                            var n = O(t);\n                            return n.persistence.runTransaction(\"Get named query\", \"readonly\", (function(t) {\n                                return n.wo.Ms(t, e);\n                            }));\n                        }, [ 4 /*yield*/ , Sa(t) ];\n\n                      case 1:\n                        return [ 2 /*return*/ , n.apply(void 0, [ r.sent(), e ]) ];\n                    }\n                }));\n            }));\n        }));\n    }(qa(e = Ls(e, Ma)), n).then((function(t) {\n        return t ? new js(e, null, t.query) : null;\n    }))).then((function(t) {\n        return t ? new Uc(r, t) : null;\n    }));\n}\n\nexport { xc as G, Oc as H, K, Ec as L, Nc as Q, Tc as U, Dc as W, Ma as X, Ua as Y, Hs as Z, Lc as a, Bc as b, Gc as c, Uc as e, Fc as i, Sc as j, zc as o, qc as s, Rc as t, Qc as u };\n//# sourceMappingURL=prebuilt-e065c69d-7a321be7.js.map\n","export default function _extends() {\n  _extends = Object.assign || 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\n  return _extends.apply(this, arguments);\n}","import createNamedContext from \"./createNameContext\";\n\nconst historyContext = /*#__PURE__*/ createNamedContext(\"Router-History\");\nexport default historyContext;\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","// 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\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        if (this._isMounted) {\n          this.setState({ location });\n        } else {\n          this._pendingLocation = location;\n        }\n      });\n    }\n  }\n\n  componentDidMount() {\n    this._isMounted = true;\n\n    if (this._pendingLocation) {\n      this.setState({ location: this._pendingLocation });\n    }\n  }\n\n  componentWillUnmount() {\n    if (this.unlisten) this.unlisten();\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) && children.length === 0) {\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 PropTypes from \"prop-types\";\nimport hoistStatics from \"hoist-non-react-statics\";\nimport invariant from \"tiny-invariant\";\n\nimport RouterContext from \"./RouterContext.js\";\n\n/**\n * A public higher-order component to access the imperative API\n */\nfunction withRouter(Component) {\n  const displayName = `withRouter(${Component.displayName || Component.name})`;\n  const C = props => {\n    const { wrappedComponentRef, ...remainingProps } = props;\n\n    return (\n      <RouterContext.Consumer>\n        {context => {\n          invariant(\n            context,\n            `You should not use <${displayName} /> outside a <Router>`\n          );\n          return (\n            <Component\n              {...remainingProps}\n              {...context}\n              ref={wrappedComponentRef}\n            />\n          );\n        }}\n      </RouterContext.Consumer>\n    );\n  };\n\n  C.displayName = displayName;\n  C.WrappedComponent = Component;\n\n  if (__DEV__) {\n    C.propTypes = {\n      wrappedComponentRef: PropTypes.oneOfType([\n        PropTypes.string,\n        PropTypes.func,\n        PropTypes.object\n      ])\n    };\n  }\n\n  return hoistStatics(C, Component);\n}\n\nexport default withRouter;\n","import React from \"react\";\nimport invariant from \"tiny-invariant\";\n\nimport Context 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(Context).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(Context).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(Context).match;\n\n  return path ? matchPath(location.pathname, path) : match;\n}\n","import arrayWithHoles from \"@babel/runtime/helpers/esm/arrayWithHoles\";\nimport iterableToArrayLimit from \"@babel/runtime/helpers/esm/iterableToArrayLimit\";\nimport unsupportedIterableToArray from \"@babel/runtime/helpers/esm/unsupportedIterableToArray\";\nimport nonIterableRest from \"@babel/runtime/helpers/esm/nonIterableRest\";\nexport default function _slicedToArray(arr, i) {\n  return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}","export default function _arrayWithHoles(arr) {\n  if (Array.isArray(arr)) return arr;\n}","export default function _iterableToArrayLimit(arr, i) {\n  if (typeof Symbol === \"undefined\" || !(Symbol.iterator in Object(arr))) return;\n  var _arr = [];\n  var _n = true;\n  var _d = false;\n  var _e = undefined;\n\n  try {\n    for (var _i = arr[Symbol.iterator](), _s; !(_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 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}","/*! *****************************************************************************\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\nfunction __extends(d, b) {\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\nfunction __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}\n\nvar commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};\n\nvar h, goog = goog || {}, k = commonjsGlobal || self;\r\nfunction aa() { }\r\nfunction ba(a) { var b = typeof a; b = \"object\" != b ? b : a ? Array.isArray(a) ? \"array\" : b : \"null\"; return \"array\" == b || \"object\" == b && \"number\" == typeof a.length; }\r\nfunction n(a) { var b = typeof a; return \"object\" == b && null != a || \"function\" == b; }\r\nfunction ca(a) { return Object.prototype.hasOwnProperty.call(a, da) && a[da] || (a[da] = ++ea); }\r\nvar da = \"closure_uid_\" + (1E9 * Math.random() >>> 0), ea = 0;\r\nfunction fa(a, b, c) { return a.call.apply(a.bind, arguments); }\r\nfunction ha(a, b, c) { if (!a)\r\n    throw Error(); if (2 < arguments.length) {\r\n    var d = Array.prototype.slice.call(arguments, 2);\r\n    return function () { var e = Array.prototype.slice.call(arguments); Array.prototype.unshift.apply(e, d); return a.apply(b, e); };\r\n} return function () { return a.apply(b, arguments); }; }\r\nfunction p(a, b, c) { Function.prototype.bind && -1 != Function.prototype.bind.toString().indexOf(\"native code\") ? p = fa : p = ha; return p.apply(null, arguments); }\r\nfunction ja(a, b) { var c = Array.prototype.slice.call(arguments, 1); return function () { var d = c.slice(); d.push.apply(d, arguments); return a.apply(this, d); }; }\r\nfunction q() { return Date.now(); }\r\nfunction r(a, b) { function c() { } c.prototype = b.prototype; a.X = b.prototype; a.prototype = new c; a.prototype.constructor = a; a.Kb = function (d, e, f) { for (var g = Array(arguments.length - 2), m = 2; m < arguments.length; m++)\r\n    g[m - 2] = arguments[m]; return b.prototype[e].apply(d, g); }; }\r\nfunction t() { this.j = this.j; this.i = this.i; }\r\nvar ka = 0;\r\nt.prototype.j = !1;\r\nt.prototype.ja = function () { if (!this.j && (this.j = !0, this.G(), 0 != ka)) {\r\n    var a = ca(this);\r\n} };\r\nt.prototype.G = function () { if (this.i)\r\n    for (; this.i.length;)\r\n        this.i.shift()(); };\r\nvar ma = Array.prototype.indexOf ? function (a, b) { return Array.prototype.indexOf.call(a, b, void 0); } : function (a, b) { if (\"string\" === typeof a)\r\n    return \"string\" !== typeof b || 1 != b.length ? -1 : a.indexOf(b, 0); for (var c = 0; c < a.length; c++)\r\n    if (c in a && a[c] === b)\r\n        return c; return -1; }, na = Array.prototype.forEach ? function (a, b, c) { Array.prototype.forEach.call(a, b, c); } : function (a, b, c) { for (var d = a.length, e = \"string\" === typeof a ? a.split(\"\") : a, f = 0; f < d; f++)\r\n    f in e && b.call(c, e[f], f, a); };\r\nfunction oa(a) { a: {\r\n    var b = pa;\r\n    for (var c = a.length, d = \"string\" === typeof a ? a.split(\"\") : a, e = 0; e < c; e++)\r\n        if (e in d && b.call(void 0, d[e], e, a)) {\r\n            b = e;\r\n            break a;\r\n        }\r\n    b = -1;\r\n} return 0 > b ? null : \"string\" === typeof a ? a.charAt(b) : a[b]; }\r\nfunction qa(a) { return Array.prototype.concat.apply([], arguments); }\r\nfunction ra(a) { var b = a.length; if (0 < b) {\r\n    for (var c = Array(b), d = 0; d < b; d++)\r\n        c[d] = a[d];\r\n    return c;\r\n} return []; }\r\nfunction sa(a) { return /^[\\s\\xa0]*$/.test(a); }\r\nvar ta = String.prototype.trim ? function (a) { return a.trim(); } : function (a) { return /^[\\s\\xa0]*([\\s\\S]*?)[\\s\\xa0]*$/.exec(a)[1]; };\r\nfunction v(a, b) { return -1 != a.indexOf(b); }\r\nfunction ua(a, b) { return a < b ? -1 : a > b ? 1 : 0; }\r\nvar w;\r\na: {\r\n    var va = k.navigator;\r\n    if (va) {\r\n        var wa = va.userAgent;\r\n        if (wa) {\r\n            w = wa;\r\n            break a;\r\n        }\r\n    }\r\n    w = \"\";\r\n}\r\nfunction za(a, b, c) { for (var d in a)\r\n    b.call(c, a[d], d, a); }\r\nfunction Aa(a) { var b = {}; for (var c in a)\r\n    b[c] = a[c]; return b; }\r\nvar Ba = \"constructor hasOwnProperty isPrototypeOf propertyIsEnumerable toLocaleString toString valueOf\".split(\" \");\r\nfunction Ca(a, b) { var c, d; for (var e = 1; e < arguments.length; e++) {\r\n    d = arguments[e];\r\n    for (c in d)\r\n        a[c] = d[c];\r\n    for (var f = 0; f < Ba.length; f++)\r\n        c = Ba[f], Object.prototype.hasOwnProperty.call(d, c) && (a[c] = d[c]);\r\n} }\r\nfunction Da(a) { Da[\" \"](a); return a; }\r\nDa[\" \"] = aa;\r\nfunction Ea(a, b) { var c = Fa; return Object.prototype.hasOwnProperty.call(c, a) ? c[a] : c[a] = b(a); }\r\nvar Ga = v(w, \"Opera\"), x = v(w, \"Trident\") || v(w, \"MSIE\"), Ha = v(w, \"Edge\"), Ia = Ha || x, Ja = v(w, \"Gecko\") && !(v(w.toLowerCase(), \"webkit\") && !v(w, \"Edge\")) && !(v(w, \"Trident\") || v(w, \"MSIE\")) && !v(w, \"Edge\"), Ka = v(w.toLowerCase(), \"webkit\") && !v(w, \"Edge\");\r\nfunction La() { var a = k.document; return a ? a.documentMode : void 0; }\r\nvar Ma;\r\na: {\r\n    var Na = \"\", Oa = function () { var a = w; if (Ja)\r\n        return /rv:([^\\);]+)(\\)|;)/.exec(a); if (Ha)\r\n        return /Edge\\/([\\d\\.]+)/.exec(a); if (x)\r\n        return /\\b(?:MSIE|rv)[: ]([^\\);]+)(\\)|;)/.exec(a); if (Ka)\r\n        return /WebKit\\/(\\S+)/.exec(a); if (Ga)\r\n        return /(?:Version)[ \\/]?(\\S+)/.exec(a); }();\r\n    Oa && (Na = Oa ? Oa[1] : \"\");\r\n    if (x) {\r\n        var Pa = La();\r\n        if (null != Pa && Pa > parseFloat(Na)) {\r\n            Ma = String(Pa);\r\n            break a;\r\n        }\r\n    }\r\n    Ma = Na;\r\n}\r\nvar Fa = {};\r\nfunction Qa(a) { return Ea(a, function () { {\r\n    var b = 0;\r\n    var e = ta(String(Ma)).split(\".\"), f = ta(String(a)).split(\".\"), g = Math.max(e.length, f.length);\r\n    for (var m = 0; 0 == b && m < g; m++) {\r\n        var c = e[m] || \"\", d = f[m] || \"\";\r\n        do {\r\n            c = /(\\d*)(\\D*)(.*)/.exec(c) || [\"\", \"\", \"\", \"\"];\r\n            d = /(\\d*)(\\D*)(.*)/.exec(d) || [\"\", \"\", \"\", \"\"];\r\n            if (0 == c[0].length && 0 == d[0].length)\r\n                break;\r\n            b = ua(0 == c[1].length ? 0 : parseInt(c[1], 10), 0 == d[1].length ? 0 : parseInt(d[1], 10)) || ua(0 == c[2].length, 0 == d[2].length) || ua(c[2], d[2]);\r\n            c = c[3];\r\n            d = d[3];\r\n        } while (0 == b);\r\n    }\r\n} return 0 <= b; }); }\r\nvar Ra;\r\nif (k.document && x) {\r\n    var Sa = La();\r\n    Ra = Sa ? Sa : parseInt(Ma, 10) || void 0;\r\n}\r\nelse\r\n    Ra = void 0;\r\nvar Ta = Ra;\r\nvar Ua = !x || 9 <= Number(Ta), Va = x && !Qa(\"9\"), Wa = function () { if (!k.addEventListener || !Object.defineProperty)\r\n    return !1; var a = !1, b = Object.defineProperty({}, \"passive\", { get: function () { a = !0; } }); try {\r\n    k.addEventListener(\"test\", aa, b), k.removeEventListener(\"test\", aa, b);\r\n}\r\ncatch (c) { } return a; }();\r\nfunction y(a, b) { this.type = a; this.a = this.target = b; this.defaultPrevented = !1; }\r\ny.prototype.b = function () { this.defaultPrevented = !0; };\r\nfunction z(a, b) {\r\n    y.call(this, a ? a.type : \"\");\r\n    this.relatedTarget = this.a = this.target = null;\r\n    this.button = this.screenY = this.screenX = this.clientY = this.clientX = 0;\r\n    this.key = \"\";\r\n    this.metaKey = this.shiftKey = this.altKey = this.ctrlKey = !1;\r\n    this.pointerId = 0;\r\n    this.pointerType = \"\";\r\n    this.c = null;\r\n    if (a) {\r\n        var c = this.type = a.type, d = a.changedTouches && a.changedTouches.length ? a.changedTouches[0] : null;\r\n        this.target = a.target || a.srcElement;\r\n        this.a = b;\r\n        if (b = a.relatedTarget) {\r\n            if (Ja) {\r\n                a: {\r\n                    try {\r\n                        Da(b.nodeName);\r\n                        var e = !0;\r\n                        break a;\r\n                    }\r\n                    catch (f) { }\r\n                    e = !1;\r\n                }\r\n                e || (b = null);\r\n            }\r\n        }\r\n        else\r\n            \"mouseover\" ==\r\n                c ? b = a.fromElement : \"mouseout\" == c && (b = a.toElement);\r\n        this.relatedTarget = b;\r\n        d ? (this.clientX = void 0 !== d.clientX ? d.clientX : d.pageX, this.clientY = void 0 !== d.clientY ? d.clientY : d.pageY, this.screenX = d.screenX || 0, this.screenY = d.screenY || 0) : (this.clientX = void 0 !== a.clientX ? a.clientX : a.pageX, this.clientY = void 0 !== a.clientY ? a.clientY : a.pageY, this.screenX = a.screenX || 0, this.screenY = a.screenY || 0);\r\n        this.button = a.button;\r\n        this.key = a.key || \"\";\r\n        this.ctrlKey = a.ctrlKey;\r\n        this.altKey = a.altKey;\r\n        this.shiftKey = a.shiftKey;\r\n        this.metaKey =\r\n            a.metaKey;\r\n        this.pointerId = a.pointerId || 0;\r\n        this.pointerType = \"string\" === typeof a.pointerType ? a.pointerType : Xa[a.pointerType] || \"\";\r\n        this.c = a;\r\n        a.defaultPrevented && this.b();\r\n    }\r\n}\r\nr(z, y);\r\nvar Xa = { 2: \"touch\", 3: \"pen\", 4: \"mouse\" };\r\nz.prototype.b = function () { z.X.b.call(this); var a = this.c; if (a.preventDefault)\r\n    a.preventDefault();\r\nelse if (a.returnValue = !1, Va)\r\n    try {\r\n        if (a.ctrlKey || 112 <= a.keyCode && 123 >= a.keyCode)\r\n            a.keyCode = -1;\r\n    }\r\n    catch (b) { } };\r\nvar A = \"closure_listenable_\" + (1E6 * Math.random() | 0), Ya = 0;\r\nfunction Za(a, b, c, d, e) { this.listener = a; this.proxy = null; this.src = b; this.type = c; this.capture = !!d; this.ca = e; this.key = ++Ya; this.Y = this.Z = !1; }\r\nfunction $a(a) { a.Y = !0; a.listener = null; a.proxy = null; a.src = null; a.ca = null; }\r\nfunction ab(a) { this.src = a; this.a = {}; this.b = 0; }\r\nab.prototype.add = function (a, b, c, d, e) { var f = a.toString(); a = this.a[f]; a || (a = this.a[f] = [], this.b++); var g = bb(a, b, d, e); -1 < g ? (b = a[g], c || (b.Z = !1)) : (b = new Za(b, this.src, f, !!d, e), b.Z = c, a.push(b)); return b; };\r\nfunction cb(a, b) { var c = b.type; if (c in a.a) {\r\n    var d = a.a[c], e = ma(d, b), f;\r\n    (f = 0 <= e) && Array.prototype.splice.call(d, e, 1);\r\n    f && ($a(b), 0 == a.a[c].length && (delete a.a[c], a.b--));\r\n} }\r\nfunction bb(a, b, c, d) { for (var e = 0; e < a.length; ++e) {\r\n    var f = a[e];\r\n    if (!f.Y && f.listener == b && f.capture == !!c && f.ca == d)\r\n        return e;\r\n} return -1; }\r\nvar db = \"closure_lm_\" + (1E6 * Math.random() | 0), eb = {};\r\nfunction gb(a, b, c, d, e) { if (d && d.once)\r\n    return hb(a, b, c, d, e); if (Array.isArray(b)) {\r\n    for (var f = 0; f < b.length; f++)\r\n        gb(a, b[f], c, d, e);\r\n    return null;\r\n} c = ib(c); return a && a[A] ? a.va(b, c, n(d) ? !!d.capture : !!d, e) : jb(a, b, c, !1, d, e); }\r\nfunction jb(a, b, c, d, e, f) {\r\n    if (!b)\r\n        throw Error(\"Invalid event type\");\r\n    var g = n(e) ? !!e.capture : !!e;\r\n    if (g && !Ua)\r\n        return null;\r\n    var m = kb(a);\r\n    m || (a[db] = m = new ab(a));\r\n    c = m.add(b, c, d, g, f);\r\n    if (c.proxy)\r\n        return c;\r\n    d = lb();\r\n    c.proxy = d;\r\n    d.src = a;\r\n    d.listener = c;\r\n    if (a.addEventListener)\r\n        Wa || (e = g), void 0 === e && (e = !1), a.addEventListener(b.toString(), d, e);\r\n    else if (a.attachEvent)\r\n        a.attachEvent(mb(b.toString()), d);\r\n    else if (a.addListener && a.removeListener)\r\n        a.addListener(d);\r\n    else\r\n        throw Error(\"addEventListener and attachEvent are unavailable.\");\r\n    return c;\r\n}\r\nfunction lb() { var a = nb, b = Ua ? function (c) { return a.call(b.src, b.listener, c); } : function (c) { c = a.call(b.src, b.listener, c); if (!c)\r\n    return c; }; return b; }\r\nfunction hb(a, b, c, d, e) { if (Array.isArray(b)) {\r\n    for (var f = 0; f < b.length; f++)\r\n        hb(a, b[f], c, d, e);\r\n    return null;\r\n} c = ib(c); return a && a[A] ? a.wa(b, c, n(d) ? !!d.capture : !!d, e) : jb(a, b, c, !0, d, e); }\r\nfunction ob(a, b, c, d, e) { if (Array.isArray(b))\r\n    for (var f = 0; f < b.length; f++)\r\n        ob(a, b[f], c, d, e);\r\nelse\r\n    (d = n(d) ? !!d.capture : !!d, c = ib(c), a && a[A]) ? (a = a.c, b = String(b).toString(), b in a.a && (f = a.a[b], c = bb(f, c, d, e), -1 < c && ($a(f[c]), Array.prototype.splice.call(f, c, 1), 0 == f.length && (delete a.a[b], a.b--)))) : a && (a = kb(a)) && (b = a.a[b.toString()], a = -1, b && (a = bb(b, c, d, e)), (c = -1 < a ? b[a] : null) && pb(c)); }\r\nfunction pb(a) { if (\"number\" !== typeof a && a && !a.Y) {\r\n    var b = a.src;\r\n    if (b && b[A])\r\n        cb(b.c, a);\r\n    else {\r\n        var c = a.type, d = a.proxy;\r\n        b.removeEventListener ? b.removeEventListener(c, d, a.capture) : b.detachEvent ? b.detachEvent(mb(c), d) : b.addListener && b.removeListener && b.removeListener(d);\r\n        (c = kb(b)) ? (cb(c, a), 0 == c.b && (c.src = null, b[db] = null)) : $a(a);\r\n    }\r\n} }\r\nfunction mb(a) { return a in eb ? eb[a] : eb[a] = \"on\" + a; }\r\nfunction qb(a, b) { var c = a.listener, d = a.ca || a.src; a.Z && pb(a); return c.call(d, b); }\r\nfunction nb(a, b) { if (a.Y)\r\n    return !0; if (!Ua) {\r\n    if (!b)\r\n        a: {\r\n            b = [\"window\", \"event\"];\r\n            for (var c = k, d = 0; d < b.length; d++)\r\n                if (c = c[b[d]], null == c) {\r\n                    b = null;\r\n                    break a;\r\n                }\r\n            b = c;\r\n        }\r\n    b = new z(b, this);\r\n    return qb(a, b);\r\n} return qb(a, new z(b, this)); }\r\nfunction kb(a) { a = a[db]; return a instanceof ab ? a : null; }\r\nvar sb = \"__closure_events_fn_\" + (1E9 * Math.random() >>> 0);\r\nfunction ib(a) { if (\"function\" === typeof a)\r\n    return a; a[sb] || (a[sb] = function (b) { return a.handleEvent(b); }); return a[sb]; }\r\nfunction D() { t.call(this); this.c = new ab(this); this.J = this; this.C = null; }\r\nr(D, t);\r\nD.prototype[A] = !0;\r\nh = D.prototype;\r\nh.addEventListener = function (a, b, c, d) { gb(this, a, b, c, d); };\r\nh.removeEventListener = function (a, b, c, d) { ob(this, a, b, c, d); };\r\nfunction E(a, b) { var c, d = a.C; if (d)\r\n    for (c = []; d; d = d.C)\r\n        c.push(d); a = a.J; d = b.type || b; if (\"string\" === typeof b)\r\n    b = new y(b, a);\r\nelse if (b instanceof y)\r\n    b.target = b.target || a;\r\nelse {\r\n    var e = b;\r\n    b = new y(d, a);\r\n    Ca(b, e);\r\n} e = !0; if (c)\r\n    for (var f = c.length - 1; 0 <= f; f--) {\r\n        var g = b.a = c[f];\r\n        e = tb(g, d, !0, b) && e;\r\n    } g = b.a = a; e = tb(g, d, !0, b) && e; e = tb(g, d, !1, b) && e; if (c)\r\n    for (f = 0; f < c.length; f++)\r\n        g = b.a = c[f], e = tb(g, d, !1, b) && e; }\r\nh.G = function () { D.X.G.call(this); if (this.c) {\r\n    var a = this.c, c;\r\n    for (c in a.a) {\r\n        for (var d = a.a[c], e = 0; e < d.length; e++)\r\n            $a(d[e]);\r\n        delete a.a[c];\r\n        a.b--;\r\n    }\r\n} this.C = null; };\r\nh.va = function (a, b, c, d) { return this.c.add(String(a), b, !1, c, d); };\r\nh.wa = function (a, b, c, d) { return this.c.add(String(a), b, !0, c, d); };\r\nfunction tb(a, b, c, d) { b = a.c.a[String(b)]; if (!b)\r\n    return !0; b = b.concat(); for (var e = !0, f = 0; f < b.length; ++f) {\r\n    var g = b[f];\r\n    if (g && !g.Y && g.capture == c) {\r\n        var m = g.listener, l = g.ca || g.src;\r\n        g.Z && cb(a.c, g);\r\n        e = !1 !== m.call(l, d) && e;\r\n    }\r\n} return e && !d.defaultPrevented; }\r\nvar ub = k.JSON.stringify;\r\nfunction vb() { this.b = this.a = null; }\r\nvar xb = new /** @class */ (function () {\r\n    function class_1(a, b) {\r\n        this.c = a;\r\n        this.f = b;\r\n        this.b = 0;\r\n        this.a = null;\r\n    }\r\n    class_1.prototype.get = function () { var a; 0 < this.b ? (this.b--, a = this.a, this.a = a.next, a.next = null) : a = this.c(); return a; };\r\n    return class_1;\r\n}())(function () { return new wb; }, function (a) { a.reset(); });\r\nvb.prototype.add = function (a, b) { var c = xb.get(); c.set(a, b); this.b ? this.b.next = c : this.a = c; this.b = c; };\r\nfunction yb() { var a = zb, b = null; a.a && (b = a.a, a.a = a.a.next, a.a || (a.b = null), b.next = null); return b; }\r\nfunction wb() { this.next = this.b = this.a = null; }\r\nwb.prototype.set = function (a, b) { this.a = a; this.b = b; this.next = null; };\r\nwb.prototype.reset = function () { this.next = this.b = this.a = null; };\r\nfunction Ab(a) { k.setTimeout(function () { throw a; }, 0); }\r\nfunction Bb(a, b) { Cb || Db(); Eb || (Cb(), Eb = !0); zb.add(a, b); }\r\nvar Cb;\r\nfunction Db() { var a = k.Promise.resolve(void 0); Cb = function () { a.then(Fb); }; }\r\nvar Eb = !1, zb = new vb;\r\nfunction Fb() { for (var a; a = yb();) {\r\n    try {\r\n        a.a.call(a.b);\r\n    }\r\n    catch (c) {\r\n        Ab(c);\r\n    }\r\n    var b = xb;\r\n    b.f(a);\r\n    100 > b.b && (b.b++, a.next = b.a, b.a = a);\r\n} Eb = !1; }\r\nfunction Gb(a, b) { D.call(this); this.b = a || 1; this.a = b || k; this.f = p(this.Za, this); this.g = q(); }\r\nr(Gb, D);\r\nh = Gb.prototype;\r\nh.aa = !1;\r\nh.M = null;\r\nh.Za = function () { if (this.aa) {\r\n    var a = q() - this.g;\r\n    0 < a && a < .8 * this.b ? this.M = this.a.setTimeout(this.f, this.b - a) : (this.M && (this.a.clearTimeout(this.M), this.M = null), E(this, \"tick\"), this.aa && (Hb(this), this.start()));\r\n} };\r\nh.start = function () { this.aa = !0; this.M || (this.M = this.a.setTimeout(this.f, this.b), this.g = q()); };\r\nfunction Hb(a) { a.aa = !1; a.M && (a.a.clearTimeout(a.M), a.M = null); }\r\nh.G = function () { Gb.X.G.call(this); Hb(this); delete this.a; };\r\nfunction Ib(a, b, c) { if (\"function\" === typeof a)\r\n    c && (a = p(a, c));\r\nelse if (a && \"function\" == typeof a.handleEvent)\r\n    a = p(a.handleEvent, a);\r\nelse\r\n    throw Error(\"Invalid listener argument\"); return 2147483647 < Number(b) ? -1 : k.setTimeout(a, b || 0); }\r\nfunction Jb(a) { a.a = Ib(function () { a.a = null; a.c && (a.c = !1, Jb(a)); }, a.h); var b = a.b; a.b = null; a.g.apply(null, b); }\r\nvar Kb = /** @class */ (function (_super) {\r\n    __extends(Kb, _super);\r\n    function Kb(a, b) {\r\n        var _this = _super.call(this) || this;\r\n        _this.g = a;\r\n        _this.h = b;\r\n        _this.b = null;\r\n        _this.c = !1;\r\n        _this.a = null;\r\n        return _this;\r\n    }\r\n    Kb.prototype.f = function (a) { this.b = arguments; this.a ? this.c = !0 : Jb(this); };\r\n    Kb.prototype.G = function () { _super.prototype.G.call(this); this.a && (k.clearTimeout(this.a), this.a = null, this.c = !1, this.b = null); };\r\n    return Kb;\r\n}(t));\r\nfunction F(a) { t.call(this); this.b = a; this.a = {}; }\r\nr(F, t);\r\nvar Lb = [];\r\nfunction Mb(a, b, c, d) { Array.isArray(c) || (c && (Lb[0] = c.toString()), c = Lb); for (var e = 0; e < c.length; e++) {\r\n    var f = gb(b, c[e], d || a.handleEvent, !1, a.b || a);\r\n    if (!f)\r\n        break;\r\n    a.a[f.key] = f;\r\n} }\r\nfunction Nb(a) { za(a.a, function (b, c) { this.a.hasOwnProperty(c) && pb(b); }, a); a.a = {}; }\r\nF.prototype.G = function () { F.X.G.call(this); Nb(this); };\r\nF.prototype.handleEvent = function () { throw Error(\"EventHandler.handleEvent not implemented\"); };\r\nfunction Ob() { this.a = !0; }\r\nfunction Pb(a, b, c, d, e, f) { a.info(function () { if (a.a)\r\n    if (f) {\r\n        var g = \"\";\r\n        for (var m = f.split(\"&\"), l = 0; l < m.length; l++) {\r\n            var u = m[l].split(\"=\");\r\n            if (1 < u.length) {\r\n                var C = u[0];\r\n                u = u[1];\r\n                var B = C.split(\"_\");\r\n                g = 2 <= B.length && \"type\" == B[1] ? g + (C + \"=\" + u + \"&\") : g + (C + \"=redacted&\");\r\n            }\r\n        }\r\n    }\r\n    else\r\n        g = null;\r\nelse\r\n    g = f; return \"XMLHTTP REQ (\" + d + \") [attempt \" + e + \"]: \" + b + \"\\n\" + c + \"\\n\" + g; }); }\r\nfunction Qb(a, b, c, d, e, f, g) { a.info(function () { return \"XMLHTTP RESP (\" + d + \") [ attempt \" + e + \"]: \" + b + \"\\n\" + c + \"\\n\" + f + \" \" + g; }); }\r\nfunction G(a, b, c, d) { a.info(function () { return \"XMLHTTP TEXT (\" + b + \"): \" + Rb(a, c) + (d ? \" \" + d : \"\"); }); }\r\nfunction Sb(a, b) { a.info(function () { return \"TIMEOUT: \" + b; }); }\r\nOb.prototype.info = function () { };\r\nfunction Rb(a, b) { if (!a.a)\r\n    return b; if (!b)\r\n    return null; try {\r\n    var c = JSON.parse(b);\r\n    if (c)\r\n        for (a = 0; a < c.length; a++)\r\n            if (Array.isArray(c[a])) {\r\n                var d = c[a];\r\n                if (!(2 > d.length)) {\r\n                    var e = d[1];\r\n                    if (Array.isArray(e) && !(1 > e.length)) {\r\n                        var f = e[0];\r\n                        if (\"noop\" != f && \"stop\" != f && \"close\" != f)\r\n                            for (var g = 1; g < e.length; g++)\r\n                                e[g] = \"\";\r\n                    }\r\n                }\r\n            }\r\n    return ub(c);\r\n}\r\ncatch (m) {\r\n    return b;\r\n} }\r\nvar H = {}, Tb = null;\r\nfunction Ub() { return Tb = Tb || new D; }\r\nH.Fa = \"serverreachability\";\r\nfunction Vb(a) { y.call(this, H.Fa, a); }\r\nr(Vb, y);\r\nfunction I(a) { var b = Ub(); E(b, new Vb(b, a)); }\r\nH.STAT_EVENT = \"statevent\";\r\nfunction Wb(a, b) { y.call(this, H.STAT_EVENT, a); this.stat = b; }\r\nr(Wb, y);\r\nfunction J(a) { var b = Ub(); E(b, new Wb(b, a)); }\r\nH.Ga = \"timingevent\";\r\nfunction Xb(a) { y.call(this, H.Ga, a); }\r\nr(Xb, y);\r\nfunction K(a, b) { if (\"function\" !== typeof a)\r\n    throw Error(\"Fn must not be null and must be a function\"); return k.setTimeout(function () { a(); }, b); }\r\nvar Yb = { NO_ERROR: 0, $a: 1, nb: 2, mb: 3, hb: 4, lb: 5, ob: 6, Da: 7, TIMEOUT: 8, rb: 9 };\r\nvar Zb = { fb: \"complete\", Bb: \"success\", Ea: \"error\", Da: \"abort\", tb: \"ready\", ub: \"readystatechange\", TIMEOUT: \"timeout\", pb: \"incrementaldata\", sb: \"progress\", ib: \"downloadprogress\", Jb: \"uploadprogress\" };\r\nfunction $b() { }\r\n$b.prototype.a = null;\r\nfunction ac(a) { var b; (b = a.a) || (b = a.a = {}); return b; }\r\nfunction bc() { }\r\nvar L = { OPEN: \"a\", eb: \"b\", Ea: \"c\", qb: \"d\" };\r\nfunction cc() { y.call(this, \"d\"); }\r\nr(cc, y);\r\nfunction dc() { y.call(this, \"c\"); }\r\nr(dc, y);\r\nvar ec;\r\nfunction fc() { }\r\nr(fc, $b);\r\nec = new fc;\r\nfunction M(a, b, c, d) { this.g = a; this.c = b; this.f = c; this.S = d || 1; this.J = new F(this); this.P = gc; a = Ia ? 125 : void 0; this.R = new Gb(a); this.B = null; this.b = !1; this.j = this.l = this.i = this.H = this.u = this.T = this.o = null; this.s = []; this.a = null; this.D = 0; this.h = this.m = null; this.N = -1; this.A = !1; this.O = 0; this.F = null; this.V = this.C = this.U = this.I = !1; }\r\nvar gc = 45E3, hc = {}, ic = {};\r\nh = M.prototype;\r\nh.setTimeout = function (a) { this.P = a; };\r\nfunction jc(a, b, c) { a.H = 1; a.i = kc(N(b)); a.j = c; a.I = !0; lc(a, null); }\r\nfunction lc(a, b) { a.u = q(); mc(a); a.l = N(a.i); var c = a.l, d = a.S; Array.isArray(d) || (d = [String(d)]); nc(c.b, \"t\", d); a.D = 0; a.a = oc(a.g, a.g.C ? b : null); 0 < a.O && (a.F = new Kb(p(a.Ca, a, a.a), a.O)); Mb(a.J, a.a, \"readystatechange\", a.Xa); b = a.B ? Aa(a.B) : {}; a.j ? (a.m || (a.m = \"POST\"), b[\"Content-Type\"] = \"application/x-www-form-urlencoded\", a.a.ba(a.l, a.m, a.j, b)) : (a.m = \"GET\", a.a.ba(a.l, a.m, null, b)); I(1); Pb(a.c, a.m, a.l, a.f, a.S, a.j); }\r\nh.Xa = function (a) { a = a.target; var b = this.F; b && 3 == O(a) ? b.f() : this.Ca(a); };\r\nh.Ca = function (a) {\r\n    try {\r\n        if (a == this.a)\r\n            a: {\r\n                var b = O(this.a), c = this.a.ua(), d = this.a.W();\r\n                if (!(3 > b || 3 == b && !Ia && !this.a.$())) {\r\n                    this.A || 4 != b || 7 == c || (8 == c || 0 >= d ? I(3) : I(2));\r\n                    pc(this);\r\n                    var e = this.a.W();\r\n                    this.N = e;\r\n                    var f = this.a.$();\r\n                    this.b = 200 == e;\r\n                    Qb(this.c, this.m, this.l, this.f, this.S, b, e);\r\n                    if (this.b) {\r\n                        if (this.U && !this.C) {\r\n                            b: {\r\n                                if (this.a) {\r\n                                    var g, m = this.a;\r\n                                    if ((g = m.a ? m.a.getResponseHeader(\"X-HTTP-Initial-Response\") : null) && !sa(g)) {\r\n                                        var l = g;\r\n                                        break b;\r\n                                    }\r\n                                }\r\n                                l = null;\r\n                            }\r\n                            if (l)\r\n                                G(this.c, this.f, l, \"Initial handshake response via X-HTTP-Initial-Response\"),\r\n                                    this.C = !0, qc(this, l);\r\n                            else {\r\n                                this.b = !1;\r\n                                this.h = 3;\r\n                                J(12);\r\n                                P(this);\r\n                                rc(this);\r\n                                break a;\r\n                            }\r\n                        }\r\n                        this.I ? (sc(this, b, f), Ia && this.b && 3 == b && (Mb(this.J, this.R, \"tick\", this.Wa), this.R.start())) : (G(this.c, this.f, f, null), qc(this, f));\r\n                        4 == b && P(this);\r\n                        this.b && !this.A && (4 == b ? uc(this.g, this) : (this.b = !1, mc(this)));\r\n                    }\r\n                    else\r\n                        400 == e && 0 < f.indexOf(\"Unknown SID\") ? (this.h = 3, J(12)) : (this.h = 0, J(13)), P(this), rc(this);\r\n                }\r\n            }\r\n    }\r\n    catch (u) { }\r\n    finally { }\r\n};\r\nfunction sc(a, b, c) { for (var d = !0; !a.A && a.D < c.length;) {\r\n    var e = vc(a, c);\r\n    if (e == ic) {\r\n        4 == b && (a.h = 4, J(14), d = !1);\r\n        G(a.c, a.f, null, \"[Incomplete Response]\");\r\n        break;\r\n    }\r\n    else if (e == hc) {\r\n        a.h = 4;\r\n        J(15);\r\n        G(a.c, a.f, c, \"[Invalid Chunk]\");\r\n        d = !1;\r\n        break;\r\n    }\r\n    else\r\n        G(a.c, a.f, e, null), qc(a, e);\r\n} 4 == b && 0 == c.length && (a.h = 1, J(16), d = !1); a.b = a.b && d; d ? 0 < c.length && !a.V && (a.V = !0, b = a.g, b.a == a && b.U && !b.F && (b.c.info(\"Great, no buffering proxy detected. Bytes received: \" + c.length), wc(b), b.F = !0, J(11))) : (G(a.c, a.f, c, \"[Invalid Chunked Response]\"), P(a), rc(a)); }\r\nh.Wa = function () { if (this.a) {\r\n    var a = O(this.a), b = this.a.$();\r\n    this.D < b.length && (pc(this), sc(this, a, b), this.b && 4 != a && mc(this));\r\n} };\r\nfunction vc(a, b) { var c = a.D, d = b.indexOf(\"\\n\", c); if (-1 == d)\r\n    return ic; c = Number(b.substring(c, d)); if (isNaN(c))\r\n    return hc; d += 1; if (d + c > b.length)\r\n    return ic; b = b.substr(d, c); a.D = d + c; return b; }\r\nh.cancel = function () { this.A = !0; P(this); };\r\nfunction mc(a) { a.T = q() + a.P; yc(a, a.P); }\r\nfunction yc(a, b) { if (null != a.o)\r\n    throw Error(\"WatchDog timer not null\"); a.o = K(p(a.Va, a), b); }\r\nfunction pc(a) { a.o && (k.clearTimeout(a.o), a.o = null); }\r\nh.Va = function () { this.o = null; var a = q(); 0 <= a - this.T ? (Sb(this.c, this.l), 2 != this.H && (I(3), J(17)), P(this), this.h = 2, rc(this)) : yc(this, this.T - a); };\r\nfunction rc(a) { 0 == a.g.v || a.A || uc(a.g, a); }\r\nfunction P(a) { pc(a); var b = a.F; b && \"function\" == typeof b.ja && b.ja(); a.F = null; Hb(a.R); Nb(a.J); a.a && (b = a.a, a.a = null, b.abort(), b.ja()); }\r\nfunction qc(a, b) {\r\n    try {\r\n        var c = a.g;\r\n        if (0 != c.v && (c.a == a || zc(c.b, a)))\r\n            if (c.I = a.N, !a.C && zc(c.b, a) && 3 == c.v) {\r\n                try {\r\n                    var d = c.ka.a.parse(b);\r\n                }\r\n                catch (tc) {\r\n                    d = null;\r\n                }\r\n                if (Array.isArray(d) && 3 == d.length) {\r\n                    var e = d;\r\n                    if (0 == e[0])\r\n                        a: {\r\n                            if (!c.j) {\r\n                                if (c.a)\r\n                                    if (c.a.u + 3E3 < a.u)\r\n                                        Ac(c), Bc(c);\r\n                                    else\r\n                                        break a;\r\n                                Cc(c);\r\n                                J(18);\r\n                            }\r\n                        }\r\n                    else\r\n                        c.oa = e[1], 0 < c.oa - c.P && 37500 > e[2] && c.H && 0 == c.o && !c.m && (c.m = K(p(c.Sa, c), 6E3));\r\n                    if (1 >= Dc(c.b) && c.ea) {\r\n                        try {\r\n                            c.ea();\r\n                        }\r\n                        catch (tc) { }\r\n                        c.ea = void 0;\r\n                    }\r\n                }\r\n                else\r\n                    Q(c, 11);\r\n            }\r\n            else if ((a.C || c.a == a) && Ac(c), !sa(b))\r\n                for (b = d = c.ka.a.parse(b), d = 0; d < b.length; d++)\r\n                    if (e =\r\n                        b[d], c.P = e[0], e = e[1], 2 == c.v)\r\n                        if (\"c\" == e[0]) {\r\n                            c.J = e[1];\r\n                            c.ga = e[2];\r\n                            var f = e[3];\r\n                            null != f && (c.ha = f, c.c.info(\"VER=\" + c.ha));\r\n                            var g = e[4];\r\n                            null != g && (c.pa = g, c.c.info(\"SVER=\" + c.pa));\r\n                            var m = e[5];\r\n                            if (null != m && \"number\" === typeof m && 0 < m) {\r\n                                var l = 1.5 * m;\r\n                                c.D = l;\r\n                                c.c.info(\"backChannelRequestTimeoutMs_=\" + l);\r\n                            }\r\n                            l = c;\r\n                            var u = a.a;\r\n                            if (u) {\r\n                                var C = u.a ? u.a.getResponseHeader(\"X-Client-Wire-Protocol\") : null;\r\n                                if (C) {\r\n                                    var B = l.b;\r\n                                    !B.a && (v(C, \"spdy\") || v(C, \"quic\") || v(C, \"h2\")) && (B.f = B.g, B.a = new Set, B.b && (Ec(B, B.b), B.b = null));\r\n                                }\r\n                                if (l.A) {\r\n                                    var rb = u.a ? u.a.getResponseHeader(\"X-HTTP-Session-Id\") :\r\n                                        null;\r\n                                    rb && (l.na = rb, R(l.B, l.A, rb));\r\n                                }\r\n                            }\r\n                            c.v = 3;\r\n                            c.f && c.f.ta();\r\n                            c.U && (c.N = q() - a.u, c.c.info(\"Handshake RTT: \" + c.N + \"ms\"));\r\n                            l = c;\r\n                            var xa = a;\r\n                            l.la = Fc(l, l.C ? l.ga : null, l.fa);\r\n                            if (xa.C) {\r\n                                Gc(l.b, xa);\r\n                                var ya = xa, xc = l.D;\r\n                                xc && ya.setTimeout(xc);\r\n                                ya.o && (pc(ya), mc(ya));\r\n                                l.a = xa;\r\n                            }\r\n                            else\r\n                                Hc(l);\r\n                            0 < c.g.length && Ic(c);\r\n                        }\r\n                        else\r\n                            \"stop\" != e[0] && \"close\" != e[0] || Q(c, 7);\r\n                    else\r\n                        3 == c.v && (\"stop\" == e[0] || \"close\" == e[0] ? \"stop\" == e[0] ? Q(c, 7) : Jc(c) : \"noop\" != e[0] && c.f && c.f.sa(e), c.o = 0);\r\n        I(4);\r\n    }\r\n    catch (tc) { }\r\n}\r\nfunction Kc(a) { if (a.K && \"function\" == typeof a.K)\r\n    return a.K(); if (\"string\" === typeof a)\r\n    return a.split(\"\"); if (ba(a)) {\r\n    for (var b = [], c = a.length, d = 0; d < c; d++)\r\n        b.push(a[d]);\r\n    return b;\r\n} b = []; c = 0; for (d in a)\r\n    b[c++] = a[d]; return a = b; }\r\nfunction Lc(a, b) { if (a.forEach && \"function\" == typeof a.forEach)\r\n    a.forEach(b, void 0);\r\nelse if (ba(a) || \"string\" === typeof a)\r\n    na(a, b, void 0);\r\nelse {\r\n    if (a.L && \"function\" == typeof a.L)\r\n        var c = a.L();\r\n    else if (a.K && \"function\" == typeof a.K)\r\n        c = void 0;\r\n    else if (ba(a) || \"string\" === typeof a) {\r\n        c = [];\r\n        for (var d = a.length, e = 0; e < d; e++)\r\n            c.push(e);\r\n    }\r\n    else\r\n        for (e in c = [], d = 0, a)\r\n            c[d++] = e;\r\n    d = Kc(a);\r\n    e = d.length;\r\n    for (var f = 0; f < e; f++)\r\n        b.call(void 0, d[f], c && c[f], a);\r\n} }\r\nfunction S(a, b) { this.b = {}; this.a = []; this.c = 0; var c = arguments.length; if (1 < c) {\r\n    if (c % 2)\r\n        throw Error(\"Uneven number of arguments\");\r\n    for (var d = 0; d < c; d += 2)\r\n        this.set(arguments[d], arguments[d + 1]);\r\n}\r\nelse if (a)\r\n    if (a instanceof S)\r\n        for (c = a.L(), d = 0; d < c.length; d++)\r\n            this.set(c[d], a.get(c[d]));\r\n    else\r\n        for (d in a)\r\n            this.set(d, a[d]); }\r\nh = S.prototype;\r\nh.K = function () { Mc(this); for (var a = [], b = 0; b < this.a.length; b++)\r\n    a.push(this.b[this.a[b]]); return a; };\r\nh.L = function () { Mc(this); return this.a.concat(); };\r\nfunction Mc(a) { if (a.c != a.a.length) {\r\n    for (var b = 0, c = 0; b < a.a.length;) {\r\n        var d = a.a[b];\r\n        T(a.b, d) && (a.a[c++] = d);\r\n        b++;\r\n    }\r\n    a.a.length = c;\r\n} if (a.c != a.a.length) {\r\n    var e = {};\r\n    for (c = b = 0; b < a.a.length;)\r\n        d = a.a[b], T(e, d) || (a.a[c++] = d, e[d] = 1), b++;\r\n    a.a.length = c;\r\n} }\r\nh.get = function (a, b) { return T(this.b, a) ? this.b[a] : b; };\r\nh.set = function (a, b) { T(this.b, a) || (this.c++, this.a.push(a)); this.b[a] = b; };\r\nh.forEach = function (a, b) { for (var c = this.L(), d = 0; d < c.length; d++) {\r\n    var e = c[d], f = this.get(e);\r\n    a.call(b, f, e, this);\r\n} };\r\nfunction T(a, b) { return Object.prototype.hasOwnProperty.call(a, b); }\r\nvar Nc = /^(?:([^:/?#.]+):)?(?:\\/\\/(?:([^\\\\/?#]*)@)?([^\\\\/?#]*?)(?::([0-9]+))?(?=[\\\\/?#]|$))?([^?#]+)?(?:\\?([^#]*))?(?:#([\\s\\S]*))?$/;\r\nfunction Oc(a, b) { if (a) {\r\n    a = a.split(\"&\");\r\n    for (var c = 0; c < a.length; c++) {\r\n        var d = a[c].indexOf(\"=\"), e = null;\r\n        if (0 <= d) {\r\n            var f = a[c].substring(0, d);\r\n            e = a[c].substring(d + 1);\r\n        }\r\n        else\r\n            f = a[c];\r\n        b(f, e ? decodeURIComponent(e.replace(/\\+/g, \" \")) : \"\");\r\n    }\r\n} }\r\nfunction U(a, b) { this.c = this.j = this.f = \"\"; this.h = null; this.i = this.g = \"\"; this.a = !1; if (a instanceof U) {\r\n    this.a = void 0 !== b ? b : a.a;\r\n    Pc(this, a.f);\r\n    this.j = a.j;\r\n    Qc(this, a.c);\r\n    Rc(this, a.h);\r\n    this.g = a.g;\r\n    b = a.b;\r\n    var c = new Sc;\r\n    c.c = b.c;\r\n    b.a && (c.a = new S(b.a), c.b = b.b);\r\n    Tc(this, c);\r\n    this.i = a.i;\r\n}\r\nelse\r\n    a && (c = String(a).match(Nc)) ? (this.a = !!b, Pc(this, c[1] || \"\", !0), this.j = Uc(c[2] || \"\"), Qc(this, c[3] || \"\", !0), Rc(this, c[4]), this.g = Uc(c[5] || \"\", !0), Tc(this, c[6] || \"\", !0), this.i = Uc(c[7] || \"\")) : (this.a = !!b, this.b = new Sc(null, this.a)); }\r\nU.prototype.toString = function () { var a = [], b = this.f; b && a.push(Vc(b, Wc, !0), \":\"); var c = this.c; if (c || \"file\" == b)\r\n    a.push(\"//\"), (b = this.j) && a.push(Vc(b, Wc, !0), \"@\"), a.push(encodeURIComponent(String(c)).replace(/%25([0-9a-fA-F]{2})/g, \"%$1\")), c = this.h, null != c && a.push(\":\", String(c)); if (c = this.g)\r\n    this.c && \"/\" != c.charAt(0) && a.push(\"/\"), a.push(Vc(c, \"/\" == c.charAt(0) ? Xc : Yc, !0)); (c = this.b.toString()) && a.push(\"?\", c); (c = this.i) && a.push(\"#\", Vc(c, Zc)); return a.join(\"\"); };\r\nfunction N(a) { return new U(a); }\r\nfunction Pc(a, b, c) { a.f = c ? Uc(b, !0) : b; a.f && (a.f = a.f.replace(/:$/, \"\")); }\r\nfunction Qc(a, b, c) { a.c = c ? Uc(b, !0) : b; }\r\nfunction Rc(a, b) { if (b) {\r\n    b = Number(b);\r\n    if (isNaN(b) || 0 > b)\r\n        throw Error(\"Bad port number \" + b);\r\n    a.h = b;\r\n}\r\nelse\r\n    a.h = null; }\r\nfunction Tc(a, b, c) { b instanceof Sc ? (a.b = b, $c(a.b, a.a)) : (c || (b = Vc(b, ad)), a.b = new Sc(b, a.a)); }\r\nfunction R(a, b, c) { a.b.set(b, c); }\r\nfunction kc(a) { R(a, \"zx\", Math.floor(2147483648 * Math.random()).toString(36) + Math.abs(Math.floor(2147483648 * Math.random()) ^ q()).toString(36)); return a; }\r\nfunction bd(a) { return a instanceof U ? N(a) : new U(a, void 0); }\r\nfunction cd(a, b, c, d) { var e = new U(null, void 0); a && Pc(e, a); b && Qc(e, b); c && Rc(e, c); d && (e.g = d); return e; }\r\nfunction Uc(a, b) { return a ? b ? decodeURI(a.replace(/%25/g, \"%2525\")) : decodeURIComponent(a) : \"\"; }\r\nfunction Vc(a, b, c) { return \"string\" === typeof a ? (a = encodeURI(a).replace(b, dd), c && (a = a.replace(/%25([0-9a-fA-F]{2})/g, \"%$1\")), a) : null; }\r\nfunction dd(a) { a = a.charCodeAt(0); return \"%\" + (a >> 4 & 15).toString(16) + (a & 15).toString(16); }\r\nvar Wc = /[#\\/\\?@]/g, Yc = /[#\\?:]/g, Xc = /[#\\?]/g, ad = /[#\\?@]/g, Zc = /#/g;\r\nfunction Sc(a, b) { this.b = this.a = null; this.c = a || null; this.f = !!b; }\r\nfunction V(a) { a.a || (a.a = new S, a.b = 0, a.c && Oc(a.c, function (b, c) { a.add(decodeURIComponent(b.replace(/\\+/g, \" \")), c); })); }\r\nh = Sc.prototype;\r\nh.add = function (a, b) { V(this); this.c = null; a = W(this, a); var c = this.a.get(a); c || this.a.set(a, c = []); c.push(b); this.b += 1; return this; };\r\nfunction ed(a, b) { V(a); b = W(a, b); T(a.a.b, b) && (a.c = null, a.b -= a.a.get(b).length, a = a.a, T(a.b, b) && (delete a.b[b], a.c--, a.a.length > 2 * a.c && Mc(a))); }\r\nfunction fd(a, b) { V(a); b = W(a, b); return T(a.a.b, b); }\r\nh.forEach = function (a, b) { V(this); this.a.forEach(function (c, d) { na(c, function (e) { a.call(b, e, d, this); }, this); }, this); };\r\nh.L = function () { V(this); for (var a = this.a.K(), b = this.a.L(), c = [], d = 0; d < b.length; d++)\r\n    for (var e = a[d], f = 0; f < e.length; f++)\r\n        c.push(b[d]); return c; };\r\nh.K = function (a) { V(this); var b = []; if (\"string\" === typeof a)\r\n    fd(this, a) && (b = qa(b, this.a.get(W(this, a))));\r\nelse {\r\n    a = this.a.K();\r\n    for (var c = 0; c < a.length; c++)\r\n        b = qa(b, a[c]);\r\n} return b; };\r\nh.set = function (a, b) { V(this); this.c = null; a = W(this, a); fd(this, a) && (this.b -= this.a.get(a).length); this.a.set(a, [b]); this.b += 1; return this; };\r\nh.get = function (a, b) { if (!a)\r\n    return b; a = this.K(a); return 0 < a.length ? String(a[0]) : b; };\r\nfunction nc(a, b, c) { ed(a, b); 0 < c.length && (a.c = null, a.a.set(W(a, b), ra(c)), a.b += c.length); }\r\nh.toString = function () { if (this.c)\r\n    return this.c; if (!this.a)\r\n    return \"\"; for (var a = [], b = this.a.L(), c = 0; c < b.length; c++) {\r\n    var d = b[c], e = encodeURIComponent(String(d));\r\n    d = this.K(d);\r\n    for (var f = 0; f < d.length; f++) {\r\n        var g = e;\r\n        \"\" !== d[f] && (g += \"=\" + encodeURIComponent(String(d[f])));\r\n        a.push(g);\r\n    }\r\n} return this.c = a.join(\"&\"); };\r\nfunction W(a, b) { b = String(b); a.f && (b = b.toLowerCase()); return b; }\r\nfunction $c(a, b) { b && !a.f && (V(a), a.c = null, a.a.forEach(function (c, d) { var e = d.toLowerCase(); d != e && (ed(this, d), nc(this, e, c)); }, a)); a.f = b; }\r\nvar gd = /** @class */ (function () {\r\n    function gd(a, b) {\r\n        this.b = a;\r\n        this.a = b;\r\n    }\r\n    return gd;\r\n}());\r\nfunction hd(a) { this.g = a || id; k.PerformanceNavigationTiming ? (a = k.performance.getEntriesByType(\"navigation\"), a = 0 < a.length && (\"hq\" == a[0].nextHopProtocol || \"h2\" == a[0].nextHopProtocol)) : a = !!(k.ia && k.ia.ya && k.ia.ya() && k.ia.ya().Lb); this.f = a ? this.g : 1; this.a = null; 1 < this.f && (this.a = new Set); this.b = null; this.c = []; }\r\nvar id = 10;\r\nfunction jd(a) { return a.b ? !0 : a.a ? a.a.size >= a.f : !1; }\r\nfunction Dc(a) { return a.b ? 1 : a.a ? a.a.size : 0; }\r\nfunction zc(a, b) { return a.b ? a.b == b : a.a ? a.a.has(b) : !1; }\r\nfunction Ec(a, b) { a.a ? a.a.add(b) : a.b = b; }\r\nfunction Gc(a, b) { a.b && a.b == b ? a.b = null : a.a && a.a.has(b) && a.a.delete(b); }\r\nhd.prototype.cancel = function () {\r\n    var e_1, _a;\r\n    this.c = kd(this);\r\n    if (this.b)\r\n        this.b.cancel(), this.b = null;\r\n    else if (this.a && 0 !== this.a.size) {\r\n        try {\r\n            for (var _b = __values(this.a.values()), _c = _b.next(); !_c.done; _c = _b.next()) {\r\n                var a = _c.value;\r\n                a.cancel();\r\n            }\r\n        }\r\n        catch (e_1_1) { e_1 = { error: e_1_1 }; }\r\n        finally {\r\n            try {\r\n                if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\r\n            }\r\n            finally { if (e_1) throw e_1.error; }\r\n        }\r\n        this.a.clear();\r\n    }\r\n};\r\nfunction kd(a) {\r\n    var e_2, _a;\r\n    if (null != a.b)\r\n        return a.c.concat(a.b.s);\r\n    if (null != a.a && 0 !== a.a.size) {\r\n        var b = a.c;\r\n        try {\r\n            for (var _b = __values(a.a.values()), _c = _b.next(); !_c.done; _c = _b.next()) {\r\n                var c = _c.value;\r\n                b = b.concat(c.s);\r\n            }\r\n        }\r\n        catch (e_2_1) { e_2 = { error: e_2_1 }; }\r\n        finally {\r\n            try {\r\n                if (_c && !_c.done && (_a = _b.return)) _a.call(_b);\r\n            }\r\n            finally { if (e_2) throw e_2.error; }\r\n        }\r\n        return b;\r\n    }\r\n    return ra(a.c);\r\n}\r\nfunction ld() { }\r\nld.prototype.stringify = function (a) { return k.JSON.stringify(a, void 0); };\r\nld.prototype.parse = function (a) { return k.JSON.parse(a, void 0); };\r\nfunction md() { this.a = new ld; }\r\nfunction nd(a, b, c) { var d = c || \"\"; try {\r\n    Lc(a, function (e, f) { var g = e; n(e) && (g = ub(e)); b.push(d + f + \"=\" + encodeURIComponent(g)); });\r\n}\r\ncatch (e) {\r\n    throw b.push(d + \"type=\" + encodeURIComponent(\"_badmap\")), e;\r\n} }\r\nfunction od(a, b) { var c = new Ob; if (k.Image) {\r\n    var d = new Image;\r\n    d.onload = ja(pd, c, d, \"TestLoadImage: loaded\", !0, b);\r\n    d.onerror = ja(pd, c, d, \"TestLoadImage: error\", !1, b);\r\n    d.onabort = ja(pd, c, d, \"TestLoadImage: abort\", !1, b);\r\n    d.ontimeout = ja(pd, c, d, \"TestLoadImage: timeout\", !1, b);\r\n    k.setTimeout(function () { if (d.ontimeout)\r\n        d.ontimeout(); }, 1E4);\r\n    d.src = a;\r\n}\r\nelse\r\n    b(!1); }\r\nfunction pd(a, b, c, d, e) { try {\r\n    b.onload = null, b.onerror = null, b.onabort = null, b.ontimeout = null, e(d);\r\n}\r\ncatch (f) { } }\r\nvar qd = k.JSON.parse;\r\nfunction X(a) { D.call(this); this.headers = new S; this.H = a || null; this.b = !1; this.s = this.a = null; this.B = \"\"; this.h = 0; this.f = \"\"; this.g = this.A = this.l = this.u = !1; this.o = 0; this.m = null; this.I = rd; this.D = this.F = !1; }\r\nr(X, D);\r\nvar rd = \"\", sd = /^https?$/i, td = [\"POST\", \"PUT\"];\r\nh = X.prototype;\r\nh.ba = function (a, b, c, d) {\r\n    if (this.a)\r\n        throw Error(\"[goog.net.XhrIo] Object is active with another request=\" + this.B + \"; newUri=\" + a);\r\n    b = b ? b.toUpperCase() : \"GET\";\r\n    this.B = a;\r\n    this.f = \"\";\r\n    this.h = 0;\r\n    this.u = !1;\r\n    this.b = !0;\r\n    this.a = new XMLHttpRequest;\r\n    this.s = this.H ? ac(this.H) : ac(ec);\r\n    this.a.onreadystatechange = p(this.za, this);\r\n    try {\r\n        this.A = !0, this.a.open(b, String(a), !0), this.A = !1;\r\n    }\r\n    catch (f) {\r\n        ud(this, f);\r\n        return;\r\n    }\r\n    a = c || \"\";\r\n    var e = new S(this.headers);\r\n    d && Lc(d, function (f, g) { e.set(g, f); });\r\n    d = oa(e.L());\r\n    c = k.FormData && a instanceof k.FormData;\r\n    !(0 <=\r\n        ma(td, b)) || d || c || e.set(\"Content-Type\", \"application/x-www-form-urlencoded;charset=utf-8\");\r\n    e.forEach(function (f, g) { this.a.setRequestHeader(g, f); }, this);\r\n    this.I && (this.a.responseType = this.I);\r\n    \"withCredentials\" in this.a && this.a.withCredentials !== this.F && (this.a.withCredentials = this.F);\r\n    try {\r\n        vd(this), 0 < this.o && ((this.D = wd(this.a)) ? (this.a.timeout = this.o, this.a.ontimeout = p(this.xa, this)) : this.m = Ib(this.xa, this.o, this)), this.l = !0, this.a.send(a), this.l = !1;\r\n    }\r\n    catch (f) {\r\n        ud(this, f);\r\n    }\r\n};\r\nfunction wd(a) { return x && Qa(9) && \"number\" === typeof a.timeout && void 0 !== a.ontimeout; }\r\nfunction pa(a) { return \"content-type\" == a.toLowerCase(); }\r\nh.xa = function () { \"undefined\" != typeof goog && this.a && (this.f = \"Timed out after \" + this.o + \"ms, aborting\", this.h = 8, E(this, \"timeout\"), this.abort(8)); };\r\nfunction ud(a, b) { a.b = !1; a.a && (a.g = !0, a.a.abort(), a.g = !1); a.f = b; a.h = 5; xd(a); yd(a); }\r\nfunction xd(a) { a.u || (a.u = !0, E(a, \"complete\"), E(a, \"error\")); }\r\nh.abort = function (a) { this.a && this.b && (this.b = !1, this.g = !0, this.a.abort(), this.g = !1, this.h = a || 7, E(this, \"complete\"), E(this, \"abort\"), yd(this)); };\r\nh.G = function () { this.a && (this.b && (this.b = !1, this.g = !0, this.a.abort(), this.g = !1), yd(this, !0)); X.X.G.call(this); };\r\nh.za = function () { this.j || (this.A || this.l || this.g ? zd(this) : this.Ua()); };\r\nh.Ua = function () { zd(this); };\r\nfunction zd(a) {\r\n    if (a.b && \"undefined\" != typeof goog && (!a.s[1] || 4 != O(a) || 2 != a.W()))\r\n        if (a.l && 4 == O(a))\r\n            Ib(a.za, 0, a);\r\n        else if (E(a, \"readystatechange\"), 4 == O(a)) {\r\n            a.b = !1;\r\n            try {\r\n                {\r\n                    var l = a.W();\r\n                    a: switch (l) {\r\n                        case 200:\r\n                        case 201:\r\n                        case 202:\r\n                        case 204:\r\n                        case 206:\r\n                        case 304:\r\n                        case 1223:\r\n                            var b = !0;\r\n                            break a;\r\n                        default: b = !1;\r\n                    }\r\n                    var c;\r\n                    if (!(c = b)) {\r\n                        var d;\r\n                        if (d = 0 === l) {\r\n                            var e = String(a.B).match(Nc)[1] || null;\r\n                            if (!e && k.self && k.self.location) {\r\n                                var f = k.self.location.protocol;\r\n                                e = f.substr(0, f.length - 1);\r\n                            }\r\n                            d = !sd.test(e ? e.toLowerCase() : \"\");\r\n                        }\r\n                        c = d;\r\n                    }\r\n                    var g = c;\r\n                }\r\n                if (g)\r\n                    E(a, \"complete\"),\r\n                        E(a, \"success\");\r\n                else {\r\n                    a.h = 6;\r\n                    try {\r\n                        var m = 2 < O(a) ? a.a.statusText : \"\";\r\n                    }\r\n                    catch (l) {\r\n                        m = \"\";\r\n                    }\r\n                    a.f = m + \" [\" + a.W() + \"]\";\r\n                    xd(a);\r\n                }\r\n            }\r\n            finally {\r\n                yd(a);\r\n            }\r\n        }\r\n}\r\nfunction yd(a, b) { if (a.a) {\r\n    vd(a);\r\n    var c = a.a, d = a.s[0] ? aa : null;\r\n    a.a = null;\r\n    a.s = null;\r\n    b || E(a, \"ready\");\r\n    try {\r\n        c.onreadystatechange = d;\r\n    }\r\n    catch (e) { }\r\n} }\r\nfunction vd(a) { a.a && a.D && (a.a.ontimeout = null); a.m && (k.clearTimeout(a.m), a.m = null); }\r\nfunction O(a) { return a.a ? a.a.readyState : 0; }\r\nh.W = function () { try {\r\n    return 2 < O(this) ? this.a.status : -1;\r\n}\r\ncatch (a) {\r\n    return -1;\r\n} };\r\nh.$ = function () { try {\r\n    return this.a ? this.a.responseText : \"\";\r\n}\r\ncatch (a) {\r\n    return \"\";\r\n} };\r\nh.Pa = function (a) { if (this.a) {\r\n    var b = this.a.responseText;\r\n    a && 0 == b.indexOf(a) && (b = b.substring(a.length));\r\n    return qd(b);\r\n} };\r\nh.ua = function () { return this.h; };\r\nh.Qa = function () { return \"string\" === typeof this.f ? this.f : String(this.f); };\r\nfunction Ad(a) { var b = \"\"; za(a, function (c, d) { b += d; b += \":\"; b += c; b += \"\\r\\n\"; }); return b; }\r\nfunction Bd(a, b, c) { a: {\r\n    for (d in c) {\r\n        var d = !1;\r\n        break a;\r\n    }\r\n    d = !0;\r\n} d || (c = Ad(c), \"string\" === typeof a ? (null != c && encodeURIComponent(String(c))) : R(a, b, c)); }\r\nfunction Cd(a, b, c) { return c && c.internalChannelParams ? c.internalChannelParams[a] || b : b; }\r\nfunction Dd(a) {\r\n    this.pa = 0;\r\n    this.g = [];\r\n    this.c = new Ob;\r\n    this.ga = this.la = this.B = this.fa = this.a = this.na = this.A = this.V = this.i = this.O = this.l = null;\r\n    this.Oa = this.R = 0;\r\n    this.La = Cd(\"failFast\", !1, a);\r\n    this.H = this.m = this.j = this.h = this.f = null;\r\n    this.S = !0;\r\n    this.I = this.oa = this.P = -1;\r\n    this.T = this.o = this.u = 0;\r\n    this.Ha = Cd(\"baseRetryDelayMs\", 5E3, a);\r\n    this.Ra = Cd(\"retryDelaySeedMs\", 1E4, a);\r\n    this.Ma = Cd(\"forwardChannelMaxRetries\", 2, a);\r\n    this.ma = Cd(\"forwardChannelRequestTimeoutMs\", 2E4, a);\r\n    this.Na = a && a.g || void 0;\r\n    this.D = void 0;\r\n    this.C = a && a.supportsCrossDomainXhr ||\r\n        !1;\r\n    this.J = \"\";\r\n    this.b = new hd(a && a.concurrentRequestLimit);\r\n    this.ka = new md;\r\n    this.da = a && a.fastHandshake || !1;\r\n    this.Ia = a && a.b || !1;\r\n    a && a.f && (this.c.a = !1);\r\n    a && a.forceLongPolling && (this.S = !1);\r\n    this.U = !this.da && this.S && a && a.detectBufferingProxy || !1;\r\n    this.ea = void 0;\r\n    this.N = 0;\r\n    this.F = !1;\r\n    this.s = null;\r\n    (this.Ka = a && a.c || !1) && this.c.info(\"Opt-in to enable Chrome Origin Trials.\");\r\n}\r\nh = Dd.prototype;\r\nh.ha = 8;\r\nh.v = 1;\r\nfunction Jc(a) { Ed(a); if (3 == a.v) {\r\n    var b = a.R++, c = N(a.B);\r\n    R(c, \"SID\", a.J);\r\n    R(c, \"RID\", b);\r\n    R(c, \"TYPE\", \"terminate\");\r\n    Fd(a, c);\r\n    b = new M(a, a.c, b, void 0);\r\n    b.H = 2;\r\n    b.i = kc(N(c));\r\n    c = !1;\r\n    k.navigator && k.navigator.sendBeacon && (c = k.navigator.sendBeacon(b.i.toString(), \"\"));\r\n    !c && k.Image && ((new Image).src = b.i, c = !0);\r\n    c || (b.a = oc(b.g, null), b.a.ba(b.i));\r\n    b.u = q();\r\n    mc(b);\r\n} Gd(a); }\r\nfunction Bc(a) { a.a && (wc(a), a.a.cancel(), a.a = null); }\r\nfunction Ed(a) { Bc(a); a.j && (k.clearTimeout(a.j), a.j = null); Ac(a); a.b.cancel(); a.h && (\"number\" === typeof a.h && k.clearTimeout(a.h), a.h = null); }\r\nfunction Hd(a, b) { a.g.push(new gd(a.Oa++, b)); 3 == a.v && Ic(a); }\r\nfunction Ic(a) { jd(a.b) || a.h || (a.h = !0, Bb(a.Ba, a), a.u = 0); }\r\nfunction Id(a, b) { if (Dc(a.b) >= a.b.f - (a.h ? 1 : 0))\r\n    return !1; if (a.h)\r\n    return a.g = b.s.concat(a.g), !0; if (1 == a.v || 2 == a.v || a.u >= (a.La ? 0 : a.Ma))\r\n    return !1; a.h = K(p(a.Ba, a, b), Jd(a, a.u)); a.u++; return !0; }\r\nh.Ba = function (a) {\r\n    if (this.h)\r\n        if (this.h = null, 1 == this.v) {\r\n            if (!a) {\r\n                this.R = Math.floor(1E5 * Math.random());\r\n                a = this.R++;\r\n                var b = new M(this, this.c, a, void 0), c = this.l;\r\n                this.O && (c ? (c = Aa(c), Ca(c, this.O)) : c = this.O);\r\n                null === this.i && (b.B = c);\r\n                var d;\r\n                if (this.da)\r\n                    a: {\r\n                        for (var e = d = 0; e < this.g.length; e++) {\r\n                            b: {\r\n                                var f = this.g[e];\r\n                                if (\"__data__\" in f.a && (f = f.a.__data__, \"string\" === typeof f)) {\r\n                                    f = f.length;\r\n                                    break b;\r\n                                }\r\n                                f = void 0;\r\n                            }\r\n                            if (void 0 === f)\r\n                                break;\r\n                            d += f;\r\n                            if (4096 < d) {\r\n                                d = e;\r\n                                break a;\r\n                            }\r\n                            if (4096 === d || e === this.g.length - 1) {\r\n                                d = e + 1;\r\n                                break a;\r\n                            }\r\n                        }\r\n                        d = 1E3;\r\n                    }\r\n                else\r\n                    d = 1E3;\r\n                d = Kd(this, b, d);\r\n                e = N(this.B);\r\n                R(e, \"RID\", a);\r\n                R(e, \"CVER\", 22);\r\n                this.A && R(e, \"X-HTTP-Session-Id\", this.A);\r\n                Fd(this, e);\r\n                this.i && c && Bd(e, this.i, c);\r\n                Ec(this.b, b);\r\n                this.Ia && R(e, \"TYPE\", \"init\");\r\n                this.da ? (R(e, \"$req\", d), R(e, \"SID\", \"null\"), b.U = !0, jc(b, e, null)) : jc(b, e, d);\r\n                this.v = 2;\r\n            }\r\n        }\r\n        else\r\n            3 == this.v && (a ? Ld(this, a) : 0 == this.g.length || jd(this.b) || Ld(this));\r\n};\r\nfunction Ld(a, b) { var c; b ? c = b.f : c = a.R++; var d = N(a.B); R(d, \"SID\", a.J); R(d, \"RID\", c); R(d, \"AID\", a.P); Fd(a, d); a.i && a.l && Bd(d, a.i, a.l); c = new M(a, a.c, c, a.u + 1); null === a.i && (c.B = a.l); b && (a.g = b.s.concat(a.g)); b = Kd(a, c, 1E3); c.setTimeout(Math.round(.5 * a.ma) + Math.round(.5 * a.ma * Math.random())); Ec(a.b, c); jc(c, d, b); }\r\nfunction Fd(a, b) { a.f && Lc({}, function (c, d) { R(b, d, c); }); }\r\nfunction Kd(a, b, c) { c = Math.min(a.g.length, c); var d = a.f ? p(a.f.Ja, a.f, a) : null; a: for (var e = a.g, f = -1;;) {\r\n    var g = [\"count=\" + c];\r\n    -1 == f ? 0 < c ? (f = e[0].b, g.push(\"ofs=\" + f)) : f = 0 : g.push(\"ofs=\" + f);\r\n    for (var m = !0, l = 0; l < c; l++) {\r\n        var u = e[l].b, C = e[l].a;\r\n        u -= f;\r\n        if (0 > u)\r\n            f = Math.max(0, e[l].b - 100), m = !1;\r\n        else\r\n            try {\r\n                nd(C, g, \"req\" + u + \"_\");\r\n            }\r\n            catch (B) {\r\n                d && d(C);\r\n            }\r\n    }\r\n    if (m) {\r\n        d = g.join(\"&\");\r\n        break a;\r\n    }\r\n} a = a.g.splice(0, c); b.s = a; return d; }\r\nfunction Hc(a) { a.a || a.j || (a.T = 1, Bb(a.Aa, a), a.o = 0); }\r\nfunction Cc(a) { if (a.a || a.j || 3 <= a.o)\r\n    return !1; a.T++; a.j = K(p(a.Aa, a), Jd(a, a.o)); a.o++; return !0; }\r\nh.Aa = function () { this.j = null; Md(this); if (this.U && !(this.F || null == this.a || 0 >= this.N)) {\r\n    var a = 2 * this.N;\r\n    this.c.info(\"BP detection timer enabled: \" + a);\r\n    this.s = K(p(this.Ta, this), a);\r\n} };\r\nh.Ta = function () { this.s && (this.s = null, this.c.info(\"BP detection timeout reached.\"), this.c.info(\"Buffering proxy detected and switch to long-polling!\"), this.H = !1, this.F = !0, J(10), Bc(this), Md(this)); };\r\nfunction wc(a) { null != a.s && (k.clearTimeout(a.s), a.s = null); }\r\nfunction Md(a) { a.a = new M(a, a.c, \"rpc\", a.T); null === a.i && (a.a.B = a.l); a.a.O = 0; var b = N(a.la); R(b, \"RID\", \"rpc\"); R(b, \"SID\", a.J); R(b, \"CI\", a.H ? \"0\" : \"1\"); R(b, \"AID\", a.P); Fd(a, b); R(b, \"TYPE\", \"xmlhttp\"); a.i && a.l && Bd(b, a.i, a.l); a.D && a.a.setTimeout(a.D); var c = a.a; a = a.ga; c.H = 1; c.i = kc(N(b)); c.j = null; c.I = !0; lc(c, a); }\r\nh.Sa = function () { null != this.m && (this.m = null, Bc(this), Cc(this), J(19)); };\r\nfunction Ac(a) { null != a.m && (k.clearTimeout(a.m), a.m = null); }\r\nfunction uc(a, b) { var c = null; if (a.a == b) {\r\n    Ac(a);\r\n    wc(a);\r\n    a.a = null;\r\n    var d = 2;\r\n}\r\nelse if (zc(a.b, b))\r\n    c = b.s, Gc(a.b, b), d = 1;\r\nelse\r\n    return; a.I = b.N; if (0 != a.v)\r\n    if (b.b)\r\n        if (1 == d) {\r\n            c = b.j ? b.j.length : 0;\r\n            b = q() - b.u;\r\n            var e = a.u;\r\n            d = Ub();\r\n            E(d, new Xb(d, c, b, e));\r\n            Ic(a);\r\n        }\r\n        else\r\n            Hc(a);\r\n    else if (e = b.h, 3 == e || 0 == e && 0 < a.I || !(1 == d && Id(a, b) || 2 == d && Cc(a)))\r\n        switch (c && 0 < c.length && (b = a.b, b.c = b.c.concat(c)), e) {\r\n            case 1:\r\n                Q(a, 5);\r\n                break;\r\n            case 4:\r\n                Q(a, 10);\r\n                break;\r\n            case 3:\r\n                Q(a, 6);\r\n                break;\r\n            default: Q(a, 2);\r\n        } }\r\nfunction Jd(a, b) { var c = a.Ha + Math.floor(Math.random() * a.Ra); a.f || (c *= 2); return c * b; }\r\nfunction Q(a, b) { a.c.info(\"Error code \" + b); if (2 == b) {\r\n    var c = null;\r\n    a.f && (c = null);\r\n    var d = p(a.Ya, a);\r\n    c || (c = new U(\"//www.google.com/images/cleardot.gif\"), k.location && \"http\" == k.location.protocol || Pc(c, \"https\"), kc(c));\r\n    od(c.toString(), d);\r\n}\r\nelse\r\n    J(2); a.v = 0; a.f && a.f.ra(b); Gd(a); Ed(a); }\r\nh.Ya = function (a) { a ? (this.c.info(\"Successfully pinged google.com\"), J(2)) : (this.c.info(\"Failed to ping google.com\"), J(1)); };\r\nfunction Gd(a) { a.v = 0; a.I = -1; if (a.f) {\r\n    if (0 != kd(a.b).length || 0 != a.g.length)\r\n        a.b.c.length = 0, ra(a.g), a.g.length = 0;\r\n    a.f.qa();\r\n} }\r\nfunction Fc(a, b, c) { var d = bd(c); if (\"\" != d.c)\r\n    b && Qc(d, b + \".\" + d.c), Rc(d, d.h);\r\nelse {\r\n    var e = k.location;\r\n    d = cd(e.protocol, b ? b + \".\" + e.hostname : e.hostname, +e.port, c);\r\n} a.V && za(a.V, function (f, g) { R(d, g, f); }); b = a.A; c = a.na; b && c && R(d, b, c); R(d, \"VER\", a.ha); Fd(a, d); return d; }\r\nfunction oc(a, b) { if (b && !a.C)\r\n    throw Error(\"Can't create secondary domain capable XhrIo object.\"); b = new X(a.Na); b.F = a.C; return b; }\r\nfunction Nd() { }\r\nh = Nd.prototype;\r\nh.ta = function () { };\r\nh.sa = function () { };\r\nh.ra = function () { };\r\nh.qa = function () { };\r\nh.Ja = function () { };\r\nfunction Od() { if (x && !(10 <= Number(Ta)))\r\n    throw Error(\"Environmental error: no available transport.\"); }\r\nOd.prototype.a = function (a, b) { return new Y(a, b); };\r\nfunction Y(a, b) {\r\n    D.call(this);\r\n    this.a = new Dd(b);\r\n    this.o = a;\r\n    this.b = b && b.messageUrlParams || null;\r\n    a = b && b.messageHeaders || null;\r\n    b && b.clientProtocolHeaderRequired && (a ? a[\"X-Client-Protocol\"] = \"webchannel\" : a = { \"X-Client-Protocol\": \"webchannel\" });\r\n    this.a.l = a;\r\n    a = b && b.initMessageHeaders || null;\r\n    b && b.messageContentType && (a ? a[\"X-WebChannel-Content-Type\"] = b.messageContentType : a = { \"X-WebChannel-Content-Type\": b.messageContentType });\r\n    b && b.a && (a ? a[\"X-WebChannel-Client-Profile\"] = b.a : a = { \"X-WebChannel-Client-Profile\": b.a });\r\n    this.a.O =\r\n        a;\r\n    (a = b && b.httpHeadersOverwriteParam) && !sa(a) && (this.a.i = a);\r\n    this.m = b && b.supportsCrossDomainXhr || !1;\r\n    this.l = b && b.sendRawJson || !1;\r\n    (b = b && b.httpSessionIdParam) && !sa(b) && (this.a.A = b, a = this.b, null !== a && b in a && (a = this.b, b in a && delete a[b]));\r\n    this.f = new Z(this);\r\n}\r\nr(Y, D);\r\nY.prototype.g = function () { this.a.f = this.f; this.m && (this.a.C = !0); var a = this.a, b = this.o, c = this.b || void 0; J(0); a.fa = b; a.V = c || {}; a.H = a.S; a.B = Fc(a, null, a.fa); Ic(a); };\r\nY.prototype.close = function () { Jc(this.a); };\r\nY.prototype.h = function (a) { if (\"string\" === typeof a) {\r\n    var b = {};\r\n    b.__data__ = a;\r\n    Hd(this.a, b);\r\n}\r\nelse\r\n    this.l ? (b = {}, b.__data__ = ub(a), Hd(this.a, b)) : Hd(this.a, a); };\r\nY.prototype.G = function () { this.a.f = null; delete this.f; Jc(this.a); delete this.a; Y.X.G.call(this); };\r\nfunction Pd(a) { cc.call(this); var b = a.__sm__; if (b) {\r\n    a: {\r\n        for (var c in b) {\r\n            a = c;\r\n            break a;\r\n        }\r\n        a = void 0;\r\n    }\r\n    (this.c = a) ? (a = this.c, this.data = null !== b && a in b ? b[a] : void 0) : this.data = b;\r\n}\r\nelse\r\n    this.data = a; }\r\nr(Pd, cc);\r\nfunction Qd() { dc.call(this); this.status = 1; }\r\nr(Qd, dc);\r\nfunction Z(a) { this.a = a; }\r\nr(Z, Nd);\r\nZ.prototype.ta = function () { E(this.a, \"a\"); };\r\nZ.prototype.sa = function (a) { E(this.a, new Pd(a)); };\r\nZ.prototype.ra = function (a) { E(this.a, new Qd(a)); };\r\nZ.prototype.qa = function () { E(this.a, \"b\"); }; /*\r\n\n Copyright 2017 Google LLC\r\n\n Licensed under the Apache License, Version 2.0 (the \"License\");\r\n you may not use this file except in compliance with the License.\r\n You may obtain a copy of the License at\r\n\n   http://www.apache.org/licenses/LICENSE-2.0\r\n\n Unless required by applicable law or agreed to in writing, software\r\n distributed under the License is distributed on an \"AS IS\" BASIS,\r\n WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r\n See the License for the specific language governing permissions and\r\n limitations under the License.\r\n*/\r\nOd.prototype.createWebChannel = Od.prototype.a;\r\nY.prototype.send = Y.prototype.h;\r\nY.prototype.open = Y.prototype.g;\r\nY.prototype.close = Y.prototype.close;\r\nYb.NO_ERROR = 0;\r\nYb.TIMEOUT = 8;\r\nYb.HTTP_ERROR = 6;\r\nZb.COMPLETE = \"complete\";\r\nbc.EventType = L;\r\nL.OPEN = \"a\";\r\nL.CLOSE = \"b\";\r\nL.ERROR = \"c\";\r\nL.MESSAGE = \"d\";\r\nD.prototype.listen = D.prototype.va;\r\nX.prototype.listenOnce = X.prototype.wa;\r\nX.prototype.getLastError = X.prototype.Qa;\r\nX.prototype.getLastErrorCode = X.prototype.ua;\r\nX.prototype.getStatus = X.prototype.W;\r\nX.prototype.getResponseJson = X.prototype.Pa;\r\nX.prototype.getResponseText = X.prototype.$;\r\nX.prototype.send = X.prototype.ba;\r\nvar createWebChannelTransport = function () { return new Od; };\r\nvar getStatEventTarget = function () { return Ub(); };\r\nvar ErrorCode = Yb;\r\nvar EventType = Zb;\r\nvar Event = H;\r\nvar Stat = { gb: 0, jb: 1, kb: 2, Db: 3, Ib: 4, Fb: 5, Gb: 6, Eb: 7, Cb: 8, Hb: 9, PROXY: 10, NOPROXY: 11, Ab: 12, wb: 13, xb: 14, vb: 15, yb: 16, zb: 17, bb: 18, ab: 19, cb: 20 };\r\nvar WebChannel = bc;\r\nvar XhrIo = X;\r\n\r\nvar esm = {\r\n    createWebChannelTransport: createWebChannelTransport,\r\n    getStatEventTarget: getStatEventTarget,\r\n    ErrorCode: ErrorCode,\r\n    EventType: EventType,\r\n    Event: Event,\r\n    Stat: Stat,\r\n    WebChannel: WebChannel,\r\n    XhrIo: XhrIo\r\n};\n\nexport default esm;\nexport { ErrorCode, Event, EventType, Stat, WebChannel, XhrIo, createWebChannelTransport, getStatEventTarget };\n//# sourceMappingURL=index.esm.js.map\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}","module.exports = require('./lib/axios');","'use strict';\n\nvar bind = require('./helpers/bind');\n\n/*global toString:true*/\n\n// utils is a library of generic helper functions non-specific to axios\n\nvar toString = Object.prototype.toString;\n\n/**\n * Determine if a value is an Array\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Array, otherwise false\n */\nfunction isArray(val) {\n  return toString.call(val) === '[object Array]';\n}\n\n/**\n * Determine if a value is undefined\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if the value is undefined, otherwise false\n */\nfunction isUndefined(val) {\n  return typeof val === 'undefined';\n}\n\n/**\n * Determine if a value is a Buffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Buffer, otherwise false\n */\nfunction isBuffer(val) {\n  return val !== null && !isUndefined(val) && val.constructor !== null && !isUndefined(val.constructor)\n    && typeof val.constructor.isBuffer === 'function' && val.constructor.isBuffer(val);\n}\n\n/**\n * Determine if a value is an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an ArrayBuffer, otherwise false\n */\nfunction isArrayBuffer(val) {\n  return toString.call(val) === '[object ArrayBuffer]';\n}\n\n/**\n * Determine if a value is a FormData\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an FormData, otherwise false\n */\nfunction isFormData(val) {\n  return (typeof FormData !== 'undefined') && (val instanceof FormData);\n}\n\n/**\n * Determine if a value is a view on an ArrayBuffer\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a view on an ArrayBuffer, otherwise false\n */\nfunction isArrayBufferView(val) {\n  var result;\n  if ((typeof ArrayBuffer !== 'undefined') && (ArrayBuffer.isView)) {\n    result = ArrayBuffer.isView(val);\n  } else {\n    result = (val) && (val.buffer) && (val.buffer instanceof ArrayBuffer);\n  }\n  return result;\n}\n\n/**\n * Determine if a value is a String\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a String, otherwise false\n */\nfunction isString(val) {\n  return typeof val === 'string';\n}\n\n/**\n * Determine if a value is a Number\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Number, otherwise false\n */\nfunction isNumber(val) {\n  return typeof val === 'number';\n}\n\n/**\n * Determine if a value is an Object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is an Object, otherwise false\n */\nfunction isObject(val) {\n  return val !== null && typeof val === 'object';\n}\n\n/**\n * Determine if a value is a plain Object\n *\n * @param {Object} val The value to test\n * @return {boolean} True if value is a plain Object, otherwise false\n */\nfunction isPlainObject(val) {\n  if (toString.call(val) !== '[object Object]') {\n    return false;\n  }\n\n  var prototype = Object.getPrototypeOf(val);\n  return prototype === null || prototype === Object.prototype;\n}\n\n/**\n * Determine if a value is a Date\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Date, otherwise false\n */\nfunction isDate(val) {\n  return toString.call(val) === '[object Date]';\n}\n\n/**\n * Determine if a value is a File\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a File, otherwise false\n */\nfunction isFile(val) {\n  return toString.call(val) === '[object File]';\n}\n\n/**\n * Determine if a value is a Blob\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Blob, otherwise false\n */\nfunction isBlob(val) {\n  return toString.call(val) === '[object Blob]';\n}\n\n/**\n * Determine if a value is a Function\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Function, otherwise false\n */\nfunction isFunction(val) {\n  return toString.call(val) === '[object Function]';\n}\n\n/**\n * Determine if a value is a Stream\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a Stream, otherwise false\n */\nfunction isStream(val) {\n  return isObject(val) && isFunction(val.pipe);\n}\n\n/**\n * Determine if a value is a URLSearchParams object\n *\n * @param {Object} val The value to test\n * @returns {boolean} True if value is a URLSearchParams object, otherwise false\n */\nfunction isURLSearchParams(val) {\n  return typeof URLSearchParams !== 'undefined' && val instanceof URLSearchParams;\n}\n\n/**\n * Trim excess whitespace off the beginning and end of a string\n *\n * @param {String} str The String to trim\n * @returns {String} The String freed of excess whitespace\n */\nfunction trim(str) {\n  return str.replace(/^\\s*/, '').replace(/\\s*$/, '');\n}\n\n/**\n * Determine if we're running in a standard browser environment\n *\n * This allows axios to run in a web worker, and react-native.\n * Both environments support XMLHttpRequest, but not fully standard globals.\n *\n * web workers:\n *  typeof window -> undefined\n *  typeof document -> undefined\n *\n * react-native:\n *  navigator.product -> 'ReactNative'\n * nativescript\n *  navigator.product -> 'NativeScript' or 'NS'\n */\nfunction isStandardBrowserEnv() {\n  if (typeof navigator !== 'undefined' && (navigator.product === 'ReactNative' ||\n                                           navigator.product === 'NativeScript' ||\n                                           navigator.product === 'NS')) {\n    return false;\n  }\n  return (\n    typeof window !== 'undefined' &&\n    typeof document !== 'undefined'\n  );\n}\n\n/**\n * Iterate over an Array or an Object invoking a function for each item.\n *\n * If `obj` is an Array callback will be called passing\n * the value, index, and complete array for each item.\n *\n * If 'obj' is an Object callback will be called passing\n * the value, key, and complete object for each property.\n *\n * @param {Object|Array} obj The object to iterate\n * @param {Function} fn The callback to invoke for each item\n */\nfunction forEach(obj, fn) {\n  // Don't bother if no value provided\n  if (obj === null || typeof obj === 'undefined') {\n    return;\n  }\n\n  // Force an array if not already something iterable\n  if (typeof obj !== 'object') {\n    /*eslint no-param-reassign:0*/\n    obj = [obj];\n  }\n\n  if (isArray(obj)) {\n    // Iterate over array values\n    for (var i = 0, l = obj.length; i < l; i++) {\n      fn.call(null, obj[i], i, obj);\n    }\n  } else {\n    // Iterate over object keys\n    for (var key in obj) {\n      if (Object.prototype.hasOwnProperty.call(obj, key)) {\n        fn.call(null, obj[key], key, obj);\n      }\n    }\n  }\n}\n\n/**\n * Accepts varargs expecting each argument to be an object, then\n * immutably merges the properties of each object and returns result.\n *\n * When multiple objects contain the same key the later object in\n * the arguments list will take precedence.\n *\n * Example:\n *\n * ```js\n * var result = merge({foo: 123}, {foo: 456});\n * console.log(result.foo); // outputs 456\n * ```\n *\n * @param {Object} obj1 Object to merge\n * @returns {Object} Result of all merge properties\n */\nfunction merge(/* obj1, obj2, obj3, ... */) {\n  var result = {};\n  function assignValue(val, key) {\n    if (isPlainObject(result[key]) && isPlainObject(val)) {\n      result[key] = merge(result[key], val);\n    } else if (isPlainObject(val)) {\n      result[key] = merge({}, val);\n    } else if (isArray(val)) {\n      result[key] = val.slice();\n    } else {\n      result[key] = val;\n    }\n  }\n\n  for (var i = 0, l = arguments.length; i < l; i++) {\n    forEach(arguments[i], assignValue);\n  }\n  return result;\n}\n\n/**\n * Extends object a by mutably adding to it the properties of object b.\n *\n * @param {Object} a The object to be extended\n * @param {Object} b The object to copy properties from\n * @param {Object} thisArg The object to bind function to\n * @return {Object} The resulting value of object a\n */\nfunction extend(a, b, thisArg) {\n  forEach(b, function assignValue(val, key) {\n    if (thisArg && typeof val === 'function') {\n      a[key] = bind(val, thisArg);\n    } else {\n      a[key] = val;\n    }\n  });\n  return a;\n}\n\n/**\n * Remove byte order marker. This catches EF BB BF (the UTF-8 BOM)\n *\n * @param {string} content with BOM\n * @return {string} content value without BOM\n */\nfunction stripBOM(content) {\n  if (content.charCodeAt(0) === 0xFEFF) {\n    content = content.slice(1);\n  }\n  return content;\n}\n\nmodule.exports = {\n  isArray: isArray,\n  isArrayBuffer: isArrayBuffer,\n  isBuffer: isBuffer,\n  isFormData: isFormData,\n  isArrayBufferView: isArrayBufferView,\n  isString: isString,\n  isNumber: isNumber,\n  isObject: isObject,\n  isPlainObject: isPlainObject,\n  isUndefined: isUndefined,\n  isDate: isDate,\n  isFile: isFile,\n  isBlob: isBlob,\n  isFunction: isFunction,\n  isStream: isStream,\n  isURLSearchParams: isURLSearchParams,\n  isStandardBrowserEnv: isStandardBrowserEnv,\n  forEach: forEach,\n  merge: merge,\n  extend: extend,\n  trim: trim,\n  stripBOM: stripBOM\n};\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 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    throw new Error(prefix + \": \" + (message || ''));\n}\n\nexport default invariant;\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","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n\nvar _ToastContainer = require('./ToastContainer');\n\nObject.defineProperty(exports, 'DefaultToastContainer', {\n  enumerable: true,\n  get: function get() {\n    return _ToastContainer.ToastContainer;\n  }\n});\n\nvar _ToastElement = require('./ToastElement');\n\nObject.defineProperty(exports, 'DefaultToast', {\n  enumerable: true,\n  get: function get() {\n    return _ToastElement.DefaultToast;\n  }\n});\n\nvar _ToastProvider = require('./ToastProvider');\n\nObject.defineProperty(exports, 'ToastConsumer', {\n  enumerable: true,\n  get: function get() {\n    return _ToastProvider.ToastConsumer;\n  }\n});\nObject.defineProperty(exports, 'ToastProvider', {\n  enumerable: true,\n  get: function get() {\n    return _ToastProvider.ToastProvider;\n  }\n});\nObject.defineProperty(exports, 'withToastManager', {\n  enumerable: true,\n  get: function get() {\n    return _ToastProvider.withToastManager;\n  }\n});\nObject.defineProperty(exports, 'useToasts', {\n  enumerable: true,\n  get: function get() {\n    return _ToastProvider.useToasts;\n  }\n});","export default function _taggedTemplateLiteral(strings, raw) {\n  if (!raw) {\n    raw = strings.slice(0);\n  }\n\n  return Object.freeze(Object.defineProperties(strings, {\n    raw: {\n      value: Object.freeze(raw)\n    }\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","(function (global, factory) {\n  typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :\n  typeof define === 'function' && define.amd ? define(['exports'], factory) :\n  (global = global || self, factory(global.idb = {}));\n}(this, function (exports) { 'use strict';\n\n  function toArray(arr) {\n    return Array.prototype.slice.call(arr);\n  }\n\n  function promisifyRequest(request) {\n    return new Promise(function(resolve, reject) {\n      request.onsuccess = function() {\n        resolve(request.result);\n      };\n\n      request.onerror = function() {\n        reject(request.error);\n      };\n    });\n  }\n\n  function promisifyRequestCall(obj, method, args) {\n    var request;\n    var p = new Promise(function(resolve, reject) {\n      request = obj[method].apply(obj, args);\n      promisifyRequest(request).then(resolve, reject);\n    });\n\n    p.request = request;\n    return p;\n  }\n\n  function promisifyCursorRequestCall(obj, method, args) {\n    var p = promisifyRequestCall(obj, method, args);\n    return p.then(function(value) {\n      if (!value) return;\n      return new Cursor(value, p.request);\n    });\n  }\n\n  function proxyProperties(ProxyClass, targetProp, properties) {\n    properties.forEach(function(prop) {\n      Object.defineProperty(ProxyClass.prototype, prop, {\n        get: function() {\n          return this[targetProp][prop];\n        },\n        set: function(val) {\n          this[targetProp][prop] = val;\n        }\n      });\n    });\n  }\n\n  function proxyRequestMethods(ProxyClass, targetProp, Constructor, properties) {\n    properties.forEach(function(prop) {\n      if (!(prop in Constructor.prototype)) return;\n      ProxyClass.prototype[prop] = function() {\n        return promisifyRequestCall(this[targetProp], prop, arguments);\n      };\n    });\n  }\n\n  function proxyMethods(ProxyClass, targetProp, Constructor, properties) {\n    properties.forEach(function(prop) {\n      if (!(prop in Constructor.prototype)) return;\n      ProxyClass.prototype[prop] = function() {\n        return this[targetProp][prop].apply(this[targetProp], arguments);\n      };\n    });\n  }\n\n  function proxyCursorRequestMethods(ProxyClass, targetProp, Constructor, properties) {\n    properties.forEach(function(prop) {\n      if (!(prop in Constructor.prototype)) return;\n      ProxyClass.prototype[prop] = function() {\n        return promisifyCursorRequestCall(this[targetProp], prop, arguments);\n      };\n    });\n  }\n\n  function Index(index) {\n    this._index = index;\n  }\n\n  proxyProperties(Index, '_index', [\n    'name',\n    'keyPath',\n    'multiEntry',\n    'unique'\n  ]);\n\n  proxyRequestMethods(Index, '_index', IDBIndex, [\n    'get',\n    'getKey',\n    'getAll',\n    'getAllKeys',\n    'count'\n  ]);\n\n  proxyCursorRequestMethods(Index, '_index', IDBIndex, [\n    'openCursor',\n    'openKeyCursor'\n  ]);\n\n  function Cursor(cursor, request) {\n    this._cursor = cursor;\n    this._request = request;\n  }\n\n  proxyProperties(Cursor, '_cursor', [\n    'direction',\n    'key',\n    'primaryKey',\n    'value'\n  ]);\n\n  proxyRequestMethods(Cursor, '_cursor', IDBCursor, [\n    'update',\n    'delete'\n  ]);\n\n  // proxy 'next' methods\n  ['advance', 'continue', 'continuePrimaryKey'].forEach(function(methodName) {\n    if (!(methodName in IDBCursor.prototype)) return;\n    Cursor.prototype[methodName] = function() {\n      var cursor = this;\n      var args = arguments;\n      return Promise.resolve().then(function() {\n        cursor._cursor[methodName].apply(cursor._cursor, args);\n        return promisifyRequest(cursor._request).then(function(value) {\n          if (!value) return;\n          return new Cursor(value, cursor._request);\n        });\n      });\n    };\n  });\n\n  function ObjectStore(store) {\n    this._store = store;\n  }\n\n  ObjectStore.prototype.createIndex = function() {\n    return new Index(this._store.createIndex.apply(this._store, arguments));\n  };\n\n  ObjectStore.prototype.index = function() {\n    return new Index(this._store.index.apply(this._store, arguments));\n  };\n\n  proxyProperties(ObjectStore, '_store', [\n    'name',\n    'keyPath',\n    'indexNames',\n    'autoIncrement'\n  ]);\n\n  proxyRequestMethods(ObjectStore, '_store', IDBObjectStore, [\n    'put',\n    'add',\n    'delete',\n    'clear',\n    'get',\n    'getAll',\n    'getKey',\n    'getAllKeys',\n    'count'\n  ]);\n\n  proxyCursorRequestMethods(ObjectStore, '_store', IDBObjectStore, [\n    'openCursor',\n    'openKeyCursor'\n  ]);\n\n  proxyMethods(ObjectStore, '_store', IDBObjectStore, [\n    'deleteIndex'\n  ]);\n\n  function Transaction(idbTransaction) {\n    this._tx = idbTransaction;\n    this.complete = new Promise(function(resolve, reject) {\n      idbTransaction.oncomplete = function() {\n        resolve();\n      };\n      idbTransaction.onerror = function() {\n        reject(idbTransaction.error);\n      };\n      idbTransaction.onabort = function() {\n        reject(idbTransaction.error);\n      };\n    });\n  }\n\n  Transaction.prototype.objectStore = function() {\n    return new ObjectStore(this._tx.objectStore.apply(this._tx, arguments));\n  };\n\n  proxyProperties(Transaction, '_tx', [\n    'objectStoreNames',\n    'mode'\n  ]);\n\n  proxyMethods(Transaction, '_tx', IDBTransaction, [\n    'abort'\n  ]);\n\n  function UpgradeDB(db, oldVersion, transaction) {\n    this._db = db;\n    this.oldVersion = oldVersion;\n    this.transaction = new Transaction(transaction);\n  }\n\n  UpgradeDB.prototype.createObjectStore = function() {\n    return new ObjectStore(this._db.createObjectStore.apply(this._db, arguments));\n  };\n\n  proxyProperties(UpgradeDB, '_db', [\n    'name',\n    'version',\n    'objectStoreNames'\n  ]);\n\n  proxyMethods(UpgradeDB, '_db', IDBDatabase, [\n    'deleteObjectStore',\n    'close'\n  ]);\n\n  function DB(db) {\n    this._db = db;\n  }\n\n  DB.prototype.transaction = function() {\n    return new Transaction(this._db.transaction.apply(this._db, arguments));\n  };\n\n  proxyProperties(DB, '_db', [\n    'name',\n    'version',\n    'objectStoreNames'\n  ]);\n\n  proxyMethods(DB, '_db', IDBDatabase, [\n    'close'\n  ]);\n\n  // Add cursor iterators\n  // TODO: remove this once browsers do the right thing with promises\n  ['openCursor', 'openKeyCursor'].forEach(function(funcName) {\n    [ObjectStore, Index].forEach(function(Constructor) {\n      // Don't create iterateKeyCursor if openKeyCursor doesn't exist.\n      if (!(funcName in Constructor.prototype)) return;\n\n      Constructor.prototype[funcName.replace('open', 'iterate')] = function() {\n        var args = toArray(arguments);\n        var callback = args[args.length - 1];\n        var nativeObject = this._store || this._index;\n        var request = nativeObject[funcName].apply(nativeObject, args.slice(0, -1));\n        request.onsuccess = function() {\n          callback(request.result);\n        };\n      };\n    });\n  });\n\n  // polyfill getAll\n  [Index, ObjectStore].forEach(function(Constructor) {\n    if (Constructor.prototype.getAll) return;\n    Constructor.prototype.getAll = function(query, count) {\n      var instance = this;\n      var items = [];\n\n      return new Promise(function(resolve) {\n        instance.iterateCursor(query, function(cursor) {\n          if (!cursor) {\n            resolve(items);\n            return;\n          }\n          items.push(cursor.value);\n\n          if (count !== undefined && items.length == count) {\n            resolve(items);\n            return;\n          }\n          cursor.continue();\n        });\n      });\n    };\n  });\n\n  function openDb(name, version, upgradeCallback) {\n    var p = promisifyRequestCall(indexedDB, 'open', [name, version]);\n    var request = p.request;\n\n    if (request) {\n      request.onupgradeneeded = function(event) {\n        if (upgradeCallback) {\n          upgradeCallback(new UpgradeDB(request.result, event.oldVersion, request.transaction));\n        }\n      };\n    }\n\n    return p.then(function(db) {\n      return new DB(db);\n    });\n  }\n\n  function deleteDb(name) {\n    return promisifyRequestCall(indexedDB, 'deleteDatabase', [name]);\n  }\n\n  exports.openDb = openDb;\n  exports.deleteDb = deleteDb;\n\n  Object.defineProperty(exports, '__esModule', { value: true });\n\n}));\n","import arrayWithoutHoles from \"@babel/runtime/helpers/esm/arrayWithoutHoles\";\nimport iterableToArray from \"@babel/runtime/helpers/esm/iterableToArray\";\nimport unsupportedIterableToArray from \"@babel/runtime/helpers/esm/unsupportedIterableToArray\";\nimport nonIterableSpread from \"@babel/runtime/helpers/esm/nonIterableSpread\";\nexport default function _toConsumableArray(arr) {\n  return arrayWithoutHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableSpread();\n}","import arrayLikeToArray from \"@babel/runtime/helpers/esm/arrayLikeToArray\";\nexport default function _arrayWithoutHoles(arr) {\n  if (Array.isArray(arr)) return arrayLikeToArray(arr);\n}","export default function _iterableToArray(iter) {\n  if (typeof Symbol !== \"undefined\" && Symbol.iterator in Object(iter)) return Array.from(iter);\n}","export default function _nonIterableSpread() {\n  throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}","import { uuid, toArray } from './util';\nexport function clonePseudoElements(nativeNode, clonedNode) {\n    const pseudos = [':before', ':after'];\n    pseudos.forEach((pseudo) => Pseudo.clonePseudoElement(nativeNode, clonedNode, pseudo));\n}\nvar Pseudo;\n(function (Pseudo) {\n    function clonePseudoElement(nativeNode, clonedNode, pseudo) {\n        const style = window.getComputedStyle(nativeNode, pseudo);\n        const content = style.getPropertyValue('content');\n        if (content === '' || content === 'none') {\n            return;\n        }\n        const className = uuid();\n        // fix: Cannot assign to read only property 'className' of object '#<…\n        try {\n            clonedNode.className = `${clonedNode.className} ${className}`;\n        }\n        catch (err) {\n            return;\n        }\n        const styleElement = document.createElement('style');\n        styleElement.appendChild(getPseudoElementStyle(className, pseudo, style));\n        clonedNode.appendChild(styleElement);\n    }\n    Pseudo.clonePseudoElement = clonePseudoElement;\n    function getPseudoElementStyle(className, pseudo, style) {\n        const selector = `.${className}:${pseudo}`;\n        const cssText = style.cssText\n            ? formatCssText(style)\n            : formatCssProperties(style);\n        return document.createTextNode(`${selector}{${cssText}}`);\n    }\n    function formatCssText(style) {\n        const content = style.getPropertyValue('content');\n        return `${style.cssText} content: ${content};`;\n    }\n    function formatCssProperties(style) {\n        return toArray(style)\n            .map((name) => {\n            const value = style.getPropertyValue(name);\n            const priority = style.getPropertyPriority(name);\n            return `${name}: ${value}${priority ? ' !important' : ''};`;\n        })\n            .join(' ');\n    }\n})(Pseudo || (Pseudo = {}));\n//# sourceMappingURL=clonePseudoElements.js.map","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nconst WOFF = 'application/font-woff';\nconst JPEG = 'image/jpeg';\nconst mimes = {\n    woff: WOFF,\n    woff2: WOFF,\n    ttf: 'application/font-truetype',\n    eot: 'application/vnd.ms-fontobject',\n    png: 'image/png',\n    jpg: JPEG,\n    jpeg: JPEG,\n    gif: 'image/gif',\n    tiff: 'image/tiff',\n    svg: 'image/svg+xml',\n};\nexport const uuid = (function uuid() {\n    // generate uuid for className of pseudo elements.\n    // We should not use GUIDs, otherwise pseudo elements sometimes cannot be captured.\n    let counter = 0;\n    // ref: http://stackoverflow.com/a/6248722/2519373\n    const random = () => `0000${((Math.random() * Math.pow(36, 4)) << 0).toString(36)}`.slice(-4);\n    return () => {\n        counter += 1;\n        return `u${random()}${counter}`;\n    };\n})();\nexport function getExtension(url) {\n    const match = /\\.([^./]*?)$/g.exec(url);\n    return match ? match[1] : '';\n}\nexport function getMimeType(url) {\n    const ext = getExtension(url).toLowerCase();\n    return mimes[ext] || '';\n}\nexport function delay(ms) {\n    return (args) => new Promise((resolve) => {\n        setTimeout(() => {\n            resolve(args);\n        }, ms);\n    });\n}\nexport function isDataUrl(url) {\n    return url.search(/^(data:)/) !== -1;\n}\nexport function toDataURL(content, mimeType) {\n    return `data:${mimeType};base64,${content}`;\n}\nexport function getDataURLContent(dataURL) {\n    return dataURL.split(/,/)[1];\n}\nfunction toBlob(canvas) {\n    return new Promise((resolve) => {\n        const binaryString = window.atob(canvas.toDataURL().split(',')[1]);\n        const len = binaryString.length;\n        const binaryArray = new Uint8Array(len);\n        for (let i = 0; i < len; i += 1) {\n            binaryArray[i] = binaryString.charCodeAt(i);\n        }\n        resolve(new Blob([binaryArray], { type: 'image/png' }));\n    });\n}\nexport function canvasToBlob(canvas) {\n    if (canvas.toBlob) {\n        return new Promise((resolve) => canvas.toBlob(resolve));\n    }\n    return toBlob(canvas);\n}\nexport function toArray(arrayLike) {\n    const result = [];\n    for (let i = 0, l = arrayLike.length; i < l; i += 1) {\n        result.push(arrayLike[i]);\n    }\n    return result;\n}\nfunction px(node, styleProperty) {\n    const val = window.getComputedStyle(node).getPropertyValue(styleProperty);\n    return parseFloat(val.replace('px', ''));\n}\nexport function getNodeWidth(node) {\n    const leftBorder = px(node, 'border-left-width');\n    const rightBorder = px(node, 'border-right-width');\n    return node.scrollWidth + leftBorder + rightBorder;\n}\nexport function getNodeHeight(node) {\n    const topBorder = px(node, 'border-top-width');\n    const bottomBorder = px(node, 'border-bottom-width');\n    return node.scrollHeight + topBorder + bottomBorder;\n}\nexport function getPixelRatio() {\n    let ratio;\n    let FINAL_PROCESS;\n    try {\n        FINAL_PROCESS = process;\n    }\n    catch (e) { }\n    const val = FINAL_PROCESS && FINAL_PROCESS.env\n        ? FINAL_PROCESS.env.devicePixelRatio\n        : null;\n    if (val) {\n        ratio = parseInt(val, 10);\n        if (isNaN(ratio)) {\n            ratio = 1;\n        }\n    }\n    return ratio || window.devicePixelRatio || 1;\n}\nexport function createImage(url) {\n    return new Promise((resolve, reject) => {\n        const image = new Image();\n        image.onload = () => resolve(image);\n        image.onerror = reject;\n        image.crossOrigin = 'anonymous';\n        image.src = url;\n    });\n}\nexport function svgToDataURL(svg) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return Promise.resolve()\n            .then(() => new XMLSerializer().serializeToString(svg))\n            .then(encodeURIComponent)\n            .then((html) => `data:image/svg+xml;charset=utf-8,${html}`);\n    });\n}\nexport function getBlobFromImageURL(url) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return createImage(url).then((image) => {\n            const { width, height } = image;\n            const canvas = document.createElement('canvas');\n            const context = canvas.getContext('2d');\n            const ratio = getPixelRatio();\n            canvas.width = width * ratio;\n            canvas.height = height * ratio;\n            canvas.style.width = `${width}`;\n            canvas.style.height = `${height}`;\n            context.scale(ratio, ratio);\n            context.drawImage(image, 0, 0);\n            const dataURL = canvas.toDataURL(getMimeType(url));\n            return getDataURLContent(dataURL);\n        });\n    });\n}\n//# sourceMappingURL=util.js.map","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport { clonePseudoElements } from './clonePseudoElements';\nimport { createImage, toArray } from './util';\nfunction cloneSingleNode(node) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (node instanceof HTMLCanvasElement) {\n            const dataURL = node.toDataURL();\n            if (dataURL === 'data:,') {\n                return Promise.resolve(node.cloneNode(false));\n            }\n            return createImage(dataURL);\n        }\n        // if (node.tagName && node.tagName.toLowerCase() === 'svg') {\n        //   return Promise.resolve(node as SVGElement)\n        //     .then((svg) => svgToDataURL(svg))\n        //     .then(createImage)\n        // }\n        return Promise.resolve(node.cloneNode(false));\n    });\n}\nfunction cloneChildren(nativeNode, clonedNode, filter) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const children = toArray(nativeNode.childNodes);\n        if (children.length === 0) {\n            return Promise.resolve(clonedNode);\n        }\n        return children\n            .reduce((done, child) => done\n            .then(() => cloneNode(child, filter))\n            .then((clonedChild) => {\n            if (clonedChild) {\n                clonedNode.appendChild(clonedChild);\n            }\n        }), Promise.resolve())\n            .then(() => clonedNode);\n    });\n}\nfunction decorate(nativeNode, clonedNode) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!(clonedNode instanceof Element)) {\n            return clonedNode;\n        }\n        return Promise.resolve()\n            .then(() => cloneCssStyle(nativeNode, clonedNode))\n            .then(() => clonePseudoElements(nativeNode, clonedNode))\n            .then(() => cloneInputValue(nativeNode, clonedNode))\n            .then(() => clonedNode);\n    });\n}\nfunction cloneCssStyle(nativeNode, clonedNode) {\n    const source = window.getComputedStyle(nativeNode);\n    const target = clonedNode.style;\n    if (source.cssText) {\n        target.cssText = source.cssText;\n    }\n    else {\n        toArray(source).forEach((name) => {\n            target.setProperty(name, source.getPropertyValue(name), source.getPropertyPriority(name));\n        });\n    }\n}\nfunction cloneInputValue(nativeNode, clonedNode) {\n    if (nativeNode instanceof HTMLTextAreaElement) {\n        clonedNode.innerHTML = nativeNode.value;\n    }\n    if (nativeNode instanceof HTMLInputElement) {\n        clonedNode.setAttribute('value', nativeNode.value);\n    }\n}\nexport function cloneNode(nativeNode, filter, isRoot) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!isRoot && filter && !filter(nativeNode)) {\n            return Promise.resolve(null);\n        }\n        return Promise.resolve(nativeNode)\n            .then(cloneSingleNode)\n            .then((clonedNode) => cloneChildren(nativeNode, clonedNode, filter))\n            .then((clonedNode) => decorate(nativeNode, clonedNode));\n    });\n}\n//# sourceMappingURL=cloneNode.js.map","/* tslint:disable:max-line-length */\nimport { getDataURLContent } from './util';\n// KNOWN ISSUE\n// -----------\n// Can not handle redirect-url, such as when access 'http://something.com/avatar.png'\n// will redirect to 'http://something.com/65fc2ffcc8aea7ba65a1d1feda173540'\nconst TIMEOUT = 30000;\nconst cache = {};\nfunction isFont(filename) {\n    return /ttf|otf|eot|woff2?/i.test(filename);\n}\nexport function getBlobFromURL(url, options) {\n    let href = url.replace(/\\?.*/, '');\n    if (isFont(href)) {\n        href = href.replace(/.*\\//, '');\n    }\n    if (cache[href]) {\n        return cache[href];\n    }\n    // cache bypass so we dont have CORS issues with cached images\n    // ref: https://developer.mozilla.org/en/docs/Web/API/XMLHttpRequest/Using_XMLHttpRequest#Bypassing_the_cache\n    if (options.cacheBust) {\n        // tslint:disable-next-line\n        url += (/\\?/.test(url) ? '&' : '?') + new Date().getTime();\n    }\n    const failed = (reason) => {\n        let placeholder = '';\n        if (options.imagePlaceholder) {\n            const parts = options.imagePlaceholder.split(/,/);\n            if (parts && parts[1]) {\n                placeholder = parts[1];\n            }\n        }\n        let msg = `Failed to fetch resource: ${url}`;\n        if (reason) {\n            msg = typeof reason === 'string' ? reason : reason.message;\n        }\n        if (msg) {\n            console.error(msg);\n        }\n        return placeholder;\n    };\n    const deferred = window.fetch\n        ? window\n            .fetch(url)\n            .then((response) => {\n            return new Promise((res, rej) => {\n                response.blob().then((blob) => {\n                    res({\n                        blob,\n                        contentType: response.headers.get('Content-Type'),\n                    });\n                });\n            });\n        })\n            .then(({ blob, contentType }) => new Promise((resolve, reject) => {\n            const reader = new FileReader();\n            reader.onloadend = () => resolve({\n                contentType,\n                blob: reader.result,\n            });\n            reader.onerror = reject;\n            reader.readAsDataURL(blob);\n        }))\n            .then(({ blob, contentType }) => ({\n            contentType,\n            blob: getDataURLContent(blob),\n        }))\n            .catch(() => new Promise((resolve, reject) => reject()))\n        : new Promise((resolve, reject) => {\n            const req = new XMLHttpRequest();\n            const timeout = () => {\n                reject(new Error(`Timeout of ${TIMEOUT}ms occured while fetching resource: ${url}`));\n            };\n            const done = () => {\n                if (req.readyState !== 4) {\n                    return;\n                }\n                if (req.status !== 200) {\n                    reject(new Error(`Failed to fetch resource: ${url}, status: ${req.status}`));\n                    return;\n                }\n                const encoder = new FileReader();\n                encoder.onloadend = () => {\n                    resolve({\n                        blob: getDataURLContent(encoder.result),\n                        contentType: req.getResponseHeader('Content-Type') || '',\n                    });\n                };\n                encoder.readAsDataURL(req.response);\n            };\n            req.onreadystatechange = done;\n            req.ontimeout = timeout;\n            req.responseType = 'blob';\n            req.timeout = TIMEOUT;\n            req.open('GET', url, true);\n            req.send();\n        });\n    const promise = deferred.catch(failed);\n    cache[href] = promise;\n    return promise;\n}\n//# sourceMappingURL=getBlobFromURL.js.map","import { getBlobFromURL } from './getBlobFromURL';\nimport { isDataUrl, toDataURL, getMimeType } from './util';\nconst URL_REGEX = /url\\((['\"]?)([^'\"]+?)\\1\\)/g;\nconst URL_WITH_FORMAT_REGEX = /url\\([^)]+\\)\\s*format\\(([\"'])([^\"']+)\\1\\)/g;\nconst FONT_SRC_REGEX = /src:\\s*(?:url\\([^)]+\\)\\s*format\\([^)]+\\)[,;]\\s*)+/g;\nexport function shouldEmbed(string) {\n    return string.search(URL_REGEX) !== -1;\n}\nexport function embedResources(cssString, baseUrl, options) {\n    if (!shouldEmbed(cssString)) {\n        return Promise.resolve(cssString);\n    }\n    const filteredCssString = filterPreferredFontFormat(cssString, options);\n    return Promise.resolve(filteredCssString)\n        .then(parseURLs)\n        .then((urls) => urls.reduce((done, url) => done.then((ret) => embed(ret, url, baseUrl, options)), Promise.resolve(filteredCssString)));\n}\nexport function filterPreferredFontFormat(str, { preferredFontFormat }) {\n    return !preferredFontFormat\n        ? str\n        : str.replace(FONT_SRC_REGEX, (match) => {\n            while (true) {\n                const [src, , format] = URL_WITH_FORMAT_REGEX.exec(match) || [];\n                if (!format) {\n                    return '';\n                }\n                if (format === preferredFontFormat) {\n                    return `src: ${src};`;\n                }\n            }\n        });\n}\nexport function parseURLs(str) {\n    const result = [];\n    str.replace(URL_REGEX, (raw, quotation, url) => {\n        result.push(url);\n        return raw;\n    });\n    return result.filter((url) => !isDataUrl(url));\n}\nexport function embed(cssString, resourceURL, baseURL, options, get) {\n    const resolvedURL = baseURL ? resolveUrl(resourceURL, baseURL) : resourceURL;\n    return Promise.resolve(resolvedURL)\n        .then((url) => get ? get(url) : getBlobFromURL(url, options))\n        .then((data) => {\n        if (typeof data === 'string') {\n            return toDataURL(data, getMimeType(resourceURL));\n        }\n        return toDataURL(data.blob, getMimeType(resourceURL) || data.contentType);\n    })\n        .then((dataURL) => cssString.replace(urlToRegex(resourceURL), `$1${dataURL}$3`))\n        .then((content) => content, () => resolvedURL);\n}\nfunction resolveUrl(url, baseUrl) {\n    // url is absolute already\n    if (url.match(/^[a-z]+:\\/\\//i)) {\n        return url;\n    }\n    // url is absolute already, without protocol\n    if (url.match(/^\\/\\//)) {\n        return window.location.protocol + url;\n    }\n    // dataURI, mailto:, tel:, etc.\n    if (url.match(/^[a-z]+:/i)) {\n        return url;\n    }\n    const doc = document.implementation.createHTMLDocument();\n    const base = doc.createElement('base');\n    const a = doc.createElement('a');\n    doc.head.appendChild(base);\n    doc.body.appendChild(a);\n    if (baseUrl) {\n        base.href = baseUrl;\n    }\n    a.href = url;\n    return a.href;\n}\nfunction urlToRegex(url) {\n    return new RegExp(`(url\\\\(['\"]?)(${escape(url)})(['\"]?\\\\))`, 'g');\n}\nfunction escape(url) {\n    return url.replace(/([.*+?^${}()|\\[\\]\\/\\\\])/g, '\\\\$1');\n}\n//# sourceMappingURL=embedResources.js.map","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport { getBlobFromURL } from './getBlobFromURL';\nimport { embedResources } from './embedResources';\nimport { toArray, isDataUrl, toDataURL, getMimeType } from './util';\nexport function embedImages(clonedNode, options) {\n    return __awaiter(this, void 0, void 0, function* () {\n        if (!(clonedNode instanceof Element)) {\n            return Promise.resolve(clonedNode);\n        }\n        return Promise.resolve(clonedNode)\n            .then((node) => embedBackground(node, options))\n            .then((node) => embedImageNode(node, options))\n            .then((node) => embedChildren(node, options));\n    });\n}\nfunction embedBackground(clonedNode, options) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const background = clonedNode.style.getPropertyValue('background');\n        if (!background) {\n            return Promise.resolve(clonedNode);\n        }\n        return Promise.resolve(background)\n            .then((cssString) => embedResources(cssString, null, options))\n            .then((cssString) => {\n            clonedNode.style.setProperty('background', cssString, clonedNode.style.getPropertyPriority('background'));\n            return clonedNode;\n        });\n    });\n}\nfunction embedImageNode(clonedNode, options) {\n    if (!(clonedNode instanceof HTMLImageElement) || isDataUrl(clonedNode.src)) {\n        return Promise.resolve(clonedNode);\n    }\n    return Promise.resolve(clonedNode.src)\n        .then((url) => getBlobFromURL(url, options))\n        .then((data) => toDataURL(data.blob, getMimeType(clonedNode.src) || data.contentType))\n        .then((dataURL) => new Promise((resolve, reject) => {\n        clonedNode.onload = resolve;\n        clonedNode.onerror = reject;\n        clonedNode.src = dataURL;\n    }))\n        .then(() => clonedNode, () => clonedNode);\n}\nfunction embedChildren(clonedNode, options) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const children = toArray(clonedNode.childNodes);\n        const deferreds = children.map((child) => embedImages(child, options));\n        return Promise.all(deferreds).then(() => clonedNode);\n    });\n}\n//# sourceMappingURL=embedImages.js.map","var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {\n    function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n    return new (P || (P = Promise))(function (resolve, reject) {\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n        function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\n    });\n};\nimport { toArray } from './util';\nimport { shouldEmbed, embedResources } from './embedResources';\nconst cssFetchPromiseStore = {};\nexport function parseWebFontRules(clonedNode) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return new Promise((resolve, reject) => {\n            if (!clonedNode.ownerDocument) {\n                reject(new Error('Provided element is not within a Document'));\n            }\n            resolve(toArray(clonedNode.ownerDocument.styleSheets));\n        })\n            .then((styleSheets) => getCssRules(styleSheets))\n            .then(getWebFontRules);\n    });\n}\nexport function embedWebFonts(clonedNode, options) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return (options.fontEmbedCss != null\n            ? Promise.resolve(options.fontEmbedCss)\n            : getWebFontCss(clonedNode, options)).then((cssString) => {\n            const styleNode = document.createElement('style');\n            const sytleContent = document.createTextNode(cssString);\n            styleNode.appendChild(sytleContent);\n            if (clonedNode.firstChild) {\n                clonedNode.insertBefore(styleNode, clonedNode.firstChild);\n            }\n            else {\n                clonedNode.appendChild(styleNode);\n            }\n            return clonedNode;\n        });\n    });\n}\nexport function getWebFontCss(node, options) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return parseWebFontRules(node)\n            .then((rules) => Promise.all(rules.map((rule) => {\n            const baseUrl = rule.parentStyleSheet\n                ? rule.parentStyleSheet.href\n                : null;\n            return embedResources(rule.cssText, baseUrl, options);\n        })))\n            .then((cssStrings) => cssStrings.join('\\n'));\n    });\n}\nexport function getCssRules(styleSheets) {\n    return __awaiter(this, void 0, void 0, function* () {\n        const ret = [];\n        const promises = [];\n        // First loop inlines imports\n        styleSheets.forEach((sheet) => {\n            if ('cssRules' in sheet) {\n                try {\n                    toArray(sheet.cssRules).forEach((item, index) => {\n                        if (item.type === CSSRule.IMPORT_RULE) {\n                            let importIndex = index + 1;\n                            promises.push(fetchCSS(item.href, sheet)\n                                .then(embedFonts)\n                                .then((cssText) => {\n                                const parsed = parseCSS(cssText);\n                                parsed.forEach((rule) => {\n                                    try {\n                                        sheet.insertRule(rule, rule.startsWith('@import')\n                                            ? (importIndex = importIndex + 1)\n                                            : sheet.cssRules.length);\n                                    }\n                                    catch (error) {\n                                        console.log('Error inserting rule from remote css', {\n                                            rule,\n                                            error,\n                                        });\n                                    }\n                                });\n                            })\n                                .catch((e) => {\n                                console.log('Error loading remote css', e.toString());\n                            }));\n                        }\n                    });\n                }\n                catch (e) {\n                    const inline = styleSheets.find((a) => a.href === null) || document.styleSheets[0];\n                    if (sheet.href != null) {\n                        promises.push(fetchCSS(sheet.href, inline)\n                            .then(embedFonts)\n                            .then((cssText) => {\n                            const parsed = parseCSS(cssText);\n                            parsed.forEach((rule) => {\n                                inline.insertRule(rule, sheet.cssRules.length);\n                            });\n                        })\n                            .catch((e) => {\n                            console.log('Error loading remote stylesheet', e.toString());\n                        }));\n                    }\n                    console.log('Error inlining remote css file', e.toString());\n                }\n            }\n        });\n        return Promise.all(promises).then(() => {\n            // Second loop parses rules\n            styleSheets.forEach((sheet) => {\n                if ('cssRules' in sheet) {\n                    try {\n                        toArray(sheet.cssRules).forEach((item) => {\n                            ret.push(item);\n                        });\n                    }\n                    catch (e) {\n                        console.log(`Error while reading CSS rules from ${sheet.href}`, e.toString());\n                    }\n                }\n            });\n            return ret;\n        });\n    });\n}\nfunction getWebFontRules(cssRules) {\n    return cssRules\n        .filter((rule) => rule.type === CSSRule.FONT_FACE_RULE)\n        .filter((rule) => shouldEmbed(rule.style.getPropertyValue('src')));\n}\nfunction parseCSS(source) {\n    if (source === undefined) {\n        return [];\n    }\n    let cssText = source;\n    const css = [];\n    const cssKeyframeRegex = '((@.*?keyframes [\\\\s\\\\S]*?){([\\\\s\\\\S]*?}\\\\s*?)})';\n    const combinedCSSRegex = '((\\\\s*?(?:\\\\/\\\\*[\\\\s\\\\S]*?\\\\*\\\\/)?\\\\s*?@media[\\\\s\\\\S]' +\n        '*?){([\\\\s\\\\S]*?)}\\\\s*?})|(([\\\\s\\\\S]*?){([\\\\s\\\\S]*?)})'; // to match css & media queries together\n    const cssCommentsRegex = /(\\/\\*[\\s\\S]*?\\*\\/)/gi;\n    const importRegex = /@import[\\s\\S]*?url\\([^)]*\\)[\\s\\S]*?;/gi;\n    // strip out comments\n    cssText = cssText.replace(cssCommentsRegex, '');\n    const keyframesRegex = new RegExp(cssKeyframeRegex, 'gi');\n    let arr;\n    while (true) {\n        arr = keyframesRegex.exec(cssText);\n        if (arr === null) {\n            break;\n        }\n        css.push(arr[0]);\n    }\n    cssText = cssText.replace(keyframesRegex, '');\n    // unified regex\n    const unified = new RegExp(combinedCSSRegex, 'gi');\n    while (true) {\n        arr = importRegex.exec(cssText);\n        if (arr === null) {\n            arr = unified.exec(cssText);\n            if (arr === null) {\n                break;\n            }\n            else {\n                importRegex.lastIndex = unified.lastIndex;\n            }\n        }\n        else {\n            unified.lastIndex = importRegex.lastIndex;\n        }\n        css.push(arr[0]);\n    }\n    return css;\n}\nfunction fetchCSS(url, sheet) {\n    if (cssFetchPromiseStore[url]) {\n        return cssFetchPromiseStore[url];\n    }\n    const promise = fetch(url).then((res) => {\n        return {\n            url,\n            cssText: res.text(),\n        };\n    }, (e) => {\n        console.log('ERROR FETCHING CSS: ', e.toString());\n    });\n    cssFetchPromiseStore[url] = promise;\n    return promise;\n}\nfunction embedFonts(data) {\n    return __awaiter(this, void 0, void 0, function* () {\n        return data.cssText.then((resolved) => {\n            let cssText = resolved;\n            const regexUrlFind = /url\\([\"']?([^\"')]+)[\"']?\\)/g;\n            const fontLocations = cssText.match(/url\\([^)]+\\)/g) || [];\n            const fontLoadedPromises = fontLocations.map((location) => {\n                let url = location.replace(regexUrlFind, '$1');\n                if (!url.startsWith('https://')) {\n                    const source = data.url;\n                    url = new URL(url, source).href;\n                }\n                return new Promise((resolve, reject) => {\n                    fetch(url)\n                        .then((res) => res.blob())\n                        .then((blob) => {\n                        const reader = new FileReader();\n                        reader.addEventListener('load', (res) => {\n                            // Side Effect\n                            cssText = cssText.replace(location, `url(${reader.result})`);\n                            resolve([location, reader.result]);\n                        });\n                        reader.readAsDataURL(blob);\n                    })\n                        .catch(reject);\n                });\n            });\n            return Promise.all(fontLoadedPromises).then(() => cssText);\n        });\n    });\n}\n//# sourceMappingURL=embedWebFonts.js.map","import { svgToDataURL } from './util';\nexport function createSvgDataURL(clonedNode, width, height) {\n    const xmlns = 'http://www.w3.org/2000/svg';\n    const svg = document.createElementNS(xmlns, 'svg');\n    const foreignObject = document.createElementNS(xmlns, 'foreignObject');\n    svg.setAttributeNS('', 'width', `${width}`);\n    svg.setAttributeNS('', 'height', `${height}`);\n    foreignObject.setAttributeNS('', 'width', '100%');\n    foreignObject.setAttributeNS('', 'height', '100%');\n    foreignObject.setAttributeNS('', 'x', '0');\n    foreignObject.setAttributeNS('', 'y', '0');\n    foreignObject.setAttributeNS('', 'externalResourcesRequired', 'true');\n    svg.appendChild(foreignObject);\n    foreignObject.appendChild(clonedNode);\n    return svgToDataURL(svg);\n}\n//# sourceMappingURL=createSvgDataURL.js.map","export function applyStyleWithOptions(clonedNode, options) {\n    const { style } = clonedNode;\n    if (options.backgroundColor) {\n        style.backgroundColor = options.backgroundColor;\n    }\n    if (options.width) {\n        style.width = `${options.width}px`;\n    }\n    if (options.height) {\n        style.height = `${options.height}px`;\n    }\n    const manual = options.style;\n    if (manual != null) {\n        Object.keys(manual).forEach((key) => {\n            // @ts-expect-error\n            style[key] = manual[key];\n        });\n    }\n    return clonedNode;\n}\n//# sourceMappingURL=applyStyleWithOptions.js.map","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nconsole.warn(`\nIt looks like you're using the development build of the Firebase JS SDK.\nWhen deploying Firebase apps to production, it is advisable to only import\nthe individual SDK components you intend to use.\n\nFor the module builds, these are available in the following manner\n(replace <PACKAGE> with the name of a component - i.e. auth, database, etc):\n\nCommonJS Modules:\nconst firebase = require('firebase/app');\nrequire('firebase/<PACKAGE>');\n\nES Modules:\nimport firebase from 'firebase/app';\nimport 'firebase/<PACKAGE>';\n\nTypescript:\nimport firebase from 'firebase/app';\nimport 'firebase/<PACKAGE>';\n`);\n\nimport firebase from '../app';\nimport { name, version } from '../package.json';\n\nimport '../auth';\nimport '../database';\nimport '../firestore';\nimport '../firestore/bundle';\nimport '../functions';\nimport '../messaging';\nimport '../storage';\nimport '../performance';\nimport '../analytics';\nimport '../remote-config';\n\nfirebase.registerVersion(name, version);\n\nexport default firebase;\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\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}","/**\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.15';\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\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 and trailing whitespace. */\n  var reTrim = /^\\s+|\\s+$/g,\n      reTrimStart = /^\\s+/,\n      reTrimEnd = /\\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  /** 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    '&': '&amp;',\n    '<': '&lt;',\n    '>': '&gt;',\n    '\"': '&quot;',\n    \"'\": '&#39;'\n  };\n\n  /** Used to map HTML entities to characters. */\n  var htmlUnescapes = {\n    '&amp;': '&',\n    '&lt;': '<',\n    '&gt;': '>',\n    '&quot;': '\"',\n    '&#39;': \"'\"\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 `_.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 `_.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      var index = -1;\n      iteratees = arrayMap(iteratees.length ? iteratees : [identity], 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 (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      value = iteratee(value);\n\n      var low = 0,\n          high = array == null ? 0 : array.length,\n          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      // Assume cyclic values are equal.\n      var stacked = stack.get(array);\n      if (stacked && stack.get(other)) {\n        return stacked == other;\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      // Assume cyclic values are equal.\n      var stacked = stack.get(object);\n      if (stacked && stack.get(other)) {\n        return stacked == other;\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    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': 40 },\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', 40]]\n     *\n     * _.sortBy(users, ['user', 'age']);\n     * // => objects for [['barney', 34], ['barney', 36], ['fred', 40], ['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, &amp; 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 = value.replace(reTrim, '');\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, &amp; 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>&lt;script&gt;</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      // with lookup (in case of e.g. prototype pollution), and strip newlines if any.\n      // A newline wouldn't be a valid sourceURL anyway, and it'd enable code injection.\n      var sourceURL = '//# sourceURL=' +\n        (hasOwnProperty.call(options, 'sourceURL')\n          ? (options.sourceURL + '').replace(/[\\r\\n]/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      // Like with sourceURL, we take care to not check the option's prototype,\n      // as this configuration is a code injection vector.\n      var variable = hasOwnProperty.call(options, 'variable') && options.variable;\n      if (!variable) {\n        source = 'with (obj) {\\n' + source + '\\n}\\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 string.replace(reTrim, '');\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.replace(reTrimEnd, '');\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     * `&amp;`, `&lt;`, `&gt;`, `&quot;`, and `&#39;` 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, &amp; 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     * @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    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     * @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    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     * @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     * @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 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","import arrayLikeToArray from \"@babel/runtime/helpers/esm/arrayLikeToArray\";\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}","export default (): string =>\n  Math.random()\n    .toString(36)\n    .substring(6)\n","import * as React from 'react'\n\nimport uid from '../shared/uid'\nimport { IContentLoaderProps } from './'\n\nconst SVG: React.FC<IContentLoaderProps> = ({\n  animate,\n  backgroundColor,\n  backgroundOpacity,\n  baseUrl,\n  children,\n  foregroundColor,\n  foregroundOpacity,\n  gradientRatio,\n  uniqueKey,\n  interval,\n  rtl,\n  speed,\n  style,\n  title,\n  ...props\n}) => {\n  const fixedId = uniqueKey || uid()\n  const idClip = `${fixedId}-diff`\n  const idGradient = `${fixedId}-animated-diff`\n  const idAria = `${fixedId}-aria`\n\n  const rtlStyle = rtl ? { transform: 'scaleX(-1)' } : null\n  const keyTimes = `0; ${interval}; 1`\n  const dur = `${speed}s`\n\n  return (\n    <svg\n      aria-labelledby={idAria}\n      role=\"img\"\n      style={{ ...style, ...rtlStyle }}\n      {...props}\n    >\n      {title ? <title id={idAria}>{title}</title> : null}\n      <rect\n        role=\"presentation\"\n        x=\"0\"\n        y=\"0\"\n        width=\"100%\"\n        height=\"100%\"\n        clipPath={`url(${baseUrl}#${idClip})`}\n        style={{ fill: `url(${baseUrl}#${idGradient})` }}\n      />\n\n      <defs role=\"presentation\">\n        <clipPath id={idClip}>{children}</clipPath>\n\n        <linearGradient id={idGradient}>\n          <stop\n            offset=\"0%\"\n            stopColor={backgroundColor}\n            stopOpacity={backgroundOpacity}\n          >\n            {animate && (\n              <animate\n                attributeName=\"offset\"\n                values={`${-gradientRatio}; ${-gradientRatio}; 1`}\n                keyTimes={keyTimes}\n                dur={dur}\n                repeatCount=\"indefinite\"\n              />\n            )}\n          </stop>\n\n          <stop\n            offset=\"50%\"\n            stopColor={foregroundColor}\n            stopOpacity={foregroundOpacity}\n          >\n            {animate && (\n              <animate\n                attributeName=\"offset\"\n                values={`${-gradientRatio / 2}; ${-gradientRatio / 2}; ${1 +\n                  gradientRatio / 2}`}\n                keyTimes={keyTimes}\n                dur={dur}\n                repeatCount=\"indefinite\"\n              />\n            )}\n          </stop>\n\n          <stop\n            offset=\"100%\"\n            stopColor={backgroundColor}\n            stopOpacity={backgroundOpacity}\n          >\n            {animate && (\n              <animate\n                attributeName=\"offset\"\n                values={`0; 0; ${1 + gradientRatio}`}\n                keyTimes={keyTimes}\n                dur={dur}\n                repeatCount=\"indefinite\"\n              />\n            )}\n          </stop>\n        </linearGradient>\n      </defs>\n    </svg>\n  )\n}\n\nSVG.defaultProps = {\n  animate: true,\n  backgroundColor: '#f5f6f7',\n  backgroundOpacity: 1,\n  baseUrl: '',\n  foregroundColor: '#eee',\n  foregroundOpacity: 1,\n  gradientRatio: 2,\n  id: null,\n  interval: 0.25,\n  rtl: false,\n  speed: 1.2,\n  style: {},\n  title: 'Loading...',\n}\n\nexport default SVG\n","import * as React from 'react'\n\nimport { Facebook, IContentLoaderProps } from '.'\nimport Svg from './Svg'\n\nconst ContentLoader: React.FC<IContentLoaderProps> = props =>\n  props.children ? <Svg {...props} /> : <Facebook {...props} />\n\nexport default ContentLoader\n","import * as React from 'react'\n\nimport { IContentLoaderProps } from '..'\nimport ContentLoader from '../ContentLoader'\n\nconst ReactContentLoaderFacebook: React.FC<IContentLoaderProps> = props => (\n  <ContentLoader viewBox=\"0 0 476 124\" {...props}>\n    <rect x=\"48\" y=\"8\" width=\"88\" height=\"6\" rx=\"3\" />\n    <rect x=\"48\" y=\"26\" width=\"52\" height=\"6\" rx=\"3\" />\n    <rect x=\"0\" y=\"56\" width=\"410\" height=\"6\" rx=\"3\" />\n    <rect x=\"0\" y=\"72\" width=\"380\" height=\"6\" rx=\"3\" />\n    <rect x=\"0\" y=\"88\" width=\"178\" height=\"6\" rx=\"3\" />\n    <circle cx=\"20\" cy=\"20\" r=\"20\" />\n  </ContentLoader>\n)\n\nexport default ReactContentLoaderFacebook\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport firebase from '@firebase/app';\nimport { FirebaseNamespace } from '@firebase/app-types';\n\nimport {\n  Firestore,\n  IndexedDbPersistenceProvider,\n  ExpFirebaseFirestore\n} from './export';\nimport { name, version } from './package.json';\nimport { configureForFirebase } from './src/config';\n\nimport './register-module';\n\n/**\n * Registers the main Firestore build with the components framework.\n * Persistence can be enabled via `firebase.firestore().enablePersistence()`.\n */\nexport function registerFirestore(instance: FirebaseNamespace): void {\n  configureForFirebase(\n    instance,\n    (app, auth) =>\n      new Firestore(\n        app,\n        new ExpFirebaseFirestore(app, auth),\n        new IndexedDbPersistenceProvider()\n      )\n  );\n  instance.registerVersion(name, version);\n}\n\nregisterFirestore(firebase);\n","/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Firestore, loadBundle, namedQuery } from './export';\n\n/**\n * Prototype patches bundle loading to Firestore.\n */\nexport function registerBundle(instance: typeof Firestore): void {\n  instance.prototype.loadBundle = loadBundle;\n  instance.prototype.namedQuery = namedQuery;\n}\n\nregisterBundle(Firestore);\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FirebaseApp, FirebaseNamespace } from '@firebase/app-types';\nimport { _FirebaseNamespace } from '@firebase/app-types/private';\nimport { FirebaseAuthInternalName } from '@firebase/auth-interop-types';\nimport { Component, ComponentType, Provider } from '@firebase/component';\n\nimport {\n  CACHE_SIZE_UNLIMITED,\n  CollectionReference,\n  DocumentReference,\n  DocumentSnapshot,\n  Firestore,\n  Query,\n  QueryDocumentSnapshot,\n  QuerySnapshot,\n  Transaction,\n  WriteBatch,\n  setLogLevel,\n  Blob,\n  FieldPath,\n  GeoPoint,\n  Timestamp,\n  FieldValue\n} from '../export';\n\nconst firestoreNamespace = {\n  Firestore,\n  GeoPoint,\n  Timestamp,\n  Blob,\n  Transaction,\n  WriteBatch,\n  DocumentReference,\n  DocumentSnapshot,\n  Query,\n  QueryDocumentSnapshot,\n  QuerySnapshot,\n  CollectionReference,\n  FieldPath,\n  FieldValue,\n  setLogLevel,\n  CACHE_SIZE_UNLIMITED\n};\n\n/**\n * Configures Firestore as part of the Firebase SDK by calling registerService.\n *\n * @param firebase - The FirebaseNamespace to register Firestore with\n * @param firestoreFactory - A factory function that returns a new Firestore\n *    instance.\n */\nexport function configureForFirebase(\n  firebase: FirebaseNamespace,\n  firestoreFactory: (\n    app: FirebaseApp,\n    auth: Provider<FirebaseAuthInternalName>\n  ) => Firestore\n): void {\n  (firebase as _FirebaseNamespace).INTERNAL.registerComponent(\n    new Component(\n      'firestore',\n      container => {\n        const app = container.getProvider('app').getImmediate()!;\n        return firestoreFactory(app, container.getProvider('auth-internal'));\n      },\n      ComponentType.PUBLIC\n    ).setServiceProps({ ...firestoreNamespace })\n  );\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { HttpsError, FunctionsErrorCode } from '@firebase/functions-types';\nimport { Serializer } from '../serializer';\nimport { HttpResponseBody } from './service';\n\n/**\n * Standard error codes for different ways a request can fail, as defined by:\n * https://github.com/googleapis/googleapis/blob/master/google/rpc/code.proto\n *\n * This map is used primarily to convert from a backend error code string to\n * a client SDK error code string, and make sure it's in the supported set.\n */\nconst errorCodeMap: { [name: string]: FunctionsErrorCode } = {\n  OK: 'ok',\n  CANCELLED: 'cancelled',\n  UNKNOWN: 'unknown',\n  INVALID_ARGUMENT: 'invalid-argument',\n  DEADLINE_EXCEEDED: 'deadline-exceeded',\n  NOT_FOUND: 'not-found',\n  ALREADY_EXISTS: 'already-exists',\n  PERMISSION_DENIED: 'permission-denied',\n  UNAUTHENTICATED: 'unauthenticated',\n  RESOURCE_EXHAUSTED: 'resource-exhausted',\n  FAILED_PRECONDITION: 'failed-precondition',\n  ABORTED: 'aborted',\n  OUT_OF_RANGE: 'out-of-range',\n  UNIMPLEMENTED: 'unimplemented',\n  INTERNAL: 'internal',\n  UNAVAILABLE: 'unavailable',\n  DATA_LOSS: 'data-loss'\n};\n\n/**\n * An explicit error that can be thrown from a handler to send an error to the\n * client that called the function.\n */\nexport class HttpsErrorImpl extends Error implements HttpsError {\n  /**\n   * A standard error code that will be returned to the client. This also\n   * determines the HTTP status code of the response, as defined in code.proto.\n   */\n  readonly code: FunctionsErrorCode;\n\n  /**\n   * Extra data to be converted to JSON and included in the error response.\n   */\n  readonly details?: unknown;\n\n  constructor(code: FunctionsErrorCode, message?: string, details?: unknown) {\n    super(message);\n\n    // This is a workaround for a bug in TypeScript when extending Error:\n    // tslint:disable-next-line\n    // https://github.com/Microsoft/TypeScript-wiki/blob/master/Breaking-Changes.md#extending-built-ins-like-error-array-and-map-may-no-longer-work\n    Object.setPrototypeOf(this, HttpsErrorImpl.prototype);\n\n    this.code = code;\n    this.details = details;\n  }\n}\n\n/**\n * Takes an HTTP status code and returns the corresponding ErrorCode.\n * This is the standard HTTP status code -> error mapping defined in:\n * https://github.com/googleapis/googleapis/blob/master/google/rpc/code.proto\n *\n * @param status An HTTP status code.\n * @return The corresponding ErrorCode, or ErrorCode.UNKNOWN if none.\n */\nfunction codeForHTTPStatus(status: number): FunctionsErrorCode {\n  // Make sure any successful status is OK.\n  if (status >= 200 && status < 300) {\n    return 'ok';\n  }\n  switch (status) {\n    case 0:\n      // This can happen if the server returns 500.\n      return 'internal';\n    case 400:\n      return 'invalid-argument';\n    case 401:\n      return 'unauthenticated';\n    case 403:\n      return 'permission-denied';\n    case 404:\n      return 'not-found';\n    case 409:\n      return 'aborted';\n    case 429:\n      return 'resource-exhausted';\n    case 499:\n      return 'cancelled';\n    case 500:\n      return 'internal';\n    case 501:\n      return 'unimplemented';\n    case 503:\n      return 'unavailable';\n    case 504:\n      return 'deadline-exceeded';\n    default: // ignore\n  }\n  return 'unknown';\n}\n\n/**\n * Takes an HTTP response and returns the corresponding Error, if any.\n */\nexport function _errorForResponse(\n  status: number,\n  bodyJSON: HttpResponseBody | null,\n  serializer: Serializer\n): Error | null {\n  let code = codeForHTTPStatus(status);\n\n  // Start with reasonable defaults from the status code.\n  let description: string = code;\n\n  let details: unknown = undefined;\n\n  // Then look through the body for explicit details.\n  try {\n    const errorJSON = bodyJSON && bodyJSON.error;\n    if (errorJSON) {\n      const status = errorJSON.status;\n      if (typeof status === 'string') {\n        if (!errorCodeMap[status]) {\n          // They must've included an unknown error code in the body.\n          return new HttpsErrorImpl('internal', 'internal');\n        }\n        code = errorCodeMap[status];\n\n        // TODO(klimt): Add better default descriptions for error enums.\n        // The default description needs to be updated for the new code.\n        description = status;\n      }\n\n      const message = errorJSON.message;\n      if (typeof message === 'string') {\n        description = message;\n      }\n\n      details = errorJSON.details;\n      if (details !== undefined) {\n        details = serializer.decode(details);\n      }\n    }\n  } catch (e) {\n    // If we couldn't parse explicit error data, that's fine.\n  }\n\n  if (code === 'ok') {\n    // Technically, there's an edge case where a developer could explicitly\n    // return an error code of OK, and we will treat it as success, but that\n    // seems reasonable.\n    return null;\n  }\n\n  return new HttpsErrorImpl(code, description, details);\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n  FirebaseMessaging,\n  FirebaseMessagingName\n} from '@firebase/messaging-types';\nimport {\n  FirebaseAuthInternal,\n  FirebaseAuthInternalName\n} from '@firebase/auth-interop-types';\nimport { Provider } from '@firebase/component';\n\n/**\n * The metadata that should be supplied with function calls.\n */\nexport interface Context {\n  authToken?: string;\n  instanceIdToken?: string;\n}\n\n/**\n * Helper class to get metadata that should be included with a function call.\n */\nexport class ContextProvider {\n  private auth: FirebaseAuthInternal | null = null;\n  private messaging: FirebaseMessaging | null = null;\n  constructor(\n    authProvider: Provider<FirebaseAuthInternalName>,\n    messagingProvider: Provider<FirebaseMessagingName>\n  ) {\n    this.auth = authProvider.getImmediate({ optional: true });\n    this.messaging = messagingProvider.getImmediate({\n      optional: true\n    });\n\n    if (!this.auth) {\n      authProvider.get().then(\n        auth => (this.auth = auth),\n        () => {\n          /* get() never rejects */\n        }\n      );\n    }\n\n    if (!this.messaging) {\n      messagingProvider.get().then(\n        messaging => (this.messaging = messaging),\n        () => {\n          /* get() never rejects */\n        }\n      );\n    }\n  }\n\n  async getAuthToken(): Promise<string | undefined> {\n    if (!this.auth) {\n      return undefined;\n    }\n\n    try {\n      const token = await this.auth.getToken();\n      if (!token) {\n        return undefined;\n      }\n      return token.accessToken;\n    } catch (e) {\n      // If there's any error when trying to get the auth token, leave it off.\n      return undefined;\n    }\n  }\n\n  async getInstanceIdToken(): Promise<string | undefined> {\n    if (\n      !this.messaging ||\n      !('Notification' in self) ||\n      Notification.permission !== 'granted'\n    ) {\n      return undefined;\n    }\n\n    try {\n      return this.messaging.getToken();\n    } catch (e) {\n      // We don't warn on this, because it usually means messaging isn't set up.\n      // console.warn('Failed to retrieve instance id token.', e);\n\n      // If there's any error when trying to get the token, leave it off.\n      return undefined;\n    }\n  }\n\n  async getContext(): Promise<Context> {\n    const authToken = await this.getAuthToken();\n    const instanceIdToken = await this.getInstanceIdToken();\n    return { authToken, instanceIdToken };\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nconst LONG_TYPE = 'type.googleapis.com/google.protobuf.Int64Value';\nconst UNSIGNED_LONG_TYPE = 'type.googleapis.com/google.protobuf.UInt64Value';\n\nfunction mapValues(\n  // { [k: string]: unknown } is no longer a wildcard assignment target after typescript 3.5\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  o: { [key: string]: any },\n  f: (arg0: unknown) => unknown\n): object {\n  const result: { [key: string]: unknown } = {};\n  for (const key in o) {\n    if (o.hasOwnProperty(key)) {\n      result[key] = f(o[key]);\n    }\n  }\n  return result;\n}\n\nexport class Serializer {\n  // Takes data and encodes it in a JSON-friendly way, such that types such as\n  // Date are preserved.\n  encode(data: unknown): unknown {\n    if (data == null) {\n      return null;\n    }\n    if (data instanceof Number) {\n      data = data.valueOf();\n    }\n    if (typeof data === 'number' && isFinite(data)) {\n      // Any number in JS is safe to put directly in JSON and parse as a double\n      // without any loss of precision.\n      return data;\n    }\n    if (data === true || data === false) {\n      return data;\n    }\n    if (Object.prototype.toString.call(data) === '[object String]') {\n      return data;\n    }\n    if (Array.isArray(data)) {\n      return data.map(x => this.encode(x));\n    }\n    if (typeof data === 'function' || typeof data === 'object') {\n      return mapValues(data!, x => this.encode(x));\n    }\n    // If we got this far, the data is not encodable.\n    throw new Error('Data cannot be encoded in JSON: ' + data);\n  }\n\n  // Takes data that's been encoded in a JSON-friendly form and returns a form\n  // with richer datatypes, such as Dates, etc.\n  decode(json: unknown): unknown {\n    if (json == null) {\n      return json;\n    }\n    if ((json as { [key: string]: unknown })['@type']) {\n      switch ((json as { [key: string]: unknown })['@type']) {\n        case LONG_TYPE:\n        // Fall through and handle this the same as unsigned.\n        case UNSIGNED_LONG_TYPE: {\n          // Technically, this could work return a valid number for malformed\n          // data if there was a number followed by garbage. But it's just not\n          // worth all the extra code to detect that case.\n          const value = Number((json as { [key: string]: unknown })['value']);\n          if (isNaN(value)) {\n            throw new Error('Data cannot be decoded from JSON: ' + json);\n          }\n          return value;\n        }\n        default: {\n          throw new Error('Data cannot be decoded from JSON: ' + json);\n        }\n      }\n    }\n    if (Array.isArray(json)) {\n      return json.map(x => this.decode(x));\n    }\n    if (typeof json === 'function' || typeof json === 'object') {\n      return mapValues(json!, x => this.decode(x));\n    }\n    // Anything else is safe to return.\n    return json;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FirebaseApp } from '@firebase/app-types';\nimport { FirebaseService } from '@firebase/app-types/private';\nimport {\n  FirebaseFunctions,\n  HttpsCallable,\n  HttpsCallableResult,\n  HttpsCallableOptions\n} from '@firebase/functions-types';\nimport { _errorForResponse, HttpsErrorImpl } from './error';\nimport { ContextProvider } from '../context';\nimport { Serializer } from '../serializer';\nimport { Provider } from '@firebase/component';\nimport { FirebaseAuthInternalName } from '@firebase/auth-interop-types';\nimport { FirebaseMessagingName } from '@firebase/messaging-types';\n\n/**\n * The response to an http request.\n */\ninterface HttpResponse {\n  status: number;\n  json: HttpResponseBody | null;\n}\n/**\n * Describes the shape of the HttpResponse body.\n * It makes functions that would otherwise take {} able to access the\n * possible elements in the body more easily\n */\nexport interface HttpResponseBody {\n  data?: unknown;\n  result?: unknown;\n  error?: {\n    message?: unknown;\n    status?: unknown;\n    details?: unknown;\n  };\n}\n\n/**\n * Returns a Promise that will be rejected after the given duration.\n * The error will be of type HttpsErrorImpl.\n *\n * @param millis Number of milliseconds to wait before rejecting.\n */\nfunction failAfter(\n  millis: number\n): {\n  timer: number | NodeJS.Timeout;\n  promise: Promise<never>;\n} {\n  let timer!: number | NodeJS.Timeout;\n  const promise = new Promise<never>((_, reject) => {\n    timer = setTimeout(() => {\n      reject(new HttpsErrorImpl('deadline-exceeded', 'deadline-exceeded'));\n    }, millis);\n  });\n\n  return {\n    timer,\n    promise\n  };\n}\n\n/**\n * The main class for the Firebase Functions SDK.\n */\nexport class Service implements FirebaseFunctions, FirebaseService {\n  private readonly contextProvider: ContextProvider;\n  private readonly serializer = new Serializer();\n  private emulatorOrigin: string | null = null;\n  private cancelAllRequests: Promise<void>;\n  private deleteService!: () => void;\n  private region: string;\n  private customDomain: string | null;\n\n  /**\n   * Creates a new Functions service for the given app and (optional) region or custom domain.\n   * @param app_ The FirebaseApp to use.\n   * @param regionOrCustomDomain_ one of:\n   *   a) A region to call functions from, such as us-central1\n   *   b) A custom domain to use as a functions prefix, such as https://mydomain.com\n   */\n  constructor(\n    private app_: FirebaseApp,\n    authProvider: Provider<FirebaseAuthInternalName>,\n    messagingProvider: Provider<FirebaseMessagingName>,\n    regionOrCustomDomain_: string = 'us-central1',\n    readonly fetchImpl: typeof fetch\n  ) {\n    this.contextProvider = new ContextProvider(authProvider, messagingProvider);\n    // Cancels all ongoing requests when resolved.\n    this.cancelAllRequests = new Promise(resolve => {\n      this.deleteService = () => {\n        return resolve();\n      };\n    });\n\n    // Resolve the region or custom domain overload by attempting to parse it.\n    try {\n      const url = new URL(regionOrCustomDomain_);\n      this.customDomain = url.origin;\n      this.region = 'us-central1';\n    } catch (e) {\n      this.customDomain = null;\n      this.region = regionOrCustomDomain_;\n    }\n  }\n\n  get app(): FirebaseApp {\n    return this.app_;\n  }\n\n  INTERNAL = {\n    delete: (): Promise<void> => {\n      return Promise.resolve(this.deleteService());\n    }\n  };\n\n  /**\n   * Returns the URL for a callable with the given name.\n   * @param name The name of the callable.\n   */\n  _url(name: string): string {\n    const projectId = this.app_.options.projectId;\n    if (this.emulatorOrigin !== null) {\n      const origin = this.emulatorOrigin;\n      return `${origin}/${projectId}/${this.region}/${name}`;\n    }\n\n    if (this.customDomain !== null) {\n      return `${this.customDomain}/${name}`;\n    }\n\n    return `https://${this.region}-${projectId}.cloudfunctions.net/${name}`;\n  }\n\n  /**\n   * Modify this instance to communicate with the Cloud Functions emulator.\n   *\n   * Note: this must be called before this instance has been used to do any operations.\n   *\n   * @param host The emulator host (ex: localhost)\n   * @param port The emulator port (ex: 5001)\n   */\n  useEmulator(host: string, port: number): void {\n    this.emulatorOrigin = `http://${host}:${port}`;\n  }\n\n  /**\n   * Changes this instance to point to a Cloud Functions emulator running\n   * locally. See https://firebase.google.com/docs/functions/local-emulator\n   *\n   * @deprecated Prefer the useEmulator(host, port) method.\n   * @param origin The origin of the local emulator, such as\n   * \"http://localhost:5005\".\n   */\n  useFunctionsEmulator(origin: string): void {\n    this.emulatorOrigin = origin;\n  }\n\n  /**\n   * Returns a reference to the callable https trigger with the given name.\n   * @param name The name of the trigger.\n   */\n  httpsCallable(name: string, options?: HttpsCallableOptions): HttpsCallable {\n    return data => {\n      return this.call(name, data, options || {});\n    };\n  }\n\n  /**\n   * Does an HTTP POST and returns the completed response.\n   * @param url The url to post to.\n   * @param body The JSON body of the post.\n   * @param headers The HTTP headers to include in the request.\n   * @return A Promise that will succeed when the request finishes.\n   */\n  private async postJSON(\n    url: string,\n    body: {},\n    headers: { [key: string]: string }\n  ): Promise<HttpResponse> {\n    headers['Content-Type'] = 'application/json';\n\n    let response: Response;\n    try {\n      response = await this.fetchImpl(url, {\n        method: 'POST',\n        body: JSON.stringify(body),\n        headers\n      });\n    } catch (e) {\n      // This could be an unhandled error on the backend, or it could be a\n      // network error. There's no way to know, since an unhandled error on the\n      // backend will fail to set the proper CORS header, and thus will be\n      // treated as a network error by fetch.\n      return {\n        status: 0,\n        json: null\n      };\n    }\n    let json: HttpResponseBody | null = null;\n    try {\n      json = await response.json();\n    } catch (e) {\n      // If we fail to parse JSON, it will fail the same as an empty body.\n    }\n    return {\n      status: response.status,\n      json\n    };\n  }\n\n  /**\n   * Calls a callable function asynchronously and returns the result.\n   * @param name The name of the callable trigger.\n   * @param data The data to pass as params to the function.s\n   */\n  private async call(\n    name: string,\n    data: unknown,\n    options: HttpsCallableOptions\n  ): Promise<HttpsCallableResult> {\n    const url = this._url(name);\n\n    // Encode any special types, such as dates, in the input data.\n    data = this.serializer.encode(data);\n    const body = { data };\n\n    // Add a header for the authToken.\n    const headers: { [key: string]: string } = {};\n    const context = await this.contextProvider.getContext();\n    if (context.authToken) {\n      headers['Authorization'] = 'Bearer ' + context.authToken;\n    }\n    if (context.instanceIdToken) {\n      headers['Firebase-Instance-ID-Token'] = context.instanceIdToken;\n    }\n\n    // Default timeout to 70s, but let the options override it.\n    const timeout = options.timeout || 70000;\n\n    const { timer, promise: failAfterPromise } = failAfter(timeout);\n\n    const response = await Promise.race([\n      clearTimeoutWrapper(timer, this.postJSON(url, body, headers)),\n      failAfterPromise,\n      clearTimeoutWrapper(timer, this.cancelAllRequests)\n    ]);\n\n    // If service was deleted, interrupted response throws an error.\n    if (!response) {\n      throw new HttpsErrorImpl(\n        'cancelled',\n        'Firebase Functions instance was deleted.'\n      );\n    }\n\n    // Check for an error status, regardless of http status.\n    const error = _errorForResponse(\n      response.status,\n      response.json,\n      this.serializer\n    );\n    if (error) {\n      throw error;\n    }\n\n    if (!response.json) {\n      throw new HttpsErrorImpl(\n        'internal',\n        'Response is not valid JSON object.'\n      );\n    }\n\n    let responseData = response.json.data;\n    // TODO(klimt): For right now, allow \"result\" instead of \"data\", for\n    // backwards compatibility.\n    if (typeof responseData === 'undefined') {\n      responseData = response.json.result;\n    }\n    if (typeof responseData === 'undefined') {\n      // Consider the response malformed.\n      throw new HttpsErrorImpl('internal', 'Response is missing data field.');\n    }\n\n    // Decode any special types, such as dates, in the returned data.\n    const decodedData = this.serializer.decode(responseData);\n\n    return { data: decodedData };\n  }\n}\n\nasync function clearTimeoutWrapper<T>(\n  timer: number | NodeJS.Timeout,\n  promise: Promise<T>\n): Promise<T> {\n  const result = await promise;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  clearTimeout(timer as any);\n  return result;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Service } from './api/service';\nimport {\n  Component,\n  ComponentType,\n  ComponentContainer\n} from '@firebase/component';\nimport { _FirebaseNamespace } from '@firebase/app-types/private';\n\n/**\n * Type constant for Firebase Functions.\n */\nconst FUNCTIONS_TYPE = 'functions';\n\nexport function registerFunctions(\n  instance: _FirebaseNamespace,\n  fetchImpl: typeof fetch\n): void {\n  const namespaceExports = {\n    // no-inline\n    Functions: Service\n  };\n\n  function factory(\n    container: ComponentContainer,\n    regionOrCustomDomain?: string\n  ): Service {\n    // Dependencies\n    const app = container.getProvider('app').getImmediate();\n    const authProvider = container.getProvider('auth-internal');\n    const messagingProvider = container.getProvider('messaging');\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return new Service(\n      app,\n      authProvider,\n      messagingProvider,\n      regionOrCustomDomain,\n      fetchImpl\n    );\n  }\n  instance.INTERNAL.registerComponent(\n    new Component(FUNCTIONS_TYPE, factory, ComponentType.PUBLIC)\n      .setServiceProps(namespaceExports)\n      .setMultipleInstances(true)\n  );\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport const DEFAULT_SW_PATH = '/firebase-messaging-sw.js';\nexport const DEFAULT_SW_SCOPE = '/firebase-cloud-messaging-push-scope';\n\nexport const DEFAULT_VAPID_KEY =\n  'BDOU99-h67HcA6JeFXHbSNMu7e2yNNu3RzoMj8TM4W88jITfq7ZmPvIM1Iv-4_l2LxQcYwhqby2xGpWwzjfAnG4';\n\nexport const ENDPOINT = 'https://fcmregistrations.googleapis.com/v1';\n\n// Key of FCM Payload in Notification's data field.\nexport const FCM_MSG = 'FCM_MSG';\nexport const TAG = 'FirebaseMessaging: ';\n\n// Set to '1' if Analytics is enabled for the campaign\nexport const CONSOLE_CAMPAIGN_ANALYTICS_ENABLED = 'google.c.a.e';\nexport const CONSOLE_CAMPAIGN_ID = 'google.c.a.c_id';\nexport const CONSOLE_CAMPAIGN_TIME = 'google.c.a.ts';\nexport const CONSOLE_CAMPAIGN_NAME = 'google.c.a.c_l';\n\n// Due to the fact that onBackgroundMessage can't be awaited (to support rxjs), a silent push\n// warning might be shown by the browser if the callback fails to completes by the end of onPush.\n// Experiments were ran to determine the majority onBackground message clock time. This brief\n// blocking time would allow majority of the onBackgroundMessage callback to finish.\nexport const BACKGROUND_HANDLE_EXECUTION_TIME_LIMIT_MS = 1000;\n\n// Preparation time for client to initialize and set up the message handler.\nexport const FOREGROUND_HANDLE_PREPARATION_TIME_MS = 3000;\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ErrorFactory, ErrorMap } from '@firebase/util';\n\nexport const enum ErrorCode {\n  MISSING_APP_CONFIG_VALUES = 'missing-app-config-values',\n  AVAILABLE_IN_WINDOW = 'only-available-in-window',\n  AVAILABLE_IN_SW = 'only-available-in-sw',\n  PERMISSION_DEFAULT = 'permission-default',\n  PERMISSION_BLOCKED = 'permission-blocked',\n  UNSUPPORTED_BROWSER = 'unsupported-browser',\n  FAILED_DEFAULT_REGISTRATION = 'failed-service-worker-registration',\n  TOKEN_SUBSCRIBE_FAILED = 'token-subscribe-failed',\n  TOKEN_SUBSCRIBE_NO_TOKEN = 'token-subscribe-no-token',\n  TOKEN_UNSUBSCRIBE_FAILED = 'token-unsubscribe-failed',\n  TOKEN_UPDATE_FAILED = 'token-update-failed',\n  TOKEN_UPDATE_NO_TOKEN = 'token-update-no-token',\n  INVALID_BG_HANDLER = 'invalid-bg-handler',\n  USE_SW_AFTER_GET_TOKEN = 'use-sw-after-get-token',\n  INVALID_SW_REGISTRATION = 'invalid-sw-registration',\n  USE_VAPID_KEY_AFTER_GET_TOKEN = 'use-vapid-key-after-get-token',\n  INVALID_VAPID_KEY = 'invalid-vapid-key'\n}\n\nexport const ERROR_MAP: ErrorMap<ErrorCode> = {\n  [ErrorCode.MISSING_APP_CONFIG_VALUES]:\n    'Missing App configuration value: \"{$valueName}\"',\n  [ErrorCode.AVAILABLE_IN_WINDOW]:\n    'This method is available in a Window context.',\n  [ErrorCode.AVAILABLE_IN_SW]:\n    'This method is available in a service worker context.',\n  [ErrorCode.PERMISSION_DEFAULT]:\n    'The notification permission was not granted and dismissed instead.',\n  [ErrorCode.PERMISSION_BLOCKED]:\n    'The notification permission was not granted and blocked instead.',\n  [ErrorCode.UNSUPPORTED_BROWSER]:\n    \"This browser doesn't support the API's required to use the firebase SDK.\",\n  [ErrorCode.FAILED_DEFAULT_REGISTRATION]:\n    'We are unable to register the default service worker. {$browserErrorMessage}',\n  [ErrorCode.TOKEN_SUBSCRIBE_FAILED]:\n    'A problem occurred while subscribing the user to FCM: {$errorInfo}',\n  [ErrorCode.TOKEN_SUBSCRIBE_NO_TOKEN]:\n    'FCM returned no token when subscribing the user to push.',\n  [ErrorCode.TOKEN_UNSUBSCRIBE_FAILED]:\n    'A problem occurred while unsubscribing the ' +\n    'user from FCM: {$errorInfo}',\n  [ErrorCode.TOKEN_UPDATE_FAILED]:\n    'A problem occurred while updating the user from FCM: {$errorInfo}',\n  [ErrorCode.TOKEN_UPDATE_NO_TOKEN]:\n    'FCM returned no token when updating the user to push.',\n  [ErrorCode.USE_SW_AFTER_GET_TOKEN]:\n    'The useServiceWorker() method may only be called once and must be ' +\n    'called before calling getToken() to ensure your service worker is used.',\n  [ErrorCode.INVALID_SW_REGISTRATION]:\n    'The input to useServiceWorker() must be a ServiceWorkerRegistration.',\n  [ErrorCode.INVALID_BG_HANDLER]:\n    'The input to setBackgroundMessageHandler() must be a function.',\n  [ErrorCode.INVALID_VAPID_KEY]: 'The public VAPID key must be a string.',\n  [ErrorCode.USE_VAPID_KEY_AFTER_GET_TOKEN]:\n    'The usePublicVapidKey() method may only be called once and must be ' +\n    'called before calling getToken() to ensure your VAPID key is used.'\n};\n\ninterface ErrorParams {\n  [ErrorCode.MISSING_APP_CONFIG_VALUES]: {\n    valueName: string;\n  };\n  [ErrorCode.FAILED_DEFAULT_REGISTRATION]: { browserErrorMessage: string };\n  [ErrorCode.TOKEN_SUBSCRIBE_FAILED]: { errorInfo: string };\n  [ErrorCode.TOKEN_UNSUBSCRIBE_FAILED]: { errorInfo: string };\n  [ErrorCode.TOKEN_UPDATE_FAILED]: { errorInfo: string };\n}\n\nexport const ERROR_FACTORY = new ErrorFactory<ErrorCode, ErrorParams>(\n  'messaging',\n  'Messaging',\n  ERROR_MAP\n);\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FirebaseError } from '@firebase/util';\nimport { GenerateAuthTokenResponse } from '../interfaces/api-response';\nimport { AppConfig } from '../interfaces/app-config';\nimport {\n  CompletedAuthToken,\n  RegisteredInstallationEntry,\n  RequestStatus\n} from '../interfaces/installation-entry';\nimport {\n  INSTALLATIONS_API_URL,\n  INTERNAL_AUTH_VERSION\n} from '../util/constants';\nimport { ERROR_FACTORY, ErrorCode } from '../util/errors';\n\nexport function getInstallationsEndpoint({ projectId }: AppConfig): string {\n  return `${INSTALLATIONS_API_URL}/projects/${projectId}/installations`;\n}\n\nexport function extractAuthTokenInfoFromResponse(\n  response: GenerateAuthTokenResponse\n): CompletedAuthToken {\n  return {\n    token: response.token,\n    requestStatus: RequestStatus.COMPLETED,\n    expiresIn: getExpiresInFromResponseExpiresIn(response.expiresIn),\n    creationTime: Date.now()\n  };\n}\n\nexport async function getErrorFromResponse(\n  requestName: string,\n  response: Response\n): Promise<FirebaseError> {\n  const responseJson: ErrorResponse = await response.json();\n  const errorData = responseJson.error;\n  return ERROR_FACTORY.create(ErrorCode.REQUEST_FAILED, {\n    requestName,\n    serverCode: errorData.code,\n    serverMessage: errorData.message,\n    serverStatus: errorData.status\n  });\n}\n\nexport function getHeaders({ apiKey }: AppConfig): Headers {\n  return new Headers({\n    'Content-Type': 'application/json',\n    Accept: 'application/json',\n    'x-goog-api-key': apiKey\n  });\n}\n\nexport function getHeadersWithAuth(\n  appConfig: AppConfig,\n  { refreshToken }: RegisteredInstallationEntry\n): Headers {\n  const headers = getHeaders(appConfig);\n  headers.append('Authorization', getAuthorizationHeader(refreshToken));\n  return headers;\n}\n\nexport interface ErrorResponse {\n  error: {\n    code: number;\n    message: string;\n    status: string;\n  };\n}\n\n/**\n * Calls the passed in fetch wrapper and returns the response.\n * If the returned response has a status of 5xx, re-runs the function once and\n * returns the response.\n */\nexport async function retryIfServerError(\n  fn: () => Promise<Response>\n): Promise<Response> {\n  const result = await fn();\n\n  if (result.status >= 500 && result.status < 600) {\n    // Internal Server Error. Retry request.\n    return fn();\n  }\n\n  return result;\n}\n\nfunction getExpiresInFromResponseExpiresIn(responseExpiresIn: string): number {\n  // This works because the server will never respond with fractions of a second.\n  return Number(responseExpiresIn.replace('s', '000'));\n}\n\nfunction getAuthorizationHeader(refreshToken: string): string {\n  return `${INTERNAL_AUTH_VERSION} ${refreshToken}`;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { CreateInstallationResponse } from '../interfaces/api-response';\nimport { AppConfig } from '../interfaces/app-config';\nimport {\n  InProgressInstallationEntry,\n  RegisteredInstallationEntry,\n  RequestStatus\n} from '../interfaces/installation-entry';\nimport { INTERNAL_AUTH_VERSION, PACKAGE_VERSION } from '../util/constants';\nimport {\n  extractAuthTokenInfoFromResponse,\n  getErrorFromResponse,\n  getHeaders,\n  getInstallationsEndpoint,\n  retryIfServerError\n} from './common';\n\nexport async function createInstallationRequest(\n  appConfig: AppConfig,\n  { fid }: InProgressInstallationEntry\n): Promise<RegisteredInstallationEntry> {\n  const endpoint = getInstallationsEndpoint(appConfig);\n\n  const headers = getHeaders(appConfig);\n  const body = {\n    fid,\n    authVersion: INTERNAL_AUTH_VERSION,\n    appId: appConfig.appId,\n    sdkVersion: PACKAGE_VERSION\n  };\n\n  const request: RequestInit = {\n    method: 'POST',\n    headers,\n    body: JSON.stringify(body)\n  };\n\n  const response = await retryIfServerError(() => fetch(endpoint, request));\n  if (response.ok) {\n    const responseValue: CreateInstallationResponse = await response.json();\n    const registeredInstallationEntry: RegisteredInstallationEntry = {\n      fid: responseValue.fid || fid,\n      registrationStatus: RequestStatus.COMPLETED,\n      refreshToken: responseValue.refreshToken,\n      authToken: extractAuthTokenInfoFromResponse(responseValue.authToken)\n    };\n    return registeredInstallationEntry;\n  } else {\n    throw await getErrorFromResponse('Create Installation', response);\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/** Returns a promise that resolves after given time passes. */\nexport function sleep(ms: number): Promise<void> {\n  return new Promise<void>(resolve => {\n    setTimeout(resolve, ms);\n  });\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { bufferToBase64UrlSafe } from './buffer-to-base64-url-safe';\n\nexport const VALID_FID_PATTERN = /^[cdef][\\w-]{21}$/;\nexport const INVALID_FID = '';\n\n/**\n * Generates a new FID using random values from Web Crypto API.\n * Returns an empty string if FID generation fails for any reason.\n */\nexport function generateFid(): string {\n  try {\n    // A valid FID has exactly 22 base64 characters, which is 132 bits, or 16.5\n    // bytes. our implementation generates a 17 byte array instead.\n    const fidByteArray = new Uint8Array(17);\n    const crypto =\n      self.crypto || ((self as unknown) as { msCrypto: Crypto }).msCrypto;\n    crypto.getRandomValues(fidByteArray);\n\n    // Replace the first 4 random bits with the constant FID header of 0b0111.\n    fidByteArray[0] = 0b01110000 + (fidByteArray[0] % 0b00010000);\n\n    const fid = encode(fidByteArray);\n\n    return VALID_FID_PATTERN.test(fid) ? fid : INVALID_FID;\n  } catch {\n    // FID generation errored\n    return INVALID_FID;\n  }\n}\n\n/** Converts a FID Uint8Array to a base64 string representation. */\nfunction encode(fidByteArray: Uint8Array): string {\n  const b64String = bufferToBase64UrlSafe(fidByteArray);\n\n  // Remove the 23rd character that was added because of the extra 4 bits at the\n  // end of our 17 byte array, and the '=' padding.\n  return b64String.substr(0, 22);\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport function bufferToBase64UrlSafe(array: Uint8Array): string {\n  const b64 = btoa(String.fromCharCode(...array));\n  return b64.replace(/\\+/g, '-').replace(/\\//g, '_');\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { AppConfig } from '../interfaces/app-config';\n\n/** Returns a string key that can be used to identify the app. */\nexport function getKey(appConfig: AppConfig): string {\n  return `${appConfig.appName}!${appConfig.appId}`;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getKey } from '../util/get-key';\nimport { AppConfig } from '../interfaces/app-config';\nimport { IdChangeCallbackFn } from '../functions';\n\nconst fidChangeCallbacks: Map<string, Set<IdChangeCallbackFn>> = new Map();\n\n/**\n * Calls the onIdChange callbacks with the new FID value, and broadcasts the\n * change to other tabs.\n */\nexport function fidChanged(appConfig: AppConfig, fid: string): void {\n  const key = getKey(appConfig);\n\n  callFidChangeCallbacks(key, fid);\n  broadcastFidChange(key, fid);\n}\n\nexport function addCallback(\n  appConfig: AppConfig,\n  callback: IdChangeCallbackFn\n): void {\n  // Open the broadcast channel if it's not already open,\n  // to be able to listen to change events from other tabs.\n  getBroadcastChannel();\n\n  const key = getKey(appConfig);\n\n  let callbackSet = fidChangeCallbacks.get(key);\n  if (!callbackSet) {\n    callbackSet = new Set();\n    fidChangeCallbacks.set(key, callbackSet);\n  }\n  callbackSet.add(callback);\n}\n\nexport function removeCallback(\n  appConfig: AppConfig,\n  callback: IdChangeCallbackFn\n): void {\n  const key = getKey(appConfig);\n\n  const callbackSet = fidChangeCallbacks.get(key);\n\n  if (!callbackSet) {\n    return;\n  }\n\n  callbackSet.delete(callback);\n  if (callbackSet.size === 0) {\n    fidChangeCallbacks.delete(key);\n  }\n\n  // Close broadcast channel if there are no more callbacks.\n  closeBroadcastChannel();\n}\n\nfunction callFidChangeCallbacks(key: string, fid: string): void {\n  const callbacks = fidChangeCallbacks.get(key);\n  if (!callbacks) {\n    return;\n  }\n\n  for (const callback of callbacks) {\n    callback(fid);\n  }\n}\n\nfunction broadcastFidChange(key: string, fid: string): void {\n  const channel = getBroadcastChannel();\n  if (channel) {\n    channel.postMessage({ key, fid });\n  }\n  closeBroadcastChannel();\n}\n\nlet broadcastChannel: BroadcastChannel | null = null;\n/** Opens and returns a BroadcastChannel if it is supported by the browser. */\nfunction getBroadcastChannel(): BroadcastChannel | null {\n  if (!broadcastChannel && 'BroadcastChannel' in self) {\n    broadcastChannel = new BroadcastChannel('[Firebase] FID Change');\n    broadcastChannel.onmessage = e => {\n      callFidChangeCallbacks(e.data.key, e.data.fid);\n    };\n  }\n  return broadcastChannel;\n}\n\nfunction closeBroadcastChannel(): void {\n  if (fidChangeCallbacks.size === 0 && broadcastChannel) {\n    broadcastChannel.close();\n    broadcastChannel = null;\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { DB, deleteDb, openDb } from 'idb';\n\nimport { FirebaseInternalDependencies } from '../interfaces/internal-dependencies';\nimport { TokenDetails } from '../interfaces/token-details';\nimport { migrateOldDatabase } from './migrate-old-database';\n\n// Exported for tests.\nexport const DATABASE_NAME = 'firebase-messaging-database';\nconst DATABASE_VERSION = 1;\nconst OBJECT_STORE_NAME = 'firebase-messaging-store';\n\nlet dbPromise: Promise<DB> | null = null;\nfunction getDbPromise(): Promise<DB> {\n  if (!dbPromise) {\n    dbPromise = openDb(DATABASE_NAME, DATABASE_VERSION, upgradeDb => {\n      // We don't use 'break' in this switch statement, the fall-through behavior is what we want,\n      // because if there are multiple versions between the old version and the current version, we\n      // want ALL the migrations that correspond to those versions to run, not only the last one.\n      // eslint-disable-next-line default-case\n      switch (upgradeDb.oldVersion) {\n        case 0:\n          upgradeDb.createObjectStore(OBJECT_STORE_NAME);\n      }\n    });\n  }\n  return dbPromise;\n}\n\n/** Gets record(s) from the objectStore that match the given key. */\nexport async function dbGet(\n  firebaseDependencies: FirebaseInternalDependencies\n): Promise<TokenDetails | undefined> {\n  const key = getKey(firebaseDependencies);\n  const db = await getDbPromise();\n  const tokenDetails = await db\n    .transaction(OBJECT_STORE_NAME)\n    .objectStore(OBJECT_STORE_NAME)\n    .get(key);\n\n  if (tokenDetails) {\n    return tokenDetails;\n  } else {\n    // Check if there is a tokenDetails object in the old DB.\n    const oldTokenDetails = await migrateOldDatabase(\n      firebaseDependencies.appConfig.senderId\n    );\n    if (oldTokenDetails) {\n      await dbSet(firebaseDependencies, oldTokenDetails);\n      return oldTokenDetails;\n    }\n  }\n}\n\n/** Assigns or overwrites the record for the given key with the given value. */\nexport async function dbSet(\n  firebaseDependencies: FirebaseInternalDependencies,\n  tokenDetails: TokenDetails\n): Promise<TokenDetails> {\n  const key = getKey(firebaseDependencies);\n  const db = await getDbPromise();\n  const tx = db.transaction(OBJECT_STORE_NAME, 'readwrite');\n  await tx.objectStore(OBJECT_STORE_NAME).put(tokenDetails, key);\n  await tx.complete;\n  return tokenDetails;\n}\n\n/** Removes record(s) from the objectStore that match the given key. */\nexport async function dbRemove(\n  firebaseDependencies: FirebaseInternalDependencies\n): Promise<void> {\n  const key = getKey(firebaseDependencies);\n  const db = await getDbPromise();\n  const tx = db.transaction(OBJECT_STORE_NAME, 'readwrite');\n  await tx.objectStore(OBJECT_STORE_NAME).delete(key);\n  await tx.complete;\n}\n\n/** Deletes the DB. Useful for tests. */\nexport async function dbDelete(): Promise<void> {\n  if (dbPromise) {\n    (await dbPromise).close();\n    await deleteDb(DATABASE_NAME);\n    dbPromise = null;\n  }\n}\n\nfunction getKey({ appConfig }: FirebaseInternalDependencies): string {\n  return appConfig.appId;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { createInstallationRequest } from '../api/create-installation-request';\nimport { AppConfig } from '../interfaces/app-config';\nimport {\n  InProgressInstallationEntry,\n  InstallationEntry,\n  RegisteredInstallationEntry,\n  RequestStatus\n} from '../interfaces/installation-entry';\nimport { PENDING_TIMEOUT_MS } from '../util/constants';\nimport { ERROR_FACTORY, ErrorCode, isServerError } from '../util/errors';\nimport { sleep } from '../util/sleep';\nimport { generateFid, INVALID_FID } from './generate-fid';\nimport { remove, set, update } from './idb-manager';\n\nexport interface InstallationEntryWithRegistrationPromise {\n  installationEntry: InstallationEntry;\n  /** Exist iff the installationEntry is not registered. */\n  registrationPromise?: Promise<RegisteredInstallationEntry>;\n}\n\n/**\n * Updates and returns the InstallationEntry from the database.\n * Also triggers a registration request if it is necessary and possible.\n */\nexport async function getInstallationEntry(\n  appConfig: AppConfig\n): Promise<InstallationEntryWithRegistrationPromise> {\n  let registrationPromise: Promise<RegisteredInstallationEntry> | undefined;\n\n  const installationEntry = await update(appConfig, oldEntry => {\n    const installationEntry = updateOrCreateInstallationEntry(oldEntry);\n    const entryWithPromise = triggerRegistrationIfNecessary(\n      appConfig,\n      installationEntry\n    );\n    registrationPromise = entryWithPromise.registrationPromise;\n    return entryWithPromise.installationEntry;\n  });\n\n  if (installationEntry.fid === INVALID_FID) {\n    // FID generation failed. Waiting for the FID from the server.\n    return { installationEntry: await registrationPromise! };\n  }\n\n  return {\n    installationEntry,\n    registrationPromise\n  };\n}\n\n/**\n * Creates a new Installation Entry if one does not exist.\n * Also clears timed out pending requests.\n */\nfunction updateOrCreateInstallationEntry(\n  oldEntry: InstallationEntry | undefined\n): InstallationEntry {\n  const entry: InstallationEntry = oldEntry || {\n    fid: generateFid(),\n    registrationStatus: RequestStatus.NOT_STARTED\n  };\n\n  return clearTimedOutRequest(entry);\n}\n\n/**\n * If the Firebase Installation is not registered yet, this will trigger the\n * registration and return an InProgressInstallationEntry.\n *\n * If registrationPromise does not exist, the installationEntry is guaranteed\n * to be registered.\n */\nfunction triggerRegistrationIfNecessary(\n  appConfig: AppConfig,\n  installationEntry: InstallationEntry\n): InstallationEntryWithRegistrationPromise {\n  if (installationEntry.registrationStatus === RequestStatus.NOT_STARTED) {\n    if (!navigator.onLine) {\n      // Registration required but app is offline.\n      const registrationPromiseWithError = Promise.reject(\n        ERROR_FACTORY.create(ErrorCode.APP_OFFLINE)\n      );\n      return {\n        installationEntry,\n        registrationPromise: registrationPromiseWithError\n      };\n    }\n\n    // Try registering. Change status to IN_PROGRESS.\n    const inProgressEntry: InProgressInstallationEntry = {\n      fid: installationEntry.fid,\n      registrationStatus: RequestStatus.IN_PROGRESS,\n      registrationTime: Date.now()\n    };\n    const registrationPromise = registerInstallation(\n      appConfig,\n      inProgressEntry\n    );\n    return { installationEntry: inProgressEntry, registrationPromise };\n  } else if (\n    installationEntry.registrationStatus === RequestStatus.IN_PROGRESS\n  ) {\n    return {\n      installationEntry,\n      registrationPromise: waitUntilFidRegistration(appConfig)\n    };\n  } else {\n    return { installationEntry };\n  }\n}\n\n/** This will be executed only once for each new Firebase Installation. */\nasync function registerInstallation(\n  appConfig: AppConfig,\n  installationEntry: InProgressInstallationEntry\n): Promise<RegisteredInstallationEntry> {\n  try {\n    const registeredInstallationEntry = await createInstallationRequest(\n      appConfig,\n      installationEntry\n    );\n    return set(appConfig, registeredInstallationEntry);\n  } catch (e) {\n    if (isServerError(e) && e.customData.serverCode === 409) {\n      // Server returned a \"FID can not be used\" error.\n      // Generate a new ID next time.\n      await remove(appConfig);\n    } else {\n      // Registration failed. Set FID as not registered.\n      await set(appConfig, {\n        fid: installationEntry.fid,\n        registrationStatus: RequestStatus.NOT_STARTED\n      });\n    }\n    throw e;\n  }\n}\n\n/** Call if FID registration is pending in another request. */\nasync function waitUntilFidRegistration(\n  appConfig: AppConfig\n): Promise<RegisteredInstallationEntry> {\n  // Unfortunately, there is no way of reliably observing when a value in\n  // IndexedDB changes (yet, see https://github.com/WICG/indexed-db-observers),\n  // so we need to poll.\n\n  let entry: InstallationEntry = await updateInstallationRequest(appConfig);\n  while (entry.registrationStatus === RequestStatus.IN_PROGRESS) {\n    // createInstallation request still in progress.\n    await sleep(100);\n\n    entry = await updateInstallationRequest(appConfig);\n  }\n\n  if (entry.registrationStatus === RequestStatus.NOT_STARTED) {\n    // The request timed out or failed in a different call. Try again.\n    const {\n      installationEntry,\n      registrationPromise\n    } = await getInstallationEntry(appConfig);\n\n    if (registrationPromise) {\n      return registrationPromise;\n    } else {\n      // if there is no registrationPromise, entry is registered.\n      return installationEntry as RegisteredInstallationEntry;\n    }\n  }\n\n  return entry;\n}\n\n/**\n * Called only if there is a CreateInstallation request in progress.\n *\n * Updates the InstallationEntry in the DB based on the status of the\n * CreateInstallation request.\n *\n * Returns the updated InstallationEntry.\n */\nfunction updateInstallationRequest(\n  appConfig: AppConfig\n): Promise<InstallationEntry> {\n  return update(appConfig, oldEntry => {\n    if (!oldEntry) {\n      throw ERROR_FACTORY.create(ErrorCode.INSTALLATION_NOT_FOUND);\n    }\n    return clearTimedOutRequest(oldEntry);\n  });\n}\n\nfunction clearTimedOutRequest(entry: InstallationEntry): InstallationEntry {\n  if (hasInstallationRequestTimedOut(entry)) {\n    return {\n      fid: entry.fid,\n      registrationStatus: RequestStatus.NOT_STARTED\n    };\n  }\n\n  return entry;\n}\n\nfunction hasInstallationRequestTimedOut(\n  installationEntry: InstallationEntry\n): boolean {\n  return (\n    installationEntry.registrationStatus === RequestStatus.IN_PROGRESS &&\n    installationEntry.registrationTime + PENDING_TIMEOUT_MS < Date.now()\n  );\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { GenerateAuthTokenResponse } from '../interfaces/api-response';\nimport { AppConfig } from '../interfaces/app-config';\nimport { FirebaseDependencies } from '../interfaces/firebase-dependencies';\nimport {\n  CompletedAuthToken,\n  RegisteredInstallationEntry\n} from '../interfaces/installation-entry';\nimport { PACKAGE_VERSION } from '../util/constants';\nimport {\n  extractAuthTokenInfoFromResponse,\n  getErrorFromResponse,\n  getHeadersWithAuth,\n  getInstallationsEndpoint,\n  retryIfServerError\n} from './common';\n\nexport async function generateAuthTokenRequest(\n  { appConfig, platformLoggerProvider }: FirebaseDependencies,\n  installationEntry: RegisteredInstallationEntry\n): Promise<CompletedAuthToken> {\n  const endpoint = getGenerateAuthTokenEndpoint(appConfig, installationEntry);\n\n  const headers = getHeadersWithAuth(appConfig, installationEntry);\n\n  // If platform logger exists, add the platform info string to the header.\n  const platformLogger = platformLoggerProvider.getImmediate({\n    optional: true\n  });\n  if (platformLogger) {\n    headers.append('x-firebase-client', platformLogger.getPlatformInfoString());\n  }\n\n  const body = {\n    installation: {\n      sdkVersion: PACKAGE_VERSION\n    }\n  };\n\n  const request: RequestInit = {\n    method: 'POST',\n    headers,\n    body: JSON.stringify(body)\n  };\n\n  const response = await retryIfServerError(() => fetch(endpoint, request));\n  if (response.ok) {\n    const responseValue: GenerateAuthTokenResponse = await response.json();\n    const completedAuthToken: CompletedAuthToken = extractAuthTokenInfoFromResponse(\n      responseValue\n    );\n    return completedAuthToken;\n  } else {\n    throw await getErrorFromResponse('Generate Auth Token', response);\n  }\n}\n\nfunction getGenerateAuthTokenEndpoint(\n  appConfig: AppConfig,\n  { fid }: RegisteredInstallationEntry\n): string {\n  return `${getInstallationsEndpoint(appConfig)}/${fid}/authTokens:generate`;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { generateAuthTokenRequest } from '../api/generate-auth-token-request';\nimport { AppConfig } from '../interfaces/app-config';\nimport { FirebaseDependencies } from '../interfaces/firebase-dependencies';\nimport {\n  AuthToken,\n  CompletedAuthToken,\n  InProgressAuthToken,\n  InstallationEntry,\n  RegisteredInstallationEntry,\n  RequestStatus\n} from '../interfaces/installation-entry';\nimport { PENDING_TIMEOUT_MS, TOKEN_EXPIRATION_BUFFER } from '../util/constants';\nimport { ERROR_FACTORY, ErrorCode, isServerError } from '../util/errors';\nimport { sleep } from '../util/sleep';\nimport { remove, set, update } from './idb-manager';\n\n/**\n * Returns a valid authentication token for the installation. Generates a new\n * token if one doesn't exist, is expired or about to expire.\n *\n * Should only be called if the Firebase Installation is registered.\n */\nexport async function refreshAuthToken(\n  dependencies: FirebaseDependencies,\n  forceRefresh = false\n): Promise<CompletedAuthToken> {\n  let tokenPromise: Promise<CompletedAuthToken> | undefined;\n  const entry = await update(dependencies.appConfig, oldEntry => {\n    if (!isEntryRegistered(oldEntry)) {\n      throw ERROR_FACTORY.create(ErrorCode.NOT_REGISTERED);\n    }\n\n    const oldAuthToken = oldEntry.authToken;\n    if (!forceRefresh && isAuthTokenValid(oldAuthToken)) {\n      // There is a valid token in the DB.\n      return oldEntry;\n    } else if (oldAuthToken.requestStatus === RequestStatus.IN_PROGRESS) {\n      // There already is a token request in progress.\n      tokenPromise = waitUntilAuthTokenRequest(dependencies, forceRefresh);\n      return oldEntry;\n    } else {\n      // No token or token expired.\n      if (!navigator.onLine) {\n        throw ERROR_FACTORY.create(ErrorCode.APP_OFFLINE);\n      }\n\n      const inProgressEntry = makeAuthTokenRequestInProgressEntry(oldEntry);\n      tokenPromise = fetchAuthTokenFromServer(dependencies, inProgressEntry);\n      return inProgressEntry;\n    }\n  });\n\n  const authToken = tokenPromise\n    ? await tokenPromise\n    : (entry.authToken as CompletedAuthToken);\n  return authToken;\n}\n\n/**\n * Call only if FID is registered and Auth Token request is in progress.\n *\n * Waits until the current pending request finishes. If the request times out,\n * tries once in this thread as well.\n */\nasync function waitUntilAuthTokenRequest(\n  dependencies: FirebaseDependencies,\n  forceRefresh: boolean\n): Promise<CompletedAuthToken> {\n  // Unfortunately, there is no way of reliably observing when a value in\n  // IndexedDB changes (yet, see https://github.com/WICG/indexed-db-observers),\n  // so we need to poll.\n\n  let entry = await updateAuthTokenRequest(dependencies.appConfig);\n  while (entry.authToken.requestStatus === RequestStatus.IN_PROGRESS) {\n    // generateAuthToken still in progress.\n    await sleep(100);\n\n    entry = await updateAuthTokenRequest(dependencies.appConfig);\n  }\n\n  const authToken = entry.authToken;\n  if (authToken.requestStatus === RequestStatus.NOT_STARTED) {\n    // The request timed out or failed in a different call. Try again.\n    return refreshAuthToken(dependencies, forceRefresh);\n  } else {\n    return authToken;\n  }\n}\n\n/**\n * Called only if there is a GenerateAuthToken request in progress.\n *\n * Updates the InstallationEntry in the DB based on the status of the\n * GenerateAuthToken request.\n *\n * Returns the updated InstallationEntry.\n */\nfunction updateAuthTokenRequest(\n  appConfig: AppConfig\n): Promise<RegisteredInstallationEntry> {\n  return update(appConfig, oldEntry => {\n    if (!isEntryRegistered(oldEntry)) {\n      throw ERROR_FACTORY.create(ErrorCode.NOT_REGISTERED);\n    }\n\n    const oldAuthToken = oldEntry.authToken;\n    if (hasAuthTokenRequestTimedOut(oldAuthToken)) {\n      return {\n        ...oldEntry,\n        authToken: { requestStatus: RequestStatus.NOT_STARTED }\n      };\n    }\n\n    return oldEntry;\n  });\n}\n\nasync function fetchAuthTokenFromServer(\n  dependencies: FirebaseDependencies,\n  installationEntry: RegisteredInstallationEntry\n): Promise<CompletedAuthToken> {\n  try {\n    const authToken = await generateAuthTokenRequest(\n      dependencies,\n      installationEntry\n    );\n    const updatedInstallationEntry: RegisteredInstallationEntry = {\n      ...installationEntry,\n      authToken\n    };\n    await set(dependencies.appConfig, updatedInstallationEntry);\n    return authToken;\n  } catch (e) {\n    if (\n      isServerError(e) &&\n      (e.customData.serverCode === 401 || e.customData.serverCode === 404)\n    ) {\n      // Server returned a \"FID not found\" or a \"Invalid authentication\" error.\n      // Generate a new ID next time.\n      await remove(dependencies.appConfig);\n    } else {\n      const updatedInstallationEntry: RegisteredInstallationEntry = {\n        ...installationEntry,\n        authToken: { requestStatus: RequestStatus.NOT_STARTED }\n      };\n      await set(dependencies.appConfig, updatedInstallationEntry);\n    }\n    throw e;\n  }\n}\n\nfunction isEntryRegistered(\n  installationEntry: InstallationEntry | undefined\n): installationEntry is RegisteredInstallationEntry {\n  return (\n    installationEntry !== undefined &&\n    installationEntry.registrationStatus === RequestStatus.COMPLETED\n  );\n}\n\nfunction isAuthTokenValid(authToken: AuthToken): boolean {\n  return (\n    authToken.requestStatus === RequestStatus.COMPLETED &&\n    !isAuthTokenExpired(authToken)\n  );\n}\n\nfunction isAuthTokenExpired(authToken: CompletedAuthToken): boolean {\n  const now = Date.now();\n  return (\n    now < authToken.creationTime ||\n    authToken.creationTime + authToken.expiresIn < now + TOKEN_EXPIRATION_BUFFER\n  );\n}\n\n/** Returns an updated InstallationEntry with an InProgressAuthToken. */\nfunction makeAuthTokenRequestInProgressEntry(\n  oldEntry: RegisteredInstallationEntry\n): RegisteredInstallationEntry {\n  const inProgressAuthToken: InProgressAuthToken = {\n    requestStatus: RequestStatus.IN_PROGRESS,\n    requestTime: Date.now()\n  };\n  return {\n    ...oldEntry,\n    authToken: inProgressAuthToken\n  };\n}\n\nfunction hasAuthTokenRequestTimedOut(authToken: AuthToken): boolean {\n  return (\n    authToken.requestStatus === RequestStatus.IN_PROGRESS &&\n    authToken.requestTime + PENDING_TIMEOUT_MS < Date.now()\n  );\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getInstallationEntry } from '../helpers/get-installation-entry';\nimport { refreshAuthToken } from '../helpers/refresh-auth-token';\nimport { AppConfig } from '../interfaces/app-config';\nimport { FirebaseDependencies } from '../interfaces/firebase-dependencies';\n\nexport async function getToken(\n  dependencies: FirebaseDependencies,\n  forceRefresh = false\n): Promise<string> {\n  await completeInstallationRegistration(dependencies.appConfig);\n\n  // At this point we either have a Registered Installation in the DB, or we've\n  // already thrown an error.\n  const authToken = await refreshAuthToken(dependencies, forceRefresh);\n  return authToken.token;\n}\n\nasync function completeInstallationRegistration(\n  appConfig: AppConfig\n): Promise<void> {\n  const { registrationPromise } = await getInstallationEntry(appConfig);\n\n  if (registrationPromise) {\n    // A createInstallation request is in progress. Wait until it finishes.\n    await registrationPromise;\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { AppConfig } from '../interfaces/app-config';\nimport { RegisteredInstallationEntry } from '../interfaces/installation-entry';\nimport {\n  getErrorFromResponse,\n  getHeadersWithAuth,\n  getInstallationsEndpoint,\n  retryIfServerError\n} from './common';\n\nexport async function deleteInstallationRequest(\n  appConfig: AppConfig,\n  installationEntry: RegisteredInstallationEntry\n): Promise<void> {\n  const endpoint = getDeleteEndpoint(appConfig, installationEntry);\n\n  const headers = getHeadersWithAuth(appConfig, installationEntry);\n  const request: RequestInit = {\n    method: 'DELETE',\n    headers\n  };\n\n  const response = await retryIfServerError(() => fetch(endpoint, request));\n  if (!response.ok) {\n    throw await getErrorFromResponse('Delete Installation', response);\n  }\n}\n\nfunction getDeleteEndpoint(\n  appConfig: AppConfig,\n  { fid }: RegisteredInstallationEntry\n): string {\n  return `${getInstallationsEndpoint(appConfig)}/${fid}`;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { addCallback, removeCallback } from '../helpers/fid-changed';\nimport { FirebaseDependencies } from '../interfaces/firebase-dependencies';\n\nexport type IdChangeCallbackFn = (installationId: string) => void;\nexport type IdChangeUnsubscribeFn = () => void;\n\n/**\n * Sets a new callback that will get called when Installation ID changes.\n * Returns an unsubscribe function that will remove the callback when called.\n */\nexport function onIdChange(\n  { appConfig }: FirebaseDependencies,\n  callback: IdChangeCallbackFn\n): IdChangeUnsubscribeFn {\n  addCallback(appConfig, callback);\n\n  return () => {\n    removeCallback(appConfig, callback);\n  };\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ERROR_FACTORY, ErrorCode } from '../util/errors';\nimport { FirebaseApp, FirebaseOptions } from '@firebase/app-types';\n\nimport { AppConfig } from '../interfaces/app-config';\nimport { FirebaseError } from '@firebase/util';\n\nexport function extractAppConfig(app: FirebaseApp): AppConfig {\n  if (!app || !app.options) {\n    throw getMissingValueError('App Configuration Object');\n  }\n\n  if (!app.name) {\n    throw getMissingValueError('App Name');\n  }\n\n  // Required app config keys\n  const configKeys: ReadonlyArray<keyof FirebaseOptions> = [\n    'projectId',\n    'apiKey',\n    'appId',\n    'messagingSenderId'\n  ];\n\n  const { options } = app;\n  for (const keyName of configKeys) {\n    if (!options[keyName]) {\n      throw getMissingValueError(keyName);\n    }\n  }\n\n  return {\n    appName: app.name,\n    projectId: options.projectId!,\n    apiKey: options.apiKey!,\n    appId: options.appId!,\n    senderId: options.messagingSenderId!\n  };\n}\n\nfunction getMissingValueError(valueName: string): FirebaseError {\n  return ERROR_FACTORY.create(ErrorCode.MISSING_APP_CONFIG_VALUES, {\n    valueName\n  });\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getInstallationEntry } from '../helpers/get-installation-entry';\nimport { refreshAuthToken } from '../helpers/refresh-auth-token';\nimport { FirebaseDependencies } from '../interfaces/firebase-dependencies';\n\nexport async function getId(\n  dependencies: FirebaseDependencies\n): Promise<string> {\n  const { installationEntry, registrationPromise } = await getInstallationEntry(\n    dependencies.appConfig\n  );\n\n  if (registrationPromise) {\n    registrationPromise.catch(console.error);\n  } else {\n    // If the installation is already registered, update the authentication\n    // token if needed.\n    refreshAuthToken(dependencies).catch(console.error);\n  }\n\n  return installationEntry.fid;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { deleteInstallationRequest } from '../api/delete-installation-request';\nimport { remove, update } from '../helpers/idb-manager';\nimport { FirebaseDependencies } from '../interfaces/firebase-dependencies';\nimport { RequestStatus } from '../interfaces/installation-entry';\nimport { ERROR_FACTORY, ErrorCode } from '../util/errors';\n\nexport async function deleteInstallation(\n  dependencies: FirebaseDependencies\n): Promise<void> {\n  const { appConfig } = dependencies;\n\n  const entry = await update(appConfig, oldEntry => {\n    if (oldEntry && oldEntry.registrationStatus === RequestStatus.NOT_STARTED) {\n      // Delete the unregistered entry without sending a deleteInstallation request.\n      return undefined;\n    }\n    return oldEntry;\n  });\n\n  if (entry) {\n    if (entry.registrationStatus === RequestStatus.IN_PROGRESS) {\n      // Can't delete while trying to register.\n      throw ERROR_FACTORY.create(ErrorCode.DELETE_PENDING_REGISTRATION);\n    } else if (entry.registrationStatus === RequestStatus.COMPLETED) {\n      if (!navigator.onLine) {\n        throw ERROR_FACTORY.create(ErrorCode.APP_OFFLINE);\n      } else {\n        await deleteInstallationRequest(appConfig, entry);\n        await remove(appConfig);\n      }\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the License\n * is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express\n * or implied. See the License for the specific language governing permissions and limitations under\n * the License.\n */\n\nimport {\n  CONSOLE_CAMPAIGN_ANALYTICS_ENABLED,\n  CONSOLE_CAMPAIGN_ID,\n  CONSOLE_CAMPAIGN_NAME,\n  CONSOLE_CAMPAIGN_TIME\n} from '../util/constants';\n\nexport interface MessagePayloadInternal {\n  notification?: NotificationPayloadInternal;\n  data?: unknown;\n  fcmOptions?: FcmOptionsInternal;\n  messageType?: MessageType;\n  isFirebaseMessaging?: boolean;\n  from: string;\n  // eslint-disable-next-line camelcase\n  collapse_key: string;\n}\n\nexport interface NotificationPayloadInternal extends NotificationOptions {\n  title: string;\n  // Supported in the Legacy Send API.\n  // See:https://firebase.google.com/docs/cloud-messaging/xmpp-server-ref.\n  // eslint-disable-next-line camelcase\n  click_action?: string;\n}\n\n// Defined in\n// https://firebase.google.com/docs/reference/fcm/rest/v1/projects.messages#webpushfcmoptions. Note\n// that the keys are sent to the clients in snake cases which we need to convert to camel so it can\n// be exposed as a type to match the Firebase API convention.\nexport interface FcmOptionsInternal {\n  link?: string;\n\n  // eslint-disable-next-line camelcase\n  analytics_label?: string;\n}\n\nexport enum MessageType {\n  PUSH_RECEIVED = 'push-received',\n  NOTIFICATION_CLICKED = 'notification-clicked'\n}\n\n/** Additional data of a message sent from the FN Console. */\nexport interface ConsoleMessageData {\n  [CONSOLE_CAMPAIGN_ID]: string;\n  [CONSOLE_CAMPAIGN_TIME]: string;\n  [CONSOLE_CAMPAIGN_NAME]?: string;\n  [CONSOLE_CAMPAIGN_ANALYTICS_ENABLED]?: '1';\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport function arrayToBase64(array: Uint8Array | ArrayBuffer): string {\n  const uint8Array = new Uint8Array(array);\n  const base64String = btoa(String.fromCharCode(...uint8Array));\n  return base64String.replace(/=/g, '').replace(/\\+/g, '-').replace(/\\//g, '_');\n}\n\nexport function base64ToArray(base64String: string): Uint8Array {\n  const padding = '='.repeat((4 - (base64String.length % 4)) % 4);\n  const base64 = (base64String + padding)\n    .replace(/\\-/g, '+')\n    .replace(/_/g, '/');\n\n  const rawData = atob(base64);\n  const outputArray = new Uint8Array(rawData.length);\n\n  for (let i = 0; i < rawData.length; ++i) {\n    outputArray[i] = rawData.charCodeAt(i);\n  }\n  return outputArray;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { deleteDb, openDb } from 'idb';\n\nimport { TokenDetails } from '../interfaces/token-details';\nimport { arrayToBase64 } from './array-base64-translator';\n\n// https://github.com/firebase/firebase-js-sdk/blob/7857c212f944a2a9eb421fd4cb7370181bc034b5/packages/messaging/src/interfaces/token-details.ts\nexport interface V2TokenDetails {\n  fcmToken: string;\n  swScope: string;\n  vapidKey: string | Uint8Array;\n  subscription: PushSubscription;\n  fcmSenderId: string;\n  fcmPushSet: string;\n  createTime?: number;\n  endpoint?: string;\n  auth?: string;\n  p256dh?: string;\n}\n\n// https://github.com/firebase/firebase-js-sdk/blob/6b5b15ce4ea3df5df5df8a8b33a4e41e249c7715/packages/messaging/src/interfaces/token-details.ts\nexport interface V3TokenDetails {\n  fcmToken: string;\n  swScope: string;\n  vapidKey: Uint8Array;\n  fcmSenderId: string;\n  fcmPushSet: string;\n  endpoint: string;\n  auth: ArrayBuffer;\n  p256dh: ArrayBuffer;\n  createTime: number;\n}\n\n// https://github.com/firebase/firebase-js-sdk/blob/9567dba664732f681fa7fe60f5b7032bb1daf4c9/packages/messaging/src/interfaces/token-details.ts\nexport interface V4TokenDetails {\n  fcmToken: string;\n  swScope: string;\n  vapidKey: Uint8Array;\n  fcmSenderId: string;\n  endpoint: string;\n  auth: ArrayBufferLike;\n  p256dh: ArrayBufferLike;\n  createTime: number;\n}\n\nconst OLD_DB_NAME = 'fcm_token_details_db';\n/**\n * The last DB version of 'fcm_token_details_db' was 4. This is one higher, so that the upgrade\n * callback is called for all versions of the old DB.\n */\nconst OLD_DB_VERSION = 5;\nconst OLD_OBJECT_STORE_NAME = 'fcm_token_object_Store';\n\nexport async function migrateOldDatabase(\n  senderId: string\n): Promise<TokenDetails | null> {\n  if ('databases' in indexedDB) {\n    // indexedDb.databases() is an IndexedDB v3 API and does not exist in all browsers. TODO: Remove\n    // typecast when it lands in TS types.\n    const databases = await (indexedDB as {\n      databases(): Promise<Array<{ name: string; version: number }>>;\n    }).databases();\n    const dbNames = databases.map(db => db.name);\n\n    if (!dbNames.includes(OLD_DB_NAME)) {\n      // old DB didn't exist, no need to open.\n      return null;\n    }\n  }\n\n  let tokenDetails: TokenDetails | null = null;\n\n  const db = await openDb(OLD_DB_NAME, OLD_DB_VERSION, async db => {\n    if (db.oldVersion < 2) {\n      // Database too old, skip migration.\n      return;\n    }\n\n    if (!db.objectStoreNames.contains(OLD_OBJECT_STORE_NAME)) {\n      // Database did not exist. Nothing to do.\n      return;\n    }\n\n    const objectStore = db.transaction.objectStore(OLD_OBJECT_STORE_NAME);\n    const value = await objectStore.index('fcmSenderId').get(senderId);\n    await objectStore.clear();\n\n    if (!value) {\n      // No entry in the database, nothing to migrate.\n      return;\n    }\n\n    if (db.oldVersion === 2) {\n      const oldDetails = value as V2TokenDetails;\n\n      if (!oldDetails.auth || !oldDetails.p256dh || !oldDetails.endpoint) {\n        return;\n      }\n\n      tokenDetails = {\n        token: oldDetails.fcmToken,\n        createTime: oldDetails.createTime ?? Date.now(),\n        subscriptionOptions: {\n          auth: oldDetails.auth,\n          p256dh: oldDetails.p256dh,\n          endpoint: oldDetails.endpoint,\n          swScope: oldDetails.swScope,\n          vapidKey:\n            typeof oldDetails.vapidKey === 'string'\n              ? oldDetails.vapidKey\n              : arrayToBase64(oldDetails.vapidKey)\n        }\n      };\n    } else if (db.oldVersion === 3) {\n      const oldDetails = value as V3TokenDetails;\n\n      tokenDetails = {\n        token: oldDetails.fcmToken,\n        createTime: oldDetails.createTime,\n        subscriptionOptions: {\n          auth: arrayToBase64(oldDetails.auth),\n          p256dh: arrayToBase64(oldDetails.p256dh),\n          endpoint: oldDetails.endpoint,\n          swScope: oldDetails.swScope,\n          vapidKey: arrayToBase64(oldDetails.vapidKey)\n        }\n      };\n    } else if (db.oldVersion === 4) {\n      const oldDetails = value as V4TokenDetails;\n\n      tokenDetails = {\n        token: oldDetails.fcmToken,\n        createTime: oldDetails.createTime,\n        subscriptionOptions: {\n          auth: arrayToBase64(oldDetails.auth),\n          p256dh: arrayToBase64(oldDetails.p256dh),\n          endpoint: oldDetails.endpoint,\n          swScope: oldDetails.swScope,\n          vapidKey: arrayToBase64(oldDetails.vapidKey)\n        }\n      };\n    }\n  });\n  db.close();\n\n  // Delete all old databases.\n  await deleteDb(OLD_DB_NAME);\n  await deleteDb('fcm_vapid_details_db');\n  await deleteDb('undefined');\n\n  return checkTokenDetails(tokenDetails) ? tokenDetails : null;\n}\n\nfunction checkTokenDetails(\n  tokenDetails: TokenDetails | null\n): tokenDetails is TokenDetails {\n  if (!tokenDetails || !tokenDetails.subscriptionOptions) {\n    return false;\n  }\n  const { subscriptionOptions } = tokenDetails;\n  return (\n    typeof tokenDetails.createTime === 'number' &&\n    tokenDetails.createTime > 0 &&\n    typeof tokenDetails.token === 'string' &&\n    tokenDetails.token.length > 0 &&\n    typeof subscriptionOptions.auth === 'string' &&\n    subscriptionOptions.auth.length > 0 &&\n    typeof subscriptionOptions.p256dh === 'string' &&\n    subscriptionOptions.p256dh.length > 0 &&\n    typeof subscriptionOptions.endpoint === 'string' &&\n    subscriptionOptions.endpoint.length > 0 &&\n    typeof subscriptionOptions.swScope === 'string' &&\n    subscriptionOptions.swScope.length > 0 &&\n    typeof subscriptionOptions.vapidKey === 'string' &&\n    subscriptionOptions.vapidKey.length > 0\n  );\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { DEFAULT_VAPID_KEY, ENDPOINT } from '../util/constants';\nimport { ERROR_FACTORY, ErrorCode } from '../util/errors';\nimport { SubscriptionOptions, TokenDetails } from '../interfaces/token-details';\n\nimport { AppConfig } from '../interfaces/app-config';\nimport { FirebaseInternalDependencies } from '../interfaces/internal-dependencies';\n\nexport interface ApiResponse {\n  token?: string;\n  error?: { message: string };\n}\n\nexport interface ApiRequestBody {\n  web: {\n    endpoint: string;\n    p256dh: string;\n    auth: string;\n    applicationPubKey?: string;\n  };\n}\n\nexport async function requestGetToken(\n  firebaseDependencies: FirebaseInternalDependencies,\n  subscriptionOptions: SubscriptionOptions\n): Promise<string> {\n  const headers = await getHeaders(firebaseDependencies);\n  const body = getBody(subscriptionOptions);\n\n  const subscribeOptions = {\n    method: 'POST',\n    headers,\n    body: JSON.stringify(body)\n  };\n\n  let responseData: ApiResponse;\n  try {\n    const response = await fetch(\n      getEndpoint(firebaseDependencies.appConfig),\n      subscribeOptions\n    );\n    responseData = await response.json();\n  } catch (err) {\n    throw ERROR_FACTORY.create(ErrorCode.TOKEN_SUBSCRIBE_FAILED, {\n      errorInfo: err\n    });\n  }\n\n  if (responseData.error) {\n    const message = responseData.error.message;\n    throw ERROR_FACTORY.create(ErrorCode.TOKEN_SUBSCRIBE_FAILED, {\n      errorInfo: message\n    });\n  }\n\n  if (!responseData.token) {\n    throw ERROR_FACTORY.create(ErrorCode.TOKEN_SUBSCRIBE_NO_TOKEN);\n  }\n\n  return responseData.token;\n}\n\nexport async function requestUpdateToken(\n  firebaseDependencies: FirebaseInternalDependencies,\n  tokenDetails: TokenDetails\n): Promise<string> {\n  const headers = await getHeaders(firebaseDependencies);\n  const body = getBody(tokenDetails.subscriptionOptions!);\n\n  const updateOptions = {\n    method: 'PATCH',\n    headers,\n    body: JSON.stringify(body)\n  };\n\n  let responseData: ApiResponse;\n  try {\n    const response = await fetch(\n      `${getEndpoint(firebaseDependencies.appConfig)}/${tokenDetails.token}`,\n      updateOptions\n    );\n    responseData = await response.json();\n  } catch (err) {\n    throw ERROR_FACTORY.create(ErrorCode.TOKEN_UPDATE_FAILED, {\n      errorInfo: err\n    });\n  }\n\n  if (responseData.error) {\n    const message = responseData.error.message;\n    throw ERROR_FACTORY.create(ErrorCode.TOKEN_UPDATE_FAILED, {\n      errorInfo: message\n    });\n  }\n\n  if (!responseData.token) {\n    throw ERROR_FACTORY.create(ErrorCode.TOKEN_UPDATE_NO_TOKEN);\n  }\n\n  return responseData.token;\n}\n\nexport async function requestDeleteToken(\n  firebaseDependencies: FirebaseInternalDependencies,\n  token: string\n): Promise<void> {\n  const headers = await getHeaders(firebaseDependencies);\n\n  const unsubscribeOptions = {\n    method: 'DELETE',\n    headers\n  };\n\n  try {\n    const response = await fetch(\n      `${getEndpoint(firebaseDependencies.appConfig)}/${token}`,\n      unsubscribeOptions\n    );\n    const responseData: ApiResponse = await response.json();\n    if (responseData.error) {\n      const message = responseData.error.message;\n      throw ERROR_FACTORY.create(ErrorCode.TOKEN_UNSUBSCRIBE_FAILED, {\n        errorInfo: message\n      });\n    }\n  } catch (err) {\n    throw ERROR_FACTORY.create(ErrorCode.TOKEN_UNSUBSCRIBE_FAILED, {\n      errorInfo: err\n    });\n  }\n}\n\nfunction getEndpoint({ projectId }: AppConfig): string {\n  return `${ENDPOINT}/projects/${projectId!}/registrations`;\n}\n\nasync function getHeaders({\n  appConfig,\n  installations\n}: FirebaseInternalDependencies): Promise<Headers> {\n  const authToken = await installations.getToken();\n\n  return new Headers({\n    'Content-Type': 'application/json',\n    Accept: 'application/json',\n    'x-goog-api-key': appConfig.apiKey!,\n    'x-goog-firebase-installations-auth': `FIS ${authToken}`\n  });\n}\n\nfunction getBody({\n  p256dh,\n  auth,\n  endpoint,\n  vapidKey\n}: SubscriptionOptions): ApiRequestBody {\n  const body: ApiRequestBody = {\n    web: {\n      endpoint,\n      auth,\n      p256dh\n    }\n  };\n\n  if (vapidKey !== DEFAULT_VAPID_KEY) {\n    body.web.applicationPubKey = vapidKey;\n  }\n\n  return body;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ERROR_FACTORY, ErrorCode } from '../util/errors';\nimport { SubscriptionOptions, TokenDetails } from '../interfaces/token-details';\nimport {\n  arrayToBase64,\n  base64ToArray\n} from '../helpers/array-base64-translator';\nimport { dbGet, dbRemove, dbSet } from '../helpers/idb-manager';\nimport { requestDeleteToken, requestGetToken, requestUpdateToken } from './api';\n\nimport { FirebaseInternalDependencies } from '../interfaces/internal-dependencies';\n\n/** UpdateRegistration will be called once every week. */\nconst TOKEN_EXPIRATION_MS = 7 * 24 * 60 * 60 * 1000; // 7 days\n\nexport async function getToken(\n  firebaseDependencies: FirebaseInternalDependencies,\n  swRegistration: ServiceWorkerRegistration,\n  vapidKey: string\n): Promise<string> {\n  if (Notification.permission !== 'granted') {\n    throw ERROR_FACTORY.create(ErrorCode.PERMISSION_BLOCKED);\n  }\n\n  // If a PushSubscription exists it's returned, otherwise a new subscription is generated and\n  // returned.\n  const pushSubscription = await getPushSubscription(swRegistration, vapidKey);\n  const tokenDetails = await dbGet(firebaseDependencies);\n\n  const subscriptionOptions: SubscriptionOptions = {\n    vapidKey,\n    swScope: swRegistration.scope,\n    endpoint: pushSubscription.endpoint,\n    auth: arrayToBase64(pushSubscription.getKey('auth')!),\n    p256dh: arrayToBase64(pushSubscription.getKey('p256dh')!)\n  };\n\n  if (!tokenDetails) {\n    // No token, get a new one.\n    return getNewToken(firebaseDependencies, subscriptionOptions);\n  } else if (\n    !isTokenValid(tokenDetails.subscriptionOptions!, subscriptionOptions)\n  ) {\n    // Invalid token, get a new one.\n    try {\n      await requestDeleteToken(firebaseDependencies, tokenDetails.token);\n    } catch (e) {\n      // Suppress errors because of #2364\n      console.warn(e);\n    }\n\n    return getNewToken(firebaseDependencies, subscriptionOptions);\n  } else if (Date.now() >= tokenDetails.createTime + TOKEN_EXPIRATION_MS) {\n    // Weekly token refresh\n    return updateToken(\n      {\n        token: tokenDetails.token,\n        createTime: Date.now(),\n        subscriptionOptions\n      },\n      firebaseDependencies,\n      swRegistration\n    );\n  } else {\n    // Valid token, nothing to do.\n    return tokenDetails.token;\n  }\n}\n\n/**\n * This method deletes the token from the database, unsubscribes the token from FCM, and unregisters\n * the push subscription if it exists.\n */\nexport async function deleteToken(\n  firebaseDependencies: FirebaseInternalDependencies,\n  swRegistration: ServiceWorkerRegistration\n): Promise<boolean> {\n  const tokenDetails = await dbGet(firebaseDependencies);\n  if (tokenDetails) {\n    await requestDeleteToken(firebaseDependencies, tokenDetails.token);\n    await dbRemove(firebaseDependencies);\n  }\n\n  // Unsubscribe from the push subscription.\n  const pushSubscription = await swRegistration.pushManager.getSubscription();\n  if (pushSubscription) {\n    return pushSubscription.unsubscribe();\n  }\n\n  // If there's no SW, consider it a success.\n  return true;\n}\n\nasync function updateToken(\n  tokenDetails: TokenDetails,\n  firebaseDependencies: FirebaseInternalDependencies,\n  swRegistration: ServiceWorkerRegistration\n): Promise<string> {\n  try {\n    const updatedToken = await requestUpdateToken(\n      firebaseDependencies,\n      tokenDetails\n    );\n\n    const updatedTokenDetails: TokenDetails = {\n      ...tokenDetails,\n      token: updatedToken,\n      createTime: Date.now()\n    };\n\n    await dbSet(firebaseDependencies, updatedTokenDetails);\n    return updatedToken;\n  } catch (e) {\n    await deleteToken(firebaseDependencies, swRegistration);\n    throw e;\n  }\n}\n\nasync function getNewToken(\n  firebaseDependencies: FirebaseInternalDependencies,\n  subscriptionOptions: SubscriptionOptions\n): Promise<string> {\n  const token = await requestGetToken(\n    firebaseDependencies,\n    subscriptionOptions\n  );\n  const tokenDetails: TokenDetails = {\n    token,\n    createTime: Date.now(),\n    subscriptionOptions\n  };\n  await dbSet(firebaseDependencies, tokenDetails);\n  return tokenDetails.token;\n}\n\n/**\n * Gets a PushSubscription for the current user.\n */\nasync function getPushSubscription(\n  swRegistration: ServiceWorkerRegistration,\n  vapidKey: string\n): Promise<PushSubscription> {\n  const subscription = await swRegistration.pushManager.getSubscription();\n  if (subscription) {\n    return subscription;\n  }\n  return swRegistration.pushManager.subscribe({\n    userVisibleOnly: true,\n    // Chrome <= 75 doesn't support base64-encoded VAPID key. For backward compatibility, VAPID key\n    // submitted to pushManager#subscribe must be of type Uint8Array.\n    applicationServerKey: base64ToArray(vapidKey)\n  });\n}\n\n/**\n * Checks if the saved tokenDetails object matches the configuration provided.\n */\nfunction isTokenValid(\n  dbOptions: SubscriptionOptions,\n  currentOptions: SubscriptionOptions\n): boolean {\n  const isVapidKeyEqual = currentOptions.vapidKey === dbOptions.vapidKey;\n  const isEndpointEqual = currentOptions.endpoint === dbOptions.endpoint;\n  const isAuthEqual = currentOptions.auth === dbOptions.auth;\n  const isP256dhEqual = currentOptions.p256dh === dbOptions.p256dh;\n\n  return isVapidKeyEqual && isEndpointEqual && isAuthEqual && isP256dhEqual;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { CONSOLE_CAMPAIGN_ID } from '../util/constants';\nimport { ConsoleMessageData } from '../interfaces/internal-message-payload';\n\nexport function isConsoleMessage(data: unknown): data is ConsoleMessageData {\n  // This message has a campaign ID, meaning it was sent using the Firebase Console.\n  return typeof data === 'object' && !!data && CONSOLE_CAMPAIGN_ID in data;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/** Returns a promise that resolves after given time passes. */\nexport function sleep(ms: number): Promise<void> {\n  return new Promise<void>(resolve => {\n    setTimeout(resolve, ms);\n  });\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  BACKGROUND_HANDLE_EXECUTION_TIME_LIMIT_MS,\n  DEFAULT_VAPID_KEY,\n  FCM_MSG,\n  FOREGROUND_HANDLE_PREPARATION_TIME_MS,\n  TAG\n} from '../util/constants';\nimport { ERROR_FACTORY, ErrorCode } from '../util/errors';\nimport { FirebaseMessaging, MessagePayload } from '@firebase/messaging-types';\nimport {\n  MessagePayloadInternal,\n  MessageType,\n  NotificationPayloadInternal\n} from '../interfaces/internal-message-payload';\nimport { NextFn, Observer, Unsubscribe } from '@firebase/util';\nimport { deleteToken, getToken } from '../core/token-management';\n\nimport { FirebaseApp } from '@firebase/app-types';\nimport { FirebaseInternalDependencies } from '../interfaces/internal-dependencies';\nimport { FirebaseService } from '@firebase/app-types/private';\nimport { dbGet } from '../helpers/idb-manager';\nimport { externalizePayload } from '../helpers/externalizePayload';\nimport { isConsoleMessage } from '../helpers/is-console-message';\nimport { sleep } from '../helpers/sleep';\n\n// Let TS know that this is a service worker\ndeclare const self: ServiceWorkerGlobalScope;\n\nexport type BgMessageHandler = (payload: MessagePayload) => unknown;\n\nexport class SwController implements FirebaseMessaging, FirebaseService {\n  // A boolean flag to determine wether an app is using onBackgroundMessage or\n  // setBackgroundMessageHandler. onBackgroundMessage will receive a MessagePayload regardless of if\n  // a notification is displayed. Whereas, setBackgroundMessageHandler will swallow the\n  // MessagePayload if a NotificationPayload is included.\n  private isOnBackgroundMessageUsed: boolean | null = null;\n  private vapidKey: string | null = null;\n  private bgMessageHandler:\n    | null\n    | BgMessageHandler\n    | NextFn<MessagePayload>\n    | Observer<MessagePayload> = null;\n\n  constructor(\n    private readonly firebaseDependencies: FirebaseInternalDependencies\n  ) {\n    self.addEventListener('push', e => {\n      e.waitUntil(this.onPush(e));\n    });\n    self.addEventListener('pushsubscriptionchange', e => {\n      e.waitUntil(this.onSubChange(e));\n    });\n    self.addEventListener('notificationclick', e => {\n      e.waitUntil(this.onNotificationClick(e));\n    });\n  }\n\n  get app(): FirebaseApp {\n    return this.firebaseDependencies.app;\n  }\n\n  /**\n   * @deprecated. Use onBackgroundMessage(nextOrObserver: NextFn<object> | Observer<object>):\n   * Unsubscribe instead.\n   *\n   * Calling setBackgroundMessageHandler will opt in to some specific behaviors.\n   *\n   * 1.) If a notification doesn't need to be shown due to a window already being visible, then push\n   * messages will be sent to the page. 2.) If a notification needs to be shown, and the message\n   * contains no notification data this method will be called and the promise it returns will be\n   * passed to event.waitUntil. If you do not set this callback then all push messages will let and\n   * the developer can handle them in a their own 'push' event callback\n   *\n   * @param callback The callback to be called when a push message is received and a notification\n   * must be shown. The callback will be given the data from the push message.\n   */\n  setBackgroundMessageHandler(callback: BgMessageHandler): void {\n    this.isOnBackgroundMessageUsed = false;\n\n    if (!callback || typeof callback !== 'function') {\n      throw ERROR_FACTORY.create(ErrorCode.INVALID_BG_HANDLER);\n    }\n\n    this.bgMessageHandler = callback;\n  }\n\n  onBackgroundMessage(\n    nextOrObserver: NextFn<MessagePayload> | Observer<MessagePayload>\n  ): Unsubscribe {\n    this.isOnBackgroundMessageUsed = true;\n    this.bgMessageHandler = nextOrObserver;\n\n    return () => {\n      this.bgMessageHandler = null;\n    };\n  }\n\n  // TODO: Remove getToken from SW Controller. Calling this from an old SW can cause all kinds of\n  // trouble.\n  async getToken(): Promise<string> {\n    if (!this.vapidKey) {\n      // Call getToken using the current VAPID key if there already is a token. This is needed\n      // because usePublicVapidKey was not available in SW. It will be removed when vapidKey becomes\n      // a parameter of getToken, or when getToken is removed from SW.\n      const tokenDetails = await dbGet(this.firebaseDependencies);\n      this.vapidKey =\n        tokenDetails?.subscriptionOptions?.vapidKey ?? DEFAULT_VAPID_KEY;\n    }\n\n    return getToken(\n      this.firebaseDependencies,\n      self.registration,\n      this.vapidKey\n    );\n  }\n\n  // TODO: Remove deleteToken from SW Controller. Calling this from an old SW can cause all kinds of\n  // trouble.\n  deleteToken(): Promise<boolean> {\n    return deleteToken(this.firebaseDependencies, self.registration);\n  }\n\n  requestPermission(): Promise<void> {\n    throw ERROR_FACTORY.create(ErrorCode.AVAILABLE_IN_WINDOW);\n  }\n\n  // TODO: Remove this together with getToken from SW Controller.\n  usePublicVapidKey(vapidKey: string): void {\n    if (this.vapidKey !== null) {\n      throw ERROR_FACTORY.create(ErrorCode.USE_VAPID_KEY_AFTER_GET_TOKEN);\n    }\n\n    if (typeof vapidKey !== 'string' || vapidKey.length === 0) {\n      throw ERROR_FACTORY.create(ErrorCode.INVALID_VAPID_KEY);\n    }\n\n    this.vapidKey = vapidKey;\n  }\n\n  useServiceWorker(): void {\n    throw ERROR_FACTORY.create(ErrorCode.AVAILABLE_IN_WINDOW);\n  }\n\n  onMessage(): Unsubscribe {\n    throw ERROR_FACTORY.create(ErrorCode.AVAILABLE_IN_WINDOW);\n  }\n\n  onTokenRefresh(): Unsubscribe {\n    throw ERROR_FACTORY.create(ErrorCode.AVAILABLE_IN_WINDOW);\n  }\n\n  /**\n   * A handler for push events that shows notifications based on the content of the payload.\n   *\n   * The payload must be a JSON-encoded Object with a `notification` key. The value of the\n   * `notification` property will be used as the NotificationOptions object passed to\n   * showNotification. Additionally, the `title` property of the notification object will be used as\n   * the title.\n   *\n   * If there is no notification data in the payload then no notification will be shown.\n   */\n  async onPush(event: PushEvent): Promise<void> {\n    const internalPayload = getMessagePayloadInternal(event);\n    if (!internalPayload) {\n      console.debug(\n        TAG +\n          'failed to get parsed MessagePayload from the PushEvent. Skip handling the push.'\n      );\n      return;\n    }\n\n    // foreground handling: eventually passed to onMessage hook\n    const clientList = await getClientList();\n    if (hasVisibleClients(clientList)) {\n      return sendMessagePayloadInternalToWindows(clientList, internalPayload);\n    }\n\n    // background handling: display and pass to onBackgroundMessage hook\n    let isNotificationShown = false;\n    if (!!internalPayload.notification) {\n      await showNotification(wrapInternalPayload(internalPayload));\n      isNotificationShown = true;\n    }\n\n    // MessagePayload is only passed to `onBackgroundMessage`. Skip passing MessagePayload for\n    // the legacy `setBackgroundMessageHandler` to preserve the SDK behaviors.\n    if (\n      isNotificationShown === true &&\n      this.isOnBackgroundMessageUsed === false\n    ) {\n      return;\n    }\n\n    if (!!this.bgMessageHandler) {\n      const payload = externalizePayload(internalPayload);\n\n      if (typeof this.bgMessageHandler === 'function') {\n        this.bgMessageHandler(payload);\n      } else {\n        this.bgMessageHandler.next(payload);\n      }\n    }\n\n    // wait briefly to allow onBackgroundMessage to complete\n    await sleep(BACKGROUND_HANDLE_EXECUTION_TIME_LIMIT_MS);\n  }\n\n  async onSubChange(event: PushSubscriptionChangeEvent): Promise<void> {\n    const { newSubscription } = event;\n    if (!newSubscription) {\n      // Subscription revoked, delete token\n      await deleteToken(this.firebaseDependencies, self.registration);\n      return;\n    }\n\n    const tokenDetails = await dbGet(this.firebaseDependencies);\n    await deleteToken(this.firebaseDependencies, self.registration);\n    await getToken(\n      this.firebaseDependencies,\n      self.registration,\n      tokenDetails?.subscriptionOptions?.vapidKey ?? DEFAULT_VAPID_KEY\n    );\n  }\n\n  async onNotificationClick(event: NotificationEvent): Promise<void> {\n    const internalPayload: MessagePayloadInternal =\n      event.notification?.data?.[FCM_MSG];\n\n    if (!internalPayload) {\n      return;\n    } else if (event.action) {\n      // User clicked on an action button. This will allow developers to act on action button clicks\n      // by using a custom onNotificationClick listener that they define.\n      return;\n    }\n\n    // Prevent other listeners from receiving the event\n    event.stopImmediatePropagation();\n    event.notification.close();\n\n    // Note clicking on a notification with no link set will focus the Chrome's current tab.\n    const link = getLink(internalPayload);\n    if (!link) {\n      return;\n    }\n\n    // FM should only open/focus links from app's origin.\n    const url = new URL(link, self.location.href);\n    const originUrl = new URL(self.location.origin);\n\n    if (url.host !== originUrl.host) {\n      return;\n    }\n\n    let client = await getWindowClient(url);\n\n    if (!client) {\n      client = await self.clients.openWindow(link);\n\n      // Wait three seconds for the client to initialize and set up the message handler so that it\n      // can receive the message.\n      await sleep(FOREGROUND_HANDLE_PREPARATION_TIME_MS);\n    } else {\n      client = await client.focus();\n    }\n\n    if (!client) {\n      // Window Client will not be returned if it's for a third party origin.\n      return;\n    }\n\n    internalPayload.messageType = MessageType.NOTIFICATION_CLICKED;\n    internalPayload.isFirebaseMessaging = true;\n    return client.postMessage(internalPayload);\n  }\n}\n\nfunction wrapInternalPayload(\n  internalPayload: MessagePayloadInternal\n): NotificationPayloadInternal {\n  const wrappedInternalPayload: NotificationPayloadInternal = {\n    ...((internalPayload.notification as unknown) as NotificationPayloadInternal)\n  };\n\n  // Put the message payload under FCM_MSG name so we can identify the notification as being an FCM\n  // notification vs a notification from somewhere else (i.e. normal web push or developer generated\n  // notification).\n  wrappedInternalPayload.data = {\n    [FCM_MSG]: internalPayload\n  };\n\n  return wrappedInternalPayload;\n}\n\nfunction getMessagePayloadInternal({\n  data\n}: PushEvent): MessagePayloadInternal | null {\n  if (!data) {\n    return null;\n  }\n\n  try {\n    return data.json();\n  } catch (err) {\n    // Not JSON so not an FCM message.\n    return null;\n  }\n}\n\n/**\n * @param url The URL to look for when focusing a client.\n * @return Returns an existing window client or a newly opened WindowClient.\n */\nasync function getWindowClient(url: URL): Promise<WindowClient | null> {\n  const clientList = await getClientList();\n\n  for (const client of clientList) {\n    const clientUrl = new URL(client.url, self.location.href);\n\n    if (url.host === clientUrl.host) {\n      return client;\n    }\n  }\n\n  return null;\n}\n\n/**\n * @returns If there is currently a visible WindowClient, this method will resolve to true,\n * otherwise false.\n */\nfunction hasVisibleClients(clientList: WindowClient[]): boolean {\n  return clientList.some(\n    client =>\n      client.visibilityState === 'visible' &&\n      // Ignore chrome-extension clients as that matches the background pages of extensions, which\n      // are always considered visible for some reason.\n      !client.url.startsWith('chrome-extension://')\n  );\n}\n\nfunction sendMessagePayloadInternalToWindows(\n  clientList: WindowClient[],\n  internalPayload: MessagePayloadInternal\n): void {\n  internalPayload.isFirebaseMessaging = true;\n  internalPayload.messageType = MessageType.PUSH_RECEIVED;\n\n  for (const client of clientList) {\n    client.postMessage(internalPayload);\n  }\n}\n\nfunction getClientList(): Promise<WindowClient[]> {\n  return self.clients.matchAll({\n    type: 'window',\n    includeUncontrolled: true\n    // TS doesn't know that \"type: 'window'\" means it'll return WindowClient[]\n  }) as Promise<WindowClient[]>;\n}\n\nfunction showNotification(\n  notificationPayloadInternal: NotificationPayloadInternal\n): Promise<void> {\n  // Note: Firefox does not support the maxActions property.\n  // https://developer.mozilla.org/en-US/docs/Web/API/notification/maxActions\n  const { actions } = notificationPayloadInternal;\n  const { maxActions } = Notification;\n  if (actions && maxActions && actions.length > maxActions) {\n    console.warn(\n      `This browser only supports ${maxActions} actions. The remaining actions will not be displayed.`\n    );\n  }\n\n  return self.registration.showNotification(\n    /* title= */ notificationPayloadInternal.title ?? '',\n    notificationPayloadInternal\n  );\n}\n\nfunction getLink(payload: MessagePayloadInternal): string | null {\n  // eslint-disable-next-line camelcase\n  const link = payload.fcmOptions?.link ?? payload.notification?.click_action;\n  if (link) {\n    return link;\n  }\n\n  if (isConsoleMessage(payload.data)) {\n    // Notification created in the Firebase Console. Redirect to origin.\n    return self.location.origin;\n  } else {\n    return null;\n  }\n}\n","/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { MessagePayload } from '@firebase/messaging-types';\nimport { MessagePayloadInternal } from '../interfaces/internal-message-payload';\n\nexport function externalizePayload(\n  internalPayload: MessagePayloadInternal\n): MessagePayload {\n  const payload: MessagePayload = {\n    from: internalPayload.from,\n    // eslint-disable-next-line camelcase\n    collapseKey: internalPayload.collapse_key\n  } as MessagePayload;\n\n  propagateNotificationPayload(payload, internalPayload);\n  propagateDataPayload(payload, internalPayload);\n  propagateFcmOptions(payload, internalPayload);\n\n  return payload;\n}\n\nfunction propagateNotificationPayload(\n  payload: MessagePayload,\n  messagePayloadInternal: MessagePayloadInternal\n): void {\n  if (!messagePayloadInternal.notification) {\n    return;\n  }\n\n  payload.notification = {};\n\n  const title = messagePayloadInternal.notification!.title;\n  if (!!title) {\n    payload.notification!.title = title;\n  }\n\n  const body = messagePayloadInternal.notification!.body;\n  if (!!body) {\n    payload.notification!.body = body;\n  }\n\n  const image = messagePayloadInternal.notification!.image;\n  if (!!image) {\n    payload.notification!.image = image;\n  }\n}\n\nfunction propagateDataPayload(\n  payload: MessagePayload,\n  messagePayloadInternal: MessagePayloadInternal\n): void {\n  if (!messagePayloadInternal.data) {\n    return;\n  }\n\n  payload.data = messagePayloadInternal.data as { [key: string]: string };\n}\n\nfunction propagateFcmOptions(\n  payload: MessagePayload,\n  messagePayloadInternal: MessagePayloadInternal\n): void {\n  if (!messagePayloadInternal.fcmOptions) {\n    return;\n  }\n\n  payload.fcmOptions = {};\n\n  const link = messagePayloadInternal.fcmOptions!.link;\n  if (!!link) {\n    payload.fcmOptions!.link = link;\n  }\n\n  // eslint-disable-next-line camelcase\n  const analyticsLabel = messagePayloadInternal.fcmOptions!.analytics_label;\n  if (!!analyticsLabel) {\n    payload.fcmOptions!.analyticsLabel = analyticsLabel;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  CONSOLE_CAMPAIGN_ANALYTICS_ENABLED,\n  CONSOLE_CAMPAIGN_ID,\n  CONSOLE_CAMPAIGN_NAME,\n  CONSOLE_CAMPAIGN_TIME,\n  DEFAULT_SW_PATH,\n  DEFAULT_SW_SCOPE,\n  DEFAULT_VAPID_KEY\n} from '../util/constants';\nimport {\n  ConsoleMessageData,\n  MessagePayloadInternal,\n  MessageType\n} from '../interfaces/internal-message-payload';\nimport { ERROR_FACTORY, ErrorCode } from '../util/errors';\nimport { NextFn, Observer, Unsubscribe } from '@firebase/util';\nimport { deleteToken, getToken } from '../core/token-management';\n\nimport { FirebaseApp } from '@firebase/app-types';\nimport { FirebaseInternalDependencies } from '../interfaces/internal-dependencies';\nimport { FirebaseMessaging } from '@firebase/messaging-types';\nimport { FirebaseService } from '@firebase/app-types/private';\nimport { isConsoleMessage } from '../helpers/is-console-message';\n\nexport class WindowController implements FirebaseMessaging, FirebaseService {\n  private vapidKey: string | null = null;\n  private swRegistration?: ServiceWorkerRegistration;\n  private onMessageCallback: NextFn<object> | Observer<object> | null = null;\n\n  constructor(\n    private readonly firebaseDependencies: FirebaseInternalDependencies\n  ) {\n    navigator.serviceWorker.addEventListener('message', e =>\n      this.messageEventListener(e)\n    );\n  }\n\n  get app(): FirebaseApp {\n    return this.firebaseDependencies.app;\n  }\n\n  private async messageEventListener(event: MessageEvent): Promise<void> {\n    const internalPayload = event.data as MessagePayloadInternal;\n\n    if (!internalPayload.isFirebaseMessaging) {\n      return;\n    }\n\n    // onMessageCallback is either a function or observer/subscriber.\n    // TODO: in the modularization release, have onMessage handle type MessagePayload as supposed to\n    // the legacy payload where some fields are in snake cases.\n    if (\n      this.onMessageCallback &&\n      internalPayload.messageType === MessageType.PUSH_RECEIVED\n    ) {\n      if (typeof this.onMessageCallback === 'function') {\n        this.onMessageCallback(\n          stripInternalFields(Object.assign({}, internalPayload))\n        );\n      } else {\n        this.onMessageCallback.next(Object.assign({}, internalPayload));\n      }\n    }\n\n    const dataPayload = internalPayload.data;\n\n    if (\n      isConsoleMessage(dataPayload) &&\n      dataPayload[CONSOLE_CAMPAIGN_ANALYTICS_ENABLED] === '1'\n    ) {\n      await this.logEvent(internalPayload.messageType!, dataPayload);\n    }\n  }\n\n  getVapidKey(): string | null {\n    return this.vapidKey;\n  }\n\n  getSwReg(): ServiceWorkerRegistration | undefined {\n    return this.swRegistration;\n  }\n\n  async getToken(options?: {\n    vapidKey?: string;\n    serviceWorkerRegistration?: ServiceWorkerRegistration;\n  }): Promise<string> {\n    if (Notification.permission === 'default') {\n      await Notification.requestPermission();\n    }\n\n    if (Notification.permission !== 'granted') {\n      throw ERROR_FACTORY.create(ErrorCode.PERMISSION_BLOCKED);\n    }\n\n    await this.updateVapidKey(options?.vapidKey);\n    await this.updateSwReg(options?.serviceWorkerRegistration);\n\n    return getToken(\n      this.firebaseDependencies,\n      this.swRegistration!,\n      this.vapidKey!\n    );\n  }\n\n  async updateVapidKey(vapidKey?: string | undefined): Promise<void> {\n    if (!!vapidKey) {\n      this.vapidKey = vapidKey;\n    } else if (!this.vapidKey) {\n      this.vapidKey = DEFAULT_VAPID_KEY;\n    }\n  }\n\n  async updateSwReg(\n    swRegistration?: ServiceWorkerRegistration | undefined\n  ): Promise<void> {\n    if (!swRegistration && !this.swRegistration) {\n      await this.registerDefaultSw();\n    }\n\n    if (!swRegistration && !!this.swRegistration) {\n      return;\n    }\n\n    if (!(swRegistration instanceof ServiceWorkerRegistration)) {\n      throw ERROR_FACTORY.create(ErrorCode.INVALID_SW_REGISTRATION);\n    }\n\n    this.swRegistration = swRegistration;\n  }\n\n  private async registerDefaultSw(): Promise<void> {\n    try {\n      this.swRegistration = await navigator.serviceWorker.register(\n        DEFAULT_SW_PATH,\n        {\n          scope: DEFAULT_SW_SCOPE\n        }\n      );\n\n      // The timing when browser updates sw when sw has an update is unreliable by my experiment. It\n      // leads to version conflict when the SDK upgrades to a newer version in the main page, but sw\n      // is stuck with the old version. For example,\n      // https://github.com/firebase/firebase-js-sdk/issues/2590 The following line reliably updates\n      // sw if there was an update.\n      this.swRegistration.update().catch(() => {\n        /* it is non blocking and we don't care if it failed */\n      });\n    } catch (e) {\n      throw ERROR_FACTORY.create(ErrorCode.FAILED_DEFAULT_REGISTRATION, {\n        browserErrorMessage: e.message\n      });\n    }\n  }\n\n  async deleteToken(): Promise<boolean> {\n    if (!this.swRegistration) {\n      await this.registerDefaultSw();\n    }\n\n    return deleteToken(this.firebaseDependencies, this.swRegistration!);\n  }\n\n  /**\n   * Request permission if it is not currently granted.\n   *\n   * @return Resolves if the permission was granted, rejects otherwise.\n   *\n   * @deprecated Use Notification.requestPermission() instead.\n   * https://developer.mozilla.org/en-US/docs/Web/API/Notification/requestPermission\n   */\n  async requestPermission(): Promise<void> {\n    if (Notification.permission === 'granted') {\n      return;\n    }\n\n    const permissionResult = await Notification.requestPermission();\n    if (permissionResult === 'granted') {\n      return;\n    } else if (permissionResult === 'denied') {\n      throw ERROR_FACTORY.create(ErrorCode.PERMISSION_BLOCKED);\n    } else {\n      throw ERROR_FACTORY.create(ErrorCode.PERMISSION_DEFAULT);\n    }\n  }\n\n  /**\n   * @deprecated. Use getToken(options?: {vapidKey?: string; serviceWorkerRegistration?:\n   * ServiceWorkerRegistration;}): Promise<string> instead.\n   */\n  usePublicVapidKey(vapidKey: string): void {\n    if (this.vapidKey !== null) {\n      throw ERROR_FACTORY.create(ErrorCode.USE_VAPID_KEY_AFTER_GET_TOKEN);\n    }\n\n    if (typeof vapidKey !== 'string' || vapidKey.length === 0) {\n      throw ERROR_FACTORY.create(ErrorCode.INVALID_VAPID_KEY);\n    }\n\n    this.vapidKey = vapidKey;\n  }\n\n  /**\n   * @deprecated. Use getToken(options?: {vapidKey?: string; serviceWorkerRegistration?:\n   * ServiceWorkerRegistration;}): Promise<string> instead.\n   */\n  useServiceWorker(swRegistration: ServiceWorkerRegistration): void {\n    if (!(swRegistration instanceof ServiceWorkerRegistration)) {\n      throw ERROR_FACTORY.create(ErrorCode.INVALID_SW_REGISTRATION);\n    }\n\n    if (this.swRegistration) {\n      throw ERROR_FACTORY.create(ErrorCode.USE_SW_AFTER_GET_TOKEN);\n    }\n\n    this.swRegistration = swRegistration;\n  }\n\n  /**\n   * @param nextOrObserver An observer object or a function triggered on message.\n   *\n   * @return The unsubscribe function for the observer.\n   */\n  onMessage(nextOrObserver: NextFn<object> | Observer<object>): Unsubscribe {\n    this.onMessageCallback = nextOrObserver;\n\n    return () => {\n      this.onMessageCallback = null;\n    };\n  }\n\n  setBackgroundMessageHandler(): void {\n    throw ERROR_FACTORY.create(ErrorCode.AVAILABLE_IN_SW);\n  }\n\n  onBackgroundMessage(): Unsubscribe {\n    throw ERROR_FACTORY.create(ErrorCode.AVAILABLE_IN_SW);\n  }\n\n  /**\n   * @deprecated No-op. It was initially designed with token rotation requests from server in mind.\n   * However, the plan to implement such feature was abandoned.\n   */\n  onTokenRefresh(): Unsubscribe {\n    return () => {};\n  }\n\n  private async logEvent(\n    messageType: MessageType,\n    data: ConsoleMessageData\n  ): Promise<void> {\n    const eventType = getEventType(messageType);\n    const analytics = await this.firebaseDependencies.analyticsProvider.get();\n    analytics.logEvent(eventType, {\n      /* eslint-disable camelcase */\n      message_id: data[CONSOLE_CAMPAIGN_ID],\n      message_name: data[CONSOLE_CAMPAIGN_NAME],\n      message_time: data[CONSOLE_CAMPAIGN_TIME],\n      message_device_time: Math.floor(Date.now() / 1000)\n      /* eslint-enable camelcase */\n    });\n  }\n}\n\nfunction getEventType(messageType: MessageType): string {\n  switch (messageType) {\n    case MessageType.NOTIFICATION_CLICKED:\n      return 'notification_open';\n    case MessageType.PUSH_RECEIVED:\n      return 'notification_foreground';\n    default:\n      throw new Error();\n  }\n}\n\nfunction stripInternalFields(\n  internalPayload: MessagePayloadInternal\n): MessagePayloadInternal {\n  delete internalPayload.messageType;\n  delete internalPayload.isFirebaseMessaging;\n  return internalPayload;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * @fileoverview Constants used in the Firebase Storage library.\n */\n\n/**\n * Domain name for firebase storage.\n */\nexport const DEFAULT_HOST = 'firebasestorage.googleapis.com';\n\n/**\n * The key in Firebase config json for the storage bucket.\n */\nexport const CONFIG_STORAGE_BUCKET_KEY = 'storageBucket';\n\n/**\n * 2 minutes\n *\n * The timeout for all operations except upload.\n */\nexport const DEFAULT_MAX_OPERATION_RETRY_TIME = 2 * 60 * 1000;\n\n/**\n * 10 minutes\n *\n * The timeout for upload.\n */\nexport const DEFAULT_MAX_UPLOAD_RETRY_TIME = 10 * 60 * 1000;\n\n/**\n * This is the value of Number.MIN_SAFE_INTEGER, which is not well supported\n * enough for us to use it directly.\n */\nexport const MIN_SAFE_INTEGER = -9007199254740991;\n","import { FirebaseError } from '@firebase/util';\n/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { CONFIG_STORAGE_BUCKET_KEY } from './constants';\n\n/**\n * An error returned by the Firebase Storage SDK.\n * @public\n */\nexport class FirebaseStorageError extends FirebaseError {\n  /**\n   * Stores custom error data unque to FirebaseStorageError.\n   */\n  customData: { serverResponse: string | null } = { serverResponse: null };\n\n  /**\n   * @param code - A StorageErrorCode string to be prefixed with 'storage/' and\n   *  added to the end of the message.\n   * @param message  - Error message.\n   */\n  constructor(code: StorageErrorCode, message: string) {\n    super(\n      prependCode(code),\n      `Firebase Storage: ${message} (${prependCode(code)})`\n    );\n    // Without this, `instanceof FirebaseStorageError`, in tests for example,\n    // returns false.\n    Object.setPrototypeOf(this, FirebaseStorageError.prototype);\n  }\n\n  /**\n   * Compares a StorageErrorCode against this error's code, filtering out the prefix.\n   */\n  _codeEquals(code: StorageErrorCode): boolean {\n    return prependCode(code) === this.code;\n  }\n\n  /**\n   * Error message including serverResponse if available.\n   */\n  get message(): string {\n    if (this.customData.serverResponse) {\n      return `${this.message}\\n${this.customData.serverResponse}`;\n    } else {\n      return this.message;\n    }\n  }\n\n  /**\n   * Optional response message that was added by the server.\n   */\n  get serverResponse(): null | string {\n    return this.customData.serverResponse;\n  }\n\n  set serverResponse(serverResponse: string | null) {\n    this.customData.serverResponse = serverResponse;\n  }\n}\n\nexport const errors = {};\n\n/**\n * @public\n * Error codes that can be attached to `FirebaseStorageError`s.\n */\nexport const enum StorageErrorCode {\n  // Shared between all platforms\n  UNKNOWN = 'unknown',\n  OBJECT_NOT_FOUND = 'object-not-found',\n  BUCKET_NOT_FOUND = 'bucket-not-found',\n  PROJECT_NOT_FOUND = 'project-not-found',\n  QUOTA_EXCEEDED = 'quota-exceeded',\n  UNAUTHENTICATED = 'unauthenticated',\n  UNAUTHORIZED = 'unauthorized',\n  RETRY_LIMIT_EXCEEDED = 'retry-limit-exceeded',\n  INVALID_CHECKSUM = 'invalid-checksum',\n  CANCELED = 'canceled',\n  // JS specific\n  INVALID_EVENT_NAME = 'invalid-event-name',\n  INVALID_URL = 'invalid-url',\n  INVALID_DEFAULT_BUCKET = 'invalid-default-bucket',\n  NO_DEFAULT_BUCKET = 'no-default-bucket',\n  CANNOT_SLICE_BLOB = 'cannot-slice-blob',\n  SERVER_FILE_WRONG_SIZE = 'server-file-wrong-size',\n  NO_DOWNLOAD_URL = 'no-download-url',\n  INVALID_ARGUMENT = 'invalid-argument',\n  INVALID_ARGUMENT_COUNT = 'invalid-argument-count',\n  APP_DELETED = 'app-deleted',\n  INVALID_ROOT_OPERATION = 'invalid-root-operation',\n  INVALID_FORMAT = 'invalid-format',\n  INTERNAL_ERROR = 'internal-error',\n  UNSUPPORTED_ENVIRONMENT = 'unsupported-environment'\n}\n\nexport function prependCode(code: StorageErrorCode): string {\n  return 'storage/' + code;\n}\n\nexport function unknown(): FirebaseStorageError {\n  const message =\n    'An unknown error occurred, please check the error payload for ' +\n    'server response.';\n  return new FirebaseStorageError(StorageErrorCode.UNKNOWN, message);\n}\n\nexport function objectNotFound(path: string): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.OBJECT_NOT_FOUND,\n    \"Object '\" + path + \"' does not exist.\"\n  );\n}\n\nexport function bucketNotFound(bucket: string): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.BUCKET_NOT_FOUND,\n    \"Bucket '\" + bucket + \"' does not exist.\"\n  );\n}\n\nexport function projectNotFound(project: string): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.PROJECT_NOT_FOUND,\n    \"Project '\" + project + \"' does not exist.\"\n  );\n}\n\nexport function quotaExceeded(bucket: string): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.QUOTA_EXCEEDED,\n    \"Quota for bucket '\" +\n      bucket +\n      \"' exceeded, please view quota on \" +\n      'https://firebase.google.com/pricing/.'\n  );\n}\n\nexport function unauthenticated(): FirebaseStorageError {\n  const message =\n    'User is not authenticated, please authenticate using Firebase ' +\n    'Authentication and try again.';\n  return new FirebaseStorageError(StorageErrorCode.UNAUTHENTICATED, message);\n}\n\nexport function unauthorized(path: string): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.UNAUTHORIZED,\n    \"User does not have permission to access '\" + path + \"'.\"\n  );\n}\n\nexport function retryLimitExceeded(): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.RETRY_LIMIT_EXCEEDED,\n    'Max retry time for operation exceeded, please try again.'\n  );\n}\n\nexport function invalidChecksum(\n  path: string,\n  checksum: string,\n  calculated: string\n): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.INVALID_CHECKSUM,\n    \"Uploaded/downloaded object '\" +\n      path +\n      \"' has checksum '\" +\n      checksum +\n      \"' which does not match '\" +\n      calculated +\n      \"'. Please retry the upload/download.\"\n  );\n}\n\nexport function canceled(): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.CANCELED,\n    'User canceled the upload/download.'\n  );\n}\n\nexport function invalidEventName(name: string): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.INVALID_EVENT_NAME,\n    \"Invalid event name '\" + name + \"'.\"\n  );\n}\n\nexport function invalidUrl(url: string): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.INVALID_URL,\n    \"Invalid URL '\" + url + \"'.\"\n  );\n}\n\nexport function invalidDefaultBucket(bucket: string): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.INVALID_DEFAULT_BUCKET,\n    \"Invalid default bucket '\" + bucket + \"'.\"\n  );\n}\n\nexport function noDefaultBucket(): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.NO_DEFAULT_BUCKET,\n    'No default bucket ' +\n      \"found. Did you set the '\" +\n      CONFIG_STORAGE_BUCKET_KEY +\n      \"' property when initializing the app?\"\n  );\n}\n\nexport function cannotSliceBlob(): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.CANNOT_SLICE_BLOB,\n    'Cannot slice blob for upload. Please retry the upload.'\n  );\n}\n\nexport function serverFileWrongSize(): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.SERVER_FILE_WRONG_SIZE,\n    'Server recorded incorrect upload file size, please retry the upload.'\n  );\n}\n\nexport function noDownloadURL(): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.NO_DOWNLOAD_URL,\n    'The given file does not have any download URLs.'\n  );\n}\n\nexport function invalidArgument(message: string): FirebaseStorageError {\n  return new FirebaseStorageError(StorageErrorCode.INVALID_ARGUMENT, message);\n}\n\nexport function invalidArgumentCount(\n  argMin: number,\n  argMax: number,\n  fnName: string,\n  real: number\n): FirebaseStorageError {\n  let countPart;\n  let plural;\n  if (argMin === argMax) {\n    countPart = argMin;\n    plural = argMin === 1 ? 'argument' : 'arguments';\n  } else {\n    countPart = 'between ' + argMin + ' and ' + argMax;\n    plural = 'arguments';\n  }\n  return new FirebaseStorageError(\n    StorageErrorCode.INVALID_ARGUMENT_COUNT,\n    'Invalid argument count in `' +\n      fnName +\n      '`: Expected ' +\n      countPart +\n      ' ' +\n      plural +\n      ', received ' +\n      real +\n      '.'\n  );\n}\n\nexport function appDeleted(): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.APP_DELETED,\n    'The Firebase app was deleted.'\n  );\n}\n\n/**\n * @param name - The name of the operation that was invalid.\n */\nexport function invalidRootOperation(name: string): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.INVALID_ROOT_OPERATION,\n    \"The operation '\" +\n      name +\n      \"' cannot be performed on a root reference, create a non-root \" +\n      \"reference using child, such as .child('file.png').\"\n  );\n}\n\n/**\n * @param format - The format that was not valid.\n * @param message - A message describing the format violation.\n */\nexport function invalidFormat(\n  format: string,\n  message: string\n): FirebaseStorageError {\n  return new FirebaseStorageError(\n    StorageErrorCode.INVALID_FORMAT,\n    \"String does not match format '\" + format + \"': \" + message\n  );\n}\n\n/**\n * @param message - A message describing the internal error.\n */\nexport function unsupportedEnvironment(message: string): FirebaseStorageError {\n  throw new FirebaseStorageError(\n    StorageErrorCode.UNSUPPORTED_ENVIRONMENT,\n    message\n  );\n}\n\n/**\n * @param message - A message describing the internal error.\n */\nexport function internalError(message: string): FirebaseStorageError {\n  throw new FirebaseStorageError(\n    StorageErrorCode.INTERNAL_ERROR,\n    'Internal error: ' + message\n  );\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { unknown, invalidFormat } from './error';\n\n/**\n * An enumeration of the possible string formats for upload.\n * @public\n */\nexport type StringFormat = string;\n/**\n * An enumeration of the possible string formats for upload.\n * @public\n */\nexport const StringFormat = {\n  /**\n   * Indicates the string should be interpreted \"raw\", that is, as normal text.\n   * The string will be interpreted as UTF-16, then uploaded as a UTF-8 byte\n   * sequence.\n   * Example: The string 'Hello! \\\\ud83d\\\\ude0a' becomes the byte sequence\n   * 48 65 6c 6c 6f 21 20 f0 9f 98 8a\n   */\n  RAW: 'raw',\n  /**\n   * Indicates the string should be interpreted as base64-encoded data.\n   * Padding characters (trailing '='s) are optional.\n   * Example: The string 'rWmO++E6t7/rlw==' becomes the byte sequence\n   * ad 69 8e fb e1 3a b7 bf eb 97\n   */\n  BASE64: 'base64',\n  /**\n   * Indicates the string should be interpreted as base64url-encoded data.\n   * Padding characters (trailing '='s) are optional.\n   * Example: The string 'rWmO--E6t7_rlw==' becomes the byte sequence\n   * ad 69 8e fb e1 3a b7 bf eb 97\n   */\n  BASE64URL: 'base64url',\n  /**\n   * Indicates the string is a data URL, such as one obtained from\n   * canvas.toDataURL().\n   * Example: the string 'data:application/octet-stream;base64,aaaa'\n   * becomes the byte sequence\n   * 69 a6 9a\n   * (the content-type \"application/octet-stream\" is also applied, but can\n   * be overridden in the metadata object).\n   */\n  DATA_URL: 'data_url'\n};\n\nexport class StringData {\n  contentType: string | null;\n\n  constructor(public data: Uint8Array, contentType?: string | null) {\n    this.contentType = contentType || null;\n  }\n}\n\nexport function dataFromString(\n  format: StringFormat,\n  stringData: string\n): StringData {\n  switch (format) {\n    case StringFormat.RAW:\n      return new StringData(utf8Bytes_(stringData));\n    case StringFormat.BASE64:\n    case StringFormat.BASE64URL:\n      return new StringData(base64Bytes_(format, stringData));\n    case StringFormat.DATA_URL:\n      return new StringData(\n        dataURLBytes_(stringData),\n        dataURLContentType_(stringData)\n      );\n    default:\n    // do nothing\n  }\n\n  // assert(false);\n  throw unknown();\n}\n\nexport function utf8Bytes_(value: string): Uint8Array {\n  const b: number[] = [];\n  for (let i = 0; i < value.length; i++) {\n    let c = value.charCodeAt(i);\n    if (c <= 127) {\n      b.push(c);\n    } else {\n      if (c <= 2047) {\n        b.push(192 | (c >> 6), 128 | (c & 63));\n      } else {\n        if ((c & 64512) === 55296) {\n          // The start of a surrogate pair.\n          const valid =\n            i < value.length - 1 && (value.charCodeAt(i + 1) & 64512) === 56320;\n          if (!valid) {\n            // The second surrogate wasn't there.\n            b.push(239, 191, 189);\n          } else {\n            const hi = c;\n            const lo = value.charCodeAt(++i);\n            c = 65536 | ((hi & 1023) << 10) | (lo & 1023);\n            b.push(\n              240 | (c >> 18),\n              128 | ((c >> 12) & 63),\n              128 | ((c >> 6) & 63),\n              128 | (c & 63)\n            );\n          }\n        } else {\n          if ((c & 64512) === 56320) {\n            // Invalid low surrogate.\n            b.push(239, 191, 189);\n          } else {\n            b.push(224 | (c >> 12), 128 | ((c >> 6) & 63), 128 | (c & 63));\n          }\n        }\n      }\n    }\n  }\n  return new Uint8Array(b);\n}\n\nexport function percentEncodedBytes_(value: string): Uint8Array {\n  let decoded;\n  try {\n    decoded = decodeURIComponent(value);\n  } catch (e) {\n    throw invalidFormat(StringFormat.DATA_URL, 'Malformed data URL.');\n  }\n  return utf8Bytes_(decoded);\n}\n\nexport function base64Bytes_(format: StringFormat, value: string): Uint8Array {\n  switch (format) {\n    case StringFormat.BASE64: {\n      const hasMinus = value.indexOf('-') !== -1;\n      const hasUnder = value.indexOf('_') !== -1;\n      if (hasMinus || hasUnder) {\n        const invalidChar = hasMinus ? '-' : '_';\n        throw invalidFormat(\n          format,\n          \"Invalid character '\" +\n            invalidChar +\n            \"' found: is it base64url encoded?\"\n        );\n      }\n      break;\n    }\n    case StringFormat.BASE64URL: {\n      const hasPlus = value.indexOf('+') !== -1;\n      const hasSlash = value.indexOf('/') !== -1;\n      if (hasPlus || hasSlash) {\n        const invalidChar = hasPlus ? '+' : '/';\n        throw invalidFormat(\n          format,\n          \"Invalid character '\" + invalidChar + \"' found: is it base64 encoded?\"\n        );\n      }\n      value = value.replace(/-/g, '+').replace(/_/g, '/');\n      break;\n    }\n    default:\n    // do nothing\n  }\n  let bytes;\n  try {\n    bytes = atob(value);\n  } catch (e) {\n    throw invalidFormat(format, 'Invalid character found');\n  }\n  const array = new Uint8Array(bytes.length);\n  for (let i = 0; i < bytes.length; i++) {\n    array[i] = bytes.charCodeAt(i);\n  }\n  return array;\n}\n\nclass DataURLParts {\n  base64: boolean = false;\n  contentType: string | null = null;\n  rest: string;\n\n  constructor(dataURL: string) {\n    const matches = dataURL.match(/^data:([^,]+)?,/);\n    if (matches === null) {\n      throw invalidFormat(\n        StringFormat.DATA_URL,\n        \"Must be formatted 'data:[<mediatype>][;base64],<data>\"\n      );\n    }\n    const middle = matches[1] || null;\n    if (middle != null) {\n      this.base64 = endsWith(middle, ';base64');\n      this.contentType = this.base64\n        ? middle.substring(0, middle.length - ';base64'.length)\n        : middle;\n    }\n    this.rest = dataURL.substring(dataURL.indexOf(',') + 1);\n  }\n}\n\nexport function dataURLBytes_(dataUrl: string): Uint8Array {\n  const parts = new DataURLParts(dataUrl);\n  if (parts.base64) {\n    return base64Bytes_(StringFormat.BASE64, parts.rest);\n  } else {\n    return percentEncodedBytes_(parts.rest);\n  }\n}\n\nexport function dataURLContentType_(dataUrl: string): string | null {\n  const parts = new DataURLParts(dataUrl);\n  return parts.contentType;\n}\n\nfunction endsWith(s: string, end: string): boolean {\n  const longEnough = s.length >= end.length;\n  if (!longEnough) {\n    return false;\n  }\n\n  return s.substring(s.length - end.length) === end;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Enumerations used for upload tasks.\n */\n\n/**\n * An event that is triggered on a task.\n */\nexport type TaskEvent = string;\n\n/**\n * An event that is triggered on a task.\n */\nexport const TaskEvent = {\n  /**\n   * For this event,\n   * <ul>\n   *   <li>The `next` function is triggered on progress updates and when the\n   *       task is paused/resumed with an `UploadTaskSnapshot` as the first\n   *       argument.</li>\n   *   <li>The `error` function is triggered if the upload is canceled or fails\n   *       for another reason.</li>\n   *   <li>The `complete` function is triggered if the upload completes\n   *       successfully.</li>\n   * </ul>\n   */\n  STATE_CHANGED: 'state_changed'\n};\n\n/**\n * Internal enum for task state.\n */\nexport const enum InternalTaskState {\n  RUNNING = 'running',\n  PAUSING = 'pausing',\n  PAUSED = 'paused',\n  SUCCESS = 'success',\n  CANCELING = 'canceling',\n  CANCELED = 'canceled',\n  ERROR = 'error'\n}\n\n/**\n * Represents the current state of a running upload.\n */\nexport type TaskState = string;\n\n/**\n * Represents the current state of a running upload.\n */\nexport const TaskState = {\n  /** The task is currently transferring data. */\n  RUNNING: 'running',\n\n  /** The task was paused by the user. */\n  PAUSED: 'paused',\n\n  /** The task completed successfully. */\n  SUCCESS: 'success',\n\n  /** The task was canceled. */\n  CANCELED: 'canceled',\n\n  /** The task failed with an error. */\n  ERROR: 'error'\n};\n\nexport function taskStateFromInternalTaskState(\n  state: InternalTaskState\n): TaskState {\n  switch (state) {\n    case InternalTaskState.RUNNING:\n    case InternalTaskState.PAUSING:\n    case InternalTaskState.CANCELING:\n      return TaskState.RUNNING;\n    case InternalTaskState.PAUSED:\n      return TaskState.PAUSED;\n    case InternalTaskState.SUCCESS:\n      return TaskState.SUCCESS;\n    case InternalTaskState.CANCELED:\n      return TaskState.CANCELED;\n    case InternalTaskState.ERROR:\n      return TaskState.ERROR;\n    default:\n      // TODO(andysoto): assert(false);\n      return TaskState.ERROR;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * XHR headers\n */\nexport interface Headers {\n  [name: string]: string | number;\n}\n\n/**\n * A lightweight wrapper around XMLHttpRequest with a\n * goog.net.XhrIo-like interface.\n */\nexport interface XhrIo {\n  send(\n    url: string,\n    method: string,\n    body?: ArrayBufferView | Blob | string | null,\n    headers?: Headers\n  ): Promise<XhrIo>;\n\n  getErrorCode(): ErrorCode;\n\n  getStatus(): number;\n\n  getResponseText(): string;\n\n  /**\n   * Abort the request.\n   */\n  abort(): void;\n\n  getResponseHeader(header: string): string | null;\n\n  addUploadProgressListener(listener: (p1: ProgressEvent) => void): void;\n\n  removeUploadProgressListener(listener: (p1: ProgressEvent) => void): void;\n}\n\n/**\n * Error codes for requests made by the the XhrIo wrapper.\n */\nexport enum ErrorCode {\n  NO_ERROR = 0,\n  NETWORK_ERROR = 1,\n  ABORT = 2\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { Headers, XhrIo, ErrorCode } from './xhrio';\nimport { internalError } from './error';\n\n/**\n * We use this instead of goog.net.XhrIo because goog.net.XhrIo is hyuuuuge and\n * doesn't work in React Native on Android.\n */\nexport class NetworkXhrIo implements XhrIo {\n  private xhr_: XMLHttpRequest;\n  private errorCode_: ErrorCode;\n  private sendPromise_: Promise<XhrIo>;\n  private sent_: boolean = false;\n\n  constructor() {\n    this.xhr_ = new XMLHttpRequest();\n    this.errorCode_ = ErrorCode.NO_ERROR;\n    this.sendPromise_ = new Promise(resolve => {\n      this.xhr_.addEventListener('abort', () => {\n        this.errorCode_ = ErrorCode.ABORT;\n        resolve(this);\n      });\n      this.xhr_.addEventListener('error', () => {\n        this.errorCode_ = ErrorCode.NETWORK_ERROR;\n        resolve(this);\n      });\n      this.xhr_.addEventListener('load', () => {\n        resolve(this);\n      });\n    });\n  }\n\n  /**\n   * @override\n   */\n  send(\n    url: string,\n    method: string,\n    body?: ArrayBufferView | Blob | string,\n    headers?: Headers\n  ): Promise<XhrIo> {\n    if (this.sent_) {\n      throw internalError('cannot .send() more than once');\n    }\n    this.sent_ = true;\n    this.xhr_.open(method, url, true);\n    if (headers !== undefined) {\n      for (const key in headers) {\n        if (headers.hasOwnProperty(key)) {\n          this.xhr_.setRequestHeader(key, headers[key].toString());\n        }\n      }\n    }\n    if (body !== undefined) {\n      this.xhr_.send(body);\n    } else {\n      this.xhr_.send();\n    }\n    return this.sendPromise_;\n  }\n\n  /**\n   * @override\n   */\n  getErrorCode(): ErrorCode {\n    if (!this.sent_) {\n      throw internalError('cannot .getErrorCode() before sending');\n    }\n    return this.errorCode_;\n  }\n\n  /**\n   * @override\n   */\n  getStatus(): number {\n    if (!this.sent_) {\n      throw internalError('cannot .getStatus() before sending');\n    }\n    try {\n      return this.xhr_.status;\n    } catch (e) {\n      return -1;\n    }\n  }\n\n  /**\n   * @override\n   */\n  getResponseText(): string {\n    if (!this.sent_) {\n      throw internalError('cannot .getResponseText() before sending');\n    }\n    return this.xhr_.responseText;\n  }\n\n  /**\n   * Aborts the request.\n   * @override\n   */\n  abort(): void {\n    this.xhr_.abort();\n  }\n\n  /**\n   * @override\n   */\n  getResponseHeader(header: string): string | null {\n    return this.xhr_.getResponseHeader(header);\n  }\n\n  /**\n   * @override\n   */\n  addUploadProgressListener(listener: (p1: ProgressEvent) => void): void {\n    if (this.xhr_.upload != null) {\n      this.xhr_.upload.addEventListener('progress', listener);\n    }\n  }\n\n  /**\n   * @override\n   */\n  removeUploadProgressListener(listener: (p1: ProgressEvent) => void): void {\n    if (this.xhr_.upload != null) {\n      this.xhr_.upload.removeEventListener('progress', listener);\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Replacement for goog.net.XhrIoPool that works with fbs.XhrIo.\n */\nimport { XhrIo } from './xhrio';\nimport { NetworkXhrIo } from './xhrio_network';\n\n/**\n * Factory-like class for creating XhrIo instances.\n */\nexport class XhrIoPool {\n  createXhrIo(): XhrIo {\n    return new NetworkXhrIo();\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { invalidArgument } from './error';\n\nexport function isJustDef<T>(p: T | null | undefined): p is T | null {\n  return p !== void 0;\n}\n\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function isFunction(p: unknown): p is Function {\n  return typeof p === 'function';\n}\n\nexport function isNonArrayObject(p: unknown): boolean {\n  return typeof p === 'object' && !Array.isArray(p);\n}\n\nexport function isString(p: unknown): p is string {\n  return typeof p === 'string' || p instanceof String;\n}\n\nexport function isNativeBlob(p: unknown): p is Blob {\n  return isNativeBlobDefined() && p instanceof Blob;\n}\n\nexport function isNativeBlobDefined(): boolean {\n  return typeof Blob !== 'undefined';\n}\n\nexport function validateNumber(\n  argument: string,\n  minValue: number,\n  maxValue: number,\n  value: number\n): void {\n  if (value < minValue) {\n    throw invalidArgument(\n      `Invalid value for '${argument}'. Expected ${minValue} or greater.`\n    );\n  }\n  if (value > maxValue) {\n    throw invalidArgument(\n      `Invalid value for '${argument}'. Expected ${maxValue} or less.`\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * @fileoverview Some methods copied from goog.fs.\n * We don't include goog.fs because it pulls in a bunch of Deferred code that\n * bloats the size of the released binary.\n */\nimport { isNativeBlobDefined } from './type';\nimport { StorageErrorCode, FirebaseStorageError } from './error';\n\nfunction getBlobBuilder(): typeof IBlobBuilder | undefined {\n  if (typeof BlobBuilder !== 'undefined') {\n    return BlobBuilder;\n  } else if (typeof WebKitBlobBuilder !== 'undefined') {\n    return WebKitBlobBuilder;\n  } else {\n    return undefined;\n  }\n}\n\n/**\n * Concatenates one or more values together and converts them to a Blob.\n *\n * @param args The values that will make up the resulting blob.\n * @return The blob.\n */\nexport function getBlob(...args: Array<string | Blob | ArrayBuffer>): Blob {\n  const BlobBuilder = getBlobBuilder();\n  if (BlobBuilder !== undefined) {\n    const bb = new BlobBuilder();\n    for (let i = 0; i < args.length; i++) {\n      bb.append(args[i]);\n    }\n    return bb.getBlob();\n  } else {\n    if (isNativeBlobDefined()) {\n      return new Blob(args);\n    } else {\n      throw new FirebaseStorageError(\n        StorageErrorCode.UNSUPPORTED_ENVIRONMENT,\n        \"This browser doesn't seem to support creating Blobs\"\n      );\n    }\n  }\n}\n\n/**\n * Slices the blob. The returned blob contains data from the start byte\n * (inclusive) till the end byte (exclusive). Negative indices cannot be used.\n *\n * @param blob The blob to be sliced.\n * @param start Index of the starting byte.\n * @param end Index of the ending byte.\n * @return The blob slice or null if not supported.\n */\nexport function sliceBlob(blob: Blob, start: number, end: number): Blob | null {\n  if (blob.webkitSlice) {\n    return blob.webkitSlice(start, end);\n  } else if (blob.mozSlice) {\n    return blob.mozSlice(start, end);\n  } else if (blob.slice) {\n    return blob.slice(start, end);\n  }\n  return null;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @file Provides a Blob-like wrapper for various binary types (including the\n * native Blob type). This makes it possible to upload types like ArrayBuffers,\n * making uploads possible in environments without the native Blob type.\n */\nimport { sliceBlob, getBlob } from './fs';\nimport { StringFormat, dataFromString } from './string';\nimport { isNativeBlob, isNativeBlobDefined, isString } from './type';\n\n/**\n * @param opt_elideCopy - If true, doesn't copy mutable input data\n *     (e.g. Uint8Arrays). Pass true only if you know the objects will not be\n *     modified after this blob's construction.\n */\nexport class FbsBlob {\n  private data_!: Blob | Uint8Array;\n  private size_: number;\n  private type_: string;\n\n  constructor(data: Blob | Uint8Array | ArrayBuffer, elideCopy?: boolean) {\n    let size: number = 0;\n    let blobType: string = '';\n    if (isNativeBlob(data)) {\n      this.data_ = data as Blob;\n      size = (data as Blob).size;\n      blobType = (data as Blob).type;\n    } else if (data instanceof ArrayBuffer) {\n      if (elideCopy) {\n        this.data_ = new Uint8Array(data);\n      } else {\n        this.data_ = new Uint8Array(data.byteLength);\n        this.data_.set(new Uint8Array(data));\n      }\n      size = this.data_.length;\n    } else if (data instanceof Uint8Array) {\n      if (elideCopy) {\n        this.data_ = data as Uint8Array;\n      } else {\n        this.data_ = new Uint8Array(data.length);\n        this.data_.set(data as Uint8Array);\n      }\n      size = data.length;\n    }\n    this.size_ = size;\n    this.type_ = blobType;\n  }\n\n  size(): number {\n    return this.size_;\n  }\n\n  type(): string {\n    return this.type_;\n  }\n\n  slice(startByte: number, endByte: number): FbsBlob | null {\n    if (isNativeBlob(this.data_)) {\n      const realBlob = this.data_ as Blob;\n      const sliced = sliceBlob(realBlob, startByte, endByte);\n      if (sliced === null) {\n        return null;\n      }\n      return new FbsBlob(sliced);\n    } else {\n      const slice = new Uint8Array(\n        (this.data_ as Uint8Array).buffer,\n        startByte,\n        endByte - startByte\n      );\n      return new FbsBlob(slice, true);\n    }\n  }\n\n  static getBlob(...args: Array<string | FbsBlob>): FbsBlob | null {\n    if (isNativeBlobDefined()) {\n      const blobby: Array<Blob | Uint8Array | string> = args.map(\n        (val: string | FbsBlob): Blob | Uint8Array | string => {\n          if (val instanceof FbsBlob) {\n            return val.data_;\n          } else {\n            return val;\n          }\n        }\n      );\n      return new FbsBlob(getBlob.apply(null, blobby));\n    } else {\n      const uint8Arrays: Uint8Array[] = args.map(\n        (val: string | FbsBlob): Uint8Array => {\n          if (isString(val)) {\n            return dataFromString(StringFormat.RAW, val as string).data;\n          } else {\n            // Blobs don't exist, so this has to be a Uint8Array.\n            return (val as FbsBlob).data_ as Uint8Array;\n          }\n        }\n      );\n      let finalLength = 0;\n      uint8Arrays.forEach((array: Uint8Array): void => {\n        finalLength += array.byteLength;\n      });\n      const merged = new Uint8Array(finalLength);\n      let index = 0;\n      uint8Arrays.forEach((array: Uint8Array) => {\n        for (let i = 0; i < array.length; i++) {\n          merged[index++] = array[i];\n        }\n      });\n      return new FbsBlob(merged, true);\n    }\n  }\n\n  uploadData(): Blob | Uint8Array {\n    return this.data_;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Functionality related to the parsing/composition of bucket/\n * object location.\n */\n\nimport { invalidDefaultBucket, invalidUrl } from './error';\nimport { DEFAULT_HOST } from './constants';\n\n/**\n * Firebase Storage location data.\n */\nexport class Location {\n  private path_: string;\n\n  constructor(public readonly bucket: string, path: string) {\n    this.path_ = path;\n  }\n\n  get path(): string {\n    return this.path_;\n  }\n\n  get isRoot(): boolean {\n    return this.path.length === 0;\n  }\n\n  fullServerUrl(): string {\n    const encode = encodeURIComponent;\n    return '/b/' + encode(this.bucket) + '/o/' + encode(this.path);\n  }\n\n  bucketOnlyServerUrl(): string {\n    const encode = encodeURIComponent;\n    return '/b/' + encode(this.bucket) + '/o';\n  }\n\n  static makeFromBucketSpec(bucketString: string): Location {\n    let bucketLocation;\n    try {\n      bucketLocation = Location.makeFromUrl(bucketString);\n    } catch (e) {\n      // Not valid URL, use as-is. This lets you put bare bucket names in\n      // config.\n      return new Location(bucketString, '');\n    }\n    if (bucketLocation.path === '') {\n      return bucketLocation;\n    } else {\n      throw invalidDefaultBucket(bucketString);\n    }\n  }\n\n  static makeFromUrl(url: string): Location {\n    let location: Location | null = null;\n    const bucketDomain = '([A-Za-z0-9.\\\\-_]+)';\n\n    function gsModify(loc: Location): void {\n      if (loc.path.charAt(loc.path.length - 1) === '/') {\n        loc.path_ = loc.path_.slice(0, -1);\n      }\n    }\n    const gsPath = '(/(.*))?$';\n    const gsRegex = new RegExp('^gs://' + bucketDomain + gsPath, 'i');\n    const gsIndices = { bucket: 1, path: 3 };\n\n    function httpModify(loc: Location): void {\n      loc.path_ = decodeURIComponent(loc.path);\n    }\n    const version = 'v[A-Za-z0-9_]+';\n    const firebaseStorageHost = DEFAULT_HOST.replace(/[.]/g, '\\\\.');\n    const firebaseStoragePath = '(/([^?#]*).*)?$';\n    const firebaseStorageRegExp = new RegExp(\n      `^https?://${firebaseStorageHost}/${version}/b/${bucketDomain}/o${firebaseStoragePath}`,\n      'i'\n    );\n    const firebaseStorageIndices = { bucket: 1, path: 3 };\n\n    const cloudStorageHost =\n      '(?:storage.googleapis.com|storage.cloud.google.com)';\n    const cloudStoragePath = '([^?#]*)';\n    const cloudStorageRegExp = new RegExp(\n      `^https?://${cloudStorageHost}/${bucketDomain}/${cloudStoragePath}`,\n      'i'\n    );\n    const cloudStorageIndices = { bucket: 1, path: 2 };\n\n    const groups = [\n      { regex: gsRegex, indices: gsIndices, postModify: gsModify },\n      {\n        regex: firebaseStorageRegExp,\n        indices: firebaseStorageIndices,\n        postModify: httpModify\n      },\n      {\n        regex: cloudStorageRegExp,\n        indices: cloudStorageIndices,\n        postModify: httpModify\n      }\n    ];\n    for (let i = 0; i < groups.length; i++) {\n      const group = groups[i];\n      const captures = group.regex.exec(url);\n      if (captures) {\n        const bucketValue = captures[group.indices.bucket];\n        let pathValue = captures[group.indices.path];\n        if (!pathValue) {\n          pathValue = '';\n        }\n        location = new Location(bucketValue, pathValue);\n        group.postModify(location);\n        break;\n      }\n    }\n    if (location == null) {\n      throw invalidUrl(url);\n    }\n    return location;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { isNonArrayObject } from './type';\n\n/**\n * Returns the Object resulting from parsing the given JSON, or null if the\n * given string does not represent a JSON object.\n */\nexport function jsonObjectOrNull(\n  s: string\n): { [name: string]: unknown } | null {\n  let obj;\n  try {\n    obj = JSON.parse(s);\n  } catch (e) {\n    return null;\n  }\n  if (isNonArrayObject(obj)) {\n    return obj;\n  } else {\n    return null;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Contains helper methods for manipulating paths.\n */\n\n/**\n * @return Null if the path is already at the root.\n */\nexport function parent(path: string): string | null {\n  if (path.length === 0) {\n    return null;\n  }\n  const index = path.lastIndexOf('/');\n  if (index === -1) {\n    return '';\n  }\n  const newPath = path.slice(0, index);\n  return newPath;\n}\n\nexport function child(path: string, childPath: string): string {\n  const canonicalChildPath = childPath\n    .split('/')\n    .filter(component => component.length > 0)\n    .join('/');\n  if (path.length === 0) {\n    return canonicalChildPath;\n  } else {\n    return path + '/' + canonicalChildPath;\n  }\n}\n\n/**\n * Returns the last component of a path.\n * '/foo/bar' -> 'bar'\n * '/foo/bar/baz/' -> 'baz/'\n * '/a' -> 'a'\n */\nexport function lastComponent(path: string): string {\n  const index = path.lastIndexOf('/', path.length - 2);\n  if (index === -1) {\n    return path;\n  } else {\n    return path.slice(index + 1);\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Functions to create and manipulate URLs for the server API.\n */\nimport { DEFAULT_HOST } from './constants';\nimport { UrlParams } from './requestinfo';\n\nexport function makeUrl(urlPart: string): string {\n  return `https://${DEFAULT_HOST}/v0${urlPart}`;\n}\n\nexport function makeQueryString(params: UrlParams): string {\n  const encode = encodeURIComponent;\n  let queryPart = '?';\n  for (const key in params) {\n    if (params.hasOwnProperty(key)) {\n      const nextPart = encode(key) + '=' + encode(params[key]);\n      queryPart = queryPart + nextPart + '&';\n    }\n  }\n\n  // Chop off the extra '&' or '?' on the end\n  queryPart = queryPart.slice(0, -1);\n  return queryPart;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Documentation for the metadata format\n */\nimport { Metadata } from '../metadata';\n\nimport { jsonObjectOrNull } from './json';\nimport { Location } from './location';\nimport { lastComponent } from './path';\nimport { isString } from './type';\nimport { makeUrl, makeQueryString } from './url';\nimport { Reference } from '../reference';\nimport { StorageService } from '../service';\n\nexport function noXform_<T>(metadata: Metadata, value: T): T {\n  return value;\n}\n\nclass Mapping<T> {\n  local: string;\n  writable: boolean;\n  xform: (p1: Metadata, p2?: T) => T | undefined;\n\n  constructor(\n    public server: string,\n    local?: string | null,\n    writable?: boolean,\n    xform?: ((p1: Metadata, p2?: T) => T | undefined) | null\n  ) {\n    this.local = local || server;\n    this.writable = !!writable;\n    this.xform = xform || noXform_;\n  }\n}\ntype Mappings = Array<Mapping<string> | Mapping<number>>;\n\nexport { Mappings };\n\nlet mappings_: Mappings | null = null;\n\nexport function xformPath(fullPath: string | undefined): string | undefined {\n  if (!isString(fullPath) || fullPath.length < 2) {\n    return fullPath;\n  } else {\n    return lastComponent(fullPath);\n  }\n}\n\nexport function getMappings(): Mappings {\n  if (mappings_) {\n    return mappings_;\n  }\n  const mappings: Mappings = [];\n  mappings.push(new Mapping<string>('bucket'));\n  mappings.push(new Mapping<string>('generation'));\n  mappings.push(new Mapping<string>('metageneration'));\n  mappings.push(new Mapping<string>('name', 'fullPath', true));\n\n  function mappingsXformPath(\n    _metadata: Metadata,\n    fullPath: string | undefined\n  ): string | undefined {\n    return xformPath(fullPath);\n  }\n  const nameMapping = new Mapping<string>('name');\n  nameMapping.xform = mappingsXformPath;\n  mappings.push(nameMapping);\n\n  /**\n   * Coerces the second param to a number, if it is defined.\n   */\n  function xformSize(\n    _metadata: Metadata,\n    size?: number | string\n  ): number | undefined {\n    if (size !== undefined) {\n      return Number(size);\n    } else {\n      return size;\n    }\n  }\n  const sizeMapping = new Mapping<number>('size');\n  sizeMapping.xform = xformSize;\n  mappings.push(sizeMapping);\n  mappings.push(new Mapping<number>('timeCreated'));\n  mappings.push(new Mapping<string>('updated'));\n  mappings.push(new Mapping<string>('md5Hash', null, true));\n  mappings.push(new Mapping<string>('cacheControl', null, true));\n  mappings.push(new Mapping<string>('contentDisposition', null, true));\n  mappings.push(new Mapping<string>('contentEncoding', null, true));\n  mappings.push(new Mapping<string>('contentLanguage', null, true));\n  mappings.push(new Mapping<string>('contentType', null, true));\n  mappings.push(new Mapping<string>('metadata', 'customMetadata', true));\n  mappings_ = mappings;\n  return mappings_;\n}\n\nexport function addRef(metadata: Metadata, service: StorageService): void {\n  function generateRef(): Reference {\n    const bucket: string = metadata['bucket'] as string;\n    const path: string = metadata['fullPath'] as string;\n    const loc = new Location(bucket, path);\n    return service._makeStorageReference(loc);\n  }\n  Object.defineProperty(metadata, 'ref', { get: generateRef });\n}\n\nexport function fromResource(\n  service: StorageService,\n  resource: { [name: string]: unknown },\n  mappings: Mappings\n): Metadata {\n  const metadata: Metadata = {} as Metadata;\n  metadata['type'] = 'file';\n  const len = mappings.length;\n  for (let i = 0; i < len; i++) {\n    const mapping = mappings[i];\n    metadata[mapping.local] = (mapping as Mapping<unknown>).xform(\n      metadata,\n      resource[mapping.server]\n    );\n  }\n  addRef(metadata, service);\n  return metadata;\n}\n\nexport function fromResourceString(\n  service: StorageService,\n  resourceString: string,\n  mappings: Mappings\n): Metadata | null {\n  const obj = jsonObjectOrNull(resourceString);\n  if (obj === null) {\n    return null;\n  }\n  const resource = obj as Metadata;\n  return fromResource(service, resource, mappings);\n}\n\nexport function downloadUrlFromResourceString(\n  metadata: Metadata,\n  resourceString: string\n): string | null {\n  const obj = jsonObjectOrNull(resourceString);\n  if (obj === null) {\n    return null;\n  }\n  if (!isString(obj['downloadTokens'])) {\n    // This can happen if objects are uploaded through GCS and retrieved\n    // through list, so we don't want to throw an Error.\n    return null;\n  }\n  const tokens: string = obj['downloadTokens'] as string;\n  if (tokens.length === 0) {\n    return null;\n  }\n  const encode = encodeURIComponent;\n  const tokensList = tokens.split(',');\n  const urls = tokensList.map((token: string): string => {\n    const bucket: string = metadata['bucket'] as string;\n    const path: string = metadata['fullPath'] as string;\n    const urlPart = '/b/' + encode(bucket) + '/o/' + encode(path);\n    const base = makeUrl(urlPart);\n    const queryString = makeQueryString({\n      alt: 'media',\n      token\n    });\n    return base + queryString;\n  });\n  return urls[0];\n}\n\nexport function toResourceString(\n  metadata: Partial<Metadata>,\n  mappings: Mappings\n): string {\n  const resource: {\n    [prop: string]: unknown;\n  } = {};\n  const len = mappings.length;\n  for (let i = 0; i < len; i++) {\n    const mapping = mappings[i];\n    if (mapping.writable) {\n      resource[mapping.server] = metadata[mapping.local];\n    }\n  }\n  return JSON.stringify(resource);\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Documentation for the listOptions and listResult format\n */\nimport { Location } from './location';\nimport { jsonObjectOrNull } from './json';\nimport { ListResult } from '../list';\nimport { StorageService } from '../service';\n\n/**\n * Represents the simplified object metadata returned by List API.\n * Other fields are filtered because list in Firebase Rules does not grant\n * the permission to read the metadata.\n */\ninterface ListMetadataResponse {\n  name: string;\n  bucket: string;\n}\n\n/**\n * Represents the JSON response of List API.\n */\ninterface ListResultResponse {\n  prefixes: string[];\n  items: ListMetadataResponse[];\n  nextPageToken?: string;\n}\n\nconst PREFIXES_KEY = 'prefixes';\nconst ITEMS_KEY = 'items';\n\nfunction fromBackendResponse(\n  service: StorageService,\n  bucket: string,\n  resource: ListResultResponse\n): ListResult {\n  const listResult: ListResult = {\n    prefixes: [],\n    items: [],\n    nextPageToken: resource['nextPageToken']\n  };\n  if (resource[PREFIXES_KEY]) {\n    for (const path of resource[PREFIXES_KEY]) {\n      const pathWithoutTrailingSlash = path.replace(/\\/$/, '');\n      const reference = service._makeStorageReference(\n        new Location(bucket, pathWithoutTrailingSlash)\n      );\n      listResult.prefixes.push(reference);\n    }\n  }\n\n  if (resource[ITEMS_KEY]) {\n    for (const item of resource[ITEMS_KEY]) {\n      const reference = service._makeStorageReference(\n        new Location(bucket, item['name'])\n      );\n      listResult.items.push(reference);\n    }\n  }\n  return listResult;\n}\n\nexport function fromResponseString(\n  service: StorageService,\n  bucket: string,\n  resourceString: string\n): ListResult | null {\n  const obj = jsonObjectOrNull(resourceString);\n  if (obj === null) {\n    return null;\n  }\n  const resource = (obj as unknown) as ListResultResponse;\n  return fromBackendResponse(service, bucket, resource);\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { FirebaseStorageError } from './error';\nimport { Headers, XhrIo } from './xhrio';\n\n/**\n * Type for url params stored in RequestInfo.\n */\nexport interface UrlParams {\n  [name: string]: string | number;\n}\n\nexport class RequestInfo<T> {\n  urlParams: UrlParams = {};\n  headers: Headers = {};\n  body: Blob | string | Uint8Array | null = null;\n\n  errorHandler:\n    | ((p1: XhrIo, p2: FirebaseStorageError) => FirebaseStorageError)\n    | null = null;\n\n  /**\n   * Called with the current number of bytes uploaded and total size (-1 if not\n   * computable) of the request body (i.e. used to report upload progress).\n   */\n  progressCallback: ((p1: number, p2: number) => void) | null = null;\n  successCodes: number[] = [200];\n  additionalRetryCodes: number[] = [];\n\n  constructor(\n    public url: string,\n    public method: string,\n    /**\n     * Returns the value with which to resolve the request's promise. Only called\n     * if the request is successful. Throw from this function to reject the\n     * returned Request's promise with the thrown error.\n     * Note: The XhrIo passed to this function may be reused after this callback\n     * returns. Do not keep a reference to it in any way.\n     */\n    public handler: (p1: XhrIo, p2: string) => T,\n    public timeout: number\n  ) {}\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Defines methods for interacting with the network.\n */\n\nimport { Metadata } from '../metadata';\nimport { ListResult } from '../list';\nimport { FbsBlob } from './blob';\nimport {\n  FirebaseStorageError,\n  cannotSliceBlob,\n  unauthenticated,\n  quotaExceeded,\n  unauthorized,\n  objectNotFound,\n  serverFileWrongSize,\n  unknown\n} from './error';\nimport { Location } from './location';\nimport {\n  Mappings,\n  fromResourceString,\n  downloadUrlFromResourceString,\n  toResourceString\n} from './metadata';\nimport { fromResponseString } from './list';\nimport { RequestInfo, UrlParams } from './requestinfo';\nimport { isString } from './type';\nimport { makeUrl } from './url';\nimport { XhrIo } from './xhrio';\nimport { StorageService } from '../service';\n\n/**\n * Throws the UNKNOWN FirebaseStorageError if cndn is false.\n */\nexport function handlerCheck(cndn: boolean): void {\n  if (!cndn) {\n    throw unknown();\n  }\n}\n\nexport function metadataHandler(\n  service: StorageService,\n  mappings: Mappings\n): (p1: XhrIo, p2: string) => Metadata {\n  function handler(xhr: XhrIo, text: string): Metadata {\n    const metadata = fromResourceString(service, text, mappings);\n    handlerCheck(metadata !== null);\n    return metadata as Metadata;\n  }\n  return handler;\n}\n\nexport function listHandler(\n  service: StorageService,\n  bucket: string\n): (p1: XhrIo, p2: string) => ListResult {\n  function handler(xhr: XhrIo, text: string): ListResult {\n    const listResult = fromResponseString(service, bucket, text);\n    handlerCheck(listResult !== null);\n    return listResult as ListResult;\n  }\n  return handler;\n}\n\nexport function downloadUrlHandler(\n  service: StorageService,\n  mappings: Mappings\n): (p1: XhrIo, p2: string) => string | null {\n  function handler(xhr: XhrIo, text: string): string | null {\n    const metadata = fromResourceString(service, text, mappings);\n    handlerCheck(metadata !== null);\n    return downloadUrlFromResourceString(metadata as Metadata, text);\n  }\n  return handler;\n}\n\nexport function sharedErrorHandler(\n  location: Location\n): (p1: XhrIo, p2: FirebaseStorageError) => FirebaseStorageError {\n  function errorHandler(\n    xhr: XhrIo,\n    err: FirebaseStorageError\n  ): FirebaseStorageError {\n    let newErr;\n    if (xhr.getStatus() === 401) {\n      newErr = unauthenticated();\n    } else {\n      if (xhr.getStatus() === 402) {\n        newErr = quotaExceeded(location.bucket);\n      } else {\n        if (xhr.getStatus() === 403) {\n          newErr = unauthorized(location.path);\n        } else {\n          newErr = err;\n        }\n      }\n    }\n    newErr.serverResponse = err.serverResponse;\n    return newErr;\n  }\n  return errorHandler;\n}\n\nexport function objectErrorHandler(\n  location: Location\n): (p1: XhrIo, p2: FirebaseStorageError) => FirebaseStorageError {\n  const shared = sharedErrorHandler(location);\n\n  function errorHandler(\n    xhr: XhrIo,\n    err: FirebaseStorageError\n  ): FirebaseStorageError {\n    let newErr = shared(xhr, err);\n    if (xhr.getStatus() === 404) {\n      newErr = objectNotFound(location.path);\n    }\n    newErr.serverResponse = err.serverResponse;\n    return newErr;\n  }\n  return errorHandler;\n}\n\nexport function getMetadata(\n  service: StorageService,\n  location: Location,\n  mappings: Mappings\n): RequestInfo<Metadata> {\n  const urlPart = location.fullServerUrl();\n  const url = makeUrl(urlPart);\n  const method = 'GET';\n  const timeout = service.maxOperationRetryTime;\n  const requestInfo = new RequestInfo(\n    url,\n    method,\n    metadataHandler(service, mappings),\n    timeout\n  );\n  requestInfo.errorHandler = objectErrorHandler(location);\n  return requestInfo;\n}\n\nexport function list(\n  service: StorageService,\n  location: Location,\n  delimiter?: string,\n  pageToken?: string | null,\n  maxResults?: number | null\n): RequestInfo<ListResult> {\n  const urlParams: UrlParams = {};\n  if (location.isRoot) {\n    urlParams['prefix'] = '';\n  } else {\n    urlParams['prefix'] = location.path + '/';\n  }\n  if (delimiter && delimiter.length > 0) {\n    urlParams['delimiter'] = delimiter;\n  }\n  if (pageToken) {\n    urlParams['pageToken'] = pageToken;\n  }\n  if (maxResults) {\n    urlParams['maxResults'] = maxResults;\n  }\n  const urlPart = location.bucketOnlyServerUrl();\n  const url = makeUrl(urlPart);\n  const method = 'GET';\n  const timeout = service.maxOperationRetryTime;\n  const requestInfo = new RequestInfo(\n    url,\n    method,\n    listHandler(service, location.bucket),\n    timeout\n  );\n  requestInfo.urlParams = urlParams;\n  requestInfo.errorHandler = sharedErrorHandler(location);\n  return requestInfo;\n}\n\nexport function getDownloadUrl(\n  service: StorageService,\n  location: Location,\n  mappings: Mappings\n): RequestInfo<string | null> {\n  const urlPart = location.fullServerUrl();\n  const url = makeUrl(urlPart);\n  const method = 'GET';\n  const timeout = service.maxOperationRetryTime;\n  const requestInfo = new RequestInfo(\n    url,\n    method,\n    downloadUrlHandler(service, mappings),\n    timeout\n  );\n  requestInfo.errorHandler = objectErrorHandler(location);\n  return requestInfo;\n}\n\nexport function updateMetadata(\n  service: StorageService,\n  location: Location,\n  metadata: Partial<Metadata>,\n  mappings: Mappings\n): RequestInfo<Metadata> {\n  const urlPart = location.fullServerUrl();\n  const url = makeUrl(urlPart);\n  const method = 'PATCH';\n  const body = toResourceString(metadata, mappings);\n  const headers = { 'Content-Type': 'application/json; charset=utf-8' };\n  const timeout = service.maxOperationRetryTime;\n  const requestInfo = new RequestInfo(\n    url,\n    method,\n    metadataHandler(service, mappings),\n    timeout\n  );\n  requestInfo.headers = headers;\n  requestInfo.body = body;\n  requestInfo.errorHandler = objectErrorHandler(location);\n  return requestInfo;\n}\n\nexport function deleteObject(\n  service: StorageService,\n  location: Location\n): RequestInfo<void> {\n  const urlPart = location.fullServerUrl();\n  const url = makeUrl(urlPart);\n  const method = 'DELETE';\n  const timeout = service.maxOperationRetryTime;\n\n  function handler(_xhr: XhrIo, _text: string): void {}\n  const requestInfo = new RequestInfo(url, method, handler, timeout);\n  requestInfo.successCodes = [200, 204];\n  requestInfo.errorHandler = objectErrorHandler(location);\n  return requestInfo;\n}\n\nexport function determineContentType_(\n  metadata: Metadata | null,\n  blob: FbsBlob | null\n): string {\n  return (\n    (metadata && metadata['contentType']) ||\n    (blob && blob.type()) ||\n    'application/octet-stream'\n  );\n}\n\nexport function metadataForUpload_(\n  location: Location,\n  blob: FbsBlob,\n  metadata?: Metadata | null\n): Metadata {\n  const metadataClone = Object.assign({}, metadata);\n  metadataClone['fullPath'] = location.path;\n  metadataClone['size'] = blob.size();\n  if (!metadataClone['contentType']) {\n    metadataClone['contentType'] = determineContentType_(null, blob);\n  }\n  return metadataClone;\n}\n\n/**\n * Prepare RequestInfo for uploads as Content-Type: multipart.\n */\nexport function multipartUpload(\n  service: StorageService,\n  location: Location,\n  mappings: Mappings,\n  blob: FbsBlob,\n  metadata?: Metadata | null\n): RequestInfo<Metadata> {\n  const urlPart = location.bucketOnlyServerUrl();\n  const headers: { [prop: string]: string } = {\n    'X-Goog-Upload-Protocol': 'multipart'\n  };\n\n  function genBoundary(): string {\n    let str = '';\n    for (let i = 0; i < 2; i++) {\n      str = str + Math.random().toString().slice(2);\n    }\n    return str;\n  }\n  const boundary = genBoundary();\n  headers['Content-Type'] = 'multipart/related; boundary=' + boundary;\n  const metadata_ = metadataForUpload_(location, blob, metadata);\n  const metadataString = toResourceString(metadata_, mappings);\n  const preBlobPart =\n    '--' +\n    boundary +\n    '\\r\\n' +\n    'Content-Type: application/json; charset=utf-8\\r\\n\\r\\n' +\n    metadataString +\n    '\\r\\n--' +\n    boundary +\n    '\\r\\n' +\n    'Content-Type: ' +\n    metadata_['contentType'] +\n    '\\r\\n\\r\\n';\n  const postBlobPart = '\\r\\n--' + boundary + '--';\n  const body = FbsBlob.getBlob(preBlobPart, blob, postBlobPart);\n  if (body === null) {\n    throw cannotSliceBlob();\n  }\n  const urlParams: UrlParams = { name: metadata_['fullPath']! };\n  const url = makeUrl(urlPart);\n  const method = 'POST';\n  const timeout = service.maxUploadRetryTime;\n  const requestInfo = new RequestInfo(\n    url,\n    method,\n    metadataHandler(service, mappings),\n    timeout\n  );\n  requestInfo.urlParams = urlParams;\n  requestInfo.headers = headers;\n  requestInfo.body = body.uploadData();\n  requestInfo.errorHandler = sharedErrorHandler(location);\n  return requestInfo;\n}\n\n/**\n * @param current The number of bytes that have been uploaded so far.\n * @param total The total number of bytes in the upload.\n * @param opt_finalized True if the server has finished the upload.\n * @param opt_metadata The upload metadata, should\n *     only be passed if opt_finalized is true.\n */\nexport class ResumableUploadStatus {\n  finalized: boolean;\n  metadata: Metadata | null;\n\n  constructor(\n    public current: number,\n    public total: number,\n    finalized?: boolean,\n    metadata?: Metadata | null\n  ) {\n    this.finalized = !!finalized;\n    this.metadata = metadata || null;\n  }\n}\n\nexport function checkResumeHeader_(xhr: XhrIo, allowed?: string[]): string {\n  let status: string | null = null;\n  try {\n    status = xhr.getResponseHeader('X-Goog-Upload-Status');\n  } catch (e) {\n    handlerCheck(false);\n  }\n  const allowedStatus = allowed || ['active'];\n  handlerCheck(!!status && allowedStatus.indexOf(status) !== -1);\n  return status as string;\n}\n\nexport function createResumableUpload(\n  service: StorageService,\n  location: Location,\n  mappings: Mappings,\n  blob: FbsBlob,\n  metadata?: Metadata | null\n): RequestInfo<string> {\n  const urlPart = location.bucketOnlyServerUrl();\n  const metadataForUpload = metadataForUpload_(location, blob, metadata);\n  const urlParams: UrlParams = { name: metadataForUpload['fullPath']! };\n  const url = makeUrl(urlPart);\n  const method = 'POST';\n  const headers = {\n    'X-Goog-Upload-Protocol': 'resumable',\n    'X-Goog-Upload-Command': 'start',\n    'X-Goog-Upload-Header-Content-Length': blob.size(),\n    'X-Goog-Upload-Header-Content-Type': metadataForUpload['contentType']!,\n    'Content-Type': 'application/json; charset=utf-8'\n  };\n  const body = toResourceString(metadataForUpload, mappings);\n  const timeout = service.maxUploadRetryTime;\n\n  function handler(xhr: XhrIo): string {\n    checkResumeHeader_(xhr);\n    let url;\n    try {\n      url = xhr.getResponseHeader('X-Goog-Upload-URL');\n    } catch (e) {\n      handlerCheck(false);\n    }\n    handlerCheck(isString(url));\n    return url as string;\n  }\n  const requestInfo = new RequestInfo(url, method, handler, timeout);\n  requestInfo.urlParams = urlParams;\n  requestInfo.headers = headers;\n  requestInfo.body = body;\n  requestInfo.errorHandler = sharedErrorHandler(location);\n  return requestInfo;\n}\n\n/**\n * @param url From a call to fbs.requests.createResumableUpload.\n */\nexport function getResumableUploadStatus(\n  service: StorageService,\n  location: Location,\n  url: string,\n  blob: FbsBlob\n): RequestInfo<ResumableUploadStatus> {\n  const headers = { 'X-Goog-Upload-Command': 'query' };\n\n  function handler(xhr: XhrIo): ResumableUploadStatus {\n    const status = checkResumeHeader_(xhr, ['active', 'final']);\n    let sizeString: string | null = null;\n    try {\n      sizeString = xhr.getResponseHeader('X-Goog-Upload-Size-Received');\n    } catch (e) {\n      handlerCheck(false);\n    }\n\n    if (!sizeString) {\n      // null or empty string\n      handlerCheck(false);\n    }\n\n    const size = Number(sizeString);\n    handlerCheck(!isNaN(size));\n    return new ResumableUploadStatus(size, blob.size(), status === 'final');\n  }\n  const method = 'POST';\n  const timeout = service.maxUploadRetryTime;\n  const requestInfo = new RequestInfo(url, method, handler, timeout);\n  requestInfo.headers = headers;\n  requestInfo.errorHandler = sharedErrorHandler(location);\n  return requestInfo;\n}\n\n/**\n * Any uploads via the resumable upload API must transfer a number of bytes\n * that is a multiple of this number.\n */\nexport const RESUMABLE_UPLOAD_CHUNK_SIZE: number = 256 * 1024;\n\n/**\n * @param url From a call to fbs.requests.createResumableUpload.\n * @param chunkSize Number of bytes to upload.\n * @param status The previous status.\n *     If not passed or null, we start from the beginning.\n * @throws fbs.Error If the upload is already complete, the passed in status\n *     has a final size inconsistent with the blob, or the blob cannot be sliced\n *     for upload.\n */\nexport function continueResumableUpload(\n  location: Location,\n  service: StorageService,\n  url: string,\n  blob: FbsBlob,\n  chunkSize: number,\n  mappings: Mappings,\n  status?: ResumableUploadStatus | null,\n  progressCallback?: ((p1: number, p2: number) => void) | null\n): RequestInfo<ResumableUploadStatus> {\n  // TODO(andysoto): standardize on internal asserts\n  // assert(!(opt_status && opt_status.finalized));\n  const status_ = new ResumableUploadStatus(0, 0);\n  if (status) {\n    status_.current = status.current;\n    status_.total = status.total;\n  } else {\n    status_.current = 0;\n    status_.total = blob.size();\n  }\n  if (blob.size() !== status_.total) {\n    throw serverFileWrongSize();\n  }\n  const bytesLeft = status_.total - status_.current;\n  let bytesToUpload = bytesLeft;\n  if (chunkSize > 0) {\n    bytesToUpload = Math.min(bytesToUpload, chunkSize);\n  }\n  const startByte = status_.current;\n  const endByte = startByte + bytesToUpload;\n  const uploadCommand =\n    bytesToUpload === bytesLeft ? 'upload, finalize' : 'upload';\n  const headers = {\n    'X-Goog-Upload-Command': uploadCommand,\n    'X-Goog-Upload-Offset': status_.current\n  };\n  const body = blob.slice(startByte, endByte);\n  if (body === null) {\n    throw cannotSliceBlob();\n  }\n\n  function handler(xhr: XhrIo, text: string): ResumableUploadStatus {\n    // TODO(andysoto): Verify the MD5 of each uploaded range:\n    // the 'x-range-md5' header comes back with status code 308 responses.\n    // We'll only be able to bail out though, because you can't re-upload a\n    // range that you previously uploaded.\n    const uploadStatus = checkResumeHeader_(xhr, ['active', 'final']);\n    const newCurrent = status_.current + bytesToUpload;\n    const size = blob.size();\n    let metadata;\n    if (uploadStatus === 'final') {\n      metadata = metadataHandler(service, mappings)(xhr, text);\n    } else {\n      metadata = null;\n    }\n    return new ResumableUploadStatus(\n      newCurrent,\n      size,\n      uploadStatus === 'final',\n      metadata\n    );\n  }\n  const method = 'POST';\n  const timeout = service.maxUploadRetryTime;\n  const requestInfo = new RequestInfo(url, method, handler, timeout);\n  requestInfo.headers = headers;\n  requestInfo.body = body.uploadData();\n  requestInfo.progressCallback = progressCallback || null;\n  requestInfo.errorHandler = sharedErrorHandler(location);\n  return requestInfo;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { isFunction } from './type';\nimport { FirebaseStorageError } from './error';\n\n/**\n * Function that is called once for each value in a stream of values.\n */\nexport type NextFn<T> = (value: T) => void;\n\n/**\n * A function that is called with a `FirebaseStorageError`\n * if the event stream ends due to an error.\n */\nexport type ErrorFn = (error: FirebaseStorageError) => void;\n\n/**\n * A function that is called if the event stream ends normally.\n */\nexport type CompleteFn = () => void;\n\n/**\n * Unsubscribes from a stream.\n */\nexport type Unsubscribe = () => void;\n\n/**\n * An observer identical to the `Observer` defined in packages/util except the\n * error passed into the ErrorFn is specifically a `FirebaseStorageError`.\n */\nexport interface StorageObserver<T> {\n  /**\n   * Function that is called once for each value in the event stream.\n   */\n  next?: NextFn<T>;\n  /**\n   * A function that is called with a `FirebaseStorageError`\n   * if the event stream ends due to an error.\n   */\n  error?: ErrorFn;\n  /**\n   * A function that is called if the event stream ends normally.\n   */\n  complete?: CompleteFn;\n}\n\n/**\n * Subscribes to an event stream.\n */\nexport type Subscribe<T> = (\n  next?: NextFn<T> | StorageObserver<T>,\n  error?: ErrorFn,\n  complete?: CompleteFn\n) => Unsubscribe;\n\nexport class Observer<T> implements StorageObserver<T> {\n  next?: NextFn<T>;\n  error?: ErrorFn;\n  complete?: CompleteFn;\n\n  constructor(\n    nextOrObserver?: NextFn<T> | StorageObserver<T>,\n    error?: ErrorFn,\n    complete?: CompleteFn\n  ) {\n    const asFunctions =\n      isFunction(nextOrObserver) || error != null || complete != null;\n    if (asFunctions) {\n      this.next = nextOrObserver as NextFn<T>;\n      this.error = error;\n      this.complete = complete;\n    } else {\n      const observer = nextOrObserver as {\n        next?: NextFn<T>;\n        error?: ErrorFn;\n        complete?: CompleteFn;\n      };\n      this.next = observer.next;\n      this.error = observer.error;\n      this.complete = observer.complete;\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Returns a function that invokes f with its arguments asynchronously as a\n * microtask, i.e. as soon as possible after the current script returns back\n * into browser code.\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function async(f: Function): Function {\n  return (...argsToForward: unknown[]) => {\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    Promise.resolve().then(() => f(...argsToForward));\n  };\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/**\n * @fileoverview Defines types for interacting with blob transfer tasks.\n */\n\nimport { FbsBlob } from './implementation/blob';\nimport {\n  canceled,\n  StorageErrorCode,\n  FirebaseStorageError\n} from './implementation/error';\nimport {\n  InternalTaskState,\n  TaskEvent,\n  TaskState,\n  taskStateFromInternalTaskState\n} from './implementation/taskenums';\nimport { Metadata } from './metadata';\nimport {\n  CompleteFn,\n  ErrorFn,\n  Observer,\n  StorageObserver,\n  Subscribe,\n  Unsubscribe\n} from './implementation/observer';\nimport { Request } from './implementation/request';\nimport { UploadTaskSnapshot } from './tasksnapshot';\nimport { async as fbsAsync } from './implementation/async';\nimport { Mappings, getMappings } from './implementation/metadata';\nimport {\n  createResumableUpload,\n  getResumableUploadStatus,\n  RESUMABLE_UPLOAD_CHUNK_SIZE,\n  ResumableUploadStatus,\n  continueResumableUpload,\n  getMetadata,\n  multipartUpload\n} from './implementation/requests';\nimport { Reference } from './reference';\n\n/**\n * Represents a blob being uploaded. Can be used to pause/resume/cancel the\n * upload and manage callbacks for various events.\n * @public\n */\nexport class UploadTask {\n  private _ref: Reference;\n  /**\n   * The data to be uploaded.\n   */\n  _blob: FbsBlob;\n  /**\n   * Metadata related to the upload.\n   */\n  _metadata: Metadata | null;\n  private _mappings: Mappings;\n  /**\n   * Number of bytes transferred so far.\n   */\n  _transferred: number = 0;\n  private _needToFetchStatus: boolean = false;\n  private _needToFetchMetadata: boolean = false;\n  private _observers: Array<StorageObserver<UploadTaskSnapshot>> = [];\n  private _resumable: boolean;\n  /**\n   * Upload state.\n   */\n  _state: InternalTaskState;\n  private _error?: FirebaseStorageError = undefined;\n  private _uploadUrl?: string = undefined;\n  private _request?: Request<unknown> = undefined;\n  private _chunkMultiplier: number = 1;\n  private _errorHandler: (p1: FirebaseStorageError) => void;\n  private _metadataErrorHandler: (p1: FirebaseStorageError) => void;\n  private _resolve?: (p1: UploadTaskSnapshot) => void = undefined;\n  private _reject?: (p1: FirebaseStorageError) => void = undefined;\n  private _promise: Promise<UploadTaskSnapshot>;\n\n  /**\n   * @param ref - The firebaseStorage.Reference object this task came\n   *     from, untyped to avoid cyclic dependencies.\n   * @param blob - The blob to upload.\n   */\n  constructor(ref: Reference, blob: FbsBlob, metadata: Metadata | null = null) {\n    this._ref = ref;\n    this._blob = blob;\n    this._metadata = metadata;\n    this._mappings = getMappings();\n    this._resumable = this._shouldDoResumable(this._blob);\n    this._state = InternalTaskState.RUNNING;\n    this._errorHandler = error => {\n      this._request = undefined;\n      this._chunkMultiplier = 1;\n      if (error._codeEquals(StorageErrorCode.CANCELED)) {\n        this._needToFetchStatus = true;\n        this.completeTransitions_();\n      } else {\n        this._error = error;\n        this._transition(InternalTaskState.ERROR);\n      }\n    };\n    this._metadataErrorHandler = error => {\n      this._request = undefined;\n      if (error._codeEquals(StorageErrorCode.CANCELED)) {\n        this.completeTransitions_();\n      } else {\n        this._error = error;\n        this._transition(InternalTaskState.ERROR);\n      }\n    };\n    this._promise = new Promise((resolve, reject) => {\n      this._resolve = resolve;\n      this._reject = reject;\n      this._start();\n    });\n\n    // Prevent uncaught rejections on the internal promise from bubbling out\n    // to the top level with a dummy handler.\n    this._promise.then(null, () => {});\n  }\n\n  private _makeProgressCallback(): (p1: number, p2: number) => void {\n    const sizeBefore = this._transferred;\n    return loaded => this._updateProgress(sizeBefore + loaded);\n  }\n\n  private _shouldDoResumable(blob: FbsBlob): boolean {\n    return blob.size() > 256 * 1024;\n  }\n\n  private _start(): void {\n    if (this._state !== InternalTaskState.RUNNING) {\n      // This can happen if someone pauses us in a resume callback, for example.\n      return;\n    }\n    if (this._request !== undefined) {\n      return;\n    }\n    if (this._resumable) {\n      if (this._uploadUrl === undefined) {\n        this._createResumable();\n      } else {\n        if (this._needToFetchStatus) {\n          this._fetchStatus();\n        } else {\n          if (this._needToFetchMetadata) {\n            // Happens if we miss the metadata on upload completion.\n            this._fetchMetadata();\n          } else {\n            this._continueUpload();\n          }\n        }\n      }\n    } else {\n      this._oneShotUpload();\n    }\n  }\n\n  private _resolveToken(callback: (p1: string | null) => void): void {\n    // eslint-disable-next-line @typescript-eslint/no-floating-promises\n    this._ref.storage._getAuthToken().then(authToken => {\n      switch (this._state) {\n        case InternalTaskState.RUNNING:\n          callback(authToken);\n          break;\n        case InternalTaskState.CANCELING:\n          this._transition(InternalTaskState.CANCELED);\n          break;\n        case InternalTaskState.PAUSING:\n          this._transition(InternalTaskState.PAUSED);\n          break;\n        default:\n      }\n    });\n  }\n\n  // TODO(andysoto): assert false\n\n  private _createResumable(): void {\n    this._resolveToken(authToken => {\n      const requestInfo = createResumableUpload(\n        this._ref.storage,\n        this._ref._location,\n        this._mappings,\n        this._blob,\n        this._metadata\n      );\n      const createRequest = this._ref.storage._makeRequest(\n        requestInfo,\n        authToken\n      );\n      this._request = createRequest;\n      createRequest.getPromise().then((url: string) => {\n        this._request = undefined;\n        this._uploadUrl = url;\n        this._needToFetchStatus = false;\n        this.completeTransitions_();\n      }, this._errorHandler);\n    });\n  }\n\n  private _fetchStatus(): void {\n    // TODO(andysoto): assert(this.uploadUrl_ !== null);\n    const url = this._uploadUrl as string;\n    this._resolveToken(authToken => {\n      const requestInfo = getResumableUploadStatus(\n        this._ref.storage,\n        this._ref._location,\n        url,\n        this._blob\n      );\n      const statusRequest = this._ref.storage._makeRequest(\n        requestInfo,\n        authToken\n      );\n      this._request = statusRequest;\n      statusRequest.getPromise().then(status => {\n        status = status as ResumableUploadStatus;\n        this._request = undefined;\n        this._updateProgress(status.current);\n        this._needToFetchStatus = false;\n        if (status.finalized) {\n          this._needToFetchMetadata = true;\n        }\n        this.completeTransitions_();\n      }, this._errorHandler);\n    });\n  }\n\n  private _continueUpload(): void {\n    const chunkSize = RESUMABLE_UPLOAD_CHUNK_SIZE * this._chunkMultiplier;\n    const status = new ResumableUploadStatus(\n      this._transferred,\n      this._blob.size()\n    );\n\n    // TODO(andysoto): assert(this.uploadUrl_ !== null);\n    const url = this._uploadUrl as string;\n    this._resolveToken(authToken => {\n      let requestInfo;\n      try {\n        requestInfo = continueResumableUpload(\n          this._ref._location,\n          this._ref.storage,\n          url,\n          this._blob,\n          chunkSize,\n          this._mappings,\n          status,\n          this._makeProgressCallback()\n        );\n      } catch (e) {\n        this._error = e;\n        this._transition(InternalTaskState.ERROR);\n        return;\n      }\n      const uploadRequest = this._ref.storage._makeRequest(\n        requestInfo,\n        authToken\n      );\n      this._request = uploadRequest;\n      uploadRequest.getPromise().then((newStatus: ResumableUploadStatus) => {\n        this._increaseMultiplier();\n        this._request = undefined;\n        this._updateProgress(newStatus.current);\n        if (newStatus.finalized) {\n          this._metadata = newStatus.metadata;\n          this._transition(InternalTaskState.SUCCESS);\n        } else {\n          this.completeTransitions_();\n        }\n      }, this._errorHandler);\n    });\n  }\n\n  private _increaseMultiplier(): void {\n    const currentSize = RESUMABLE_UPLOAD_CHUNK_SIZE * this._chunkMultiplier;\n\n    // Max chunk size is 32M.\n    if (currentSize < 32 * 1024 * 1024) {\n      this._chunkMultiplier *= 2;\n    }\n  }\n\n  private _fetchMetadata(): void {\n    this._resolveToken(authToken => {\n      const requestInfo = getMetadata(\n        this._ref.storage,\n        this._ref._location,\n        this._mappings\n      );\n      const metadataRequest = this._ref.storage._makeRequest(\n        requestInfo,\n        authToken\n      );\n      this._request = metadataRequest;\n      metadataRequest.getPromise().then(metadata => {\n        this._request = undefined;\n        this._metadata = metadata;\n        this._transition(InternalTaskState.SUCCESS);\n      }, this._metadataErrorHandler);\n    });\n  }\n\n  private _oneShotUpload(): void {\n    this._resolveToken(authToken => {\n      const requestInfo = multipartUpload(\n        this._ref.storage,\n        this._ref._location,\n        this._mappings,\n        this._blob,\n        this._metadata\n      );\n      const multipartRequest = this._ref.storage._makeRequest(\n        requestInfo,\n        authToken\n      );\n      this._request = multipartRequest;\n      multipartRequest.getPromise().then(metadata => {\n        this._request = undefined;\n        this._metadata = metadata;\n        this._updateProgress(this._blob.size());\n        this._transition(InternalTaskState.SUCCESS);\n      }, this._errorHandler);\n    });\n  }\n\n  private _updateProgress(transferred: number): void {\n    const old = this._transferred;\n    this._transferred = transferred;\n\n    // A progress update can make the \"transferred\" value smaller (e.g. a\n    // partial upload not completed by server, after which the \"transferred\"\n    // value may reset to the value at the beginning of the request).\n    if (this._transferred !== old) {\n      this._notifyObservers();\n    }\n  }\n\n  private _transition(state: InternalTaskState): void {\n    if (this._state === state) {\n      return;\n    }\n    switch (state) {\n      case InternalTaskState.CANCELING:\n        // TODO(andysoto):\n        // assert(this.state_ === InternalTaskState.RUNNING ||\n        //        this.state_ === InternalTaskState.PAUSING);\n        this._state = state;\n        if (this._request !== undefined) {\n          this._request.cancel();\n        }\n        break;\n      case InternalTaskState.PAUSING:\n        // TODO(andysoto):\n        // assert(this.state_ === InternalTaskState.RUNNING);\n        this._state = state;\n        if (this._request !== undefined) {\n          this._request.cancel();\n        }\n        break;\n      case InternalTaskState.RUNNING:\n        // TODO(andysoto):\n        // assert(this.state_ === InternalTaskState.PAUSED ||\n        //        this.state_ === InternalTaskState.PAUSING);\n        const wasPaused = this._state === InternalTaskState.PAUSED;\n        this._state = state;\n        if (wasPaused) {\n          this._notifyObservers();\n          this._start();\n        }\n        break;\n      case InternalTaskState.PAUSED:\n        // TODO(andysoto):\n        // assert(this.state_ === InternalTaskState.PAUSING);\n        this._state = state;\n        this._notifyObservers();\n        break;\n      case InternalTaskState.CANCELED:\n        // TODO(andysoto):\n        // assert(this.state_ === InternalTaskState.PAUSED ||\n        //        this.state_ === InternalTaskState.CANCELING);\n        this._error = canceled();\n        this._state = state;\n        this._notifyObservers();\n        break;\n      case InternalTaskState.ERROR:\n        // TODO(andysoto):\n        // assert(this.state_ === InternalTaskState.RUNNING ||\n        //        this.state_ === InternalTaskState.PAUSING ||\n        //        this.state_ === InternalTaskState.CANCELING);\n        this._state = state;\n        this._notifyObservers();\n        break;\n      case InternalTaskState.SUCCESS:\n        // TODO(andysoto):\n        // assert(this.state_ === InternalTaskState.RUNNING ||\n        //        this.state_ === InternalTaskState.PAUSING ||\n        //        this.state_ === InternalTaskState.CANCELING);\n        this._state = state;\n        this._notifyObservers();\n        break;\n      default: // Ignore\n    }\n  }\n\n  private completeTransitions_(): void {\n    switch (this._state) {\n      case InternalTaskState.PAUSING:\n        this._transition(InternalTaskState.PAUSED);\n        break;\n      case InternalTaskState.CANCELING:\n        this._transition(InternalTaskState.CANCELED);\n        break;\n      case InternalTaskState.RUNNING:\n        this._start();\n        break;\n      default:\n        // TODO(andysoto): assert(false);\n        break;\n    }\n  }\n\n  /**\n   * A snapshot of the current task state.\n   */\n  get snapshot(): UploadTaskSnapshot {\n    const externalState = taskStateFromInternalTaskState(this._state);\n    return {\n      bytesTransferred: this._transferred,\n      totalBytes: this._blob.size(),\n      state: externalState,\n      metadata: this._metadata!,\n      task: this,\n      ref: this._ref\n    };\n  }\n\n  /**\n   * Adds a callback for an event.\n   * @param type - The type of event to listen for.\n   * @param nextOrObserver -\n   *     The `next` function, which gets called for each item in\n   *     the event stream, or an observer object with some or all of these three\n   *     properties (`next`, `error`, `complete`).\n   * @param error - A function that gets called with a `FirebaseStorageError`\n   *     if the event stream ends due to an error.\n   * @param completed - A function that gets called if the\n   *     event stream ends normally.\n   * @returns\n   *     If only the event argument is passed, returns a function you can use to\n   *     add callbacks (see the examples above). If more than just the event\n   *     argument is passed, returns a function you can call to unregister the\n   *     callbacks.\n   */\n  on(\n    type: TaskEvent,\n    nextOrObserver?:\n      | StorageObserver<UploadTaskSnapshot>\n      | ((a: UploadTaskSnapshot) => unknown),\n    error?: ErrorFn,\n    completed?: CompleteFn\n  ): Unsubscribe | Subscribe<UploadTaskSnapshot> {\n    const observer = new Observer(nextOrObserver, error, completed);\n    this._addObserver(observer);\n    return () => {\n      this._removeObserver(observer);\n    };\n  }\n\n  /**\n   * This object behaves like a Promise, and resolves with its snapshot data\n   * when the upload completes.\n   * @param onFulfilled - The fulfillment callback. Promise chaining works as normal.\n   * @param onRejected - The rejection callback.\n   */\n  then<U>(\n    onFulfilled?: ((value: UploadTaskSnapshot) => U | Promise<U>) | null,\n    onRejected?: ((error: FirebaseStorageError) => U | Promise<U>) | null\n  ): Promise<U> {\n    // These casts are needed so that TypeScript can infer the types of the\n    // resulting Promise.\n    return this._promise.then<U>(\n      onFulfilled as (value: UploadTaskSnapshot) => U | Promise<U>,\n      onRejected as ((error: unknown) => Promise<never>) | null\n    );\n  }\n\n  /**\n   * Equivalent to calling `then(null, onRejected)`.\n   */\n  catch<T>(\n    onRejected: (p1: FirebaseStorageError) => T | Promise<T>\n  ): Promise<T> {\n    return this.then(null, onRejected);\n  }\n\n  /**\n   * Adds the given observer.\n   */\n  private _addObserver(observer: Observer<UploadTaskSnapshot>): void {\n    this._observers.push(observer);\n    this._notifyObserver(observer);\n  }\n\n  /**\n   * Removes the given observer.\n   */\n  private _removeObserver(observer: Observer<UploadTaskSnapshot>): void {\n    const i = this._observers.indexOf(observer);\n    if (i !== -1) {\n      this._observers.splice(i, 1);\n    }\n  }\n\n  private _notifyObservers(): void {\n    this._finishPromise();\n    const observers = this._observers.slice();\n    observers.forEach(observer => {\n      this._notifyObserver(observer);\n    });\n  }\n\n  private _finishPromise(): void {\n    if (this._resolve !== undefined) {\n      let triggered = true;\n      switch (taskStateFromInternalTaskState(this._state)) {\n        case TaskState.SUCCESS:\n          fbsAsync(this._resolve.bind(null, this.snapshot))();\n          break;\n        case TaskState.CANCELED:\n        case TaskState.ERROR:\n          const toCall = this._reject as (p1: FirebaseStorageError) => void;\n          fbsAsync(toCall.bind(null, this._error as FirebaseStorageError))();\n          break;\n        default:\n          triggered = false;\n          break;\n      }\n      if (triggered) {\n        this._resolve = undefined;\n        this._reject = undefined;\n      }\n    }\n  }\n\n  private _notifyObserver(observer: Observer<UploadTaskSnapshot>): void {\n    const externalState = taskStateFromInternalTaskState(this._state);\n    switch (externalState) {\n      case TaskState.RUNNING:\n      case TaskState.PAUSED:\n        if (observer.next) {\n          fbsAsync(observer.next.bind(observer, this.snapshot))();\n        }\n        break;\n      case TaskState.SUCCESS:\n        if (observer.complete) {\n          fbsAsync(observer.complete.bind(observer))();\n        }\n        break;\n      case TaskState.CANCELED:\n      case TaskState.ERROR:\n        if (observer.error) {\n          fbsAsync(\n            observer.error.bind(observer, this._error as FirebaseStorageError)\n          )();\n        }\n        break;\n      default:\n        // TODO(andysoto): assert(false);\n        if (observer.error) {\n          fbsAsync(\n            observer.error.bind(observer, this._error as FirebaseStorageError)\n          )();\n        }\n    }\n  }\n\n  /**\n   * Resumes a paused task. Has no effect on a currently running or failed task.\n   * @returns True if the operation took effect, false if ignored.\n   */\n  resume(): boolean {\n    const valid =\n      this._state === InternalTaskState.PAUSED ||\n      this._state === InternalTaskState.PAUSING;\n    if (valid) {\n      this._transition(InternalTaskState.RUNNING);\n    }\n    return valid;\n  }\n\n  /**\n   * Pauses a currently running task. Has no effect on a paused or failed task.\n   * @returns True if the operation took effect, false if ignored.\n   */\n  pause(): boolean {\n    const valid = this._state === InternalTaskState.RUNNING;\n    if (valid) {\n      this._transition(InternalTaskState.PAUSING);\n    }\n    return valid;\n  }\n\n  /**\n   * Cancels a currently running or paused task. Has no effect on a complete or\n   * failed task.\n   * @returns True if the operation took effect, false if ignored.\n   */\n  cancel(): boolean {\n    const valid =\n      this._state === InternalTaskState.RUNNING ||\n      this._state === InternalTaskState.PAUSING;\n    if (valid) {\n      this._transition(InternalTaskState.CANCELING);\n    }\n    return valid;\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Defines the Firebase StorageReference class.\n */\n\nimport { FbsBlob } from './implementation/blob';\nimport { Location } from './implementation/location';\nimport { getMappings } from './implementation/metadata';\nimport { child, parent, lastComponent } from './implementation/path';\nimport {\n  list as requestsList,\n  getMetadata as requestsGetMetadata,\n  updateMetadata as requestsUpdateMetadata,\n  getDownloadUrl as requestsGetDownloadUrl,\n  deleteObject as requestsDeleteObject,\n  multipartUpload\n} from './implementation/requests';\nimport { ListOptions } from '../exp/public-types';\nimport { StringFormat, dataFromString } from './implementation/string';\nimport { Metadata } from './metadata';\nimport { StorageService } from './service';\nimport { ListResult } from './list';\nimport { UploadTask } from './task';\nimport { invalidRootOperation, noDownloadURL } from './implementation/error';\nimport { validateNumber } from './implementation/type';\nimport { UploadResult } from './tasksnapshot';\n\n/**\n * Provides methods to interact with a bucket in the Firebase Storage service.\n * @public\n * @param _location - An fbs.location, or the URL at\n *     which to base this object, in one of the following forms:\n *         gs://<bucket>/<object-path>\n *         http[s]://firebasestorage.googleapis.com/\n *                     <api-version>/b/<bucket>/o/<object-path>\n *     Any query or fragment strings will be ignored in the http[s]\n *     format. If no value is passed, the storage object will use a URL based on\n *     the project ID of the base firebase.App instance.\n */\nexport class Reference {\n  _location: Location;\n\n  constructor(private _service: StorageService, location: string | Location) {\n    if (location instanceof Location) {\n      this._location = location;\n    } else {\n      this._location = Location.makeFromUrl(location);\n    }\n  }\n\n  /**\n   * Returns the URL for the bucket and path this object references,\n   *     in the form gs://<bucket>/<object-path>\n   * @override\n   */\n  toString(): string {\n    return 'gs://' + this._location.bucket + '/' + this._location.path;\n  }\n\n  protected _newRef(service: StorageService, location: Location): Reference {\n    return new Reference(service, location);\n  }\n\n  /**\n   * A reference to the root of this object's bucket.\n   */\n  get root(): Reference {\n    const location = new Location(this._location.bucket, '');\n    return this._newRef(this._service, location);\n  }\n\n  /**\n   * The name of the bucket containing this reference's object.\n   */\n  get bucket(): string {\n    return this._location.bucket;\n  }\n\n  /**\n   * The full path of this object.\n   */\n  get fullPath(): string {\n    return this._location.path;\n  }\n\n  /**\n   * The short name of this object, which is the last component of the full path.\n   * For example, if fullPath is 'full/path/image.png', name is 'image.png'.\n   */\n  get name(): string {\n    return lastComponent(this._location.path);\n  }\n\n  /**\n   * The `StorageService` instance this `StorageReference` is associated with.\n   */\n  get storage(): StorageService {\n    return this._service;\n  }\n\n  /**\n   * A `StorageReference` pointing to the parent location of this `StorageReference`, or null if\n   * this reference is the root.\n   */\n  get parent(): Reference | null {\n    const newPath = parent(this._location.path);\n    if (newPath === null) {\n      return null;\n    }\n    const location = new Location(this._location.bucket, newPath);\n    return new Reference(this._service, location);\n  }\n\n  /**\n   * Utility function to throw an error in methods that do not accept a root reference.\n   */\n  _throwIfRoot(name: string): void {\n    if (this._location.path === '') {\n      throw invalidRootOperation(name);\n    }\n  }\n}\n\n/**\n * Uploads data to this object's location.\n * The upload is not resumable.\n *\n * @param ref - StorageReference where data should be uploaded.\n * @param data - The data to upload.\n * @param metadata - Metadata for the newly uploaded data.\n * @returns A Promise containing an UploadResult\n */\nexport function uploadBytes(\n  ref: Reference,\n  data: Blob | Uint8Array | ArrayBuffer,\n  metadata?: Metadata\n): Promise<UploadResult> {\n  ref._throwIfRoot('uploadBytes');\n  return ref.storage\n    ._getAuthToken()\n    .then(authToken => {\n      const requestInfo = multipartUpload(\n        ref.storage,\n        ref._location,\n        getMappings(),\n        new FbsBlob(data, true),\n        metadata\n      );\n      const multipartRequest = ref.storage._makeRequest(requestInfo, authToken);\n      return multipartRequest.getPromise();\n    })\n    .then(finalMetadata => {\n      return {\n        metadata: finalMetadata,\n        ref\n      };\n    });\n}\n\n/**\n * Uploads data to this object's location.\n * The upload can be paused and resumed, and exposes progress updates.\n * @public\n * @param ref - StorageReference where data should be uploaded.\n * @param data - The data to upload.\n * @param metadata - Metadata for the newly uploaded data.\n * @returns An UploadTask\n */\nexport function uploadBytesResumable(\n  ref: Reference,\n  data: Blob | Uint8Array | ArrayBuffer,\n  metadata?: Metadata\n): UploadTask {\n  ref._throwIfRoot('uploadBytesResumable');\n  return new UploadTask(ref, new FbsBlob(data), metadata);\n}\n\n/**\n * Uploads a string to this object's location.\n * The upload is not resumable.\n * @public\n * @param ref - StorageReference where string should be uploaded.\n * @param value - The string to upload.\n * @param format - The format of the string to upload.\n * @param metadata - Metadata for the newly uploaded string.\n * @returns A Promise containing an UploadResult\n */\nexport function uploadString(\n  ref: Reference,\n  value: string,\n  format: StringFormat = StringFormat.RAW,\n  metadata?: Metadata\n): Promise<UploadResult> {\n  ref._throwIfRoot('uploadString');\n  const data = dataFromString(format, value);\n  const metadataClone = { ...metadata } as Metadata;\n  if (metadataClone['contentType'] == null && data.contentType != null) {\n    metadataClone['contentType'] = data.contentType!;\n  }\n  return uploadBytes(ref, data.data, metadataClone);\n}\n\n/**\n * List all items (files) and prefixes (folders) under this storage reference.\n *\n * This is a helper method for calling list() repeatedly until there are\n * no more results. The default pagination size is 1000.\n *\n * Note: The results may not be consistent if objects are changed while this\n * operation is running.\n *\n * Warning: listAll may potentially consume too many resources if there are\n * too many results.\n * @public\n * @param ref - StorageReference to get list from.\n *\n * @returns A Promise that resolves with all the items and prefixes under\n *      the current storage reference. `prefixes` contains references to\n *      sub-directories and `items` contains references to objects in this\n *      folder. `nextPageToken` is never returned.\n */\nexport function listAll(ref: Reference): Promise<ListResult> {\n  const accumulator: ListResult = {\n    prefixes: [],\n    items: []\n  };\n  return listAllHelper(ref, accumulator).then(() => accumulator);\n}\n\n/**\n * Separated from listAll because async functions can't use \"arguments\".\n * @param ref\n * @param accumulator\n * @param pageToken\n */\nasync function listAllHelper(\n  ref: Reference,\n  accumulator: ListResult,\n  pageToken?: string\n): Promise<void> {\n  const opt: ListOptions = {\n    // maxResults is 1000 by default.\n    pageToken\n  };\n  const nextPage = await list(ref, opt);\n  accumulator.prefixes.push(...nextPage.prefixes);\n  accumulator.items.push(...nextPage.items);\n  if (nextPage.nextPageToken != null) {\n    await listAllHelper(ref, accumulator, nextPage.nextPageToken);\n  }\n}\n\n/**\n * List items (files) and prefixes (folders) under this storage reference.\n *\n * List API is only available for Firebase Rules Version 2.\n *\n * GCS is a key-blob store. Firebase Storage imposes the semantic of '/'\n * delimited folder structure.\n * Refer to GCS's List API if you want to learn more.\n *\n * To adhere to Firebase Rules's Semantics, Firebase Storage does not\n * support objects whose paths end with \"/\" or contain two consecutive\n * \"/\"s. Firebase Storage List API will filter these unsupported objects.\n * list() may fail if there are too many unsupported objects in the bucket.\n * @public\n *\n * @param ref - StorageReference to get list from.\n * @param options - See ListOptions for details.\n * @returns A Promise that resolves with the items and prefixes.\n *      `prefixes` contains references to sub-folders and `items`\n *      contains references to objects in this folder. `nextPageToken`\n *      can be used to get the rest of the results.\n */\nexport async function list(\n  ref: Reference,\n  options?: ListOptions | null\n): Promise<ListResult> {\n  if (options != null) {\n    if (typeof options.maxResults === 'number') {\n      validateNumber(\n        'options.maxResults',\n        /* minValue= */ 1,\n        /* maxValue= */ 1000,\n        options.maxResults\n      );\n    }\n  }\n  const authToken = await ref.storage._getAuthToken();\n  const op = options || {};\n  const requestInfo = requestsList(\n    ref.storage,\n    ref._location,\n    /*delimiter= */ '/',\n    op.pageToken,\n    op.maxResults\n  );\n  return ref.storage._makeRequest(requestInfo, authToken).getPromise();\n}\n\n/**\n * A promise that resolves with the metadata for this object. If this\n * object doesn't exist or metadata cannot be retreived, the promise is\n * rejected.\n * @public\n * @param ref - StorageReference to get metadata from.\n */\nexport async function getMetadata(ref: Reference): Promise<Metadata> {\n  ref._throwIfRoot('getMetadata');\n  const authToken = await ref.storage._getAuthToken();\n  const requestInfo = requestsGetMetadata(\n    ref.storage,\n    ref._location,\n    getMappings()\n  );\n  return ref.storage._makeRequest(requestInfo, authToken).getPromise();\n}\n\n/**\n * Updates the metadata for this object.\n * @public\n * @param ref - StorageReference to update metadata for.\n * @param metadata - The new metadata for the object.\n *     Only values that have been explicitly set will be changed. Explicitly\n *     setting a value to null will remove the metadata.\n * @returns A promise that resolves\n *     with the new metadata for this object.\n *     See `firebaseStorage.Reference.prototype.getMetadata`\n */\nexport async function updateMetadata(\n  ref: Reference,\n  metadata: Partial<Metadata>\n): Promise<Metadata> {\n  ref._throwIfRoot('updateMetadata');\n  const authToken = await ref.storage._getAuthToken();\n  const requestInfo = requestsUpdateMetadata(\n    ref.storage,\n    ref._location,\n    metadata,\n    getMappings()\n  );\n  return ref.storage._makeRequest(requestInfo, authToken).getPromise();\n}\n\n/**\n * Returns the download URL for the given Reference.\n * @public\n * @returns A promise that resolves with the download\n *     URL for this object.\n */\nexport async function getDownloadURL(ref: Reference): Promise<string> {\n  ref._throwIfRoot('getDownloadURL');\n  const authToken = await ref.storage._getAuthToken();\n  const requestInfo = requestsGetDownloadUrl(\n    ref.storage,\n    ref._location,\n    getMappings()\n  );\n  return ref.storage\n    ._makeRequest(requestInfo, authToken)\n    .getPromise()\n    .then(url => {\n      if (url === null) {\n        throw noDownloadURL();\n      }\n      return url;\n    });\n}\n\n/**\n * Deletes the object at this location.\n * @public\n * @param ref - StorageReference for object to delete.\n * @returns A promise that resolves if the deletion succeeds.\n */\nexport async function deleteObject(ref: Reference): Promise<void> {\n  ref._throwIfRoot('deleteObject');\n  const authToken = await ref.storage._getAuthToken();\n  const requestInfo = requestsDeleteObject(ref.storage, ref._location);\n  return ref.storage._makeRequest(requestInfo, authToken).getPromise();\n}\n\n/**\n * Returns reference for object obtained by appending `childPath` to `ref`.\n *\n * @param ref - StorageReference to get child of.\n * @param childPath - Child path from provided ref.\n * @returns A reference to the object obtained by\n * appending childPath, removing any duplicate, beginning, or trailing\n * slashes.\n */\nexport function _getChild(ref: Reference, childPath: string): Reference {\n  const newPath = child(ref._location.path, childPath);\n  const location = new Location(ref._location.bucket, newPath);\n  return new Reference(ref.storage, location);\n}\n","/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport * as types from '@firebase/storage-types';\nimport { ReferenceCompat } from './reference';\nimport { UploadTaskCompat } from './task';\nimport { UploadTaskSnapshot } from '../src/tasksnapshot';\n\nexport class UploadTaskSnapshotCompat implements types.UploadTaskSnapshot {\n  constructor(\n    readonly _delegate: UploadTaskSnapshot,\n    readonly task: UploadTaskCompat,\n    readonly ref: ReferenceCompat\n  ) {}\n\n  get bytesTransferred(): number {\n    return this._delegate.bytesTransferred;\n  }\n  get metadata(): types.FullMetadata {\n    return this._delegate.metadata as types.FullMetadata;\n  }\n  get state(): string {\n    return this._delegate.state;\n  }\n  get totalBytes(): number {\n    return this._delegate.totalBytes;\n  }\n}\n","/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { UploadTask } from '../src/task';\nimport { UploadTaskSnapshotCompat } from './tasksnapshot';\nimport { TaskEvent } from '../src/implementation/taskenums';\nimport * as types from '@firebase/storage-types';\nimport {\n  StorageObserver,\n  ErrorFn,\n  CompleteFn,\n  Subscribe,\n  Unsubscribe\n} from '../src/implementation/observer';\nimport { UploadTaskSnapshot } from '../src/tasksnapshot';\nimport { ReferenceCompat } from './reference';\nimport { FirebaseStorageError } from '../src/implementation/error';\n\nexport class UploadTaskCompat implements types.UploadTask {\n  constructor(\n    private readonly _delegate: UploadTask,\n    private readonly _ref: ReferenceCompat\n  ) {}\n\n  get snapshot(): UploadTaskSnapshotCompat {\n    return new UploadTaskSnapshotCompat(\n      this._delegate.snapshot,\n      this,\n      this._ref\n    );\n  }\n\n  cancel = this._delegate.cancel.bind(this._delegate);\n  catch = this._delegate.catch.bind(this._delegate);\n  pause = this._delegate.pause.bind(this._delegate);\n  resume = this._delegate.resume.bind(this._delegate);\n\n  then(\n    onFulfilled?: ((a: UploadTaskSnapshotCompat) => unknown) | null,\n    onRejected?: ((a: FirebaseStorageError) => unknown) | null\n  ): Promise<unknown> {\n    return this._delegate.then(snapshot => {\n      if (onFulfilled) {\n        return onFulfilled(\n          new UploadTaskSnapshotCompat(snapshot, this, this._ref)\n        );\n      }\n    }, onRejected);\n  }\n\n  on(\n    type: TaskEvent,\n    nextOrObserver?:\n      | types.StorageObserver<UploadTaskSnapshotCompat>\n      | null\n      | ((a: UploadTaskSnapshotCompat) => unknown),\n    error?: ErrorFn | null,\n    completed?: CompleteFn | null\n  ): Unsubscribe | Subscribe<UploadTaskSnapshotCompat> {\n    let wrappedNextOrObserver:\n      | StorageObserver<UploadTaskSnapshot>\n      | undefined\n      | ((a: UploadTaskSnapshot) => unknown) = undefined;\n    if (!!nextOrObserver) {\n      if (typeof nextOrObserver === 'function') {\n        wrappedNextOrObserver = (taskSnapshot: UploadTaskSnapshot) =>\n          nextOrObserver(\n            new UploadTaskSnapshotCompat(taskSnapshot, this, this._ref)\n          );\n      } else {\n        wrappedNextOrObserver = {\n          next: !!nextOrObserver.next\n            ? (taskSnapshot: UploadTaskSnapshot) =>\n                nextOrObserver.next!(\n                  new UploadTaskSnapshotCompat(taskSnapshot, this, this._ref)\n                )\n            : undefined,\n          complete: nextOrObserver.complete || undefined,\n          error: nextOrObserver.error || undefined\n        };\n      }\n    }\n    return this._delegate.on(\n      type,\n      wrappedNextOrObserver,\n      error || undefined,\n      completed || undefined\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport * as types from '@firebase/storage-types';\nimport { ListResult } from '../src/list';\nimport { ReferenceCompat } from './reference';\nimport { StorageServiceCompat } from './service';\n\nexport class ListResultCompat implements types.ListResult {\n  constructor(\n    private readonly _delegate: ListResult,\n    private readonly _service: StorageServiceCompat\n  ) {}\n\n  get prefixes(): ReferenceCompat[] {\n    return this._delegate.prefixes.map(\n      ref => new ReferenceCompat(ref, this._service)\n    );\n  }\n  get items(): ReferenceCompat[] {\n    return this._delegate.items.map(\n      ref => new ReferenceCompat(ref, this._service)\n    );\n  }\n  get nextPageToken(): string | null {\n    return this._delegate.nextPageToken || null;\n  }\n}\n","/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *  http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  Reference,\n  _getChild,\n  uploadBytesResumable,\n  list,\n  listAll,\n  getDownloadURL,\n  getMetadata,\n  updateMetadata,\n  deleteObject\n} from '../src/reference';\nimport * as types from '@firebase/storage-types';\nimport { Metadata } from '../src/metadata';\nimport { dataFromString, StringFormat } from '../src/implementation/string';\nimport { UploadTaskCompat } from './task';\nimport { ListResultCompat } from './list';\nimport { StorageServiceCompat } from './service';\nimport { invalidRootOperation } from '../src/implementation/error';\nimport { UploadTask } from '../src/task';\nimport { FbsBlob } from '../src/implementation/blob';\n\nexport class ReferenceCompat implements types.Reference {\n  constructor(\n    private readonly _delegate: Reference,\n    public storage: StorageServiceCompat\n  ) {}\n\n  get name(): string {\n    return this._delegate.name;\n  }\n\n  get bucket(): string {\n    return this._delegate.bucket;\n  }\n\n  get fullPath(): string {\n    return this._delegate.fullPath;\n  }\n\n  toString(): string {\n    return this._delegate.toString();\n  }\n\n  /**\n   * @returns A reference to the object obtained by\n   * appending childPath, removing any duplicate, beginning, or trailing\n   * slashes.\n   */\n  child(childPath: string): types.Reference {\n    const reference = _getChild(this._delegate, childPath);\n    return new ReferenceCompat(reference, this.storage);\n  }\n\n  get root(): types.Reference {\n    return new ReferenceCompat(this._delegate.root, this.storage);\n  }\n\n  /**\n   * @returns A reference to the parent of the\n   * current object, or null if the current object is the root.\n   */\n  get parent(): types.Reference | null {\n    const reference = this._delegate.parent;\n    if (reference == null) {\n      return null;\n    }\n    return new ReferenceCompat(reference, this.storage);\n  }\n\n  /**\n   * Uploads a blob to this object's location.\n   * @param data - The blob to upload.\n   * @returns An UploadTask that lets you control and\n   * observe the upload.\n   */\n  put(\n    data: Blob | Uint8Array | ArrayBuffer,\n    metadata?: types.FullMetadata\n  ): types.UploadTask {\n    this._throwIfRoot('put');\n    return new UploadTaskCompat(\n      uploadBytesResumable(this._delegate, data, metadata as Metadata),\n      this\n    );\n  }\n\n  /**\n   * Uploads a string to this object's location.\n   * @param value - The string to upload.\n   * @param format - The format of the string to upload.\n   * @returns An UploadTask that lets you control and\n   * observe the upload.\n   */\n  putString(\n    value: string,\n    format: StringFormat = StringFormat.RAW,\n    metadata?: Metadata\n  ): types.UploadTask {\n    this._throwIfRoot('putString');\n    const data = dataFromString(format, value);\n    const metadataClone = { ...metadata } as Metadata;\n    if (metadataClone['contentType'] == null && data.contentType != null) {\n      metadataClone['contentType'] = data.contentType;\n    }\n    return new UploadTaskCompat(\n      new UploadTask(\n        this._delegate,\n        new FbsBlob(data.data, true),\n        metadataClone\n      ),\n      this\n    );\n  }\n\n  /**\n   * List all items (files) and prefixes (folders) under this storage reference.\n   *\n   * This is a helper method for calling list() repeatedly until there are\n   * no more results. The default pagination size is 1000.\n   *\n   * Note: The results may not be consistent if objects are changed while this\n   * operation is running.\n   *\n   * Warning: listAll may potentially consume too many resources if there are\n   * too many results.\n   *\n   * @returns A Promise that resolves with all the items and prefixes under\n   *  the current storage reference. `prefixes` contains references to\n   *  sub-directories and `items` contains references to objects in this\n   *  folder. `nextPageToken` is never returned.\n   */\n  listAll(): Promise<types.ListResult> {\n    return listAll(this._delegate).then(\n      r => new ListResultCompat(r, this.storage)\n    );\n  }\n\n  /**\n   * List items (files) and prefixes (folders) under this storage reference.\n   *\n   * List API is only available for Firebase Rules Version 2.\n   *\n   * GCS is a key-blob store. Firebase Storage imposes the semantic of '/'\n   * delimited folder structure. Refer to GCS's List API if you want to learn more.\n   *\n   * To adhere to Firebase Rules's Semantics, Firebase Storage does not\n   * support objects whose paths end with \"/\" or contain two consecutive\n   * \"/\"s. Firebase Storage List API will filter these unsupported objects.\n   * list() may fail if there are too many unsupported objects in the bucket.\n   *\n   * @param options - See ListOptions for details.\n   * @returns A Promise that resolves with the items and prefixes.\n   * `prefixes` contains references to sub-folders and `items`\n   * contains references to objects in this folder. `nextPageToken`\n   * can be used to get the rest of the results.\n   */\n  list(options?: types.ListOptions | null): Promise<types.ListResult> {\n    return list(this._delegate, options).then(\n      r => new ListResultCompat(r, this.storage)\n    );\n  }\n\n  /**\n   * A promise that resolves with the metadata for this object. If this\n   * object doesn't exist or metadata cannot be retreived, the promise is\n   * rejected.\n   */\n  getMetadata(): Promise<types.FullMetadata> {\n    return getMetadata(this._delegate) as Promise<types.FullMetadata>;\n  }\n\n  /**\n   * Updates the metadata for this object.\n   * @param metadata - The new metadata for the object.\n   * Only values that have been explicitly set will be changed. Explicitly\n   * setting a value to null will remove the metadata.\n   * @returns A promise that resolves\n   * with the new metadata for this object.\n   * @see firebaseStorage.Reference.prototype.getMetadata\n   */\n  updateMetadata(\n    metadata: types.SettableMetadata\n  ): Promise<types.FullMetadata> {\n    return updateMetadata(\n      this._delegate,\n      metadata as Metadata\n    ) as Promise<types.FullMetadata>;\n  }\n\n  /**\n   * @returns A promise that resolves with the download\n   * URL for this object.\n   */\n  getDownloadURL(): Promise<string> {\n    return getDownloadURL(this._delegate);\n  }\n\n  /**\n   * Deletes the object at this location.\n   * @returns A promise that resolves if the deletion succeeds.\n   */\n  delete(): Promise<void> {\n    this._throwIfRoot('delete');\n    return deleteObject(this._delegate);\n  }\n\n  private _throwIfRoot(name: string): void {\n    if (this._delegate._location.path === '') {\n      throw invalidRootOperation(name);\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { FirebaseStorageError } from './error';\nimport { Request } from './request';\n\n/**\n * A request whose promise always fails.\n */\nexport class FailRequest<T> implements Request<T> {\n  promise_: Promise<T>;\n\n  constructor(error: FirebaseStorageError) {\n    this.promise_ = Promise.reject<T>(error);\n  }\n\n  /** @inheritDoc */\n  getPromise(): Promise<T> {\n    return this.promise_;\n  }\n\n  /** @inheritDoc */\n  cancel(_appDelete = false): void {}\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Defines methods used to actually send HTTP requests from\n * abstract representations.\n */\n\nimport { start, stop, id as backoffId } from './backoff';\nimport {\n  FirebaseStorageError,\n  unknown,\n  appDeleted,\n  canceled,\n  retryLimitExceeded\n} from './error';\nimport { RequestInfo } from './requestinfo';\nimport { isJustDef } from './type';\nimport { makeQueryString } from './url';\nimport { Headers, XhrIo, ErrorCode } from './xhrio';\nimport { XhrIoPool } from './xhriopool';\n\nexport interface Request<T> {\n  getPromise(): Promise<T>;\n\n  /**\n   * Cancels the request. IMPORTANT: the promise may still be resolved with an\n   * appropriate value (if the request is finished before you call this method,\n   * but the promise has not yet been resolved), so don't just assume it will be\n   * rejected if you call this function.\n   * @param appDelete - True if the cancelation came from the app being deleted.\n   */\n  cancel(appDelete?: boolean): void;\n}\n\nclass NetworkRequest<T> implements Request<T> {\n  private url_: string;\n  private method_: string;\n  private headers_: Headers;\n  private body_: string | Blob | Uint8Array | null;\n  private successCodes_: number[];\n  private additionalRetryCodes_: number[];\n  private pendingXhr_: XhrIo | null = null;\n  private backoffId_: backoffId | null = null;\n  private resolve_!: (value?: T | PromiseLike<T>) => void;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  private reject_!: (reason?: any) => void;\n  private canceled_: boolean = false;\n  private appDelete_: boolean = false;\n  private callback_: (p1: XhrIo, p2: string) => T;\n  private errorCallback_:\n    | ((p1: XhrIo, p2: FirebaseStorageError) => FirebaseStorageError)\n    | null;\n  private progressCallback_: ((p1: number, p2: number) => void) | null;\n  private timeout_: number;\n  private pool_: XhrIoPool;\n  promise_: Promise<T>;\n\n  constructor(\n    url: string,\n    method: string,\n    headers: Headers,\n    body: string | Blob | Uint8Array | null,\n    successCodes: number[],\n    additionalRetryCodes: number[],\n    callback: (p1: XhrIo, p2: string) => T,\n    errorCallback:\n      | ((p1: XhrIo, p2: FirebaseStorageError) => FirebaseStorageError)\n      | null,\n    timeout: number,\n    progressCallback: ((p1: number, p2: number) => void) | null,\n    pool: XhrIoPool\n  ) {\n    this.url_ = url;\n    this.method_ = method;\n    this.headers_ = headers;\n    this.body_ = body;\n    this.successCodes_ = successCodes.slice();\n    this.additionalRetryCodes_ = additionalRetryCodes.slice();\n    this.callback_ = callback;\n    this.errorCallback_ = errorCallback;\n    this.progressCallback_ = progressCallback;\n    this.timeout_ = timeout;\n    this.pool_ = pool;\n    this.promise_ = new Promise((resolve, reject) => {\n      this.resolve_ = resolve as (value?: T | PromiseLike<T>) => void;\n      this.reject_ = reject;\n      this.start_();\n    });\n  }\n\n  /**\n   * Actually starts the retry loop.\n   */\n  private start_(): void {\n    const self = this;\n\n    function doTheRequest(\n      backoffCallback: (p1: boolean, ...p2: unknown[]) => void,\n      canceled: boolean\n    ): void {\n      if (canceled) {\n        backoffCallback(false, new RequestEndStatus(false, null, true));\n        return;\n      }\n      const xhr = self.pool_.createXhrIo();\n      self.pendingXhr_ = xhr;\n\n      function progressListener(progressEvent: ProgressEvent): void {\n        const loaded = progressEvent.loaded;\n        const total = progressEvent.lengthComputable ? progressEvent.total : -1;\n        if (self.progressCallback_ !== null) {\n          self.progressCallback_(loaded, total);\n        }\n      }\n      if (self.progressCallback_ !== null) {\n        xhr.addUploadProgressListener(progressListener);\n      }\n\n      // eslint-disable-next-line @typescript-eslint/no-floating-promises\n      xhr\n        .send(self.url_, self.method_, self.body_, self.headers_)\n        .then((xhr: XhrIo) => {\n          if (self.progressCallback_ !== null) {\n            xhr.removeUploadProgressListener(progressListener);\n          }\n          self.pendingXhr_ = null;\n          xhr = xhr as XhrIo;\n          const hitServer = xhr.getErrorCode() === ErrorCode.NO_ERROR;\n          const status = xhr.getStatus();\n          if (!hitServer || self.isRetryStatusCode_(status)) {\n            const wasCanceled = xhr.getErrorCode() === ErrorCode.ABORT;\n            backoffCallback(\n              false,\n              new RequestEndStatus(false, null, wasCanceled)\n            );\n            return;\n          }\n          const successCode = self.successCodes_.indexOf(status) !== -1;\n          backoffCallback(true, new RequestEndStatus(successCode, xhr));\n        });\n    }\n\n    /**\n     * @param requestWentThrough - True if the request eventually went\n     *     through, false if it hit the retry limit or was canceled.\n     */\n    function backoffDone(\n      requestWentThrough: boolean,\n      status: RequestEndStatus\n    ): void {\n      const resolve = self.resolve_;\n      const reject = self.reject_;\n      const xhr = status.xhr as XhrIo;\n      if (status.wasSuccessCode) {\n        try {\n          const result = self.callback_(xhr, xhr.getResponseText());\n          if (isJustDef(result)) {\n            resolve(result);\n          } else {\n            resolve();\n          }\n        } catch (e) {\n          reject(e);\n        }\n      } else {\n        if (xhr !== null) {\n          const err = unknown();\n          err.serverResponse = xhr.getResponseText();\n          if (self.errorCallback_) {\n            reject(self.errorCallback_(xhr, err));\n          } else {\n            reject(err);\n          }\n        } else {\n          if (status.canceled) {\n            const err = self.appDelete_ ? appDeleted() : canceled();\n            reject(err);\n          } else {\n            const err = retryLimitExceeded();\n            reject(err);\n          }\n        }\n      }\n    }\n    if (this.canceled_) {\n      backoffDone(false, new RequestEndStatus(false, null, true));\n    } else {\n      this.backoffId_ = start(doTheRequest, backoffDone, this.timeout_);\n    }\n  }\n\n  /** @inheritDoc */\n  getPromise(): Promise<T> {\n    return this.promise_;\n  }\n\n  /** @inheritDoc */\n  cancel(appDelete?: boolean): void {\n    this.canceled_ = true;\n    this.appDelete_ = appDelete || false;\n    if (this.backoffId_ !== null) {\n      stop(this.backoffId_);\n    }\n    if (this.pendingXhr_ !== null) {\n      this.pendingXhr_.abort();\n    }\n  }\n\n  private isRetryStatusCode_(status: number): boolean {\n    // The codes for which to retry came from this page:\n    // https://cloud.google.com/storage/docs/exponential-backoff\n    const isFiveHundredCode = status >= 500 && status < 600;\n    const extraRetryCodes = [\n      // Request Timeout: web server didn't receive full request in time.\n      408,\n      // Too Many Requests: you're getting rate-limited, basically.\n      429\n    ];\n    const isExtraRetryCode = extraRetryCodes.indexOf(status) !== -1;\n    const isRequestSpecificRetryCode =\n      this.additionalRetryCodes_.indexOf(status) !== -1;\n    return isFiveHundredCode || isExtraRetryCode || isRequestSpecificRetryCode;\n  }\n}\n\n/**\n * A collection of information about the result of a network request.\n * @param opt_canceled - Defaults to false.\n */\nexport class RequestEndStatus {\n  /**\n   * True if the request was canceled.\n   */\n  canceled: boolean;\n\n  constructor(\n    public wasSuccessCode: boolean,\n    public xhr: XhrIo | null,\n    canceled?: boolean\n  ) {\n    this.canceled = !!canceled;\n  }\n}\n\nexport function addAuthHeader_(\n  headers: Headers,\n  authToken: string | null\n): void {\n  if (authToken !== null && authToken.length > 0) {\n    headers['Authorization'] = 'Firebase ' + authToken;\n  }\n}\n\nexport function addVersionHeader_(\n  headers: Headers,\n  firebaseVersion?: string\n): void {\n  headers['X-Firebase-Storage-Version'] =\n    'webjs/' + (firebaseVersion ?? 'AppManager');\n}\n\nexport function addGmpidHeader_(headers: Headers, appId: string | null): void {\n  if (appId) {\n    headers['X-Firebase-GMPID'] = appId;\n  }\n}\n\nexport function makeRequest<T>(\n  requestInfo: RequestInfo<T>,\n  appId: string | null,\n  authToken: string | null,\n  pool: XhrIoPool,\n  firebaseVersion?: string\n): Request<T> {\n  const queryPart = makeQueryString(requestInfo.urlParams);\n  const url = requestInfo.url + queryPart;\n  const headers = Object.assign({}, requestInfo.headers);\n  addGmpidHeader_(headers, appId);\n  addAuthHeader_(headers, authToken);\n  addVersionHeader_(headers, firebaseVersion);\n  return new NetworkRequest<T>(\n    url,\n    requestInfo.method,\n    headers,\n    requestInfo.body,\n    requestInfo.successCodes,\n    requestInfo.additionalRetryCodes,\n    requestInfo.handler,\n    requestInfo.errorHandler,\n    requestInfo.timeout,\n    requestInfo.progressCallback,\n    pool\n  );\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Provides a method for running a function with exponential\n * backoff.\n */\ntype id = (p1: boolean) => void;\n\nexport { id };\n\n/**\n * @param f May be invoked\n *     before the function returns.\n * @param callback Get all the arguments passed to the function\n *     passed to f, including the initial boolean.\n */\nexport function start(\n  f: (p1: (success: boolean) => void, canceled: boolean) => void,\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  callback: (...args: any[]) => unknown,\n  timeout: number\n): id {\n  // TODO(andysoto): make this code cleaner (probably refactor into an actual\n  // type instead of a bunch of functions with state shared in the closure)\n  let waitSeconds = 1;\n  // Would type this as \"number\" but that doesn't work for Node so ¯\\_(ツ)_/¯\n  // TODO: find a way to exclude Node type definition for storage because storage only works in browser\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  let timeoutId: any = null;\n  let hitTimeout = false;\n  let cancelState = 0;\n\n  function canceled(): boolean {\n    return cancelState === 2;\n  }\n  let triggeredCallback = false;\n\n  function triggerCallback(...args: any[]): void {\n    if (!triggeredCallback) {\n      triggeredCallback = true;\n      callback.apply(null, args);\n    }\n  }\n\n  function callWithDelay(millis: number): void {\n    timeoutId = setTimeout(() => {\n      timeoutId = null;\n      f(handler, canceled());\n    }, millis);\n  }\n\n  function handler(success: boolean, ...args: any[]): void {\n    if (triggeredCallback) {\n      return;\n    }\n    if (success) {\n      triggerCallback.call(null, success, ...args);\n      return;\n    }\n    const mustStop = canceled() || hitTimeout;\n    if (mustStop) {\n      triggerCallback.call(null, success, ...args);\n      return;\n    }\n    if (waitSeconds < 64) {\n      /* TODO(andysoto): don't back off so quickly if we know we're offline. */\n      waitSeconds *= 2;\n    }\n    let waitMillis;\n    if (cancelState === 1) {\n      cancelState = 2;\n      waitMillis = 0;\n    } else {\n      waitMillis = (waitSeconds + Math.random()) * 1000;\n    }\n    callWithDelay(waitMillis);\n  }\n  let stopped = false;\n\n  function stop(wasTimeout: boolean): void {\n    if (stopped) {\n      return;\n    }\n    stopped = true;\n    if (triggeredCallback) {\n      return;\n    }\n    if (timeoutId !== null) {\n      if (!wasTimeout) {\n        cancelState = 2;\n      }\n      clearTimeout(timeoutId);\n      callWithDelay(0);\n    } else {\n      if (!wasTimeout) {\n        cancelState = 1;\n      }\n    }\n  }\n  callWithDelay(0);\n  setTimeout(() => {\n    hitTimeout = true;\n    stop(true);\n  }, timeout);\n  return stop;\n}\n\n/**\n * Stops the retry loop from repeating.\n * If the function is currently \"in between\" retries, it is invoked immediately\n * with the second parameter as \"true\". Otherwise, it will be invoked once more\n * after the current invocation finishes iff the current invocation would have\n * triggered another retry.\n */\nexport function stop(id: id): void {\n  id(false);\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Location } from './implementation/location';\nimport { FailRequest } from './implementation/failrequest';\nimport { Request, makeRequest } from './implementation/request';\nimport { RequestInfo } from './implementation/requestinfo';\nimport { XhrIoPool } from './implementation/xhriopool';\nimport { Reference, _getChild } from './reference';\nimport { Provider } from '@firebase/component';\nimport { FirebaseAuthInternalName } from '@firebase/auth-interop-types';\nimport {\n  FirebaseApp,\n  FirebaseOptions,\n  _FirebaseService\n  // eslint-disable-next-line import/no-extraneous-dependencies\n} from '@firebase/app-exp';\nimport {\n  CONFIG_STORAGE_BUCKET_KEY,\n  DEFAULT_MAX_OPERATION_RETRY_TIME,\n  DEFAULT_MAX_UPLOAD_RETRY_TIME\n} from '../src/implementation/constants';\nimport {\n  invalidArgument,\n  appDeleted,\n  noDefaultBucket\n} from './implementation/error';\nimport { validateNumber } from './implementation/type';\n\nexport function isUrl(path?: string): boolean {\n  return /^[A-Za-z]+:\\/\\//.test(path as string);\n}\n\n/**\n * Returns a firebaseStorage.Reference for the given url.\n */\nfunction refFromURL(service: StorageService, url: string): Reference {\n  return new Reference(service, url);\n}\n\n/**\n * Returns a firebaseStorage.Reference for the given path in the default\n * bucket.\n */\nfunction refFromPath(\n  ref: StorageService | Reference,\n  path?: string\n): Reference {\n  if (ref instanceof StorageService) {\n    const service = ref;\n    if (service._bucket == null) {\n      throw noDefaultBucket();\n    }\n    const reference = new Reference(service, service._bucket!);\n    if (path != null) {\n      return refFromPath(reference, path);\n    } else {\n      return reference;\n    }\n  } else {\n    // ref is a Reference\n    if (path !== undefined) {\n      if (path.includes('..')) {\n        throw invalidArgument('`path` param cannot contain \"..\"');\n      }\n      return _getChild(ref, path);\n    } else {\n      return ref;\n    }\n  }\n}\n\n/**\n * Returns a storage Reference for the given url.\n * @param storage - `Storage` instance.\n * @param url - URL. If empty, returns root reference.\n * @public\n */\nexport function ref(storage: StorageService, url?: string): Reference;\n/**\n * Returns a storage Reference for the given path in the\n * default bucket.\n * @param storageOrRef - `Storage` service or storage `Reference`.\n * @param pathOrUrlStorage - path. If empty, returns root reference (if Storage\n * instance provided) or returns same reference (if Reference provided).\n * @public\n */\nexport function ref(\n  storageOrRef: StorageService | Reference,\n  path?: string\n): Reference;\nexport function ref(\n  serviceOrRef: StorageService | Reference,\n  pathOrUrl?: string\n): Reference | null {\n  if (pathOrUrl && isUrl(pathOrUrl)) {\n    if (serviceOrRef instanceof StorageService) {\n      return refFromURL(serviceOrRef, pathOrUrl);\n    } else {\n      throw invalidArgument(\n        'To use ref(service, url), the first argument must be a Storage instance.'\n      );\n    }\n  } else {\n    return refFromPath(serviceOrRef, pathOrUrl);\n  }\n}\n\nfunction extractBucket(config?: FirebaseOptions): Location | null {\n  const bucketString = config?.[CONFIG_STORAGE_BUCKET_KEY];\n  if (bucketString == null) {\n    return null;\n  }\n  return Location.makeFromBucketSpec(bucketString);\n}\n\n/**\n * A service that provides Firebase Storage Reference instances.\n * @public\n * @param opt_url - gs:// url to a custom Storage Bucket\n */\nexport class StorageService implements _FirebaseService {\n  readonly _bucket: Location | null = null;\n  protected readonly _appId: string | null = null;\n  private readonly _requests: Set<Request<unknown>>;\n  private _deleted: boolean = false;\n  private _maxOperationRetryTime: number;\n  private _maxUploadRetryTime: number;\n\n  constructor(\n    /**\n     * FirebaseApp associated with this StorageService instance.\n     */\n    readonly app: FirebaseApp,\n    readonly _authProvider: Provider<FirebaseAuthInternalName>,\n    readonly _pool: XhrIoPool,\n    readonly _url?: string,\n    readonly _firebaseVersion?: string\n  ) {\n    this._maxOperationRetryTime = DEFAULT_MAX_OPERATION_RETRY_TIME;\n    this._maxUploadRetryTime = DEFAULT_MAX_UPLOAD_RETRY_TIME;\n    this._requests = new Set();\n    if (_url != null) {\n      this._bucket = Location.makeFromBucketSpec(_url);\n    } else {\n      this._bucket = extractBucket(this.app.options);\n    }\n  }\n\n  /**\n   * The maximum time to retry uploads in milliseconds.\n   */\n  get maxUploadRetryTime(): number {\n    return this._maxUploadRetryTime;\n  }\n\n  set maxUploadRetryTime(time: number) {\n    validateNumber(\n      'time',\n      /* minValue=*/ 0,\n      /* maxValue= */ Number.POSITIVE_INFINITY,\n      time\n    );\n    this._maxUploadRetryTime = time;\n  }\n\n  /**\n   * The maximum time to retry operations other than uploads or downloads in\n   * milliseconds.\n   */\n  get maxOperationRetryTime(): number {\n    return this._maxOperationRetryTime;\n  }\n\n  set maxOperationRetryTime(time: number) {\n    validateNumber(\n      'time',\n      /* minValue=*/ 0,\n      /* maxValue= */ Number.POSITIVE_INFINITY,\n      time\n    );\n    this._maxOperationRetryTime = time;\n  }\n\n  async _getAuthToken(): Promise<string | null> {\n    const auth = this._authProvider.getImmediate({ optional: true });\n    if (auth) {\n      const tokenData = await auth.getToken();\n      if (tokenData !== null) {\n        return tokenData.accessToken;\n      }\n    }\n    return null;\n  }\n\n  /**\n   * Stop running requests and prevent more from being created.\n   */\n  _delete(): Promise<void> {\n    this._deleted = true;\n    this._requests.forEach(request => request.cancel());\n    this._requests.clear();\n    return Promise.resolve();\n  }\n\n  /**\n   * Returns a new firebaseStorage.Reference object referencing this StorageService\n   * at the given Location.\n   */\n  _makeStorageReference(loc: Location): Reference {\n    return new Reference(this, loc);\n  }\n\n  /**\n   * @param requestInfo - HTTP RequestInfo object\n   * @param authToken - Firebase auth token\n   */\n  _makeRequest<T>(\n    requestInfo: RequestInfo<T>,\n    authToken: string | null\n  ): Request<T> {\n    if (!this._deleted) {\n      const request = makeRequest(\n        requestInfo,\n        this._appId,\n        authToken,\n        this._pool,\n        this._firebaseVersion\n      );\n      this._requests.add(request);\n      // Request removes itself from set when complete.\n      request.getPromise().then(\n        () => this._requests.delete(request),\n        () => this._requests.delete(request)\n      );\n      return request;\n    } else {\n      return new FailRequest(appDeleted());\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport * as types from '@firebase/storage-types';\nimport { StorageService, isUrl, ref } from '../src/service';\nimport { Location } from '../src/implementation/location';\nimport { ReferenceCompat } from './reference';\nimport { invalidArgument } from '../src/implementation/error';\nimport { FirebaseApp } from '@firebase/app-types';\n\n/**\n * A service that provides firebaseStorage.Reference instances.\n * @param opt_url gs:// url to a custom Storage Bucket\n */\nexport class StorageServiceCompat implements types.FirebaseStorage {\n  constructor(public app: FirebaseApp, readonly _delegate: StorageService) {}\n\n  INTERNAL = {\n    /**\n     * Called when the associated app is deleted.\n     */\n    delete: () => {\n      return this._delegate._delete();\n    }\n  };\n\n  get maxOperationRetryTime(): number {\n    return this._delegate.maxOperationRetryTime;\n  }\n\n  get maxUploadRetryTime(): number {\n    return this._delegate.maxUploadRetryTime;\n  }\n\n  /**\n   * Returns a firebaseStorage.Reference for the given path in the default\n   * bucket.\n   */\n  ref(path?: string): types.Reference {\n    if (isUrl(path)) {\n      throw invalidArgument(\n        'ref() expected a child path but got a URL, use refFromURL instead.'\n      );\n    }\n    return new ReferenceCompat(ref(this._delegate, path), this);\n  }\n\n  /**\n   * Returns a firebaseStorage.Reference object for the given absolute URL,\n   * which must be a gs:// or http[s]:// URL.\n   */\n  refFromURL(url: string): types.Reference {\n    if (!isUrl(url)) {\n      throw invalidArgument(\n        'refFromURL() expected a full URL but got a child path, use ref() instead.'\n      );\n    }\n    try {\n      Location.makeFromUrl(url);\n    } catch (e) {\n      throw invalidArgument(\n        'refFromUrl() expected a valid full URL but got an invalid one.'\n      );\n    }\n    return new ReferenceCompat(ref(this._delegate, url), this);\n  }\n\n  setMaxUploadRetryTime(time: number): void {\n    this._delegate.maxUploadRetryTime = time;\n  }\n\n  setMaxOperationRetryTime(time: number): void {\n    this._delegate.maxOperationRetryTime = time;\n  }\n}\n","/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport firebase from '@firebase/app';\nimport { _FirebaseNamespace } from '@firebase/app-types/private';\nimport { StringFormat } from '../src/implementation/string';\nimport { TaskEvent, TaskState } from '../src/implementation/taskenums';\n\nimport { XhrIoPool } from '../src/implementation/xhriopool';\nimport { ReferenceCompat } from './reference';\nimport { StorageServiceCompat } from './service';\nimport { StorageService } from '../src/service';\nimport * as types from '@firebase/storage-types';\nimport {\n  Component,\n  ComponentType,\n  ComponentContainer\n} from '@firebase/component';\n\nimport { name, version } from '../package.json';\n\n/**\n * Type constant for Firebase Storage.\n */\nconst STORAGE_TYPE = 'storage';\n\nfunction factory(\n  container: ComponentContainer,\n  url?: string\n): types.FirebaseStorage {\n  // Dependencies\n  // TODO: This should eventually be 'app-compat'\n  const app = container.getProvider('app').getImmediate();\n  const authProvider = container.getProvider('auth-internal');\n\n  // TODO: get StorageService instance from component framework instead\n  // of creating a new one.\n  const storageServiceCompat: StorageServiceCompat = new StorageServiceCompat(\n    app,\n    new StorageService(\n      app,\n      authProvider,\n      new XhrIoPool(),\n      url,\n      firebase.SDK_VERSION\n    )\n  );\n  return storageServiceCompat;\n}\n\nexport function registerStorage(instance: _FirebaseNamespace): void {\n  const namespaceExports = {\n    // no-inline\n    TaskState,\n    TaskEvent,\n    StringFormat,\n    Storage: StorageService,\n    Reference: ReferenceCompat\n  };\n  instance.INTERNAL.registerComponent(\n    new Component(STORAGE_TYPE, factory, ComponentType.PUBLIC)\n      .setServiceProps(namespaceExports)\n      .setMultipleInstances(true)\n  );\n\n  instance.registerVersion(name, version);\n}\n\nregisterStorage(firebase as _FirebaseNamespace);\n\n/**\n * Define extension behavior for `registerStorage`\n */\ndeclare module '@firebase/app-types' {\n  interface FirebaseNamespace {\n    storage?: {\n      (app?: FirebaseApp, url?: string): types.FirebaseStorage;\n      Storage: typeof types.FirebaseStorage;\n\n      StringFormat: {\n        BASE64: types.StringFormat;\n        BASE64URL: types.StringFormat;\n        DATA_URL: types.StringFormat;\n        RAW: types.StringFormat;\n      };\n      TaskEvent: {\n        STATE_CHANGED: types.TaskEvent;\n      };\n      TaskState: {\n        CANCELED: types.TaskState;\n        ERROR: types.TaskState;\n        PAUSED: types.TaskState;\n        RUNNING: types.TaskState;\n        SUCCESS: types.TaskState;\n      };\n    };\n  }\n  interface FirebaseApp {\n    storage?(storageBucket?: string): types.FirebaseStorage;\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ERROR_FACTORY, ErrorCode } from '../utils/errors';\nimport { isIndexedDBAvailable } from '@firebase/util';\nimport { consoleLogger } from '../utils/console_logger';\ndeclare global {\n  interface Window {\n    PerformanceObserver: typeof PerformanceObserver;\n    // eslint-disable-next-line @typescript-eslint/ban-types\n    perfMetrics?: { onFirstInputDelay: Function };\n  }\n}\n\nlet apiInstance: Api | undefined;\nlet windowInstance: Window | undefined;\n\nexport type EntryType =\n  | 'mark'\n  | 'measure'\n  | 'paint'\n  | 'resource'\n  | 'frame'\n  | 'navigation';\n\n/**\n * This class holds a reference to various browser related objects injected by\n * set methods.\n */\nexport class Api {\n  private readonly performance: Performance;\n  /** PreformanceObserver constructor function. */\n  private readonly PerformanceObserver: typeof PerformanceObserver;\n  private readonly windowLocation: Location;\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  readonly onFirstInputDelay?: Function;\n  readonly localStorage?: Storage;\n  readonly document: Document;\n  readonly navigator: Navigator;\n\n  constructor(readonly window?: Window) {\n    if (!window) {\n      throw ERROR_FACTORY.create(ErrorCode.NO_WINDOW);\n    }\n    this.performance = window.performance;\n    this.PerformanceObserver = window.PerformanceObserver;\n    this.windowLocation = window.location;\n    this.navigator = window.navigator;\n    this.document = window.document;\n    if (this.navigator && this.navigator.cookieEnabled) {\n      // If user blocks cookies on the browser, accessing localStorage will\n      // throw an exception.\n      this.localStorage = window.localStorage;\n    }\n    if (window.perfMetrics && window.perfMetrics.onFirstInputDelay) {\n      this.onFirstInputDelay = window.perfMetrics.onFirstInputDelay;\n    }\n  }\n\n  getUrl(): string {\n    // Do not capture the string query part of url.\n    return this.windowLocation.href.split('?')[0];\n  }\n\n  mark(name: string): void {\n    if (!this.performance || !this.performance.mark) {\n      return;\n    }\n    this.performance.mark(name);\n  }\n\n  measure(measureName: string, mark1: string, mark2: string): void {\n    if (!this.performance || !this.performance.measure) {\n      return;\n    }\n    this.performance.measure(measureName, mark1, mark2);\n  }\n\n  getEntriesByType(type: EntryType): PerformanceEntry[] {\n    if (!this.performance || !this.performance.getEntriesByType) {\n      return [];\n    }\n    return this.performance.getEntriesByType(type);\n  }\n\n  getEntriesByName(name: string): PerformanceEntry[] {\n    if (!this.performance || !this.performance.getEntriesByName) {\n      return [];\n    }\n    return this.performance.getEntriesByName(name);\n  }\n\n  getTimeOrigin(): number {\n    // Polyfill the time origin with performance.timing.navigationStart.\n    return (\n      this.performance &&\n      (this.performance.timeOrigin || this.performance.timing.navigationStart)\n    );\n  }\n\n  requiredApisAvailable(): boolean {\n    if (\n      !fetch ||\n      !Promise ||\n      !this.navigator ||\n      !this.navigator.cookieEnabled\n    ) {\n      consoleLogger.info(\n        'Firebase Performance cannot start if browser does not support fetch and Promise or cookie is disabled.'\n      );\n      return false;\n    }\n\n    if (!isIndexedDBAvailable()) {\n      consoleLogger.info('IndexedDB is not supported by current browswer');\n      return false;\n    }\n    return true;\n  }\n\n  setupObserver(\n    entryType: EntryType,\n    callback: (entry: PerformanceEntry) => void\n  ): void {\n    if (!this.PerformanceObserver) {\n      return;\n    }\n    const observer = new this.PerformanceObserver(list => {\n      for (const entry of list.getEntries()) {\n        // `entry` is a PerformanceEntry instance.\n        callback(entry);\n      }\n    });\n\n    // Start observing the entry types you care about.\n    observer.observe({ entryTypes: [entryType] });\n  }\n\n  static getInstance(): Api {\n    if (apiInstance === undefined) {\n      apiInstance = new Api(windowInstance);\n    }\n    return apiInstance;\n  }\n}\n\nexport function setupApi(window: Window): void {\n  windowInstance = window;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ErrorFactory } from '@firebase/util';\nimport { SERVICE, SERVICE_NAME } from '../constants';\n\nexport const enum ErrorCode {\n  TRACE_STARTED_BEFORE = 'trace started',\n  TRACE_STOPPED_BEFORE = 'trace stopped',\n  NONPOSITIVE_TRACE_START_TIME = 'nonpositive trace startTime',\n  NONPOSITIVE_TRACE_DURATION = 'nonpositive trace duration',\n  NO_WINDOW = 'no window',\n  NO_APP_ID = 'no app id',\n  NO_PROJECT_ID = 'no project id',\n  NO_API_KEY = 'no api key',\n  INVALID_CC_LOG = 'invalid cc log',\n  FB_NOT_DEFAULT = 'FB not default',\n  RC_NOT_OK = 'RC response not ok',\n  INVALID_ATTRIBUTE_NAME = 'invalid attribute name',\n  INVALID_ATTRIBUTE_VALUE = 'invalid attribute value',\n  INVALID_CUSTOM_METRIC_NAME = 'invalid custom metric name',\n  INVALID_STRING_MERGER_PARAMETER = 'invalid String merger input'\n}\n\nconst ERROR_DESCRIPTION_MAP: { readonly [key in ErrorCode]: string } = {\n  [ErrorCode.TRACE_STARTED_BEFORE]: 'Trace {$traceName} was started before.',\n  [ErrorCode.TRACE_STOPPED_BEFORE]: 'Trace {$traceName} is not running.',\n  [ErrorCode.NONPOSITIVE_TRACE_START_TIME]:\n    'Trace {$traceName} startTime should be positive.',\n  [ErrorCode.NONPOSITIVE_TRACE_DURATION]:\n    'Trace {$traceName} duration should be positive.',\n  [ErrorCode.NO_WINDOW]: 'Window is not available.',\n  [ErrorCode.NO_APP_ID]: 'App id is not available.',\n  [ErrorCode.NO_PROJECT_ID]: 'Project id is not available.',\n  [ErrorCode.NO_API_KEY]: 'Api key is not available.',\n  [ErrorCode.INVALID_CC_LOG]: 'Attempted to queue invalid cc event',\n  [ErrorCode.FB_NOT_DEFAULT]:\n    'Performance can only start when Firebase app instance is the default one.',\n  [ErrorCode.RC_NOT_OK]: 'RC response is not ok',\n  [ErrorCode.INVALID_ATTRIBUTE_NAME]:\n    'Attribute name {$attributeName} is invalid.',\n  [ErrorCode.INVALID_ATTRIBUTE_VALUE]:\n    'Attribute value {$attributeValue} is invalid.',\n  [ErrorCode.INVALID_CUSTOM_METRIC_NAME]:\n    'Custom metric name {$customMetricName} is invalid',\n  [ErrorCode.INVALID_STRING_MERGER_PARAMETER]:\n    'Input for String merger is invalid, contact support team to resolve.'\n};\n\ninterface ErrorParams {\n  [ErrorCode.TRACE_STARTED_BEFORE]: { traceName: string };\n  [ErrorCode.TRACE_STOPPED_BEFORE]: { traceName: string };\n  [ErrorCode.NONPOSITIVE_TRACE_START_TIME]: { traceName: string };\n  [ErrorCode.NONPOSITIVE_TRACE_DURATION]: { traceName: string };\n  [ErrorCode.INVALID_ATTRIBUTE_NAME]: { attributeName: string };\n  [ErrorCode.INVALID_ATTRIBUTE_VALUE]: { attributeValue: string };\n  [ErrorCode.INVALID_CUSTOM_METRIC_NAME]: { customMetricName: string };\n}\n\nexport const ERROR_FACTORY = new ErrorFactory<ErrorCode, ErrorParams>(\n  SERVICE,\n  SERVICE_NAME,\n  ERROR_DESCRIPTION_MAP\n);\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Logger, LogLevel } from '@firebase/logger';\nimport { SERVICE_NAME } from '../constants';\n\nexport const consoleLogger = new Logger(SERVICE_NAME);\nconsoleLogger.logLevel = LogLevel.INFO;\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FirebaseApp } from '@firebase/app-types';\nimport { ERROR_FACTORY, ErrorCode } from '../utils/errors';\nimport { FirebaseInstallations } from '@firebase/installations-types';\nimport { mergeStrings } from '../utils/string_merger';\n\nlet settingsServiceInstance: SettingsService | undefined;\n\nexport class SettingsService {\n  // The variable which controls logging of automatic traces and HTTP/S network monitoring.\n  instrumentationEnabled = true;\n\n  // The variable which controls logging of custom traces.\n  dataCollectionEnabled = true;\n\n  // Configuration flags set through remote config.\n  loggingEnabled = false;\n  // Sampling rate between 0 and 1.\n  tracesSamplingRate = 1;\n  networkRequestsSamplingRate = 1;\n\n  // Address of logging service.\n  logEndPointUrl =\n    'https://firebaselogging.googleapis.com/v0cc/log?format=json_proto';\n  // Performance event transport endpoint URL which should be compatible with proto3.\n  // New Address for transport service, not configurable via Remote Config.\n  flTransportEndpointUrl = mergeStrings(\n    'hts/frbslgigp.ogepscmv/ieo/eaylg',\n    'tp:/ieaeogn-agolai.o/1frlglgc/o'\n  );\n\n  transportKey = mergeStrings('AzSC8r6ReiGqFMyfvgow', 'Iayx0u-XT3vksVM-pIV');\n\n  // Source type for performance event logs.\n  logSource = 462;\n\n  // Flags which control per session logging of traces and network requests.\n  logTraceAfterSampling = false;\n  logNetworkAfterSampling = false;\n\n  // TTL of config retrieved from remote config in hours.\n  configTimeToLive = 12;\n\n  firebaseAppInstance!: FirebaseApp;\n\n  installationsService!: FirebaseInstallations;\n\n  getAppId(): string {\n    const appId =\n      this.firebaseAppInstance &&\n      this.firebaseAppInstance.options &&\n      this.firebaseAppInstance.options.appId;\n    if (!appId) {\n      throw ERROR_FACTORY.create(ErrorCode.NO_APP_ID);\n    }\n    return appId;\n  }\n\n  getProjectId(): string {\n    const projectId =\n      this.firebaseAppInstance &&\n      this.firebaseAppInstance.options &&\n      this.firebaseAppInstance.options.projectId;\n    if (!projectId) {\n      throw ERROR_FACTORY.create(ErrorCode.NO_PROJECT_ID);\n    }\n    return projectId;\n  }\n\n  getApiKey(): string {\n    const apiKey =\n      this.firebaseAppInstance &&\n      this.firebaseAppInstance.options &&\n      this.firebaseAppInstance.options.apiKey;\n    if (!apiKey) {\n      throw ERROR_FACTORY.create(ErrorCode.NO_API_KEY);\n    }\n    return apiKey;\n  }\n\n  getFlTransportFullUrl(): string {\n    return this.flTransportEndpointUrl.concat('?key=', this.transportKey);\n  }\n\n  static getInstance(): SettingsService {\n    if (settingsServiceInstance === undefined) {\n      settingsServiceInstance = new SettingsService();\n    }\n    return settingsServiceInstance;\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ERROR_FACTORY, ErrorCode } from './errors';\n\nexport function mergeStrings(part1: string, part2: string): string {\n  const sizeDiff = part1.length - part2.length;\n  if (sizeDiff < 0 || sizeDiff > 1) {\n    throw ERROR_FACTORY.create(ErrorCode.INVALID_STRING_MERGER_PARAMETER);\n  }\n\n  const resultArray = [];\n  for (let i = 0; i < part1.length; i++) {\n    resultArray.push(part1.charAt(i));\n    if (part2.length > i) {\n      resultArray.push(part2.charAt(i));\n    }\n  }\n\n  return resultArray.join('');\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { SettingsService } from './settings_service';\n\nlet iid: string | undefined;\nlet authToken: string | undefined;\n\nexport function getIidPromise(): Promise<string> {\n  const iidPromise = SettingsService.getInstance().installationsService.getId();\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  iidPromise.then((iidVal: string) => {\n    iid = iidVal;\n  });\n  return iidPromise;\n}\n\n// This method should be used after the iid is retrieved by getIidPromise method.\nexport function getIid(): string | undefined {\n  return iid;\n}\n\nexport function getAuthTokenPromise(): Promise<string> {\n  const authTokenPromise = SettingsService.getInstance().installationsService.getToken();\n  // eslint-disable-next-line @typescript-eslint/no-floating-promises\n  authTokenPromise.then((authTokenVal: string) => {\n    authToken = authTokenVal;\n  });\n  return authTokenPromise;\n}\n\nexport function getAuthenticationToken(): string | undefined {\n  return authToken;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Api } from '../services/api_service';\n\n// The values and orders of the following enums should not be changed.\nconst enum ServiceWorkerStatus {\n  UNKNOWN = 0,\n  UNSUPPORTED = 1,\n  CONTROLLED = 2,\n  UNCONTROLLED = 3\n}\n\nexport enum VisibilityState {\n  UNKNOWN = 0,\n  VISIBLE = 1,\n  HIDDEN = 2\n}\n\nconst enum EffectiveConnectionType {\n  UNKNOWN = 0,\n  CONNECTION_SLOW_2G = 1,\n  CONNECTION_2G = 2,\n  CONNECTION_3G = 3,\n  CONNECTION_4G = 4\n}\n\n/**\n * NetworkInformation\n *\n * ref: https://developer.mozilla.org/en-US/docs/Web/API/NetworkInformation\n */\ninterface NetworkInformation {\n  readonly effectiveType?: 'slow-2g' | '2g' | '3g' | '4g';\n}\n\ninterface NavigatorWithConnection extends Navigator {\n  readonly connection: NetworkInformation;\n}\n\nconst RESERVED_ATTRIBUTE_PREFIXES = ['firebase_', 'google_', 'ga_'];\nconst ATTRIBUTE_FORMAT_REGEX = new RegExp('^[a-zA-Z]\\\\w*$');\nconst MAX_ATTRIBUTE_NAME_LENGTH = 40;\nconst MAX_ATTRIBUTE_VALUE_LENGTH = 100;\n\nexport function getServiceWorkerStatus(): ServiceWorkerStatus {\n  const navigator = Api.getInstance().navigator;\n  if ('serviceWorker' in navigator) {\n    if (navigator.serviceWorker.controller) {\n      return ServiceWorkerStatus.CONTROLLED;\n    } else {\n      return ServiceWorkerStatus.UNCONTROLLED;\n    }\n  } else {\n    return ServiceWorkerStatus.UNSUPPORTED;\n  }\n}\n\nexport function getVisibilityState(): VisibilityState {\n  const document = Api.getInstance().document;\n  const visibilityState = document.visibilityState;\n  switch (visibilityState) {\n    case 'visible':\n      return VisibilityState.VISIBLE;\n    case 'hidden':\n      return VisibilityState.HIDDEN;\n    default:\n      return VisibilityState.UNKNOWN;\n  }\n}\n\nexport function getEffectiveConnectionType(): EffectiveConnectionType {\n  const navigator = Api.getInstance().navigator;\n  const navigatorConnection = (navigator as NavigatorWithConnection).connection;\n  const effectiveType =\n    navigatorConnection && navigatorConnection.effectiveType;\n  switch (effectiveType) {\n    case 'slow-2g':\n      return EffectiveConnectionType.CONNECTION_SLOW_2G;\n    case '2g':\n      return EffectiveConnectionType.CONNECTION_2G;\n    case '3g':\n      return EffectiveConnectionType.CONNECTION_3G;\n    case '4g':\n      return EffectiveConnectionType.CONNECTION_4G;\n    default:\n      return EffectiveConnectionType.UNKNOWN;\n  }\n}\n\nexport function isValidCustomAttributeName(name: string): boolean {\n  if (name.length === 0 || name.length > MAX_ATTRIBUTE_NAME_LENGTH) {\n    return false;\n  }\n  const matchesReservedPrefix = RESERVED_ATTRIBUTE_PREFIXES.some(prefix =>\n    name.startsWith(prefix)\n  );\n  return !matchesReservedPrefix && !!name.match(ATTRIBUTE_FORMAT_REGEX);\n}\n\nexport function isValidCustomAttributeValue(value: string): boolean {\n  return value.length !== 0 && value.length <= MAX_ATTRIBUTE_VALUE_LENGTH;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  CONFIG_EXPIRY_LOCAL_STORAGE_KEY,\n  CONFIG_LOCAL_STORAGE_KEY,\n  SDK_VERSION\n} from '../constants';\nimport { consoleLogger } from '../utils/console_logger';\nimport { ERROR_FACTORY, ErrorCode } from '../utils/errors';\n\nimport { Api } from './api_service';\nimport { getAuthTokenPromise } from './iid_service';\nimport { SettingsService } from './settings_service';\n\nconst REMOTE_CONFIG_SDK_VERSION = '0.0.1';\n\ninterface SecondaryConfig {\n  loggingEnabled?: boolean;\n  logSource?: number;\n  logEndPointUrl?: string;\n  transportKey?: string;\n  tracesSamplingRate?: number;\n  networkRequestsSamplingRate?: number;\n}\n\n// These values will be used if the remote config object is successfully\n// retrieved, but the template does not have these fields.\nconst DEFAULT_CONFIGS: SecondaryConfig = {\n  loggingEnabled: true\n};\n\n/* eslint-disable camelcase */\ninterface RemoteConfigTemplate {\n  fpr_enabled?: string;\n  fpr_log_source?: string;\n  fpr_log_endpoint_url?: string;\n  fpr_log_transport_key?: string;\n  fpr_log_transport_web_percent?: string;\n  fpr_vc_network_request_sampling_rate?: string;\n  fpr_vc_trace_sampling_rate?: string;\n  fpr_vc_session_sampling_rate?: string;\n}\n/* eslint-enable camelcase */\n\ninterface RemoteConfigResponse {\n  entries?: RemoteConfigTemplate;\n  state?: string;\n}\n\nconst FIS_AUTH_PREFIX = 'FIREBASE_INSTALLATIONS_AUTH';\n\nexport function getConfig(iid: string): Promise<void> {\n  const config = getStoredConfig();\n  if (config) {\n    processConfig(config);\n    return Promise.resolve();\n  }\n\n  return getRemoteConfig(iid)\n    .then(processConfig)\n    .then(\n      config => storeConfig(config),\n      /** Do nothing for error, use defaults set in settings service. */\n      () => {}\n    );\n}\n\nfunction getStoredConfig(): RemoteConfigResponse | undefined {\n  const localStorage = Api.getInstance().localStorage;\n  if (!localStorage) {\n    return;\n  }\n  const expiryString = localStorage.getItem(CONFIG_EXPIRY_LOCAL_STORAGE_KEY);\n  if (!expiryString || !configValid(expiryString)) {\n    return;\n  }\n\n  const configStringified = localStorage.getItem(CONFIG_LOCAL_STORAGE_KEY);\n  if (!configStringified) {\n    return;\n  }\n  try {\n    const configResponse: RemoteConfigResponse = JSON.parse(configStringified);\n    return configResponse;\n  } catch {\n    return;\n  }\n}\n\nfunction storeConfig(config: RemoteConfigResponse | undefined): void {\n  const localStorage = Api.getInstance().localStorage;\n  if (!config || !localStorage) {\n    return;\n  }\n\n  localStorage.setItem(CONFIG_LOCAL_STORAGE_KEY, JSON.stringify(config));\n  localStorage.setItem(\n    CONFIG_EXPIRY_LOCAL_STORAGE_KEY,\n    String(\n      Date.now() +\n        SettingsService.getInstance().configTimeToLive * 60 * 60 * 1000\n    )\n  );\n}\n\nconst COULD_NOT_GET_CONFIG_MSG =\n  'Could not fetch config, will use default configs';\n\nfunction getRemoteConfig(\n  iid: string\n): Promise<RemoteConfigResponse | undefined> {\n  // Perf needs auth token only to retrieve remote config.\n  return getAuthTokenPromise()\n    .then(authToken => {\n      const projectId = SettingsService.getInstance().getProjectId();\n      const configEndPoint = `https://firebaseremoteconfig.googleapis.com/v1/projects/${projectId}/namespaces/fireperf:fetch?key=${SettingsService.getInstance().getApiKey()}`;\n      const request = new Request(configEndPoint, {\n        method: 'POST',\n        headers: { Authorization: `${FIS_AUTH_PREFIX} ${authToken}` },\n        /* eslint-disable camelcase */\n        body: JSON.stringify({\n          app_instance_id: iid,\n          app_instance_id_token: authToken,\n          app_id: SettingsService.getInstance().getAppId(),\n          app_version: SDK_VERSION,\n          sdk_version: REMOTE_CONFIG_SDK_VERSION\n        })\n        /* eslint-enable camelcase */\n      });\n      return fetch(request).then(response => {\n        if (response.ok) {\n          return response.json() as RemoteConfigResponse;\n        }\n        // In case response is not ok. This will be caught by catch.\n        throw ERROR_FACTORY.create(ErrorCode.RC_NOT_OK);\n      });\n    })\n    .catch(() => {\n      consoleLogger.info(COULD_NOT_GET_CONFIG_MSG);\n      return undefined;\n    });\n}\n\n/**\n * Processes config coming either from calling RC or from local storage.\n * This method only runs if call is successful or config in storage\n * is valid.\n */\nfunction processConfig(\n  config?: RemoteConfigResponse\n): RemoteConfigResponse | undefined {\n  if (!config) {\n    return config;\n  }\n  const settingsServiceInstance = SettingsService.getInstance();\n  const entries = config.entries || {};\n  if (entries.fpr_enabled !== undefined) {\n    // TODO: Change the assignment of loggingEnabled once the received type is\n    // known.\n    settingsServiceInstance.loggingEnabled =\n      String(entries.fpr_enabled) === 'true';\n  } else if (DEFAULT_CONFIGS.loggingEnabled !== undefined) {\n    // Config retrieved successfully, but there is no fpr_enabled in template.\n    // Use secondary configs value.\n    settingsServiceInstance.loggingEnabled = DEFAULT_CONFIGS.loggingEnabled;\n  }\n  if (entries.fpr_log_source) {\n    settingsServiceInstance.logSource = Number(entries.fpr_log_source);\n  } else if (DEFAULT_CONFIGS.logSource) {\n    settingsServiceInstance.logSource = DEFAULT_CONFIGS.logSource;\n  }\n\n  if (entries.fpr_log_endpoint_url) {\n    settingsServiceInstance.logEndPointUrl = entries.fpr_log_endpoint_url;\n  } else if (DEFAULT_CONFIGS.logEndPointUrl) {\n    settingsServiceInstance.logEndPointUrl = DEFAULT_CONFIGS.logEndPointUrl;\n  }\n\n  // Key from Remote Config has to be non-empty string, otherwsie use local value.\n  if (entries.fpr_log_transport_key) {\n    settingsServiceInstance.transportKey = entries.fpr_log_transport_key;\n  } else if (DEFAULT_CONFIGS.transportKey) {\n    settingsServiceInstance.transportKey = DEFAULT_CONFIGS.transportKey;\n  }\n\n  if (entries.fpr_vc_network_request_sampling_rate !== undefined) {\n    settingsServiceInstance.networkRequestsSamplingRate = Number(\n      entries.fpr_vc_network_request_sampling_rate\n    );\n  } else if (DEFAULT_CONFIGS.networkRequestsSamplingRate !== undefined) {\n    settingsServiceInstance.networkRequestsSamplingRate =\n      DEFAULT_CONFIGS.networkRequestsSamplingRate;\n  }\n  if (entries.fpr_vc_trace_sampling_rate !== undefined) {\n    settingsServiceInstance.tracesSamplingRate = Number(\n      entries.fpr_vc_trace_sampling_rate\n    );\n  } else if (DEFAULT_CONFIGS.tracesSamplingRate !== undefined) {\n    settingsServiceInstance.tracesSamplingRate =\n      DEFAULT_CONFIGS.tracesSamplingRate;\n  }\n  // Set the per session trace and network logging flags.\n  settingsServiceInstance.logTraceAfterSampling = shouldLogAfterSampling(\n    settingsServiceInstance.tracesSamplingRate\n  );\n  settingsServiceInstance.logNetworkAfterSampling = shouldLogAfterSampling(\n    settingsServiceInstance.networkRequestsSamplingRate\n  );\n  return config;\n}\n\nfunction configValid(expiry: string): boolean {\n  return Number(expiry) > Date.now();\n}\n\nfunction shouldLogAfterSampling(samplingRate: number): boolean {\n  return Math.random() <= samplingRate;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getIidPromise } from './iid_service';\nimport { getConfig } from './remote_config_service';\nimport { Api } from './api_service';\n\nconst enum InitializationStatus {\n  notInitialized = 1,\n  initializationPending,\n  initialized\n}\n\nlet initializationStatus = InitializationStatus.notInitialized;\n\nlet initializationPromise: Promise<void> | undefined;\n\nexport function getInitializationPromise(): Promise<void> {\n  initializationStatus = InitializationStatus.initializationPending;\n\n  initializationPromise = initializationPromise || initializePerf();\n\n  return initializationPromise;\n}\n\nexport function isPerfInitialized(): boolean {\n  return initializationStatus === InitializationStatus.initialized;\n}\n\nfunction initializePerf(): Promise<void> {\n  return getDocumentReadyComplete()\n    .then(() => getIidPromise())\n    .then(iid => getConfig(iid))\n    .then(\n      () => changeInitializationStatus(),\n      () => changeInitializationStatus()\n    );\n}\n\n/**\n * Returns a promise which resolves whenever the document readystate is complete or\n * immediately if it is called after page load complete.\n */\nfunction getDocumentReadyComplete(): Promise<void> {\n  const document = Api.getInstance().document;\n  return new Promise(resolve => {\n    if (document && document.readyState !== 'complete') {\n      const handler = (): void => {\n        if (document.readyState === 'complete') {\n          document.removeEventListener('readystatechange', handler);\n          resolve();\n        }\n      };\n      document.addEventListener('readystatechange', handler);\n    } else {\n      resolve();\n    }\n  });\n}\n\nfunction changeInitializationStatus(): void {\n  initializationStatus = InitializationStatus.initialized;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { SettingsService } from './settings_service';\nimport { ERROR_FACTORY, ErrorCode } from '../utils/errors';\nimport { consoleLogger } from '../utils/console_logger';\n\nconst DEFAULT_SEND_INTERVAL_MS = 10 * 1000;\nconst INITIAL_SEND_TIME_DELAY_MS = 5.5 * 1000;\n// If end point does not work, the call will be tried for these many times.\nconst DEFAULT_REMAINING_TRIES = 3;\nconst MAX_EVENT_COUNT_PER_REQUEST = 1000;\nlet remainingTries = DEFAULT_REMAINING_TRIES;\n\ninterface LogResponseDetails {\n  responseAction?: string;\n}\n\ninterface BatchEvent {\n  message: string;\n  eventTime: number;\n}\n\n/* eslint-disable camelcase */\n// CC/Fl accepted log format.\ninterface TransportBatchLogFormat {\n  request_time_ms: string;\n  client_info: ClientInfo;\n  log_source: number;\n  log_event: Log[];\n}\n\ninterface ClientInfo {\n  client_type: number;\n  js_client_info: {};\n}\n\ninterface Log {\n  source_extension_json_proto3: string;\n  event_time_ms: string;\n}\n/* eslint-enable camelcase */\n\nlet queue: BatchEvent[] = [];\n\nlet isTransportSetup: boolean = false;\n\nexport function setupTransportService(): void {\n  if (!isTransportSetup) {\n    processQueue(INITIAL_SEND_TIME_DELAY_MS);\n    isTransportSetup = true;\n  }\n}\n\n/**\n * Utilized by testing to clean up message queue and un-initialize transport service.\n */\nexport function resetTransportService(): void {\n  isTransportSetup = false;\n  queue = [];\n}\n\nfunction processQueue(timeOffset: number): void {\n  setTimeout(() => {\n    // If there is no remainingTries left, stop retrying.\n    if (remainingTries === 0) {\n      return;\n    }\n\n    // If there are no events to process, wait for DEFAULT_SEND_INTERVAL_MS and try again.\n    if (!queue.length) {\n      return processQueue(DEFAULT_SEND_INTERVAL_MS);\n    }\n\n    dispatchQueueEvents();\n  }, timeOffset);\n}\n\nfunction dispatchQueueEvents(): void {\n  // Extract events up to the maximum cap of single logRequest from top of \"official queue\".\n  // The staged events will be used for current logRequest attempt, remaining events will be kept\n  // for next attempt.\n  const staged = queue.splice(0, MAX_EVENT_COUNT_PER_REQUEST);\n\n  /* eslint-disable camelcase */\n  // We will pass the JSON serialized event to the backend.\n  const log_event: Log[] = staged.map(evt => ({\n    source_extension_json_proto3: evt.message,\n    event_time_ms: String(evt.eventTime)\n  }));\n\n  const data: TransportBatchLogFormat = {\n    request_time_ms: String(Date.now()),\n    client_info: {\n      client_type: 1, // 1 is JS\n      js_client_info: {}\n    },\n    log_source: SettingsService.getInstance().logSource,\n    log_event\n  };\n  /* eslint-enable camelcase */\n\n  sendEventsToFl(data, staged).catch(() => {\n    // If the request fails for some reason, add the events that were attempted\n    // back to the primary queue to retry later.\n    queue = [...staged, ...queue];\n    remainingTries--;\n    consoleLogger.info(`Tries left: ${remainingTries}.`);\n    processQueue(DEFAULT_SEND_INTERVAL_MS);\n  });\n}\n\nfunction sendEventsToFl(\n  data: TransportBatchLogFormat,\n  staged: BatchEvent[]\n): Promise<void> {\n  return postToFlEndpoint(data)\n    .then(res => {\n      if (!res.ok) {\n        consoleLogger.info('Call to Firebase backend failed.');\n      }\n      return res.json();\n    })\n    .then(res => {\n      // Find the next call wait time from the response.\n      const transportWait = Number(res.nextRequestWaitMillis);\n      let requestOffset = DEFAULT_SEND_INTERVAL_MS;\n      if (!isNaN(transportWait)) {\n        requestOffset = Math.max(transportWait, requestOffset);\n      }\n\n      // Delete request if response include RESPONSE_ACTION_UNKNOWN or DELETE_REQUEST action.\n      // Otherwise, retry request using normal scheduling if response include RETRY_REQUEST_LATER.\n      const logResponseDetails: LogResponseDetails[] = res.logResponseDetails;\n      if (\n        Array.isArray(logResponseDetails) &&\n        logResponseDetails.length > 0 &&\n        logResponseDetails[0].responseAction === 'RETRY_REQUEST_LATER'\n      ) {\n        queue = [...staged, ...queue];\n        consoleLogger.info(`Retry transport request later.`);\n      }\n\n      remainingTries = DEFAULT_REMAINING_TRIES;\n      // Schedule the next process.\n      processQueue(requestOffset);\n    });\n}\n\nfunction postToFlEndpoint(data: TransportBatchLogFormat): Promise<Response> {\n  const flTransportFullUrl = SettingsService.getInstance().getFlTransportFullUrl();\n  return fetch(flTransportFullUrl, {\n    method: 'POST',\n    body: JSON.stringify(data)\n  });\n}\n\nfunction addToQueue(evt: BatchEvent): void {\n  if (!evt.eventTime || !evt.message) {\n    throw ERROR_FACTORY.create(ErrorCode.INVALID_CC_LOG);\n  }\n  // Add the new event to the queue.\n  queue = [...queue, evt];\n}\n\n/** Log handler for cc service to send the performance logs to the server. */\nexport function transportHandler(\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  serializer: (...args: any[]) => string\n): (...args: unknown[]) => void {\n  return (...args) => {\n    const message = serializer(...args);\n    addToQueue({\n      message,\n      eventTime: Date.now()\n    });\n  };\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { getIid } from './iid_service';\nimport { NetworkRequest } from '../resources/network_request';\nimport { Trace } from '../resources/trace';\nimport { Api } from './api_service';\nimport { SettingsService } from './settings_service';\nimport {\n  getServiceWorkerStatus,\n  getVisibilityState,\n  VisibilityState,\n  getEffectiveConnectionType\n} from '../utils/attributes_utils';\nimport {\n  isPerfInitialized,\n  getInitializationPromise\n} from './initialization_service';\nimport { transportHandler } from './transport_service';\nimport { SDK_VERSION } from '../constants';\n\nconst enum ResourceType {\n  NetworkRequest,\n  Trace\n}\n\n/* eslint-disable camelcase */\ninterface ApplicationInfo {\n  google_app_id: string;\n  app_instance_id?: string;\n  web_app_info: WebAppInfo;\n  application_process_state: number;\n}\n\ninterface WebAppInfo {\n  sdk_version: string;\n  page_url: string;\n  service_worker_status: number;\n  visibility_state: number;\n  effective_connection_type: number;\n}\n\ninterface PerfNetworkLog {\n  application_info: ApplicationInfo;\n  network_request_metric: NetworkRequestMetric;\n}\n\ninterface PerfTraceLog {\n  application_info: ApplicationInfo;\n  trace_metric: TraceMetric;\n}\n\ninterface NetworkRequestMetric {\n  url: string;\n  http_method: number;\n  http_response_code: number;\n  response_payload_bytes?: number;\n  client_start_time_us?: number;\n  time_to_response_initiated_us?: number;\n  time_to_response_completed_us?: number;\n}\n\ninterface TraceMetric {\n  name: string;\n  is_auto: boolean;\n  client_start_time_us: number;\n  duration_us: number;\n  counters?: { [key: string]: number };\n  custom_attributes?: { [key: string]: string };\n}\n\n/* eslint-enble camelcase */\n\nlet logger: (\n  resource: NetworkRequest | Trace,\n  resourceType: ResourceType\n) => void | undefined;\n// This method is not called before initialization.\nfunction sendLog(\n  resource: NetworkRequest | Trace,\n  resourceType: ResourceType\n): void {\n  if (!logger) {\n    logger = transportHandler(serializer);\n  }\n  logger(resource, resourceType);\n}\n\nexport function logTrace(trace: Trace): void {\n  const settingsService = SettingsService.getInstance();\n  // Do not log if trace is auto generated and instrumentation is disabled.\n  if (!settingsService.instrumentationEnabled && trace.isAuto) {\n    return;\n  }\n  // Do not log if trace is custom and data collection is disabled.\n  if (!settingsService.dataCollectionEnabled && !trace.isAuto) {\n    return;\n  }\n  // Do not log if required apis are not available.\n  if (!Api.getInstance().requiredApisAvailable()) {\n    return;\n  }\n\n  // Only log the page load auto traces if page is visible.\n  if (trace.isAuto && getVisibilityState() !== VisibilityState.VISIBLE) {\n    return;\n  }\n\n  if (isPerfInitialized()) {\n    sendTraceLog(trace);\n  } else {\n    // Custom traces can be used before the initialization but logging\n    // should wait until after.\n\n    getInitializationPromise().then(\n      () => sendTraceLog(trace),\n      () => sendTraceLog(trace)\n    );\n  }\n}\n\nfunction sendTraceLog(trace: Trace): void {\n  if (!getIid()) {\n    return;\n  }\n\n  const settingsService = SettingsService.getInstance();\n  if (\n    !settingsService.loggingEnabled ||\n    !settingsService.logTraceAfterSampling\n  ) {\n    return;\n  }\n\n  setTimeout(() => sendLog(trace, ResourceType.Trace), 0);\n}\n\nexport function logNetworkRequest(networkRequest: NetworkRequest): void {\n  const settingsService = SettingsService.getInstance();\n  // Do not log network requests if instrumentation is disabled.\n  if (!settingsService.instrumentationEnabled) {\n    return;\n  }\n\n  // Do not log the js sdk's call to transport service domain to avoid unnecessary cycle.\n  // Need to blacklist both old and new endpoints to avoid migration gap.\n  const networkRequestUrl = networkRequest.url;\n\n  // Blacklist old log endpoint and new transport endpoint.\n  // Because Performance SDK doesn't instrument requests sent from SDK itself.\n  const logEndpointUrl = settingsService.logEndPointUrl.split('?')[0];\n  const flEndpointUrl = settingsService.flTransportEndpointUrl.split('?')[0];\n  if (\n    networkRequestUrl === logEndpointUrl ||\n    networkRequestUrl === flEndpointUrl\n  ) {\n    return;\n  }\n\n  if (\n    !settingsService.loggingEnabled ||\n    !settingsService.logNetworkAfterSampling\n  ) {\n    return;\n  }\n\n  setTimeout(() => sendLog(networkRequest, ResourceType.NetworkRequest), 0);\n}\n\nfunction serializer(\n  resource: NetworkRequest | Trace,\n  resourceType: ResourceType\n): string {\n  if (resourceType === ResourceType.NetworkRequest) {\n    return serializeNetworkRequest(resource as NetworkRequest);\n  }\n  return serializeTrace(resource as Trace);\n}\n\nfunction serializeNetworkRequest(networkRequest: NetworkRequest): string {\n  const networkRequestMetric: NetworkRequestMetric = {\n    url: networkRequest.url,\n    http_method: networkRequest.httpMethod || 0,\n    http_response_code: 200,\n    response_payload_bytes: networkRequest.responsePayloadBytes,\n    client_start_time_us: networkRequest.startTimeUs,\n    time_to_response_initiated_us: networkRequest.timeToResponseInitiatedUs,\n    time_to_response_completed_us: networkRequest.timeToResponseCompletedUs\n  };\n  const perfMetric: PerfNetworkLog = {\n    application_info: getApplicationInfo(),\n    network_request_metric: networkRequestMetric\n  };\n  return JSON.stringify(perfMetric);\n}\n\nfunction serializeTrace(trace: Trace): string {\n  const traceMetric: TraceMetric = {\n    name: trace.name,\n    is_auto: trace.isAuto,\n    client_start_time_us: trace.startTimeUs,\n    duration_us: trace.durationUs\n  };\n\n  if (Object.keys(trace.counters).length !== 0) {\n    traceMetric.counters = trace.counters;\n  }\n  const customAttributes = trace.getAttributes();\n  if (Object.keys(customAttributes).length !== 0) {\n    traceMetric.custom_attributes = customAttributes;\n  }\n\n  const perfMetric: PerfTraceLog = {\n    application_info: getApplicationInfo(),\n    trace_metric: traceMetric\n  };\n  return JSON.stringify(perfMetric);\n}\n\nfunction getApplicationInfo(): ApplicationInfo {\n  return {\n    google_app_id: SettingsService.getInstance().getAppId(),\n    app_instance_id: getIid(),\n    web_app_info: {\n      sdk_version: SDK_VERSION,\n      page_url: Api.getInstance().getUrl(),\n      service_worker_status: getServiceWorkerStatus(),\n      visibility_state: getVisibilityState(),\n      effective_connection_type: getEffectiveConnectionType()\n    },\n    application_process_state: 0\n  };\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  FIRST_PAINT_COUNTER_NAME,\n  FIRST_CONTENTFUL_PAINT_COUNTER_NAME,\n  FIRST_INPUT_DELAY_COUNTER_NAME,\n  OOB_TRACE_PAGE_LOAD_PREFIX\n} from '../constants';\nimport { consoleLogger } from '../utils/console_logger';\n\nconst MAX_METRIC_NAME_LENGTH = 100;\nconst RESERVED_AUTO_PREFIX = '_';\nconst oobMetrics = [\n  FIRST_PAINT_COUNTER_NAME,\n  FIRST_CONTENTFUL_PAINT_COUNTER_NAME,\n  FIRST_INPUT_DELAY_COUNTER_NAME\n];\n\n/**\n * Returns true if the metric is custom and does not start with reserved prefix, or if\n * the metric is one of out of the box page load trace metrics.\n */\nexport function isValidMetricName(name: string, traceName?: string): boolean {\n  if (name.length === 0 || name.length > MAX_METRIC_NAME_LENGTH) {\n    return false;\n  }\n  return (\n    (traceName &&\n      traceName.startsWith(OOB_TRACE_PAGE_LOAD_PREFIX) &&\n      oobMetrics.indexOf(name) > -1) ||\n    !name.startsWith(RESERVED_AUTO_PREFIX)\n  );\n}\n\n/**\n * Converts the provided value to an integer value to be used in case of a metric.\n * @param providedValue Provided number value of the metric that needs to be converted to an integer.\n *\n * @returns Converted integer number to be set for the metric.\n */\nexport function convertMetricValueToInteger(providedValue: number): number {\n  const valueAsInteger: number = Math.floor(providedValue);\n  if (valueAsInteger < providedValue) {\n    consoleLogger.info(\n      `Metric value should be an Integer, setting the value as : ${valueAsInteger}.`\n    );\n  }\n  return valueAsInteger;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  TRACE_START_MARK_PREFIX,\n  TRACE_STOP_MARK_PREFIX,\n  TRACE_MEASURE_PREFIX,\n  OOB_TRACE_PAGE_LOAD_PREFIX,\n  FIRST_PAINT_COUNTER_NAME,\n  FIRST_CONTENTFUL_PAINT_COUNTER_NAME,\n  FIRST_INPUT_DELAY_COUNTER_NAME\n} from '../constants';\nimport { Api } from '../services/api_service';\nimport { logTrace } from '../services/perf_logger';\nimport { ERROR_FACTORY, ErrorCode } from '../utils/errors';\nimport {\n  isValidCustomAttributeName,\n  isValidCustomAttributeValue\n} from '../utils/attributes_utils';\nimport {\n  isValidMetricName,\n  convertMetricValueToInteger\n} from '../utils/metric_utils';\nimport { PerformanceTrace } from '@firebase/performance-types';\n\nconst enum TraceState {\n  UNINITIALIZED = 1,\n  RUNNING,\n  TERMINATED\n}\n\nexport class Trace implements PerformanceTrace {\n  private state: TraceState = TraceState.UNINITIALIZED;\n  startTimeUs!: number;\n  durationUs!: number;\n  private customAttributes: { [key: string]: string } = {};\n  counters: { [counterName: string]: number } = {};\n  private api = Api.getInstance();\n  private randomId = Math.floor(Math.random() * 1000000);\n  private traceStartMark!: string;\n  private traceStopMark!: string;\n  private traceMeasure!: string;\n\n  /**\n   * @param name The name of the trace.\n   * @param isAuto If the trace is auto-instrumented.\n   * @param traceMeasureName The name of the measure marker in user timing specification. This field\n   * is only set when the trace is built for logging when the user directly uses the user timing\n   * api (performance.mark and performance.measure).\n   */\n  constructor(\n    readonly name: string,\n    readonly isAuto = false,\n    traceMeasureName?: string\n  ) {\n    if (!this.isAuto) {\n      this.traceStartMark = `${TRACE_START_MARK_PREFIX}-${this.randomId}-${this.name}`;\n      this.traceStopMark = `${TRACE_STOP_MARK_PREFIX}-${this.randomId}-${this.name}`;\n      this.traceMeasure =\n        traceMeasureName ||\n        `${TRACE_MEASURE_PREFIX}-${this.randomId}-${this.name}`;\n\n      if (traceMeasureName) {\n        // For the case of direct user timing traces, no start stop will happen. The measure object\n        // is already available.\n        this.calculateTraceMetrics();\n      }\n    }\n  }\n\n  /**\n   * Starts a trace. The measurement of the duration starts at this point.\n   */\n  start(): void {\n    if (this.state !== TraceState.UNINITIALIZED) {\n      throw ERROR_FACTORY.create(ErrorCode.TRACE_STARTED_BEFORE, {\n        traceName: this.name\n      });\n    }\n    this.api.mark(this.traceStartMark);\n    this.state = TraceState.RUNNING;\n  }\n\n  /**\n   * Stops the trace. The measurement of the duration of the trace stops at this point and trace\n   * is logged.\n   */\n  stop(): void {\n    if (this.state !== TraceState.RUNNING) {\n      throw ERROR_FACTORY.create(ErrorCode.TRACE_STOPPED_BEFORE, {\n        traceName: this.name\n      });\n    }\n    this.state = TraceState.TERMINATED;\n    this.api.mark(this.traceStopMark);\n    this.api.measure(\n      this.traceMeasure,\n      this.traceStartMark,\n      this.traceStopMark\n    );\n    this.calculateTraceMetrics();\n    logTrace(this);\n  }\n\n  /**\n   * Records a trace with predetermined values. If this method is used a trace is created and logged\n   * directly. No need to use start and stop methods.\n   * @param startTime Trace start time since epoch in millisec\n   * @param duration The duraction of the trace in millisec\n   * @param options An object which can optionally hold maps of custom metrics and custom attributes\n   */\n  record(\n    startTime: number,\n    duration: number,\n    options?: {\n      metrics?: { [key: string]: number };\n      attributes?: { [key: string]: string };\n    }\n  ): void {\n    if (startTime <= 0) {\n      throw ERROR_FACTORY.create(ErrorCode.NONPOSITIVE_TRACE_START_TIME, {\n        traceName: this.name\n      });\n    }\n    if (duration <= 0) {\n      throw ERROR_FACTORY.create(ErrorCode.NONPOSITIVE_TRACE_DURATION, {\n        traceName: this.name\n      });\n    }\n\n    this.durationUs = Math.floor(duration * 1000);\n    this.startTimeUs = Math.floor(startTime * 1000);\n    if (options && options.attributes) {\n      this.customAttributes = { ...options.attributes };\n    }\n    if (options && options.metrics) {\n      for (const metric of Object.keys(options.metrics)) {\n        if (!isNaN(Number(options.metrics[metric]))) {\n          this.counters[metric] = Number(Math.floor(options.metrics[metric]));\n        }\n      }\n    }\n    logTrace(this);\n  }\n\n  /**\n   * Increments a custom metric by a certain number or 1 if number not specified. Will create a new\n   * custom metric if one with the given name does not exist. The value will be floored down to an\n   * integer.\n   * @param counter Name of the custom metric\n   * @param numAsInteger Increment by value\n   */\n  incrementMetric(counter: string, numAsInteger = 1): void {\n    if (this.counters[counter] === undefined) {\n      this.putMetric(counter, numAsInteger);\n    } else {\n      this.putMetric(counter, this.counters[counter] + numAsInteger);\n    }\n  }\n\n  /**\n   * Sets a custom metric to a specified value. Will create a new custom metric if one with the\n   * given name does not exist. The value will be floored down to an integer.\n   * @param counter Name of the custom metric\n   * @param numAsInteger Set custom metric to this value\n   */\n  putMetric(counter: string, numAsInteger: number): void {\n    if (isValidMetricName(counter, this.name)) {\n      this.counters[counter] = convertMetricValueToInteger(numAsInteger);\n    } else {\n      throw ERROR_FACTORY.create(ErrorCode.INVALID_CUSTOM_METRIC_NAME, {\n        customMetricName: counter\n      });\n    }\n  }\n\n  /**\n   * Returns the value of the custom metric by that name. If a custom metric with that name does\n   * not exist will return zero.\n   * @param counter\n   */\n  getMetric(counter: string): number {\n    return this.counters[counter] || 0;\n  }\n\n  /**\n   * Sets a custom attribute of a trace to a certain value.\n   * @param attr\n   * @param value\n   */\n  putAttribute(attr: string, value: string): void {\n    const isValidName = isValidCustomAttributeName(attr);\n    const isValidValue = isValidCustomAttributeValue(value);\n    if (isValidName && isValidValue) {\n      this.customAttributes[attr] = value;\n      return;\n    }\n    // Throw appropriate error when the attribute name or value is invalid.\n    if (!isValidName) {\n      throw ERROR_FACTORY.create(ErrorCode.INVALID_ATTRIBUTE_NAME, {\n        attributeName: attr\n      });\n    }\n    if (!isValidValue) {\n      throw ERROR_FACTORY.create(ErrorCode.INVALID_ATTRIBUTE_VALUE, {\n        attributeValue: value\n      });\n    }\n  }\n\n  /**\n   * Retrieves the value a custom attribute of a trace is set to.\n   * @param attr\n   */\n  getAttribute(attr: string): string | undefined {\n    return this.customAttributes[attr];\n  }\n\n  removeAttribute(attr: string): void {\n    if (this.customAttributes[attr] === undefined) {\n      return;\n    }\n    delete this.customAttributes[attr];\n  }\n\n  getAttributes(): { [key: string]: string } {\n    return { ...this.customAttributes };\n  }\n\n  private setStartTime(startTime: number): void {\n    this.startTimeUs = startTime;\n  }\n\n  private setDuration(duration: number): void {\n    this.durationUs = duration;\n  }\n\n  /**\n   * Calculates and assigns the duration and start time of the trace using the measure performance\n   * entry.\n   */\n  private calculateTraceMetrics(): void {\n    const perfMeasureEntries = this.api.getEntriesByName(this.traceMeasure);\n    const perfMeasureEntry = perfMeasureEntries && perfMeasureEntries[0];\n    if (perfMeasureEntry) {\n      this.durationUs = Math.floor(perfMeasureEntry.duration * 1000);\n      this.startTimeUs = Math.floor(\n        (perfMeasureEntry.startTime + this.api.getTimeOrigin()) * 1000\n      );\n    }\n  }\n\n  /**\n   * @param navigationTimings A single element array which contains the navigationTIming object of\n   * the page load\n   * @param paintTimings A array which contains paintTiming object of the page load\n   * @param firstInputDelay First input delay in millisec\n   */\n  static createOobTrace(\n    navigationTimings: PerformanceNavigationTiming[],\n    paintTimings: PerformanceEntry[],\n    firstInputDelay?: number\n  ): void {\n    const route = Api.getInstance().getUrl();\n    if (!route) {\n      return;\n    }\n    const trace = new Trace(OOB_TRACE_PAGE_LOAD_PREFIX + route, true);\n    const timeOriginUs = Math.floor(Api.getInstance().getTimeOrigin() * 1000);\n    trace.setStartTime(timeOriginUs);\n\n    // navigationTimings includes only one element.\n    if (navigationTimings && navigationTimings[0]) {\n      trace.setDuration(Math.floor(navigationTimings[0].duration * 1000));\n      trace.putMetric(\n        'domInteractive',\n        Math.floor(navigationTimings[0].domInteractive * 1000)\n      );\n      trace.putMetric(\n        'domContentLoadedEventEnd',\n        Math.floor(navigationTimings[0].domContentLoadedEventEnd * 1000)\n      );\n      trace.putMetric(\n        'loadEventEnd',\n        Math.floor(navigationTimings[0].loadEventEnd * 1000)\n      );\n    }\n\n    const FIRST_PAINT = 'first-paint';\n    const FIRST_CONTENTFUL_PAINT = 'first-contentful-paint';\n    if (paintTimings) {\n      const firstPaint = paintTimings.find(\n        paintObject => paintObject.name === FIRST_PAINT\n      );\n      if (firstPaint && firstPaint.startTime) {\n        trace.putMetric(\n          FIRST_PAINT_COUNTER_NAME,\n          Math.floor(firstPaint.startTime * 1000)\n        );\n      }\n      const firstContentfulPaint = paintTimings.find(\n        paintObject => paintObject.name === FIRST_CONTENTFUL_PAINT\n      );\n      if (firstContentfulPaint && firstContentfulPaint.startTime) {\n        trace.putMetric(\n          FIRST_CONTENTFUL_PAINT_COUNTER_NAME,\n          Math.floor(firstContentfulPaint.startTime * 1000)\n        );\n      }\n\n      if (firstInputDelay) {\n        trace.putMetric(\n          FIRST_INPUT_DELAY_COUNTER_NAME,\n          Math.floor(firstInputDelay * 1000)\n        );\n      }\n    }\n\n    logTrace(trace);\n  }\n\n  static createUserTimingTrace(measureName: string): void {\n    const trace = new Trace(measureName, false, measureName);\n    logTrace(trace);\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Api } from '../services/api_service';\nimport { logNetworkRequest } from '../services/perf_logger';\n\n// The order of values of this enum should not be changed.\nexport const enum HttpMethod {\n  HTTP_METHOD_UNKNOWN = 0,\n  GET = 1,\n  PUT = 2,\n  POST = 3,\n  DELETE = 4,\n  HEAD = 5,\n  PATCH = 6,\n  OPTIONS = 7,\n  TRACE = 8,\n  CONNECT = 9\n}\n\n// Durations are in microseconds.\nexport interface NetworkRequest {\n  url: string;\n  httpMethod?: HttpMethod;\n  requestPayloadBytes?: number;\n  responsePayloadBytes?: number;\n  httpResponseCode?: number;\n  responseContentType?: string;\n  startTimeUs?: number;\n  timeToRequestCompletedUs?: number;\n  timeToResponseInitiatedUs?: number;\n  timeToResponseCompletedUs?: number;\n}\n\nexport function createNetworkRequestEntry(entry: PerformanceEntry): void {\n  const performanceEntry = entry as PerformanceResourceTiming;\n  if (!performanceEntry || performanceEntry.responseStart === undefined) {\n    return;\n  }\n  const timeOrigin = Api.getInstance().getTimeOrigin();\n  const startTimeUs = Math.floor(\n    (performanceEntry.startTime + timeOrigin) * 1000\n  );\n  const timeToResponseInitiatedUs = performanceEntry.responseStart\n    ? Math.floor(\n        (performanceEntry.responseStart - performanceEntry.startTime) * 1000\n      )\n    : undefined;\n  const timeToResponseCompletedUs = Math.floor(\n    (performanceEntry.responseEnd - performanceEntry.startTime) * 1000\n  );\n  // Remove the query params from logged network request url.\n  const url = performanceEntry.name && performanceEntry.name.split('?')[0];\n  const networkRequest: NetworkRequest = {\n    url,\n    responsePayloadBytes: performanceEntry.transferSize,\n    startTimeUs,\n    timeToResponseInitiatedUs,\n    timeToResponseCompletedUs\n  };\n\n  logNetworkRequest(networkRequest);\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { Api } from './api_service';\nimport { Trace } from '../resources/trace';\nimport { createNetworkRequestEntry } from '../resources/network_request';\nimport { TRACE_MEASURE_PREFIX } from '../constants';\nimport { getIid } from './iid_service';\n\nconst FID_WAIT_TIME_MS = 5000;\n\nexport function setupOobResources(): void {\n  // Do not initialize unless iid is available.\n  if (!getIid()) {\n    return;\n  }\n  // The load event might not have fired yet, and that means performance navigation timing\n  // object has a duration of 0. The setup should run after all current tasks in js queue.\n  setTimeout(() => setupOobTraces(), 0);\n  setTimeout(() => setupNetworkRequests(), 0);\n  setTimeout(() => setupUserTimingTraces(), 0);\n}\n\nfunction setupNetworkRequests(): void {\n  const api = Api.getInstance();\n  const resources = api.getEntriesByType('resource');\n  for (const resource of resources) {\n    createNetworkRequestEntry(resource);\n  }\n  api.setupObserver('resource', createNetworkRequestEntry);\n}\n\nfunction setupOobTraces(): void {\n  const api = Api.getInstance();\n  const navigationTimings = api.getEntriesByType(\n    'navigation'\n  ) as PerformanceNavigationTiming[];\n  const paintTimings = api.getEntriesByType('paint');\n  // If First Input Desly polyfill is added to the page, report the fid value.\n  // https://github.com/GoogleChromeLabs/first-input-delay\n  if (api.onFirstInputDelay) {\n    // If the fid call back is not called for certain time, continue without it.\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    let timeoutId: any = setTimeout(() => {\n      Trace.createOobTrace(navigationTimings, paintTimings);\n      timeoutId = undefined;\n    }, FID_WAIT_TIME_MS);\n    api.onFirstInputDelay((fid: number) => {\n      if (timeoutId) {\n        clearTimeout(timeoutId);\n        Trace.createOobTrace(navigationTimings, paintTimings, fid);\n      }\n    });\n  } else {\n    Trace.createOobTrace(navigationTimings, paintTimings);\n  }\n}\n\nfunction setupUserTimingTraces(): void {\n  const api = Api.getInstance();\n  // Run through the measure performance entries collected up to this point.\n  const measures = api.getEntriesByType('measure');\n  for (const measure of measures) {\n    createUserTimingTrace(measure);\n  }\n  // Setup an observer to capture the measures from this point on.\n  api.setupObserver('measure', createUserTimingTrace);\n}\n\nfunction createUserTimingTrace(measure: PerformanceEntry): void {\n  const measureName = measure.name;\n  // Do not create a trace, if the user timing marks and measures are created by the sdk itself.\n  if (\n    measureName.substring(0, TRACE_MEASURE_PREFIX.length) ===\n    TRACE_MEASURE_PREFIX\n  ) {\n    return;\n  }\n  Trace.createUserTimingTrace(measureName);\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport { Trace } from '../resources/trace';\nimport { setupOobResources } from '../services/oob_resources_service';\nimport { SettingsService } from '../services/settings_service';\nimport { getInitializationPromise } from '../services/initialization_service';\nimport { Api } from '../services/api_service';\nimport { FirebaseApp } from '@firebase/app-types';\nimport { FirebasePerformance } from '@firebase/performance-types';\nimport { setupTransportService } from '../services/transport_service';\nimport { validateIndexedDBOpenable } from '@firebase/util';\nimport { consoleLogger } from '../utils/console_logger';\nexport class PerformanceController implements FirebasePerformance {\n  constructor(readonly app: FirebaseApp) {\n    if (Api.getInstance().requiredApisAvailable()) {\n      validateIndexedDBOpenable()\n        .then(isAvailable => {\n          if (isAvailable) {\n            setupTransportService();\n            getInitializationPromise().then(\n              setupOobResources,\n              setupOobResources\n            );\n          }\n        })\n        .catch(error => {\n          consoleLogger.info(`Environment doesn't support IndexedDB: ${error}`);\n        });\n    }\n  }\n\n  trace(name: string): Trace {\n    return new Trace(name);\n  }\n\n  set instrumentationEnabled(val: boolean) {\n    SettingsService.getInstance().instrumentationEnabled = val;\n  }\n  get instrumentationEnabled(): boolean {\n    return SettingsService.getInstance().instrumentationEnabled;\n  }\n\n  set dataCollectionEnabled(val: boolean) {\n    SettingsService.getInstance().dataCollectionEnabled = val;\n  }\n  get dataCollectionEnabled(): boolean {\n    return SettingsService.getInstance().dataCollectionEnabled;\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  DynamicConfig,\n  DataLayer,\n  Gtag,\n  CustomParams,\n  ControlParams,\n  EventParams,\n  MinimalDynamicConfig\n} from '@firebase/analytics-types';\nimport { GtagCommand, GTAG_URL } from './constants';\nimport { logger } from './logger';\n\n/**\n * Inserts gtag script tag into the page to asynchronously download gtag.\n * @param dataLayerName Name of datalayer (most often the default, \"_dataLayer\").\n */\nexport function insertScriptTag(\n  dataLayerName: string,\n  measurementId: string\n): void {\n  const script = document.createElement('script');\n  script.src = `${GTAG_URL}?l=${dataLayerName}&id=${measurementId}`;\n  script.async = true;\n  document.head.appendChild(script);\n}\n\n/**\n * Get reference to, or create, global datalayer.\n * @param dataLayerName Name of datalayer (most often the default, \"_dataLayer\").\n */\nexport function getOrCreateDataLayer(dataLayerName: string): DataLayer {\n  // Check for existing dataLayer and create if needed.\n  let dataLayer: DataLayer = [];\n  if (Array.isArray(window[dataLayerName])) {\n    dataLayer = window[dataLayerName] as DataLayer;\n  } else {\n    window[dataLayerName] = dataLayer;\n  }\n  return dataLayer;\n}\n\n/**\n * Wrapped gtag logic when gtag is called with 'config' command.\n *\n * @param gtagCore Basic gtag function that just appends to dataLayer.\n * @param initializationPromisesMap Map of appIds to their initialization promises.\n * @param dynamicConfigPromisesList Array of dynamic config fetch promises.\n * @param measurementIdToAppId Map of GA measurementIDs to corresponding Firebase appId.\n * @param measurementId GA Measurement ID to set config for.\n * @param gtagParams Gtag config params to set.\n */\nasync function gtagOnConfig(\n  gtagCore: Gtag,\n  initializationPromisesMap: { [appId: string]: Promise<string> },\n  dynamicConfigPromisesList: Array<\n    Promise<DynamicConfig | MinimalDynamicConfig>\n  >,\n  measurementIdToAppId: { [measurementId: string]: string },\n  measurementId: string,\n  gtagParams?: ControlParams & EventParams & CustomParams\n): Promise<void> {\n  // If config is already fetched, we know the appId and can use it to look up what FID promise we\n  /// are waiting for, and wait only on that one.\n  const correspondingAppId = measurementIdToAppId[measurementId as string];\n  try {\n    if (correspondingAppId) {\n      await initializationPromisesMap[correspondingAppId];\n    } else {\n      // If config is not fetched yet, wait for all configs (we don't know which one we need) and\n      // find the appId (if any) corresponding to this measurementId. If there is one, wait on\n      // that appId's initialization promise. If there is none, promise resolves and gtag\n      // call goes through.\n      const dynamicConfigResults = await Promise.all(dynamicConfigPromisesList);\n      const foundConfig = dynamicConfigResults.find(\n        config => config.measurementId === measurementId\n      );\n      if (foundConfig) {\n        await initializationPromisesMap[foundConfig.appId];\n      }\n    }\n  } catch (e) {\n    logger.error(e);\n  }\n  gtagCore(GtagCommand.CONFIG, measurementId, gtagParams);\n}\n\n/**\n * Wrapped gtag logic when gtag is called with 'event' command.\n *\n * @param gtagCore Basic gtag function that just appends to dataLayer.\n * @param initializationPromisesMap Map of appIds to their initialization promises.\n * @param dynamicConfigPromisesList Array of dynamic config fetch promises.\n * @param measurementId GA Measurement ID to log event to.\n * @param gtagParams Params to log with this event.\n */\nasync function gtagOnEvent(\n  gtagCore: Gtag,\n  initializationPromisesMap: { [appId: string]: Promise<string> },\n  dynamicConfigPromisesList: Array<\n    Promise<DynamicConfig | MinimalDynamicConfig>\n  >,\n  measurementId: string,\n  gtagParams?: ControlParams & EventParams & CustomParams\n): Promise<void> {\n  try {\n    let initializationPromisesToWaitFor: Array<Promise<string>> = [];\n\n    // If there's a 'send_to' param, check if any ID specified matches\n    // an initializeIds() promise we are waiting for.\n    if (gtagParams && gtagParams['send_to']) {\n      let gaSendToList: string | string[] = gtagParams['send_to'];\n      // Make it an array if is isn't, so it can be dealt with the same way.\n      if (!Array.isArray(gaSendToList)) {\n        gaSendToList = [gaSendToList];\n      }\n      // Checking 'send_to' fields requires having all measurement ID results back from\n      // the dynamic config fetch.\n      const dynamicConfigResults = await Promise.all(dynamicConfigPromisesList);\n      for (const sendToId of gaSendToList) {\n        // Any fetched dynamic measurement ID that matches this 'send_to' ID\n        const foundConfig = dynamicConfigResults.find(\n          config => config.measurementId === sendToId\n        );\n        const initializationPromise =\n          foundConfig && initializationPromisesMap[foundConfig.appId];\n        if (initializationPromise) {\n          initializationPromisesToWaitFor.push(initializationPromise);\n        } else {\n          // Found an item in 'send_to' that is not associated\n          // directly with an FID, possibly a group.  Empty this array,\n          // exit the loop early, and let it get populated below.\n          initializationPromisesToWaitFor = [];\n          break;\n        }\n      }\n    }\n\n    // This will be unpopulated if there was no 'send_to' field , or\n    // if not all entries in the 'send_to' field could be mapped to\n    // a FID. In these cases, wait on all pending initialization promises.\n    if (initializationPromisesToWaitFor.length === 0) {\n      initializationPromisesToWaitFor = Object.values(\n        initializationPromisesMap\n      );\n    }\n\n    // Run core gtag function with args after all relevant initialization\n    // promises have been resolved.\n    await Promise.all(initializationPromisesToWaitFor);\n    // Workaround for http://b/141370449 - third argument cannot be undefined.\n    gtagCore(GtagCommand.EVENT, measurementId, gtagParams || {});\n  } catch (e) {\n    logger.error(e);\n  }\n}\n\n/**\n * Wraps a standard gtag function with extra code to wait for completion of\n * relevant initialization promises before sending requests.\n *\n * @param gtagCore Basic gtag function that just appends to dataLayer.\n * @param initializationPromisesMap Map of appIds to their initialization promises.\n * @param dynamicConfigPromisesList Array of dynamic config fetch promises.\n * @param measurementIdToAppId Map of GA measurementIDs to corresponding Firebase appId.\n */\nfunction wrapGtag(\n  gtagCore: Gtag,\n  /**\n   * Allows wrapped gtag calls to wait on whichever intialization promises are required,\n   * depending on the contents of the gtag params' `send_to` field, if any.\n   */\n  initializationPromisesMap: { [appId: string]: Promise<string> },\n  /**\n   * Wrapped gtag calls sometimes require all dynamic config fetches to have returned\n   * before determining what initialization promises (which include FIDs) to wait for.\n   */\n  dynamicConfigPromisesList: Array<\n    Promise<DynamicConfig | MinimalDynamicConfig>\n  >,\n  /**\n   * Wrapped gtag config calls can narrow down which initialization promise (with FID)\n   * to wait for if the measurementId is already fetched, by getting the corresponding appId,\n   * which is the key for the initialization promises map.\n   */\n  measurementIdToAppId: { [measurementId: string]: string }\n): Gtag {\n  /**\n   * Wrapper around gtag that ensures FID is sent with gtag calls.\n   * @param command Gtag command type.\n   * @param idOrNameOrParams Measurement ID if command is EVENT/CONFIG, params if command is SET.\n   * @param gtagParams Params if event is EVENT/CONFIG.\n   */\n  async function gtagWrapper(\n    command: 'config' | 'set' | 'event',\n    idOrNameOrParams: string | ControlParams,\n    gtagParams?: ControlParams & EventParams & CustomParams\n  ): Promise<void> {\n    try {\n      // If event, check that relevant initialization promises have completed.\n      if (command === GtagCommand.EVENT) {\n        // If EVENT, second arg must be measurementId.\n        await gtagOnEvent(\n          gtagCore,\n          initializationPromisesMap,\n          dynamicConfigPromisesList,\n          idOrNameOrParams as string,\n          gtagParams\n        );\n      } else if (command === GtagCommand.CONFIG) {\n        // If CONFIG, second arg must be measurementId.\n        await gtagOnConfig(\n          gtagCore,\n          initializationPromisesMap,\n          dynamicConfigPromisesList,\n          measurementIdToAppId,\n          idOrNameOrParams as string,\n          gtagParams\n        );\n      } else {\n        // If SET, second arg must be params.\n        gtagCore(GtagCommand.SET, idOrNameOrParams as CustomParams);\n      }\n    } catch (e) {\n      logger.error(e);\n    }\n  }\n  return gtagWrapper;\n}\n\n/**\n * Creates global gtag function or wraps existing one if found.\n * This wrapped function attaches Firebase instance ID (FID) to gtag 'config' and\n * 'event' calls that belong to the GAID associated with this Firebase instance.\n *\n * @param initializationPromisesMap Map of appIds to their initialization promises.\n * @param dynamicConfigPromisesList Array of dynamic config fetch promises.\n * @param measurementIdToAppId Map of GA measurementIDs to corresponding Firebase appId.\n * @param dataLayerName Name of global GA datalayer array.\n * @param gtagFunctionName Name of global gtag function (\"gtag\" if not user-specified).\n */\nexport function wrapOrCreateGtag(\n  initializationPromisesMap: { [appId: string]: Promise<string> },\n  dynamicConfigPromisesList: Array<\n    Promise<DynamicConfig | MinimalDynamicConfig>\n  >,\n  measurementIdToAppId: { [measurementId: string]: string },\n  dataLayerName: string,\n  gtagFunctionName: string\n): {\n  gtagCore: Gtag;\n  wrappedGtag: Gtag;\n} {\n  // Create a basic core gtag function\n  let gtagCore: Gtag = function (..._args: unknown[]) {\n    // Must push IArguments object, not an array.\n    (window[dataLayerName] as DataLayer).push(arguments);\n  };\n\n  // Replace it with existing one if found\n  if (\n    window[gtagFunctionName] &&\n    typeof window[gtagFunctionName] === 'function'\n  ) {\n    // @ts-ignore\n    gtagCore = window[gtagFunctionName];\n  }\n\n  window[gtagFunctionName] = wrapGtag(\n    gtagCore,\n    initializationPromisesMap,\n    dynamicConfigPromisesList,\n    measurementIdToAppId\n  );\n\n  return {\n    gtagCore,\n    wrappedGtag: window[gtagFunctionName] as Gtag\n  };\n}\n\n/**\n * Returns first script tag in DOM matching our gtag url pattern.\n */\nexport function findGtagScriptOnPage(): HTMLScriptElement | null {\n  const scriptTags = window.document.getElementsByTagName('script');\n  for (const tag of Object.values(scriptTags)) {\n    if (tag.src && tag.src.includes(GTAG_URL)) {\n      return tag;\n    }\n  }\n  return null;\n}\n","/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Most logic is copied from packages/remote-config/src/client/retrying_client.ts\n */\n\nimport { FirebaseApp } from '@firebase/app-types';\nimport {\n  DynamicConfig,\n  ThrottleMetadata,\n  MinimalDynamicConfig\n} from '@firebase/analytics-types';\nimport { FirebaseError, calculateBackoffMillis } from '@firebase/util';\nimport { AnalyticsError, ERROR_FACTORY } from './errors';\nimport { DYNAMIC_CONFIG_URL, FETCH_TIMEOUT_MILLIS } from './constants';\nimport { logger } from './logger';\n\n// App config fields needed by analytics.\nexport interface AppFields {\n  appId: string;\n  apiKey: string;\n  measurementId?: string;\n}\n\n/**\n * Backoff factor for 503 errors, which we want to be conservative about\n * to avoid overloading servers. Each retry interval will be\n * BASE_INTERVAL_MILLIS * LONG_RETRY_FACTOR ^ retryCount, so the second one\n * will be ~30 seconds (with fuzzing).\n */\nexport const LONG_RETRY_FACTOR = 30;\n\n/**\n * Base wait interval to multiplied by backoffFactor^backoffCount.\n */\nconst BASE_INTERVAL_MILLIS = 1000;\n\n/**\n * Stubbable retry data storage class.\n */\nclass RetryData {\n  constructor(\n    public throttleMetadata: { [appId: string]: ThrottleMetadata } = {},\n    public intervalMillis: number = BASE_INTERVAL_MILLIS\n  ) {}\n\n  getThrottleMetadata(appId: string): ThrottleMetadata {\n    return this.throttleMetadata[appId];\n  }\n\n  setThrottleMetadata(appId: string, metadata: ThrottleMetadata): void {\n    this.throttleMetadata[appId] = metadata;\n  }\n\n  deleteThrottleMetadata(appId: string): void {\n    delete this.throttleMetadata[appId];\n  }\n}\n\nconst defaultRetryData = new RetryData();\n\n/**\n * Set GET request headers.\n * @param apiKey App API key.\n */\nfunction getHeaders(apiKey: string): Headers {\n  return new Headers({\n    Accept: 'application/json',\n    'x-goog-api-key': apiKey\n  });\n}\n\n/**\n * Fetches dynamic config from backend.\n * @param app Firebase app to fetch config for.\n */\nexport async function fetchDynamicConfig(\n  appFields: AppFields\n): Promise<DynamicConfig> {\n  const { appId, apiKey } = appFields;\n  const request: RequestInit = {\n    method: 'GET',\n    headers: getHeaders(apiKey)\n  };\n  const appUrl = DYNAMIC_CONFIG_URL.replace('{app-id}', appId);\n  const response = await fetch(appUrl, request);\n  if (response.status !== 200 && response.status !== 304) {\n    let errorMessage = '';\n    try {\n      // Try to get any error message text from server response.\n      const jsonResponse = (await response.json()) as {\n        error?: { message?: string };\n      };\n      if (jsonResponse.error?.message) {\n        errorMessage = jsonResponse.error.message;\n      }\n    } catch (_ignored) {}\n    throw ERROR_FACTORY.create(AnalyticsError.CONFIG_FETCH_FAILED, {\n      httpStatus: response.status,\n      responseMessage: errorMessage\n    });\n  }\n  return response.json();\n}\n\n/**\n * Fetches dynamic config from backend, retrying if failed.\n * @param app Firebase app to fetch config for.\n */\nexport async function fetchDynamicConfigWithRetry(\n  app: FirebaseApp,\n  // retryData and timeoutMillis are parameterized to allow passing a different value for testing.\n  retryData: RetryData = defaultRetryData,\n  timeoutMillis?: number\n): Promise<DynamicConfig | MinimalDynamicConfig> {\n  const { appId, apiKey, measurementId } = app.options;\n\n  if (!appId) {\n    throw ERROR_FACTORY.create(AnalyticsError.NO_APP_ID);\n  }\n\n  if (!apiKey) {\n    if (measurementId) {\n      return {\n        measurementId,\n        appId\n      };\n    }\n    throw ERROR_FACTORY.create(AnalyticsError.NO_API_KEY);\n  }\n\n  const throttleMetadata: ThrottleMetadata = retryData.getThrottleMetadata(\n    appId\n  ) || {\n    backoffCount: 0,\n    throttleEndTimeMillis: Date.now()\n  };\n\n  const signal = new AnalyticsAbortSignal();\n\n  setTimeout(\n    async () => {\n      // Note a very low delay, eg < 10ms, can elapse before listeners are initialized.\n      signal.abort();\n    },\n    timeoutMillis !== undefined ? timeoutMillis : FETCH_TIMEOUT_MILLIS\n  );\n\n  return attemptFetchDynamicConfigWithRetry(\n    { appId, apiKey, measurementId },\n    throttleMetadata,\n    signal,\n    retryData\n  );\n}\n\n/**\n * Runs one retry attempt.\n * @param appFields Necessary app config fields.\n * @param throttleMetadata Ongoing metadata to determine throttling times.\n * @param signal Abort signal.\n */\nasync function attemptFetchDynamicConfigWithRetry(\n  appFields: AppFields,\n  { throttleEndTimeMillis, backoffCount }: ThrottleMetadata,\n  signal: AnalyticsAbortSignal,\n  retryData: RetryData = defaultRetryData // for testing\n): Promise<DynamicConfig | MinimalDynamicConfig> {\n  const { appId, measurementId } = appFields;\n  // Starts with a (potentially zero) timeout to support resumption from stored state.\n  // Ensures the throttle end time is honored if the last attempt timed out.\n  // Note the SDK will never make a request if the fetch timeout expires at this point.\n  try {\n    await setAbortableTimeout(signal, throttleEndTimeMillis);\n  } catch (e) {\n    if (measurementId) {\n      logger.warn(\n        `Timed out fetching this Firebase app's measurement ID from the server.` +\n          ` Falling back to the measurement ID ${measurementId}` +\n          ` provided in the \"measurementId\" field in the local Firebase config. [${e.message}]`\n      );\n      return { appId, measurementId };\n    }\n    throw e;\n  }\n\n  try {\n    const response = await fetchDynamicConfig(appFields);\n\n    // Note the SDK only clears throttle state if response is success or non-retriable.\n    retryData.deleteThrottleMetadata(appId);\n\n    return response;\n  } catch (e) {\n    if (!isRetriableError(e)) {\n      retryData.deleteThrottleMetadata(appId);\n      if (measurementId) {\n        logger.warn(\n          `Failed to fetch this Firebase app's measurement ID from the server.` +\n            ` Falling back to the measurement ID ${measurementId}` +\n            ` provided in the \"measurementId\" field in the local Firebase config. [${e.message}]`\n        );\n        return { appId, measurementId };\n      } else {\n        throw e;\n      }\n    }\n\n    const backoffMillis =\n      Number(e.customData.httpStatus) === 503\n        ? calculateBackoffMillis(\n            backoffCount,\n            retryData.intervalMillis,\n            LONG_RETRY_FACTOR\n          )\n        : calculateBackoffMillis(backoffCount, retryData.intervalMillis);\n\n    // Increments backoff state.\n    const throttleMetadata = {\n      throttleEndTimeMillis: Date.now() + backoffMillis,\n      backoffCount: backoffCount + 1\n    };\n\n    // Persists state.\n    retryData.setThrottleMetadata(appId, throttleMetadata);\n    logger.debug(`Calling attemptFetch again in ${backoffMillis} millis`);\n\n    return attemptFetchDynamicConfigWithRetry(\n      appFields,\n      throttleMetadata,\n      signal,\n      retryData\n    );\n  }\n}\n\n/**\n * Supports waiting on a backoff by:\n *\n * <ul>\n *   <li>Promisifying setTimeout, so we can set a timeout in our Promise chain</li>\n *   <li>Listening on a signal bus for abort events, just like the Fetch API</li>\n *   <li>Failing in the same way the Fetch API fails, so timing out a live request and a throttled\n *       request appear the same.</li>\n * </ul>\n *\n * <p>Visible for testing.\n */\nfunction setAbortableTimeout(\n  signal: AnalyticsAbortSignal,\n  throttleEndTimeMillis: number\n): Promise<void> {\n  return new Promise((resolve, reject) => {\n    // Derives backoff from given end time, normalizing negative numbers to zero.\n    const backoffMillis = Math.max(throttleEndTimeMillis - Date.now(), 0);\n\n    const timeout = setTimeout(resolve, backoffMillis);\n\n    // Adds listener, rather than sets onabort, because signal is a shared object.\n    signal.addEventListener(() => {\n      clearTimeout(timeout);\n      // If the request completes before this timeout, the rejection has no effect.\n      reject(\n        ERROR_FACTORY.create(AnalyticsError.FETCH_THROTTLE, {\n          throttleEndTimeMillis\n        })\n      );\n    });\n  });\n}\n\ntype RetriableError = FirebaseError & { customData: { httpStatus: string } };\n\n/**\n * Returns true if the {@link Error} indicates a fetch request may succeed later.\n */\nfunction isRetriableError(e: Error): e is RetriableError {\n  if (!(e instanceof FirebaseError) || !e.customData) {\n    return false;\n  }\n\n  // Uses string index defined by ErrorData, which FirebaseError implements.\n  const httpStatus = Number(e.customData['httpStatus']);\n\n  return (\n    httpStatus === 429 ||\n    httpStatus === 500 ||\n    httpStatus === 503 ||\n    httpStatus === 504\n  );\n}\n\n/**\n * Shims a minimal AbortSignal (copied from Remote Config).\n *\n * <p>AbortController's AbortSignal conveniently decouples fetch timeout logic from other aspects\n * of networking, such as retries. Firebase doesn't use AbortController enough to justify a\n * polyfill recommendation, like we do with the Fetch API, but this minimal shim can easily be\n * swapped out if/when we do.\n */\nexport class AnalyticsAbortSignal {\n  listeners: Array<() => void> = [];\n  addEventListener(listener: () => void): void {\n    this.listeners.push(listener);\n  }\n  abort(): void {\n    this.listeners.forEach(listener => listener());\n  }\n}\n","/**\n * @license\n * Copyright 2020 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  DynamicConfig,\n  Gtag,\n  MinimalDynamicConfig\n} from '@firebase/analytics-types';\nimport { GtagCommand, GA_FID_KEY, ORIGIN_KEY } from './constants';\nimport { FirebaseInstallations } from '@firebase/installations-types';\nimport { fetchDynamicConfigWithRetry } from './get-config';\nimport { logger } from './logger';\nimport { FirebaseApp } from '@firebase/app-types';\nimport {\n  isIndexedDBAvailable,\n  validateIndexedDBOpenable\n} from '@firebase/util';\nimport { ERROR_FACTORY, AnalyticsError } from './errors';\nimport { findGtagScriptOnPage, insertScriptTag } from './helpers';\n\nasync function validateIndexedDB(): Promise<boolean> {\n  if (!isIndexedDBAvailable()) {\n    logger.warn(\n      ERROR_FACTORY.create(AnalyticsError.INDEXEDDB_UNAVAILABLE, {\n        errorInfo: 'IndexedDB is not available in this environment.'\n      }).message\n    );\n    return false;\n  } else {\n    try {\n      await validateIndexedDBOpenable();\n    } catch (e) {\n      logger.warn(\n        ERROR_FACTORY.create(AnalyticsError.INDEXEDDB_UNAVAILABLE, {\n          errorInfo: e\n        }).message\n      );\n      return false;\n    }\n  }\n  return true;\n}\n\n/**\n * Initialize the analytics instance in gtag.js by calling config command with fid.\n *\n * NOTE: We combine analytics initialization and setting fid together because we want fid to be\n * part of the `page_view` event that's sent during the initialization\n * @param app Firebase app\n * @param gtagCore The gtag function that's not wrapped.\n * @param dynamicConfigPromisesList Array of all dynamic config promises.\n * @param measurementIdToAppId Maps measurementID to appID.\n * @param installations FirebaseInstallations instance.\n *\n * @returns Measurement ID.\n */\nexport async function initializeIds(\n  app: FirebaseApp,\n  dynamicConfigPromisesList: Array<\n    Promise<DynamicConfig | MinimalDynamicConfig>\n  >,\n  measurementIdToAppId: { [key: string]: string },\n  installations: FirebaseInstallations,\n  gtagCore: Gtag,\n  dataLayerName: string\n): Promise<string> {\n  const dynamicConfigPromise = fetchDynamicConfigWithRetry(app);\n  // Once fetched, map measurementIds to appId, for ease of lookup in wrapped gtag function.\n  dynamicConfigPromise\n    .then(config => {\n      measurementIdToAppId[config.measurementId] = config.appId;\n      if (\n        app.options.measurementId &&\n        config.measurementId !== app.options.measurementId\n      ) {\n        logger.warn(\n          `The measurement ID in the local Firebase config (${app.options.measurementId})` +\n            ` does not match the measurement ID fetched from the server (${config.measurementId}).` +\n            ` To ensure analytics events are always sent to the correct Analytics property,` +\n            ` update the` +\n            ` measurement ID field in the local config or remove it from the local config.`\n        );\n      }\n    })\n    .catch(e => logger.error(e));\n  // Add to list to track state of all dynamic config promises.\n  dynamicConfigPromisesList.push(dynamicConfigPromise);\n\n  const fidPromise: Promise<string | undefined> = validateIndexedDB().then(\n    envIsValid => {\n      if (envIsValid) {\n        return installations.getId();\n      } else {\n        return undefined;\n      }\n    }\n  );\n\n  const [dynamicConfig, fid] = await Promise.all([\n    dynamicConfigPromise,\n    fidPromise\n  ]);\n\n  // Detect if user has already put the gtag <script> tag on this page.\n  if (!findGtagScriptOnPage()) {\n    insertScriptTag(dataLayerName, dynamicConfig.measurementId);\n  }\n\n  // This command initializes gtag.js and only needs to be called once for the entire web app,\n  // but since it is idempotent, we can call it multiple times.\n  // We keep it together with other initialization logic for better code structure.\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  gtagCore('js' as any, new Date());\n\n  const configProperties: { [key: string]: string | boolean } = {\n    // guard against developers accidentally setting properties with prefix `firebase_`\n    [ORIGIN_KEY]: 'firebase',\n    update: true\n  };\n\n  if (fid != null) {\n    configProperties[GA_FID_KEY] = fid;\n  }\n\n  // It should be the first config command called on this GA-ID\n  // Initialize this GA-ID and set FID on it using the gtag config API.\n  // Note: This will trigger a page_view event unless 'send_page_view' is set to false in\n  // `configProperties`.\n  gtagCore(GtagCommand.CONFIG, dynamicConfig.measurementId, configProperties);\n  return dynamicConfig.measurementId;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  FirebaseAnalytics,\n  Gtag,\n  SettingsOptions,\n  DynamicConfig,\n  MinimalDynamicConfig,\n  AnalyticsCallOptions,\n  CustomParams,\n  EventParams\n} from '@firebase/analytics-types';\nimport {\n  logEvent,\n  setCurrentScreen,\n  setUserId,\n  setUserProperties,\n  setAnalyticsCollectionEnabled\n} from './functions';\nimport { getOrCreateDataLayer, wrapOrCreateGtag } from './helpers';\nimport { AnalyticsError, ERROR_FACTORY } from './errors';\nimport { FirebaseApp } from '@firebase/app-types';\nimport { FirebaseInstallations } from '@firebase/installations-types';\nimport { areCookiesEnabled, isBrowserExtension } from '@firebase/util';\nimport { initializeIds } from './initialize-ids';\nimport { logger } from './logger';\nimport { FirebaseService } from '@firebase/app-types/private';\n\ninterface FirebaseAnalyticsInternal\n  extends FirebaseAnalytics,\n    FirebaseService {}\n\n/**\n * Maps appId to full initialization promise. Wrapped gtag calls must wait on\n * all or some of these, depending on the call's `send_to` param and the status\n * of the dynamic config fetches (see below).\n */\nlet initializationPromisesMap: {\n  [appId: string]: Promise<string>; // Promise contains measurement ID string.\n} = {};\n\n/**\n * List of dynamic config fetch promises. In certain cases, wrapped gtag calls\n * wait on all these to be complete in order to determine if it can selectively\n * wait for only certain initialization (FID) promises or if it must wait for all.\n */\nlet dynamicConfigPromisesList: Array<\n  Promise<DynamicConfig | MinimalDynamicConfig>\n> = [];\n\n/**\n * Maps fetched measurementIds to appId. Populated when the app's dynamic config\n * fetch completes. If already populated, gtag config calls can use this to\n * selectively wait for only this app's initialization promise (FID) instead of all\n * initialization promises.\n */\nconst measurementIdToAppId: { [measurementId: string]: string } = {};\n\n/**\n * Name for window global data layer array used by GA: defaults to 'dataLayer'.\n */\nlet dataLayerName: string = 'dataLayer';\n\n/**\n * Name for window global gtag function used by GA: defaults to 'gtag'.\n */\nlet gtagName: string = 'gtag';\n\n/**\n * Reproduction of standard gtag function or reference to existing\n * gtag function on window object.\n */\nlet gtagCoreFunction: Gtag;\n\n/**\n * Wrapper around gtag function that ensures FID is sent with all\n * relevant event and config calls.\n */\nlet wrappedGtagFunction: Gtag;\n\n/**\n * Flag to ensure page initialization steps (creation or wrapping of\n * dataLayer and gtag script) are only run once per page load.\n */\nlet globalInitDone: boolean = false;\n\n/**\n * For testing\n */\nexport function resetGlobalVars(\n  newGlobalInitDone = false,\n  newInitializationPromisesMap = {},\n  newDynamicPromises = []\n): void {\n  globalInitDone = newGlobalInitDone;\n  initializationPromisesMap = newInitializationPromisesMap;\n  dynamicConfigPromisesList = newDynamicPromises;\n  dataLayerName = 'dataLayer';\n  gtagName = 'gtag';\n}\n\n/**\n * For testing\n */\nexport function getGlobalVars(): {\n  initializationPromisesMap: { [appId: string]: Promise<string> };\n  dynamicConfigPromisesList: Array<\n    Promise<DynamicConfig | MinimalDynamicConfig>\n  >;\n} {\n  return {\n    initializationPromisesMap,\n    dynamicConfigPromisesList\n  };\n}\n\n/**\n * This must be run before calling firebase.analytics() or it won't\n * have any effect.\n * @param options Custom gtag and dataLayer names.\n */\nexport function settings(options: SettingsOptions): void {\n  if (globalInitDone) {\n    throw ERROR_FACTORY.create(AnalyticsError.ALREADY_INITIALIZED);\n  }\n  if (options.dataLayerName) {\n    dataLayerName = options.dataLayerName;\n  }\n  if (options.gtagName) {\n    gtagName = options.gtagName;\n  }\n}\n\n/**\n * Returns true if no environment mismatch is found.\n * If environment mismatches are found, throws an INVALID_ANALYTICS_CONTEXT\n * error that also lists details for each mismatch found.\n */\nfunction warnOnBrowserContextMismatch(): void {\n  const mismatchedEnvMessages = [];\n  if (isBrowserExtension()) {\n    mismatchedEnvMessages.push('This is a browser extension environment.');\n  }\n  if (!areCookiesEnabled()) {\n    mismatchedEnvMessages.push('Cookies are not available.');\n  }\n  if (mismatchedEnvMessages.length > 0) {\n    const details = mismatchedEnvMessages\n      .map((message, index) => `(${index + 1}) ${message}`)\n      .join(' ');\n    const err = ERROR_FACTORY.create(AnalyticsError.INVALID_ANALYTICS_CONTEXT, {\n      errorInfo: details\n    });\n    logger.warn(err.message);\n  }\n}\n\nexport function factory(\n  app: FirebaseApp,\n  installations: FirebaseInstallations\n): FirebaseAnalytics {\n  warnOnBrowserContextMismatch();\n  const appId = app.options.appId;\n  if (!appId) {\n    throw ERROR_FACTORY.create(AnalyticsError.NO_APP_ID);\n  }\n  if (!app.options.apiKey) {\n    if (app.options.measurementId) {\n      logger.warn(\n        `The \"apiKey\" field is empty in the local Firebase config. This is needed to fetch the latest` +\n          ` measurement ID for this Firebase app. Falling back to the measurement ID ${app.options.measurementId}` +\n          ` provided in the \"measurementId\" field in the local Firebase config.`\n      );\n    } else {\n      throw ERROR_FACTORY.create(AnalyticsError.NO_API_KEY);\n    }\n  }\n  if (initializationPromisesMap[appId] != null) {\n    throw ERROR_FACTORY.create(AnalyticsError.ALREADY_EXISTS, {\n      id: appId\n    });\n  }\n\n  if (!globalInitDone) {\n    // Steps here should only be done once per page: creation or wrapping\n    // of dataLayer and global gtag function.\n\n    getOrCreateDataLayer(dataLayerName);\n\n    const { wrappedGtag, gtagCore } = wrapOrCreateGtag(\n      initializationPromisesMap,\n      dynamicConfigPromisesList,\n      measurementIdToAppId,\n      dataLayerName,\n      gtagName\n    );\n    wrappedGtagFunction = wrappedGtag;\n    gtagCoreFunction = gtagCore;\n\n    globalInitDone = true;\n  }\n  // Async but non-blocking.\n  // This map reflects the completion state of all promises for each appId.\n  initializationPromisesMap[appId] = initializeIds(\n    app,\n    dynamicConfigPromisesList,\n    measurementIdToAppId,\n    installations,\n    gtagCoreFunction,\n    dataLayerName\n  );\n\n  const analyticsInstance: FirebaseAnalyticsInternal = {\n    app,\n    // Public methods return void for API simplicity and to better match gtag,\n    // while internal implementations return promises.\n    logEvent: (\n      eventName: string,\n      eventParams?: EventParams | CustomParams,\n      options?: AnalyticsCallOptions\n    ) => {\n      logEvent(\n        wrappedGtagFunction,\n        initializationPromisesMap[appId],\n        eventName,\n        eventParams,\n        options\n      ).catch(e => logger.error(e));\n    },\n    setCurrentScreen: (screenName, options) => {\n      setCurrentScreen(\n        wrappedGtagFunction,\n        initializationPromisesMap[appId],\n        screenName,\n        options\n      ).catch(e => logger.error(e));\n    },\n    setUserId: (id, options) => {\n      setUserId(\n        wrappedGtagFunction,\n        initializationPromisesMap[appId],\n        id,\n        options\n      ).catch(e => logger.error(e));\n    },\n    setUserProperties: (properties, options) => {\n      setUserProperties(\n        wrappedGtagFunction,\n        initializationPromisesMap[appId],\n        properties,\n        options\n      ).catch(e => logger.error(e));\n    },\n    setAnalyticsCollectionEnabled: enabled => {\n      setAnalyticsCollectionEnabled(\n        initializationPromisesMap[appId],\n        enabled\n      ).catch(e => logger.error(e));\n    },\n    INTERNAL: {\n      delete: (): Promise<void> => {\n        delete initializationPromisesMap[appId];\n        return Promise.resolve();\n      }\n    }\n  };\n\n  return analyticsInstance;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  AnalyticsCallOptions,\n  Gtag,\n  CustomParams,\n  ControlParams,\n  EventParams\n} from '@firebase/analytics-types';\nimport { GtagCommand } from './constants';\n/**\n * Logs an analytics event through the Firebase SDK.\n *\n * @param gtagFunction Wrapped gtag function that waits for fid to be set before sending an event\n * @param eventName Google Analytics event name, choose from standard list or use a custom string.\n * @param eventParams Analytics event parameters.\n */\nexport async function logEvent(\n  gtagFunction: Gtag,\n  initializationPromise: Promise<string>,\n  eventName: string,\n  eventParams?: EventParams,\n  options?: AnalyticsCallOptions\n): Promise<void> {\n  if (options && options.global) {\n    gtagFunction(GtagCommand.EVENT, eventName, eventParams);\n    return;\n  } else {\n    const measurementId = await initializationPromise;\n    const params: EventParams | ControlParams = {\n      ...eventParams,\n      'send_to': measurementId\n    };\n    gtagFunction(GtagCommand.EVENT, eventName, params);\n  }\n}\n\n/**\n * Set screen_name parameter for this Google Analytics ID.\n *\n * @param gtagFunction Wrapped gtag function that waits for fid to be set before sending an event\n * @param screenName Screen name string to set.\n */\nexport async function setCurrentScreen(\n  gtagFunction: Gtag,\n  initializationPromise: Promise<string>,\n  screenName: string | null,\n  options?: AnalyticsCallOptions\n): Promise<void> {\n  if (options && options.global) {\n    gtagFunction(GtagCommand.SET, { 'screen_name': screenName });\n    return Promise.resolve();\n  } else {\n    const measurementId = await initializationPromise;\n    gtagFunction(GtagCommand.CONFIG, measurementId, {\n      update: true,\n      'screen_name': screenName\n    });\n  }\n}\n\n/**\n * Set user_id parameter for this Google Analytics ID.\n *\n * @param gtagFunction Wrapped gtag function that waits for fid to be set before sending an event\n * @param id User ID string to set\n */\nexport async function setUserId(\n  gtagFunction: Gtag,\n  initializationPromise: Promise<string>,\n  id: string | null,\n  options?: AnalyticsCallOptions\n): Promise<void> {\n  if (options && options.global) {\n    gtagFunction(GtagCommand.SET, { 'user_id': id });\n    return Promise.resolve();\n  } else {\n    const measurementId = await initializationPromise;\n    gtagFunction(GtagCommand.CONFIG, measurementId, {\n      update: true,\n      'user_id': id\n    });\n  }\n}\n\n/**\n * Set all other user properties other than user_id and screen_name.\n *\n * @param gtagFunction Wrapped gtag function that waits for fid to be set before sending an event\n * @param properties Map of user properties to set\n */\nexport async function setUserProperties(\n  gtagFunction: Gtag,\n  initializationPromise: Promise<string>,\n  properties: CustomParams,\n  options?: AnalyticsCallOptions\n): Promise<void> {\n  if (options && options.global) {\n    const flatProperties: { [key: string]: unknown } = {};\n    for (const key of Object.keys(properties)) {\n      // use dot notation for merge behavior in gtag.js\n      flatProperties[`user_properties.${key}`] = properties[key];\n    }\n    gtagFunction(GtagCommand.SET, flatProperties);\n    return Promise.resolve();\n  } else {\n    const measurementId = await initializationPromise;\n    gtagFunction(GtagCommand.CONFIG, measurementId, {\n      update: true,\n      'user_properties': properties\n    });\n  }\n}\n\n/**\n * Set whether collection is enabled for this ID.\n *\n * @param enabled If true, collection is enabled for this ID.\n */\nexport async function setAnalyticsCollectionEnabled(\n  initializationPromise: Promise<string>,\n  enabled: boolean\n): Promise<void> {\n  const measurementId = await initializationPromise;\n  window[`ga-disable-${measurementId}`] = !enabled;\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { StorageCache } from '../storage/storage_cache';\nimport {\n  FetchResponse,\n  RemoteConfigFetchClient,\n  FetchRequest\n} from './remote_config_fetch_client';\nimport { Storage } from '../storage/storage';\nimport { Logger } from '@firebase/logger';\n\n/**\n * Implements the {@link RemoteConfigClient} abstraction with success response caching.\n *\n * <p>Comparable to the browser's Cache API for responses, but the Cache API requires a Service\n * Worker, which requires HTTPS, which would significantly complicate SDK installation. Also, the\n * Cache API doesn't support matching entries by time.\n */\nexport class CachingClient implements RemoteConfigFetchClient {\n  constructor(\n    private readonly client: RemoteConfigFetchClient,\n    private readonly storage: Storage,\n    private readonly storageCache: StorageCache,\n    private readonly logger: Logger\n  ) {}\n\n  /**\n   * Returns true if the age of the cached fetched configs is less than or equal to\n   * {@link Settings#minimumFetchIntervalInSeconds}.\n   *\n   * <p>This is comparable to passing `headers = { 'Cache-Control': max-age <maxAge> }` to the\n   * native Fetch API.\n   *\n   * <p>Visible for testing.\n   */\n  isCachedDataFresh(\n    cacheMaxAgeMillis: number,\n    lastSuccessfulFetchTimestampMillis: number | undefined\n  ): boolean {\n    // Cache can only be fresh if it's populated.\n    if (!lastSuccessfulFetchTimestampMillis) {\n      this.logger.debug('Config fetch cache check. Cache unpopulated.');\n      return false;\n    }\n\n    // Calculates age of cache entry.\n    const cacheAgeMillis = Date.now() - lastSuccessfulFetchTimestampMillis;\n\n    const isCachedDataFresh = cacheAgeMillis <= cacheMaxAgeMillis;\n\n    this.logger.debug(\n      'Config fetch cache check.' +\n        ` Cache age millis: ${cacheAgeMillis}.` +\n        ` Cache max age millis (minimumFetchIntervalMillis setting): ${cacheMaxAgeMillis}.` +\n        ` Is cache hit: ${isCachedDataFresh}.`\n    );\n\n    return isCachedDataFresh;\n  }\n\n  async fetch(request: FetchRequest): Promise<FetchResponse> {\n    // Reads from persisted storage to avoid cache miss if callers don't wait on initialization.\n    const [\n      lastSuccessfulFetchTimestampMillis,\n      lastSuccessfulFetchResponse\n    ] = await Promise.all([\n      this.storage.getLastSuccessfulFetchTimestampMillis(),\n      this.storage.getLastSuccessfulFetchResponse()\n    ]);\n\n    // Exits early on cache hit.\n    if (\n      lastSuccessfulFetchResponse &&\n      this.isCachedDataFresh(\n        request.cacheMaxAgeMillis,\n        lastSuccessfulFetchTimestampMillis\n      )\n    ) {\n      return lastSuccessfulFetchResponse;\n    }\n\n    // Deviates from pure decorator by not honoring a passed ETag since we don't have a public API\n    // that allows the caller to pass an ETag.\n    request.eTag =\n      lastSuccessfulFetchResponse && lastSuccessfulFetchResponse.eTag;\n\n    // Falls back to service on cache miss.\n    const response = await this.client.fetch(request);\n\n    // Fetch throws for non-success responses, so success is guaranteed here.\n\n    const storageOperations = [\n      // Uses write-through cache for consistency with synchronous public API.\n      this.storageCache.setLastSuccessfulFetchTimestampMillis(Date.now())\n    ];\n\n    if (response.status === 200) {\n      // Caches response only if it has changed, ie non-304 responses.\n      storageOperations.push(\n        this.storage.setLastSuccessfulFetchResponse(response)\n      );\n    }\n\n    await Promise.all(storageOperations);\n\n    return response;\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FirebaseInstallations } from '@firebase/installations-types';\nimport {\n  FetchResponse,\n  RemoteConfigFetchClient,\n  FirebaseRemoteConfigObject,\n  FetchRequest\n} from './remote_config_fetch_client';\nimport { ERROR_FACTORY, ErrorCode } from '../errors';\nimport { getUserLanguage } from '../language';\n\n/**\n * Defines request body parameters required to call the fetch API:\n * https://firebase.google.com/docs/reference/remote-config/rest\n *\n * <p>Not exported because this file encapsulates REST API specifics.\n *\n * <p>Not passing User Properties because Analytics' source of truth on Web is server-side.\n */\ninterface FetchRequestBody {\n  // Disables camelcase linting for request body params.\n  /* eslint-disable camelcase*/\n  sdk_version: string;\n  app_instance_id: string;\n  app_instance_id_token: string;\n  app_id: string;\n  language_code: string;\n  /* eslint-enable camelcase */\n}\n\n/**\n * Implements the Client abstraction for the Remote Config REST API.\n */\nexport class RestClient implements RemoteConfigFetchClient {\n  constructor(\n    private readonly firebaseInstallations: FirebaseInstallations,\n    private readonly sdkVersion: string,\n    private readonly namespace: string,\n    private readonly projectId: string,\n    private readonly apiKey: string,\n    private readonly appId: string\n  ) {}\n\n  /**\n   * Fetches from the Remote Config REST API.\n   *\n   * @throws a {@link ErrorCode.FETCH_NETWORK} error if {@link GlobalFetch#fetch} can't\n   * connect to the network.\n   * @throws a {@link ErrorCode.FETCH_PARSE} error if {@link Response#json} can't parse the\n   * fetch response.\n   * @throws a {@link ErrorCode.FETCH_STATUS} error if the service returns an HTTP error status.\n   */\n  async fetch(request: FetchRequest): Promise<FetchResponse> {\n    const [installationId, installationToken] = await Promise.all([\n      this.firebaseInstallations.getId(),\n      this.firebaseInstallations.getToken()\n    ]);\n\n    const urlBase =\n      window.FIREBASE_REMOTE_CONFIG_URL_BASE ||\n      'https://firebaseremoteconfig.googleapis.com';\n\n    const url = `${urlBase}/v1/projects/${this.projectId}/namespaces/${this.namespace}:fetch?key=${this.apiKey}`;\n\n    const headers = {\n      'Content-Type': 'application/json',\n      'Content-Encoding': 'gzip',\n      // Deviates from pure decorator by not passing max-age header since we don't currently have\n      // service behavior using that header.\n      'If-None-Match': request.eTag || '*'\n    };\n\n    const requestBody: FetchRequestBody = {\n      /* eslint-disable camelcase */\n      sdk_version: this.sdkVersion,\n      app_instance_id: installationId,\n      app_instance_id_token: installationToken,\n      app_id: this.appId,\n      language_code: getUserLanguage()\n      /* eslint-enable camelcase */\n    };\n\n    const options = {\n      method: 'POST',\n      headers,\n      body: JSON.stringify(requestBody)\n    };\n\n    // This logic isn't REST-specific, but shimming abort logic isn't worth another decorator.\n    const fetchPromise = fetch(url, options);\n    const timeoutPromise = new Promise((_resolve, reject) => {\n      // Maps async event listener to Promise API.\n      request.signal.addEventListener(() => {\n        // Emulates https://heycam.github.io/webidl/#aborterror\n        const error = new Error('The operation was aborted.');\n        error.name = 'AbortError';\n        reject(error);\n      });\n    });\n\n    let response;\n    try {\n      await Promise.race([fetchPromise, timeoutPromise]);\n      response = await fetchPromise;\n    } catch (originalError) {\n      let errorCode = ErrorCode.FETCH_NETWORK;\n      if (originalError.name === 'AbortError') {\n        errorCode = ErrorCode.FETCH_TIMEOUT;\n      }\n      throw ERROR_FACTORY.create(errorCode, {\n        originalErrorMessage: originalError.message\n      });\n    }\n\n    let status = response.status;\n\n    // Normalizes nullable header to optional.\n    const responseEtag = response.headers.get('ETag') || undefined;\n\n    let config: FirebaseRemoteConfigObject | undefined;\n    let state: string | undefined;\n\n    // JSON parsing throws SyntaxError if the response body isn't a JSON string.\n    // Requesting application/json and checking for a 200 ensures there's JSON data.\n    if (response.status === 200) {\n      let responseBody;\n      try {\n        responseBody = await response.json();\n      } catch (originalError) {\n        throw ERROR_FACTORY.create(ErrorCode.FETCH_PARSE, {\n          originalErrorMessage: originalError.message\n        });\n      }\n      config = responseBody['entries'];\n      state = responseBody['state'];\n    }\n\n    // Normalizes based on legacy state.\n    if (state === 'INSTANCE_STATE_UNSPECIFIED') {\n      status = 500;\n    } else if (state === 'NO_CHANGE') {\n      status = 304;\n    } else if (state === 'NO_TEMPLATE' || state === 'EMPTY_CONFIG') {\n      // These cases can be fixed remotely, so normalize to safe value.\n      config = {};\n    }\n\n    // Normalize to exception-based control flow for non-success cases.\n    // Encapsulates HTTP specifics in this class as much as possible. Status is still the best for\n    // differentiating success states (200 from 304; the state body param is undefined in a\n    // standard 304).\n    if (status !== 304 && status !== 200) {\n      throw ERROR_FACTORY.create(ErrorCode.FETCH_STATUS, {\n        httpStatus: status\n      });\n    }\n\n    return { status, eTag: responseEtag, config };\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Attempts to get the most accurate browser language setting.\n *\n * <p>Adapted from getUserLanguage in packages/auth/src/utils.js for TypeScript.\n *\n * <p>Defers default language specification to server logic for consistency.\n *\n * @param navigatorLanguage Enables tests to override read-only {@link NavigatorLanguage}.\n */\nexport function getUserLanguage(\n  navigatorLanguage: NavigatorLanguage = navigator\n): string {\n  return (\n    // Most reliable, but only supported in Chrome/Firefox.\n    (navigatorLanguage.languages && navigatorLanguage.languages[0]) ||\n    // Supported in most browsers, but returns the language of the browser\n    // UI, not the language set in browser settings.\n    navigatorLanguage.language\n    // Polyfill otherwise.\n  );\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * Defines a client, as in https://en.wikipedia.org/wiki/Client%E2%80%93server_model, for the\n * Remote Config server (https://firebase.google.com/docs/reference/remote-config/rest).\n *\n * <p>Abstracts throttle, response cache and network implementation details.\n *\n * <p>Modeled after the native {@link GlobalFetch} interface, which is relatively modern and\n * convenient, but simplified for Remote Config's use case.\n *\n * Disambiguation: {@link GlobalFetch} interface and the Remote Config service define \"fetch\"\n * methods. The RestClient uses the former to make HTTP calls. This interface abstracts the latter.\n */\nexport interface RemoteConfigFetchClient {\n  /**\n   * @throws if response status is not 200 or 304.\n   */\n  fetch(request: FetchRequest): Promise<FetchResponse>;\n}\n\n/**\n * Defines a self-descriptive reference for config key-value pairs.\n */\nexport interface FirebaseRemoteConfigObject {\n  [key: string]: string;\n}\n\n/**\n * Shims a minimal AbortSignal.\n *\n * <p>AbortController's AbortSignal conveniently decouples fetch timeout logic from other aspects\n * of networking, such as retries. Firebase doesn't use AbortController enough to justify a\n * polyfill recommendation, like we do with the Fetch API, but this minimal shim can easily be\n * swapped out if/when we do.\n */\nexport class RemoteConfigAbortSignal {\n  listeners: Array<() => void> = [];\n  addEventListener(listener: () => void): void {\n    this.listeners.push(listener);\n  }\n  abort(): void {\n    this.listeners.forEach(listener => listener());\n  }\n}\n\n/**\n * Defines per-request inputs for the Remote Config fetch request.\n *\n * <p>Modeled after the native {@link Request} interface, but simplified for Remote Config's\n * use case.\n */\nexport interface FetchRequest {\n  /**\n   * Uses cached config if it is younger than this age.\n   *\n   * <p>Required because it's defined by settings, which always have a value.\n   *\n   * <p>Comparable to passing `headers = { 'Cache-Control': max-age <maxAge> }` to the native\n   * Fetch API.\n   */\n  cacheMaxAgeMillis: number;\n\n  /**\n   * An event bus for the signal to abort a request.\n   *\n   * <p>Required because all requests should be abortable.\n   *\n   * <p>Comparable to the native\n   * Fetch API's \"signal\" field on its request configuration object\n   * https://fetch.spec.whatwg.org/#dom-requestinit-signal.\n   *\n   * <p>Disambiguation: Remote Config commonly refers to API inputs as\n   * \"signals\". See the private ConfigFetchRequestBody interface for those:\n   * http://google3/firebase/remote_config/web/src/core/rest_client.ts?l=14&rcl=255515243.\n   */\n  signal: RemoteConfigAbortSignal;\n\n  /**\n   * The ETag header value from the last response.\n   *\n   * <p>Optional in case this is the first request.\n   *\n   * <p>Comparable to passing `headers = { 'If-None-Match': <eTag> }` to the native Fetch API.\n   */\n  eTag?: string;\n}\n\n/**\n * Defines a successful response (200 or 304).\n *\n * <p>Modeled after the native {@link Response} interface, but simplified for Remote Config's\n * use case.\n */\nexport interface FetchResponse {\n  /**\n   * The HTTP status, which is useful for differentiating success responses with data from\n   * those without.\n   *\n   * <p>{@link RemoteConfigClient} is modeled after the native {@link GlobalFetch} interface, so\n   * HTTP status is first-class.\n   *\n   * <p>Disambiguation: the fetch response returns a legacy \"state\" value that is redundant with the\n   * HTTP status code. The former is normalized into the latter.\n   */\n  status: number;\n\n  /**\n   * Defines the ETag response header value.\n   *\n   * <p>Only defined for 200 and 304 responses.\n   */\n  eTag?: string;\n\n  /**\n   * Defines the map of parameters returned as \"entries\" in the fetch response body.\n   *\n   * <p>Only defined for 200 responses.\n   */\n  config?: FirebaseRemoteConfigObject;\n\n  // Note: we're not extracting experiment metadata until\n  // ABT and Analytics have Web SDKs.\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Value as ValueType, ValueSource } from '@firebase/remote-config-types';\n\nconst DEFAULT_VALUE_FOR_BOOLEAN = false;\nconst DEFAULT_VALUE_FOR_STRING = '';\nconst DEFAULT_VALUE_FOR_NUMBER = 0;\n\nconst BOOLEAN_TRUTHY_VALUES = ['1', 'true', 't', 'yes', 'y', 'on'];\n\nexport class Value implements ValueType {\n  constructor(\n    private readonly _source: ValueSource,\n    private readonly _value: string = DEFAULT_VALUE_FOR_STRING\n  ) {}\n\n  asString(): string {\n    return this._value;\n  }\n\n  asBoolean(): boolean {\n    if (this._source === 'static') {\n      return DEFAULT_VALUE_FOR_BOOLEAN;\n    }\n    return BOOLEAN_TRUTHY_VALUES.indexOf(this._value.toLowerCase()) >= 0;\n  }\n\n  asNumber(): number {\n    if (this._source === 'static') {\n      return DEFAULT_VALUE_FOR_NUMBER;\n    }\n    let num = Number(this._value);\n    if (isNaN(num)) {\n      num = DEFAULT_VALUE_FOR_NUMBER;\n    }\n    return num;\n  }\n\n  getSource(): ValueSource {\n    return this._source;\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FirebaseApp } from '@firebase/app-types';\nimport {\n  RemoteConfig as RemoteConfigType,\n  FetchStatus,\n  Settings,\n  Value as ValueType,\n  LogLevel as RemoteConfigLogLevel\n} from '@firebase/remote-config-types';\nimport { StorageCache } from './storage/storage_cache';\nimport {\n  RemoteConfigFetchClient,\n  RemoteConfigAbortSignal\n} from './client/remote_config_fetch_client';\nimport { Value } from './value';\nimport { ErrorCode, hasErrorCode } from './errors';\nimport { Storage } from './storage/storage';\nimport { Logger, LogLevel as FirebaseLogLevel } from '@firebase/logger';\n\nconst DEFAULT_FETCH_TIMEOUT_MILLIS = 60 * 1000; // One minute\nconst DEFAULT_CACHE_MAX_AGE_MILLIS = 12 * 60 * 60 * 1000; // Twelve hours.\n\n/**\n * Encapsulates business logic mapping network and storage dependencies to the public SDK API.\n *\n * See {@link https://github.com/FirebasePrivate/firebase-js-sdk/blob/master/packages/firebase/index.d.ts|interface documentation} for method descriptions.\n */\nexport class RemoteConfig implements RemoteConfigType {\n  // Tracks completion of initialization promise.\n  private _isInitializationComplete = false;\n\n  // De-duplicates initialization calls.\n  private _initializePromise?: Promise<void>;\n\n  settings: Settings = {\n    fetchTimeoutMillis: DEFAULT_FETCH_TIMEOUT_MILLIS,\n    minimumFetchIntervalMillis: DEFAULT_CACHE_MAX_AGE_MILLIS\n  };\n\n  defaultConfig: { [key: string]: string | number | boolean } = {};\n\n  // Based on packages/firestore/src/util/log.ts but not static because we need per-instance levels\n  // to differentiate 2p and 3p use-cases.\n  setLogLevel(logLevel: RemoteConfigLogLevel): void {\n    switch (logLevel) {\n      case 'debug':\n        this._logger.logLevel = FirebaseLogLevel.DEBUG;\n        break;\n      case 'silent':\n        this._logger.logLevel = FirebaseLogLevel.SILENT;\n        break;\n      default:\n        this._logger.logLevel = FirebaseLogLevel.ERROR;\n    }\n  }\n\n  get fetchTimeMillis(): number {\n    return this._storageCache.getLastSuccessfulFetchTimestampMillis() || -1;\n  }\n\n  get lastFetchStatus(): FetchStatus {\n    return this._storageCache.getLastFetchStatus() || 'no-fetch-yet';\n  }\n\n  constructor(\n    // Required by FirebaseServiceFactory interface.\n    readonly app: FirebaseApp,\n    // JS doesn't support private yet\n    // (https://github.com/tc39/proposal-class-fields#private-fields), so we hint using an\n    // underscore prefix.\n    private readonly _client: RemoteConfigFetchClient,\n    private readonly _storageCache: StorageCache,\n    private readonly _storage: Storage,\n    private readonly _logger: Logger\n  ) {}\n\n  async activate(): Promise<boolean> {\n    const [lastSuccessfulFetchResponse, activeConfigEtag] = await Promise.all([\n      this._storage.getLastSuccessfulFetchResponse(),\n      this._storage.getActiveConfigEtag()\n    ]);\n    if (\n      !lastSuccessfulFetchResponse ||\n      !lastSuccessfulFetchResponse.config ||\n      !lastSuccessfulFetchResponse.eTag ||\n      lastSuccessfulFetchResponse.eTag === activeConfigEtag\n    ) {\n      // Either there is no successful fetched config, or is the same as current active\n      // config.\n      return false;\n    }\n    await Promise.all([\n      this._storageCache.setActiveConfig(lastSuccessfulFetchResponse.config),\n      this._storage.setActiveConfigEtag(lastSuccessfulFetchResponse.eTag)\n    ]);\n    return true;\n  }\n\n  ensureInitialized(): Promise<void> {\n    if (!this._initializePromise) {\n      this._initializePromise = this._storageCache\n        .loadFromStorage()\n        .then(() => {\n          this._isInitializationComplete = true;\n        });\n    }\n    return this._initializePromise;\n  }\n\n  /**\n   * @throws a {@link ErrorCode.FETCH_CLIENT_TIMEOUT} if the request takes longer than\n   * {@link Settings.fetchTimeoutInSeconds} or\n   * {@link DEFAULT_FETCH_TIMEOUT_SECONDS}.\n   */\n  async fetch(): Promise<void> {\n    // Aborts the request after the given timeout, causing the fetch call to\n    // reject with an AbortError.\n    //\n    // <p>Aborting after the request completes is a no-op, so we don't need a\n    // corresponding clearTimeout.\n    //\n    // Locating abort logic here because:\n    // * it uses a developer setting (timeout)\n    // * it applies to all retries (like curl's max-time arg)\n    // * it is consistent with the Fetch API's signal input\n    const abortSignal = new RemoteConfigAbortSignal();\n\n    setTimeout(async () => {\n      // Note a very low delay, eg < 10ms, can elapse before listeners are initialized.\n      abortSignal.abort();\n    }, this.settings.fetchTimeoutMillis);\n\n    // Catches *all* errors thrown by client so status can be set consistently.\n    try {\n      await this._client.fetch({\n        cacheMaxAgeMillis: this.settings.minimumFetchIntervalMillis,\n        signal: abortSignal\n      });\n\n      await this._storageCache.setLastFetchStatus('success');\n    } catch (e) {\n      const lastFetchStatus = hasErrorCode(e, ErrorCode.FETCH_THROTTLE)\n        ? 'throttle'\n        : 'failure';\n      await this._storageCache.setLastFetchStatus(lastFetchStatus);\n      throw e;\n    }\n  }\n\n  async fetchAndActivate(): Promise<boolean> {\n    await this.fetch();\n    return this.activate();\n  }\n\n  getAll(): { [key: string]: ValueType } {\n    return getAllKeys(\n      this._storageCache.getActiveConfig(),\n      this.defaultConfig\n    ).reduce((allConfigs, key) => {\n      allConfigs[key] = this.getValue(key);\n      return allConfigs;\n    }, {} as { [key: string]: ValueType });\n  }\n\n  getBoolean(key: string): boolean {\n    return this.getValue(key).asBoolean();\n  }\n\n  getNumber(key: string): number {\n    return this.getValue(key).asNumber();\n  }\n\n  getString(key: string): string {\n    return this.getValue(key).asString();\n  }\n\n  getValue(key: string): ValueType {\n    if (!this._isInitializationComplete) {\n      this._logger.debug(\n        `A value was requested for key \"${key}\" before SDK initialization completed.` +\n          ' Await on ensureInitialized if the intent was to get a previously activated value.'\n      );\n    }\n    const activeConfig = this._storageCache.getActiveConfig();\n    if (activeConfig && activeConfig[key] !== undefined) {\n      return new Value('remote', activeConfig[key]);\n    } else if (this.defaultConfig && this.defaultConfig[key] !== undefined) {\n      return new Value('default', String(this.defaultConfig[key]));\n    }\n    this._logger.debug(\n      `Returning static value for key \"${key}\".` +\n        ' Define a default or remote value if this is unintentional.'\n    );\n    return new Value('static');\n  }\n}\n\n/**\n * Dedupes and returns an array of all the keys of the received objects.\n */\nfunction getAllKeys(obj1: {} = {}, obj2: {} = {}): string[] {\n  return Object.keys({ ...obj1, ...obj2 });\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FetchStatus } from '@firebase/remote-config-types';\nimport {\n  FetchResponse,\n  FirebaseRemoteConfigObject\n} from '../client/remote_config_fetch_client';\nimport { ERROR_FACTORY, ErrorCode } from '../errors';\nimport { FirebaseError } from '@firebase/util';\n\n/**\n * Converts an error event associated with a {@link IDBRequest} to a {@link FirebaseError}.\n */\nfunction toFirebaseError(event: Event, errorCode: ErrorCode): FirebaseError {\n  const originalError = (event.target as IDBRequest).error || undefined;\n  return ERROR_FACTORY.create(errorCode, {\n    originalErrorMessage: originalError && originalError.message\n  });\n}\n\n/**\n * A general-purpose store keyed by app + namespace + {@link\n * ProjectNamespaceKeyFieldValue}.\n *\n * <p>The Remote Config SDK can be used with multiple app installations, and each app can interact\n * with multiple namespaces, so this store uses app (ID + name) and namespace as common parent keys\n * for a set of key-value pairs. See {@link Storage#createCompositeKey}.\n *\n * <p>Visible for testing.\n */\nexport const APP_NAMESPACE_STORE = 'app_namespace_store';\n\nconst DB_NAME = 'firebase_remote_config';\nconst DB_VERSION = 1;\n\n/**\n * Encapsulates metadata concerning throttled fetch requests.\n */\nexport interface ThrottleMetadata {\n  // The number of times fetch has backed off. Used for resuming backoff after a timeout.\n  backoffCount: number;\n  // The Unix timestamp in milliseconds when callers can retry a request.\n  throttleEndTimeMillis: number;\n}\n\n/**\n * Provides type-safety for the \"key\" field used by {@link APP_NAMESPACE_STORE}.\n *\n * <p>This seems like a small price to avoid potentially subtle bugs caused by a typo.\n */\ntype ProjectNamespaceKeyFieldValue =\n  | 'active_config'\n  | 'active_config_etag'\n  | 'last_fetch_status'\n  | 'last_successful_fetch_timestamp_millis'\n  | 'last_successful_fetch_response'\n  | 'settings'\n  | 'throttle_metadata';\n\n// Visible for testing.\nexport function openDatabase(): Promise<IDBDatabase> {\n  return new Promise((resolve, reject) => {\n    const request = indexedDB.open(DB_NAME, DB_VERSION);\n    request.onerror = event => {\n      reject(toFirebaseError(event, ErrorCode.STORAGE_OPEN));\n    };\n    request.onsuccess = event => {\n      resolve((event.target as IDBOpenDBRequest).result);\n    };\n    request.onupgradeneeded = event => {\n      const db = (event.target as IDBOpenDBRequest).result;\n\n      // We don't use 'break' in this switch statement, the fall-through\n      // behavior is what we want, because if there are multiple versions between\n      // the old version and the current version, we want ALL the migrations\n      // that correspond to those versions to run, not only the last one.\n      // eslint-disable-next-line default-case\n      switch (event.oldVersion) {\n        case 0:\n          db.createObjectStore(APP_NAMESPACE_STORE, {\n            keyPath: 'compositeKey'\n          });\n      }\n    };\n  });\n}\n\n/**\n * Abstracts data persistence.\n */\nexport class Storage {\n  /**\n   * @param appId enables storage segmentation by app (ID + name).\n   * @param appName enables storage segmentation by app (ID + name).\n   * @param namespace enables storage segmentation by namespace.\n   */\n  constructor(\n    private readonly appId: string,\n    private readonly appName: string,\n    private readonly namespace: string,\n    private readonly openDbPromise = openDatabase()\n  ) {}\n\n  getLastFetchStatus(): Promise<FetchStatus | undefined> {\n    return this.get<FetchStatus>('last_fetch_status');\n  }\n\n  setLastFetchStatus(status: FetchStatus): Promise<void> {\n    return this.set<FetchStatus>('last_fetch_status', status);\n  }\n\n  // This is comparable to a cache entry timestamp. If we need to expire other data, we could\n  // consider adding timestamp to all storage records and an optional max age arg to getters.\n  getLastSuccessfulFetchTimestampMillis(): Promise<number | undefined> {\n    return this.get<number>('last_successful_fetch_timestamp_millis');\n  }\n\n  setLastSuccessfulFetchTimestampMillis(timestamp: number): Promise<void> {\n    return this.set<number>(\n      'last_successful_fetch_timestamp_millis',\n      timestamp\n    );\n  }\n\n  getLastSuccessfulFetchResponse(): Promise<FetchResponse | undefined> {\n    return this.get<FetchResponse>('last_successful_fetch_response');\n  }\n\n  setLastSuccessfulFetchResponse(response: FetchResponse): Promise<void> {\n    return this.set<FetchResponse>('last_successful_fetch_response', response);\n  }\n\n  getActiveConfig(): Promise<FirebaseRemoteConfigObject | undefined> {\n    return this.get<FirebaseRemoteConfigObject>('active_config');\n  }\n\n  setActiveConfig(config: FirebaseRemoteConfigObject): Promise<void> {\n    return this.set<FirebaseRemoteConfigObject>('active_config', config);\n  }\n\n  getActiveConfigEtag(): Promise<string | undefined> {\n    return this.get<string>('active_config_etag');\n  }\n\n  setActiveConfigEtag(etag: string): Promise<void> {\n    return this.set<string>('active_config_etag', etag);\n  }\n\n  getThrottleMetadata(): Promise<ThrottleMetadata | undefined> {\n    return this.get<ThrottleMetadata>('throttle_metadata');\n  }\n\n  setThrottleMetadata(metadata: ThrottleMetadata): Promise<void> {\n    return this.set<ThrottleMetadata>('throttle_metadata', metadata);\n  }\n\n  deleteThrottleMetadata(): Promise<void> {\n    return this.delete('throttle_metadata');\n  }\n\n  async get<T>(key: ProjectNamespaceKeyFieldValue): Promise<T | undefined> {\n    const db = await this.openDbPromise;\n    return new Promise((resolve, reject) => {\n      const transaction = db.transaction([APP_NAMESPACE_STORE], 'readonly');\n      const objectStore = transaction.objectStore(APP_NAMESPACE_STORE);\n      const compositeKey = this.createCompositeKey(key);\n      try {\n        const request = objectStore.get(compositeKey);\n        request.onerror = event => {\n          reject(toFirebaseError(event, ErrorCode.STORAGE_GET));\n        };\n        request.onsuccess = event => {\n          const result = (event.target as IDBRequest).result;\n          if (result) {\n            resolve(result.value);\n          } else {\n            resolve(undefined);\n          }\n        };\n      } catch (e) {\n        reject(\n          ERROR_FACTORY.create(ErrorCode.STORAGE_GET, {\n            originalErrorMessage: e && e.message\n          })\n        );\n      }\n    });\n  }\n\n  async set<T>(key: ProjectNamespaceKeyFieldValue, value: T): Promise<void> {\n    const db = await this.openDbPromise;\n    return new Promise((resolve, reject) => {\n      const transaction = db.transaction([APP_NAMESPACE_STORE], 'readwrite');\n      const objectStore = transaction.objectStore(APP_NAMESPACE_STORE);\n      const compositeKey = this.createCompositeKey(key);\n      try {\n        const request = objectStore.put({\n          compositeKey,\n          value\n        });\n        request.onerror = (event: Event) => {\n          reject(toFirebaseError(event, ErrorCode.STORAGE_SET));\n        };\n        request.onsuccess = () => {\n          resolve();\n        };\n      } catch (e) {\n        reject(\n          ERROR_FACTORY.create(ErrorCode.STORAGE_SET, {\n            originalErrorMessage: e && e.message\n          })\n        );\n      }\n    });\n  }\n\n  async delete(key: ProjectNamespaceKeyFieldValue): Promise<void> {\n    const db = await this.openDbPromise;\n    return new Promise((resolve, reject) => {\n      const transaction = db.transaction([APP_NAMESPACE_STORE], 'readwrite');\n      const objectStore = transaction.objectStore(APP_NAMESPACE_STORE);\n      const compositeKey = this.createCompositeKey(key);\n      try {\n        const request = objectStore.delete(compositeKey);\n        request.onerror = (event: Event) => {\n          reject(toFirebaseError(event, ErrorCode.STORAGE_DELETE));\n        };\n        request.onsuccess = () => {\n          resolve();\n        };\n      } catch (e) {\n        reject(\n          ERROR_FACTORY.create(ErrorCode.STORAGE_DELETE, {\n            originalErrorMessage: e && e.message\n          })\n        );\n      }\n    });\n  }\n\n  // Facilitates composite key functionality (which is unsupported in IE).\n  createCompositeKey(key: ProjectNamespaceKeyFieldValue): string {\n    return [this.appId, this.appName, this.namespace, key].join();\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FetchStatus } from '@firebase/remote-config-types';\nimport { FirebaseRemoteConfigObject } from '../client/remote_config_fetch_client';\nimport { Storage } from './storage';\n\n/**\n * A memory cache layer over storage to support the SDK's synchronous read requirements.\n */\nexport class StorageCache {\n  constructor(private readonly storage: Storage) {}\n\n  /**\n   * Memory caches.\n   */\n  private lastFetchStatus?: FetchStatus;\n  private lastSuccessfulFetchTimestampMillis?: number;\n  private activeConfig?: FirebaseRemoteConfigObject;\n\n  /**\n   * Memory-only getters\n   */\n  getLastFetchStatus(): FetchStatus | undefined {\n    return this.lastFetchStatus;\n  }\n\n  getLastSuccessfulFetchTimestampMillis(): number | undefined {\n    return this.lastSuccessfulFetchTimestampMillis;\n  }\n\n  getActiveConfig(): FirebaseRemoteConfigObject | undefined {\n    return this.activeConfig;\n  }\n\n  /**\n   * Read-ahead getter\n   */\n  async loadFromStorage(): Promise<void> {\n    const lastFetchStatusPromise = this.storage.getLastFetchStatus();\n    const lastSuccessfulFetchTimestampMillisPromise = this.storage.getLastSuccessfulFetchTimestampMillis();\n    const activeConfigPromise = this.storage.getActiveConfig();\n\n    // Note:\n    // 1. we consistently check for undefined to avoid clobbering defined values\n    //   in memory\n    // 2. we defer awaiting to improve readability, as opposed to destructuring\n    //   a Promise.all result, for example\n\n    const lastFetchStatus = await lastFetchStatusPromise;\n    if (lastFetchStatus) {\n      this.lastFetchStatus = lastFetchStatus;\n    }\n\n    const lastSuccessfulFetchTimestampMillis = await lastSuccessfulFetchTimestampMillisPromise;\n    if (lastSuccessfulFetchTimestampMillis) {\n      this.lastSuccessfulFetchTimestampMillis = lastSuccessfulFetchTimestampMillis;\n    }\n\n    const activeConfig = await activeConfigPromise;\n    if (activeConfig) {\n      this.activeConfig = activeConfig;\n    }\n  }\n\n  /**\n   * Write-through setters\n   */\n  setLastFetchStatus(status: FetchStatus): Promise<void> {\n    this.lastFetchStatus = status;\n    return this.storage.setLastFetchStatus(status);\n  }\n\n  setLastSuccessfulFetchTimestampMillis(\n    timestampMillis: number\n  ): Promise<void> {\n    this.lastSuccessfulFetchTimestampMillis = timestampMillis;\n    return this.storage.setLastSuccessfulFetchTimestampMillis(timestampMillis);\n  }\n\n  setActiveConfig(activeConfig: FirebaseRemoteConfigObject): Promise<void> {\n    this.activeConfig = activeConfig;\n    return this.storage.setActiveConfig(activeConfig);\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  RemoteConfigAbortSignal,\n  RemoteConfigFetchClient,\n  FetchResponse,\n  FetchRequest\n} from './remote_config_fetch_client';\nimport { ThrottleMetadata, Storage } from '../storage/storage';\nimport { ErrorCode, ERROR_FACTORY } from '../errors';\nimport { FirebaseError, calculateBackoffMillis } from '@firebase/util';\n\n/**\n * Supports waiting on a backoff by:\n *\n * <ul>\n *   <li>Promisifying setTimeout, so we can set a timeout in our Promise chain</li>\n *   <li>Listening on a signal bus for abort events, just like the Fetch API</li>\n *   <li>Failing in the same way the Fetch API fails, so timing out a live request and a throttled\n *       request appear the same.</li>\n * </ul>\n *\n * <p>Visible for testing.\n */\nexport function setAbortableTimeout(\n  signal: RemoteConfigAbortSignal,\n  throttleEndTimeMillis: number\n): Promise<void> {\n  return new Promise((resolve, reject) => {\n    // Derives backoff from given end time, normalizing negative numbers to zero.\n    const backoffMillis = Math.max(throttleEndTimeMillis - Date.now(), 0);\n\n    const timeout = setTimeout(resolve, backoffMillis);\n\n    // Adds listener, rather than sets onabort, because signal is a shared object.\n    signal.addEventListener(() => {\n      clearTimeout(timeout);\n\n      // If the request completes before this timeout, the rejection has no effect.\n      reject(\n        ERROR_FACTORY.create(ErrorCode.FETCH_THROTTLE, {\n          throttleEndTimeMillis\n        })\n      );\n    });\n  });\n}\n\ntype RetriableError = FirebaseError & { customData: { httpStatus: string } };\n/**\n * Returns true if the {@link Error} indicates a fetch request may succeed later.\n */\nfunction isRetriableError(e: Error): e is RetriableError {\n  if (!(e instanceof FirebaseError) || !e.customData) {\n    return false;\n  }\n\n  // Uses string index defined by ErrorData, which FirebaseError implements.\n  const httpStatus = Number(e.customData['httpStatus']);\n\n  return (\n    httpStatus === 429 ||\n    httpStatus === 500 ||\n    httpStatus === 503 ||\n    httpStatus === 504\n  );\n}\n\n/**\n * Decorates a Client with retry logic.\n *\n * <p>Comparable to CachingClient, but uses backoff logic instead of cache max age and doesn't cache\n * responses (because the SDK has no use for error responses).\n */\nexport class RetryingClient implements RemoteConfigFetchClient {\n  constructor(\n    private readonly client: RemoteConfigFetchClient,\n    private readonly storage: Storage\n  ) {}\n\n  async fetch(request: FetchRequest): Promise<FetchResponse> {\n    const throttleMetadata = (await this.storage.getThrottleMetadata()) || {\n      backoffCount: 0,\n      throttleEndTimeMillis: Date.now()\n    };\n\n    return this.attemptFetch(request, throttleMetadata);\n  }\n\n  /**\n   * A recursive helper for attempting a fetch request repeatedly.\n   *\n   * @throws any non-retriable errors.\n   */\n  async attemptFetch(\n    request: FetchRequest,\n    { throttleEndTimeMillis, backoffCount }: ThrottleMetadata\n  ): Promise<FetchResponse> {\n    // Starts with a (potentially zero) timeout to support resumption from stored state.\n    // Ensures the throttle end time is honored if the last attempt timed out.\n    // Note the SDK will never make a request if the fetch timeout expires at this point.\n    await setAbortableTimeout(request.signal, throttleEndTimeMillis);\n\n    try {\n      const response = await this.client.fetch(request);\n\n      // Note the SDK only clears throttle state if response is success or non-retriable.\n      await this.storage.deleteThrottleMetadata();\n\n      return response;\n    } catch (e) {\n      if (!isRetriableError(e)) {\n        throw e;\n      }\n\n      // Increments backoff state.\n      const throttleMetadata = {\n        throttleEndTimeMillis:\n          Date.now() + calculateBackoffMillis(backoffCount),\n        backoffCount: backoffCount + 1\n      };\n\n      // Persists state.\n      await this.storage.setThrottleMetadata(throttleMetadata);\n\n      return this.attemptFetch(request, throttleMetadata);\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport firebase from '@firebase/app';\nimport { name, version } from '../package.json';\n\nfirebase.registerVersion(name, version, 'app');\n\nexport default firebase;\n","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.DefaultToast = exports.shrinkKeyframes = exports.toastWidth = exports.gutter = exports.borderRadius = undefined;\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar _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; };\n\nvar _templateObject = _taggedTemplateLiteral(['from { height: 100%; } to { height: 0% }'], ['from { height: 100%; } to { height: 0% }']);\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _core = require('@emotion/core');\n\nvar _icons = require('./icons');\n\nvar _colors = require('./colors');\n\nvar colors = _interopRequireWildcard(_colors);\n\nvar _utils = require('./utils');\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nfunction _taggedTemplateLiteral(strings, raw) { return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }\n/** @jsx jsx */\n\n// common\nvar borderRadius = exports.borderRadius = 4;\nvar gutter = exports.gutter = 8;\nvar toastWidth = exports.toastWidth = 360;\nvar shrinkKeyframes = exports.shrinkKeyframes = (0, _core.keyframes)(_templateObject);\n\n// a11y helper\nvar A11yText = function A11yText(_ref) {\n  var Tag = _ref.tag,\n      props = _objectWithoutProperties(_ref, ['tag']);\n\n  return (0, _core.jsx)(Tag, _extends({\n    css: {\n      border: 0,\n      clip: 'rect(1px, 1px, 1px, 1px)',\n      height: 1,\n      overflow: 'hidden',\n      padding: 0,\n      position: 'absolute',\n      whiteSpace: 'nowrap',\n      width: 1\n    }\n  }, props));\n};\nA11yText.defaultProps = {\n  tag: 'span'\n};\n\n// default appearances\n\nvar appearances = {\n  success: {\n    icon: _icons.CheckIcon,\n    text: colors.G500,\n    fg: colors.G300,\n    bg: colors.G50\n  },\n  error: {\n    icon: _icons.FlameIcon,\n    text: colors.R500,\n    fg: colors.R300,\n    bg: colors.R50\n  },\n  warning: {\n    icon: _icons.AlertIcon,\n    text: colors.Y500,\n    fg: colors.Y300,\n    bg: colors.Y50\n  },\n  info: {\n    icon: _icons.InfoIcon,\n    text: colors.N400,\n    fg: colors.B200,\n    bg: 'white'\n  }\n};\n\n\nvar Button = function Button(props) {\n  return (0, _core.jsx)('div', _extends({\n    role: 'button',\n    className: 'react-toast-notifications__toast__dismiss-button',\n    css: {\n      cursor: 'pointer',\n      flexShrink: 0,\n      opacity: 0.5,\n      padding: gutter + 'px ' + gutter * 1.5 + 'px',\n      transition: 'opacity 150ms',\n\n      ':hover': { opacity: 1 }\n    }\n  }, props));\n};\n\nvar Content = function Content(props) {\n  return (0, _core.jsx)('div', _extends({\n    className: 'react-toast-notifications__toast__content',\n    css: {\n      flexGrow: 1,\n      fontSize: 14,\n      lineHeight: 1.4,\n      minHeight: 40,\n      padding: gutter + 'px ' + gutter * 1.5 + 'px'\n    }\n  }, props));\n};\n\n// NOTE: invoke animation when NOT `autoDismiss` with opacity of 0 to avoid a\n// paint bug in FireFox.\n// https://bugzilla.mozilla.org/show_bug.cgi?id=625289\nvar Countdown = function Countdown(_ref2) {\n  var autoDismissTimeout = _ref2.autoDismissTimeout,\n      opacity = _ref2.opacity,\n      isRunning = _ref2.isRunning,\n      props = _objectWithoutProperties(_ref2, ['autoDismissTimeout', 'opacity', 'isRunning']);\n\n  return (0, _core.jsx)('div', _extends({\n    className: 'react-toast-notifications__toast__countdown',\n    css: {\n      animation: shrinkKeyframes + ' ' + autoDismissTimeout + 'ms linear',\n      animationPlayState: isRunning ? 'running' : 'paused',\n      backgroundColor: 'rgba(0,0,0,0.1)',\n      bottom: 0,\n      height: 0,\n      left: 0,\n      opacity: opacity,\n      position: 'absolute',\n      width: '100%'\n    }\n  }, props));\n};\n\nvar Icon = function Icon(_ref3) {\n  var appearance = _ref3.appearance,\n      autoDismiss = _ref3.autoDismiss,\n      autoDismissTimeout = _ref3.autoDismissTimeout,\n      isRunning = _ref3.isRunning;\n\n  var meta = appearances[appearance];\n  var Glyph = meta.icon;\n\n  return (0, _core.jsx)(\n    'div',\n    {\n      className: 'react-toast-notifications__toast__icon-wrapper',\n      css: {\n        backgroundColor: meta.fg,\n        borderTopLeftRadius: borderRadius,\n        borderBottomLeftRadius: borderRadius,\n        color: meta.bg,\n        flexShrink: 0,\n        paddingBottom: gutter,\n        paddingTop: gutter,\n        position: 'relative',\n        overflow: 'hidden',\n        textAlign: 'center',\n        width: 30\n      }\n    },\n    (0, _core.jsx)(Countdown, {\n      opacity: autoDismiss ? 1 : 0,\n      autoDismissTimeout: autoDismissTimeout,\n      isRunning: isRunning\n    }),\n    (0, _core.jsx)(Glyph, {\n      className: 'react-toast-notifications__toast__icon',\n      css: { position: 'relative', zIndex: 1 }\n    })\n  );\n};\n\n// Transitions\n// ------------------------------\n\nfunction getTranslate(placement) {\n  var pos = placement.split('-');\n  var relevantPlacement = pos[1] === 'center' ? pos[0] : pos[1];\n  var translateMap = {\n    right: 'translate3d(120%, 0, 0)',\n    left: 'translate3d(-120%, 0, 0)',\n    bottom: 'translate3d(0, 120%, 0)',\n    top: 'translate3d(0, -120%, 0)'\n  };\n\n  return translateMap[relevantPlacement];\n}\n\nvar toastStates = function toastStates(placement) {\n  return {\n    entering: { transform: getTranslate(placement) },\n    entered: { transform: 'translate3d(0,0,0)' },\n    exiting: { transform: 'scale(0.66)', opacity: 0 },\n    exited: { transform: 'scale(0.66)', opacity: 0 }\n  };\n};\n\nvar ToastElement = function ToastElement(_ref4) {\n  var appearance = _ref4.appearance,\n      placement = _ref4.placement,\n      transitionDuration = _ref4.transitionDuration,\n      transitionState = _ref4.transitionState,\n      props = _objectWithoutProperties(_ref4, ['appearance', 'placement', 'transitionDuration', 'transitionState']);\n\n  var _useState = (0, _react.useState)('auto'),\n      _useState2 = _slicedToArray(_useState, 2),\n      height = _useState2[0],\n      setHeight = _useState2[1];\n\n  var elementRef = (0, _react.useRef)(null);\n\n  (0, _react.useEffect)(function () {\n    if (transitionState === 'entered') {\n      var el = elementRef.current;\n      setHeight(el.offsetHeight + gutter);\n    }\n    if (transitionState === 'exiting') {\n      setHeight(0);\n    }\n  }, [transitionState]);\n\n  return (0, _core.jsx)(\n    'div',\n    {\n      ref: elementRef,\n      style: { height: height },\n      css: {\n        transition: 'height ' + (transitionDuration - 100) + 'ms 100ms'\n      }\n    },\n    (0, _core.jsx)('div', _extends({\n      className: 'react-toast-notifications__toast react-toast-notifications__toast--' + appearance,\n      css: _extends({\n        backgroundColor: appearances[appearance].bg,\n        borderRadius: borderRadius,\n        boxShadow: '0 3px 8px rgba(0, 0, 0, 0.175)',\n        color: appearances[appearance].text,\n        display: 'flex',\n        marginBottom: gutter,\n        maxWidth: '100%',\n        transition: 'transform ' + transitionDuration + 'ms cubic-bezier(0.2, 0, 0, 1), opacity ' + transitionDuration + 'ms',\n        width: toastWidth\n      }, toastStates(placement)[transitionState])\n    }, props))\n  );\n};\n\n// ==============================\n// DefaultToast\n// ==============================\n\nvar DefaultToast = function DefaultToast(_ref5) {\n  var appearance = _ref5.appearance,\n      autoDismiss = _ref5.autoDismiss,\n      autoDismissTimeout = _ref5.autoDismissTimeout,\n      children = _ref5.children,\n      isRunning = _ref5.isRunning,\n      onDismiss = _ref5.onDismiss,\n      placement = _ref5.placement,\n      transitionDuration = _ref5.transitionDuration,\n      transitionState = _ref5.transitionState,\n      onMouseEnter = _ref5.onMouseEnter,\n      onMouseLeave = _ref5.onMouseLeave,\n      otherProps = _objectWithoutProperties(_ref5, ['appearance', 'autoDismiss', 'autoDismissTimeout', 'children', 'isRunning', 'onDismiss', 'placement', 'transitionDuration', 'transitionState', 'onMouseEnter', 'onMouseLeave']);\n\n  return (0, _core.jsx)(\n    ToastElement,\n    _extends({\n      appearance: appearance,\n      placement: placement,\n      transitionState: transitionState,\n      transitionDuration: transitionDuration,\n      onMouseEnter: onMouseEnter,\n      onMouseLeave: onMouseLeave\n    }, otherProps),\n    (0, _core.jsx)(Icon, {\n      appearance: appearance,\n      autoDismiss: autoDismiss,\n      autoDismissTimeout: autoDismissTimeout,\n      isRunning: isRunning\n    }),\n    (0, _core.jsx)(\n      Content,\n      null,\n      children\n    ),\n    onDismiss ? (0, _core.jsx)(\n      Button,\n      { onClick: onDismiss },\n      (0, _core.jsx)(_icons.CloseIcon, { className: 'react-toast-notifications__toast__dismiss-icon' }),\n      (0, _core.jsx)(\n        A11yText,\n        { className: 'react-toast-notifications__toast__dismiss-text' },\n        'Close'\n      )\n    ) : null\n  );\n};\n\nexports.DefaultToast = DefaultToast;\nDefaultToast.defaultProps = {\n  onDismiss: _utils.NOOP\n};","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.generateUEID = generateUEID;\nvar NOOP = exports.NOOP = function NOOP() {};\nfunction generateUEID() {\n  var first = Math.random() * 46656 | 0;\n  var second = Math.random() * 46656 | 0;\n  first = ('000' + first.toString(36)).slice(-3);\n  second = ('000' + second.toString(36)).slice(-3);\n  return first + second;\n}","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","function replaceClassName(origClass, classToRemove) {\n  return origClass.replace(new RegExp(\"(^|\\\\s)\" + classToRemove + \"(?:\\\\s|$)\", 'g'), '$1').replace(/\\s+/g, ' ').replace(/^\\s*|\\s*$/g, '');\n}\n\nexport default function removeClass(element, className) {\n  if (element.classList) {\n    element.classList.remove(className);\n  } else if (typeof element.className === 'string') {\n    ;\n    element.className = replaceClassName(element.className, className);\n  } else {\n    element.setAttribute('class', replaceClassName(element.className && element.className.baseVal || '', className));\n  }\n}","export default {\n  disabled: false\n};","import React from 'react';\nexport default React.createContext(null);","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport config from './config';\nimport { timeoutsShape } from './utils/PropTypes';\nimport TransitionGroupContext from './TransitionGroupContext';\nexport var UNMOUNTED = 'unmounted';\nexport var EXITED = 'exited';\nexport var ENTERING = 'entering';\nexport var ENTERED = 'entered';\nexport var EXITING = 'exiting';\n/**\n * The Transition component lets you describe a transition from one component\n * state to another _over time_ with a simple declarative API. Most commonly\n * it's used to animate the mounting and unmounting of a component, but can also\n * be used to describe in-place transition states as well.\n *\n * ---\n *\n * **Note**: `Transition` is a platform-agnostic base component. If you're using\n * transitions in CSS, you'll probably want to use\n * [`CSSTransition`](https://reactcommunity.org/react-transition-group/css-transition)\n * instead. It inherits all the features of `Transition`, but contains\n * additional features necessary to play nice with CSS transitions (hence the\n * name of the component).\n *\n * ---\n *\n * By default the `Transition` component does not alter the behavior of the\n * component it renders, it only tracks \"enter\" and \"exit\" states for the\n * components. It's up to you to give meaning and effect to those states. For\n * example we can add styles to a component when it enters or exits:\n *\n * ```jsx\n * import { Transition } from 'react-transition-group';\n *\n * const duration = 300;\n *\n * const defaultStyle = {\n *   transition: `opacity ${duration}ms ease-in-out`,\n *   opacity: 0,\n * }\n *\n * const transitionStyles = {\n *   entering: { opacity: 1 },\n *   entered:  { opacity: 1 },\n *   exiting:  { opacity: 0 },\n *   exited:  { opacity: 0 },\n * };\n *\n * const Fade = ({ in: inProp }) => (\n *   <Transition in={inProp} timeout={duration}>\n *     {state => (\n *       <div style={{\n *         ...defaultStyle,\n *         ...transitionStyles[state]\n *       }}>\n *         I'm a fade Transition!\n *       </div>\n *     )}\n *   </Transition>\n * );\n * ```\n *\n * There are 4 main states a Transition can be in:\n *  - `'entering'`\n *  - `'entered'`\n *  - `'exiting'`\n *  - `'exited'`\n *\n * Transition state is toggled via the `in` prop. When `true` the component\n * begins the \"Enter\" stage. During this stage, the component will shift from\n * its current transition state, to `'entering'` for the duration of the\n * transition and then to the `'entered'` stage once it's complete. Let's take\n * the following example (we'll use the\n * [useState](https://reactjs.org/docs/hooks-reference.html#usestate) hook):\n *\n * ```jsx\n * function App() {\n *   const [inProp, setInProp] = useState(false);\n *   return (\n *     <div>\n *       <Transition in={inProp} timeout={500}>\n *         {state => (\n *           // ...\n *         )}\n *       </Transition>\n *       <button onClick={() => setInProp(true)}>\n *         Click to Enter\n *       </button>\n *     </div>\n *   );\n * }\n * ```\n *\n * When the button is clicked the component will shift to the `'entering'` state\n * and stay there for 500ms (the value of `timeout`) before it finally switches\n * to `'entered'`.\n *\n * When `in` is `false` the same thing happens except the state moves from\n * `'exiting'` to `'exited'`.\n */\n\nvar Transition = /*#__PURE__*/function (_React$Component) {\n  _inheritsLoose(Transition, _React$Component);\n\n  function Transition(props, context) {\n    var _this;\n\n    _this = _React$Component.call(this, props, context) || this;\n    var parentGroup = context; // In the context of a TransitionGroup all enters are really appears\n\n    var appear = parentGroup && !parentGroup.isMounting ? props.enter : props.appear;\n    var initialStatus;\n    _this.appearStatus = null;\n\n    if (props.in) {\n      if (appear) {\n        initialStatus = EXITED;\n        _this.appearStatus = ENTERING;\n      } else {\n        initialStatus = ENTERED;\n      }\n    } else {\n      if (props.unmountOnExit || props.mountOnEnter) {\n        initialStatus = UNMOUNTED;\n      } else {\n        initialStatus = EXITED;\n      }\n    }\n\n    _this.state = {\n      status: initialStatus\n    };\n    _this.nextCallback = null;\n    return _this;\n  }\n\n  Transition.getDerivedStateFromProps = function getDerivedStateFromProps(_ref, prevState) {\n    var nextIn = _ref.in;\n\n    if (nextIn && prevState.status === UNMOUNTED) {\n      return {\n        status: EXITED\n      };\n    }\n\n    return null;\n  } // getSnapshotBeforeUpdate(prevProps) {\n  //   let nextStatus = null\n  //   if (prevProps !== this.props) {\n  //     const { status } = this.state\n  //     if (this.props.in) {\n  //       if (status !== ENTERING && status !== ENTERED) {\n  //         nextStatus = ENTERING\n  //       }\n  //     } else {\n  //       if (status === ENTERING || status === ENTERED) {\n  //         nextStatus = EXITING\n  //       }\n  //     }\n  //   }\n  //   return { nextStatus }\n  // }\n  ;\n\n  var _proto = Transition.prototype;\n\n  _proto.componentDidMount = function componentDidMount() {\n    this.updateStatus(true, this.appearStatus);\n  };\n\n  _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n    var nextStatus = null;\n\n    if (prevProps !== this.props) {\n      var status = this.state.status;\n\n      if (this.props.in) {\n        if (status !== ENTERING && status !== ENTERED) {\n          nextStatus = ENTERING;\n        }\n      } else {\n        if (status === ENTERING || status === ENTERED) {\n          nextStatus = EXITING;\n        }\n      }\n    }\n\n    this.updateStatus(false, nextStatus);\n  };\n\n  _proto.componentWillUnmount = function componentWillUnmount() {\n    this.cancelNextCallback();\n  };\n\n  _proto.getTimeouts = function getTimeouts() {\n    var timeout = this.props.timeout;\n    var exit, enter, appear;\n    exit = enter = appear = timeout;\n\n    if (timeout != null && typeof timeout !== 'number') {\n      exit = timeout.exit;\n      enter = timeout.enter; // TODO: remove fallback for next major\n\n      appear = timeout.appear !== undefined ? timeout.appear : enter;\n    }\n\n    return {\n      exit: exit,\n      enter: enter,\n      appear: appear\n    };\n  };\n\n  _proto.updateStatus = function updateStatus(mounting, nextStatus) {\n    if (mounting === void 0) {\n      mounting = false;\n    }\n\n    if (nextStatus !== null) {\n      // nextStatus will always be ENTERING or EXITING.\n      this.cancelNextCallback();\n\n      if (nextStatus === ENTERING) {\n        this.performEnter(mounting);\n      } else {\n        this.performExit();\n      }\n    } else if (this.props.unmountOnExit && this.state.status === EXITED) {\n      this.setState({\n        status: UNMOUNTED\n      });\n    }\n  };\n\n  _proto.performEnter = function performEnter(mounting) {\n    var _this2 = this;\n\n    var enter = this.props.enter;\n    var appearing = this.context ? this.context.isMounting : mounting;\n\n    var _ref2 = this.props.nodeRef ? [appearing] : [ReactDOM.findDOMNode(this), appearing],\n        maybeNode = _ref2[0],\n        maybeAppearing = _ref2[1];\n\n    var timeouts = this.getTimeouts();\n    var enterTimeout = appearing ? timeouts.appear : timeouts.enter; // no enter animation skip right to ENTERED\n    // if we are mounting and running this it means appear _must_ be set\n\n    if (!mounting && !enter || config.disabled) {\n      this.safeSetState({\n        status: ENTERED\n      }, function () {\n        _this2.props.onEntered(maybeNode);\n      });\n      return;\n    }\n\n    this.props.onEnter(maybeNode, maybeAppearing);\n    this.safeSetState({\n      status: ENTERING\n    }, function () {\n      _this2.props.onEntering(maybeNode, maybeAppearing);\n\n      _this2.onTransitionEnd(enterTimeout, function () {\n        _this2.safeSetState({\n          status: ENTERED\n        }, function () {\n          _this2.props.onEntered(maybeNode, maybeAppearing);\n        });\n      });\n    });\n  };\n\n  _proto.performExit = function performExit() {\n    var _this3 = this;\n\n    var exit = this.props.exit;\n    var timeouts = this.getTimeouts();\n    var maybeNode = this.props.nodeRef ? undefined : ReactDOM.findDOMNode(this); // no exit animation skip right to EXITED\n\n    if (!exit || config.disabled) {\n      this.safeSetState({\n        status: EXITED\n      }, function () {\n        _this3.props.onExited(maybeNode);\n      });\n      return;\n    }\n\n    this.props.onExit(maybeNode);\n    this.safeSetState({\n      status: EXITING\n    }, function () {\n      _this3.props.onExiting(maybeNode);\n\n      _this3.onTransitionEnd(timeouts.exit, function () {\n        _this3.safeSetState({\n          status: EXITED\n        }, function () {\n          _this3.props.onExited(maybeNode);\n        });\n      });\n    });\n  };\n\n  _proto.cancelNextCallback = function cancelNextCallback() {\n    if (this.nextCallback !== null) {\n      this.nextCallback.cancel();\n      this.nextCallback = null;\n    }\n  };\n\n  _proto.safeSetState = function safeSetState(nextState, callback) {\n    // This shouldn't be necessary, but there are weird race conditions with\n    // setState callbacks and unmounting in testing, so always make sure that\n    // we can cancel any pending setState callbacks after we unmount.\n    callback = this.setNextCallback(callback);\n    this.setState(nextState, callback);\n  };\n\n  _proto.setNextCallback = function setNextCallback(callback) {\n    var _this4 = this;\n\n    var active = true;\n\n    this.nextCallback = function (event) {\n      if (active) {\n        active = false;\n        _this4.nextCallback = null;\n        callback(event);\n      }\n    };\n\n    this.nextCallback.cancel = function () {\n      active = false;\n    };\n\n    return this.nextCallback;\n  };\n\n  _proto.onTransitionEnd = function onTransitionEnd(timeout, handler) {\n    this.setNextCallback(handler);\n    var node = this.props.nodeRef ? this.props.nodeRef.current : ReactDOM.findDOMNode(this);\n    var doesNotHaveTimeoutOrListener = timeout == null && !this.props.addEndListener;\n\n    if (!node || doesNotHaveTimeoutOrListener) {\n      setTimeout(this.nextCallback, 0);\n      return;\n    }\n\n    if (this.props.addEndListener) {\n      var _ref3 = this.props.nodeRef ? [this.nextCallback] : [node, this.nextCallback],\n          maybeNode = _ref3[0],\n          maybeNextCallback = _ref3[1];\n\n      this.props.addEndListener(maybeNode, maybeNextCallback);\n    }\n\n    if (timeout != null) {\n      setTimeout(this.nextCallback, timeout);\n    }\n  };\n\n  _proto.render = function render() {\n    var status = this.state.status;\n\n    if (status === UNMOUNTED) {\n      return null;\n    }\n\n    var _this$props = this.props,\n        children = _this$props.children,\n        _in = _this$props.in,\n        _mountOnEnter = _this$props.mountOnEnter,\n        _unmountOnExit = _this$props.unmountOnExit,\n        _appear = _this$props.appear,\n        _enter = _this$props.enter,\n        _exit = _this$props.exit,\n        _timeout = _this$props.timeout,\n        _addEndListener = _this$props.addEndListener,\n        _onEnter = _this$props.onEnter,\n        _onEntering = _this$props.onEntering,\n        _onEntered = _this$props.onEntered,\n        _onExit = _this$props.onExit,\n        _onExiting = _this$props.onExiting,\n        _onExited = _this$props.onExited,\n        _nodeRef = _this$props.nodeRef,\n        childProps = _objectWithoutPropertiesLoose(_this$props, [\"children\", \"in\", \"mountOnEnter\", \"unmountOnExit\", \"appear\", \"enter\", \"exit\", \"timeout\", \"addEndListener\", \"onEnter\", \"onEntering\", \"onEntered\", \"onExit\", \"onExiting\", \"onExited\", \"nodeRef\"]);\n\n    return (\n      /*#__PURE__*/\n      // allows for nested Transitions\n      React.createElement(TransitionGroupContext.Provider, {\n        value: null\n      }, typeof children === 'function' ? children(status, childProps) : React.cloneElement(React.Children.only(children), childProps))\n    );\n  };\n\n  return Transition;\n}(React.Component);\n\nTransition.contextType = TransitionGroupContext;\nTransition.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /**\n   * A React reference to DOM element that need to transition:\n   * https://stackoverflow.com/a/51127130/4671932\n   *\n   *   - When `nodeRef` prop is used, `node` is not passed to callback functions\n   *      (e.g. `onEnter`) because user already has direct access to the node.\n   *   - When changing `key` prop of `Transition` in a `TransitionGroup` a new\n   *     `nodeRef` need to be provided to `Transition` with changed `key` prop\n   *     (see\n   *     [test/CSSTransition-test.js](https://github.com/reactjs/react-transition-group/blob/13435f897b3ab71f6e19d724f145596f5910581c/test/CSSTransition-test.js#L362-L437)).\n   */\n  nodeRef: PropTypes.shape({\n    current: typeof Element === 'undefined' ? PropTypes.any : PropTypes.instanceOf(Element)\n  }),\n\n  /**\n   * A `function` child can be used instead of a React element. This function is\n   * called with the current transition status (`'entering'`, `'entered'`,\n   * `'exiting'`, `'exited'`), which can be used to apply context\n   * specific props to a component.\n   *\n   * ```jsx\n   * <Transition in={this.state.in} timeout={150}>\n   *   {state => (\n   *     <MyComponent className={`fade fade-${state}`} />\n   *   )}\n   * </Transition>\n   * ```\n   */\n  children: PropTypes.oneOfType([PropTypes.func.isRequired, PropTypes.element.isRequired]).isRequired,\n\n  /**\n   * Show the component; triggers the enter or exit states\n   */\n  in: PropTypes.bool,\n\n  /**\n   * By default the child component is mounted immediately along with\n   * the parent `Transition` component. If you want to \"lazy mount\" the component on the\n   * first `in={true}` you can set `mountOnEnter`. After the first enter transition the component will stay\n   * mounted, even on \"exited\", unless you also specify `unmountOnExit`.\n   */\n  mountOnEnter: PropTypes.bool,\n\n  /**\n   * By default the child component stays mounted after it reaches the `'exited'` state.\n   * Set `unmountOnExit` if you'd prefer to unmount the component after it finishes exiting.\n   */\n  unmountOnExit: PropTypes.bool,\n\n  /**\n   * By default the child component does not perform the enter transition when\n   * it first mounts, regardless of the value of `in`. If you want this\n   * behavior, set both `appear` and `in` to `true`.\n   *\n   * > **Note**: there are no special appear states like `appearing`/`appeared`, this prop\n   * > only adds an additional enter transition. However, in the\n   * > `<CSSTransition>` component that first enter transition does result in\n   * > additional `.appear-*` classes, that way you can choose to style it\n   * > differently.\n   */\n  appear: PropTypes.bool,\n\n  /**\n   * Enable or disable enter transitions.\n   */\n  enter: PropTypes.bool,\n\n  /**\n   * Enable or disable exit transitions.\n   */\n  exit: PropTypes.bool,\n\n  /**\n   * The duration of the transition, in milliseconds.\n   * Required unless `addEndListener` is provided.\n   *\n   * You may specify a single timeout for all transitions:\n   *\n   * ```jsx\n   * timeout={500}\n   * ```\n   *\n   * or individually:\n   *\n   * ```jsx\n   * timeout={{\n   *  appear: 500,\n   *  enter: 300,\n   *  exit: 500,\n   * }}\n   * ```\n   *\n   * - `appear` defaults to the value of `enter`\n   * - `enter` defaults to `0`\n   * - `exit` defaults to `0`\n   *\n   * @type {number | { enter?: number, exit?: number, appear?: number }}\n   */\n  timeout: function timeout(props) {\n    var pt = timeoutsShape;\n    if (!props.addEndListener) pt = pt.isRequired;\n\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    return pt.apply(void 0, [props].concat(args));\n  },\n\n  /**\n   * Add a custom transition end trigger. Called with the transitioning\n   * DOM node and a `done` callback. Allows for more fine grained transition end\n   * logic. Timeouts are still used as a fallback if provided.\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n   *\n   * ```jsx\n   * addEndListener={(node, done) => {\n   *   // use the css transitionend event to mark the finish of a transition\n   *   node.addEventListener('transitionend', done, false);\n   * }}\n   * ```\n   */\n  addEndListener: PropTypes.func,\n\n  /**\n   * Callback fired before the \"entering\" status is applied. An extra parameter\n   * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool) -> void\n   */\n  onEnter: PropTypes.func,\n\n  /**\n   * Callback fired after the \"entering\" status is applied. An extra parameter\n   * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool)\n   */\n  onEntering: PropTypes.func,\n\n  /**\n   * Callback fired after the \"entered\" status is applied. An extra parameter\n   * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool) -> void\n   */\n  onEntered: PropTypes.func,\n\n  /**\n   * Callback fired before the \"exiting\" status is applied.\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n   *\n   * @type Function(node: HtmlElement) -> void\n   */\n  onExit: PropTypes.func,\n\n  /**\n   * Callback fired after the \"exiting\" status is applied.\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n   *\n   * @type Function(node: HtmlElement) -> void\n   */\n  onExiting: PropTypes.func,\n\n  /**\n   * Callback fired after the \"exited\" status is applied.\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed\n   *\n   * @type Function(node: HtmlElement) -> void\n   */\n  onExited: PropTypes.func\n} : {}; // Name the function so it is clearer in the documentation\n\nfunction noop() {}\n\nTransition.defaultProps = {\n  in: false,\n  mountOnEnter: false,\n  unmountOnExit: false,\n  appear: false,\n  enter: true,\n  exit: true,\n  onEnter: noop,\n  onEntering: noop,\n  onEntered: noop,\n  onExit: noop,\n  onExiting: noop,\n  onExited: noop\n};\nTransition.UNMOUNTED = UNMOUNTED;\nTransition.EXITED = EXITED;\nTransition.ENTERING = ENTERING;\nTransition.ENTERED = ENTERED;\nTransition.EXITING = EXITING;\nexport default Transition;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport PropTypes from 'prop-types';\nimport addOneClass from 'dom-helpers/addClass';\nimport removeOneClass from 'dom-helpers/removeClass';\nimport React from 'react';\nimport Transition from './Transition';\nimport { classNamesShape } from './utils/PropTypes';\n\nvar _addClass = function addClass(node, classes) {\n  return node && classes && classes.split(' ').forEach(function (c) {\n    return addOneClass(node, c);\n  });\n};\n\nvar removeClass = function removeClass(node, classes) {\n  return node && classes && classes.split(' ').forEach(function (c) {\n    return removeOneClass(node, c);\n  });\n};\n/**\n * A transition component inspired by the excellent\n * [ng-animate](https://docs.angularjs.org/api/ngAnimate) library, you should\n * use it if you're using CSS transitions or animations. It's built upon the\n * [`Transition`](https://reactcommunity.org/react-transition-group/transition)\n * component, so it inherits all of its props.\n *\n * `CSSTransition` applies a pair of class names during the `appear`, `enter`,\n * and `exit` states of the transition. The first class is applied and then a\n * second `*-active` class in order to activate the CSS transition. After the\n * transition, matching `*-done` class names are applied to persist the\n * transition state.\n *\n * ```jsx\n * function App() {\n *   const [inProp, setInProp] = useState(false);\n *   return (\n *     <div>\n *       <CSSTransition in={inProp} timeout={200} classNames=\"my-node\">\n *         <div>\n *           {\"I'll receive my-node-* classes\"}\n *         </div>\n *       </CSSTransition>\n *       <button type=\"button\" onClick={() => setInProp(true)}>\n *         Click to Enter\n *       </button>\n *     </div>\n *   );\n * }\n * ```\n *\n * When the `in` prop is set to `true`, the child component will first receive\n * the class `example-enter`, then the `example-enter-active` will be added in\n * the next tick. `CSSTransition` [forces a\n * reflow](https://github.com/reactjs/react-transition-group/blob/5007303e729a74be66a21c3e2205e4916821524b/src/CSSTransition.js#L208-L215)\n * between before adding the `example-enter-active`. This is an important trick\n * because it allows us to transition between `example-enter` and\n * `example-enter-active` even though they were added immediately one after\n * another. Most notably, this is what makes it possible for us to animate\n * _appearance_.\n *\n * ```css\n * .my-node-enter {\n *   opacity: 0;\n * }\n * .my-node-enter-active {\n *   opacity: 1;\n *   transition: opacity 200ms;\n * }\n * .my-node-exit {\n *   opacity: 1;\n * }\n * .my-node-exit-active {\n *   opacity: 0;\n *   transition: opacity 200ms;\n * }\n * ```\n *\n * `*-active` classes represent which styles you want to animate **to**, so it's\n * important to add `transition` declaration only to them, otherwise transitions\n * might not behave as intended! This might not be obvious when the transitions\n * are symmetrical, i.e. when `*-enter-active` is the same as `*-exit`, like in\n * the example above (minus `transition`), but it becomes apparent in more\n * complex transitions.\n *\n * **Note**: If you're using the\n * [`appear`](http://reactcommunity.org/react-transition-group/transition#Transition-prop-appear)\n * prop, make sure to define styles for `.appear-*` classes as well.\n */\n\n\nvar CSSTransition = /*#__PURE__*/function (_React$Component) {\n  _inheritsLoose(CSSTransition, _React$Component);\n\n  function CSSTransition() {\n    var _this;\n\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n    _this.appliedClasses = {\n      appear: {},\n      enter: {},\n      exit: {}\n    };\n\n    _this.onEnter = function (maybeNode, maybeAppearing) {\n      var _this$resolveArgument = _this.resolveArguments(maybeNode, maybeAppearing),\n          node = _this$resolveArgument[0],\n          appearing = _this$resolveArgument[1];\n\n      _this.removeClasses(node, 'exit');\n\n      _this.addClass(node, appearing ? 'appear' : 'enter', 'base');\n\n      if (_this.props.onEnter) {\n        _this.props.onEnter(maybeNode, maybeAppearing);\n      }\n    };\n\n    _this.onEntering = function (maybeNode, maybeAppearing) {\n      var _this$resolveArgument2 = _this.resolveArguments(maybeNode, maybeAppearing),\n          node = _this$resolveArgument2[0],\n          appearing = _this$resolveArgument2[1];\n\n      var type = appearing ? 'appear' : 'enter';\n\n      _this.addClass(node, type, 'active');\n\n      if (_this.props.onEntering) {\n        _this.props.onEntering(maybeNode, maybeAppearing);\n      }\n    };\n\n    _this.onEntered = function (maybeNode, maybeAppearing) {\n      var _this$resolveArgument3 = _this.resolveArguments(maybeNode, maybeAppearing),\n          node = _this$resolveArgument3[0],\n          appearing = _this$resolveArgument3[1];\n\n      var type = appearing ? 'appear' : 'enter';\n\n      _this.removeClasses(node, type);\n\n      _this.addClass(node, type, 'done');\n\n      if (_this.props.onEntered) {\n        _this.props.onEntered(maybeNode, maybeAppearing);\n      }\n    };\n\n    _this.onExit = function (maybeNode) {\n      var _this$resolveArgument4 = _this.resolveArguments(maybeNode),\n          node = _this$resolveArgument4[0];\n\n      _this.removeClasses(node, 'appear');\n\n      _this.removeClasses(node, 'enter');\n\n      _this.addClass(node, 'exit', 'base');\n\n      if (_this.props.onExit) {\n        _this.props.onExit(maybeNode);\n      }\n    };\n\n    _this.onExiting = function (maybeNode) {\n      var _this$resolveArgument5 = _this.resolveArguments(maybeNode),\n          node = _this$resolveArgument5[0];\n\n      _this.addClass(node, 'exit', 'active');\n\n      if (_this.props.onExiting) {\n        _this.props.onExiting(maybeNode);\n      }\n    };\n\n    _this.onExited = function (maybeNode) {\n      var _this$resolveArgument6 = _this.resolveArguments(maybeNode),\n          node = _this$resolveArgument6[0];\n\n      _this.removeClasses(node, 'exit');\n\n      _this.addClass(node, 'exit', 'done');\n\n      if (_this.props.onExited) {\n        _this.props.onExited(maybeNode);\n      }\n    };\n\n    _this.resolveArguments = function (maybeNode, maybeAppearing) {\n      return _this.props.nodeRef ? [_this.props.nodeRef.current, maybeNode] // here `maybeNode` is actually `appearing`\n      : [maybeNode, maybeAppearing];\n    };\n\n    _this.getClassNames = function (type) {\n      var classNames = _this.props.classNames;\n      var isStringClassNames = typeof classNames === 'string';\n      var prefix = isStringClassNames && classNames ? classNames + \"-\" : '';\n      var baseClassName = isStringClassNames ? \"\" + prefix + type : classNames[type];\n      var activeClassName = isStringClassNames ? baseClassName + \"-active\" : classNames[type + \"Active\"];\n      var doneClassName = isStringClassNames ? baseClassName + \"-done\" : classNames[type + \"Done\"];\n      return {\n        baseClassName: baseClassName,\n        activeClassName: activeClassName,\n        doneClassName: doneClassName\n      };\n    };\n\n    return _this;\n  }\n\n  var _proto = CSSTransition.prototype;\n\n  _proto.addClass = function addClass(node, type, phase) {\n    var className = this.getClassNames(type)[phase + \"ClassName\"];\n\n    var _this$getClassNames = this.getClassNames('enter'),\n        doneClassName = _this$getClassNames.doneClassName;\n\n    if (type === 'appear' && phase === 'done' && doneClassName) {\n      className += \" \" + doneClassName;\n    } // This is for to force a repaint,\n    // which is necessary in order to transition styles when adding a class name.\n\n\n    if (phase === 'active') {\n      /* eslint-disable no-unused-expressions */\n      node && node.scrollTop;\n    }\n\n    if (className) {\n      this.appliedClasses[type][phase] = className;\n\n      _addClass(node, className);\n    }\n  };\n\n  _proto.removeClasses = function removeClasses(node, type) {\n    var _this$appliedClasses$ = this.appliedClasses[type],\n        baseClassName = _this$appliedClasses$.base,\n        activeClassName = _this$appliedClasses$.active,\n        doneClassName = _this$appliedClasses$.done;\n    this.appliedClasses[type] = {};\n\n    if (baseClassName) {\n      removeClass(node, baseClassName);\n    }\n\n    if (activeClassName) {\n      removeClass(node, activeClassName);\n    }\n\n    if (doneClassName) {\n      removeClass(node, doneClassName);\n    }\n  };\n\n  _proto.render = function render() {\n    var _this$props = this.props,\n        _ = _this$props.classNames,\n        props = _objectWithoutPropertiesLoose(_this$props, [\"classNames\"]);\n\n    return /*#__PURE__*/React.createElement(Transition, _extends({}, props, {\n      onEnter: this.onEnter,\n      onEntered: this.onEntered,\n      onEntering: this.onEntering,\n      onExit: this.onExit,\n      onExiting: this.onExiting,\n      onExited: this.onExited\n    }));\n  };\n\n  return CSSTransition;\n}(React.Component);\n\nCSSTransition.defaultProps = {\n  classNames: ''\n};\nCSSTransition.propTypes = process.env.NODE_ENV !== \"production\" ? _extends({}, Transition.propTypes, {\n  /**\n   * The animation classNames applied to the component as it appears, enters,\n   * exits or has finished the transition. A single name can be provided, which\n   * will be suffixed for each stage, e.g. `classNames=\"fade\"` applies:\n   *\n   * - `fade-appear`, `fade-appear-active`, `fade-appear-done`\n   * - `fade-enter`, `fade-enter-active`, `fade-enter-done`\n   * - `fade-exit`, `fade-exit-active`, `fade-exit-done`\n   *\n   * A few details to note about how these classes are applied:\n   *\n   * 1. They are _joined_ with the ones that are already defined on the child\n   *    component, so if you want to add some base styles, you can use\n   *    `className` without worrying that it will be overridden.\n   *\n   * 2. If the transition component mounts with `in={false}`, no classes are\n   *    applied yet. You might be expecting `*-exit-done`, but if you think\n   *    about it, a component cannot finish exiting if it hasn't entered yet.\n   *\n   * 2. `fade-appear-done` and `fade-enter-done` will _both_ be applied. This\n   *    allows you to define different behavior for when appearing is done and\n   *    when regular entering is done, using selectors like\n   *    `.fade-enter-done:not(.fade-appear-done)`. For example, you could apply\n   *    an epic entrance animation when element first appears in the DOM using\n   *    [Animate.css](https://daneden.github.io/animate.css/). Otherwise you can\n   *    simply use `fade-enter-done` for defining both cases.\n   *\n   * Each individual classNames can also be specified independently like:\n   *\n   * ```js\n   * classNames={{\n   *  appear: 'my-appear',\n   *  appearActive: 'my-active-appear',\n   *  appearDone: 'my-done-appear',\n   *  enter: 'my-enter',\n   *  enterActive: 'my-active-enter',\n   *  enterDone: 'my-done-enter',\n   *  exit: 'my-exit',\n   *  exitActive: 'my-active-exit',\n   *  exitDone: 'my-done-exit',\n   * }}\n   * ```\n   *\n   * If you want to set these classes using CSS Modules:\n   *\n   * ```js\n   * import styles from './styles.css';\n   * ```\n   *\n   * you might want to use camelCase in your CSS file, that way could simply\n   * spread them instead of listing them one by one:\n   *\n   * ```js\n   * classNames={{ ...styles }}\n   * ```\n   *\n   * @type {string | {\n   *  appear?: string,\n   *  appearActive?: string,\n   *  appearDone?: string,\n   *  enter?: string,\n   *  enterActive?: string,\n   *  enterDone?: string,\n   *  exit?: string,\n   *  exitActive?: string,\n   *  exitDone?: string,\n   * }}\n   */\n  classNames: classNamesShape,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'enter' or 'appear' class is\n   * applied.\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool)\n   */\n  onEnter: PropTypes.func,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'enter-active' or\n   * 'appear-active' class is applied.\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool)\n   */\n  onEntering: PropTypes.func,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'enter' or\n   * 'appear' classes are **removed** and the `done` class is added to the DOM node.\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool)\n   */\n  onEntered: PropTypes.func,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'exit' class is\n   * applied.\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed\n   *\n   * @type Function(node: HtmlElement)\n   */\n  onExit: PropTypes.func,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'exit-active' is applied.\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed\n   *\n   * @type Function(node: HtmlElement)\n   */\n  onExiting: PropTypes.func,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'exit' classes\n   * are **removed** and the `exit-done` class is added to the DOM node.\n   *\n   * **Note**: when `nodeRef` prop is passed, `node` is not passed\n   *\n   * @type Function(node: HtmlElement)\n   */\n  onExited: PropTypes.func\n}) : {};\nexport default CSSTransition;","import hasClass from './hasClass';\nexport default function addClass(element, className) {\n  if (element.classList) element.classList.add(className);else if (!hasClass(element, className)) if (typeof element.className === 'string') element.className = element.className + \" \" + className;else element.setAttribute('class', (element.className && element.className.baseVal || '') + \" \" + className);\n}","export default function hasClass(element, className) {\n  if (element.classList) return !!className && element.classList.contains(className);\n  return (\" \" + (element.className.baseVal || element.className) + \" \").indexOf(\" \" + className + \" \") !== -1;\n}","import { Children, cloneElement, isValidElement } from 'react';\n/**\n * Given `this.props.children`, return an object mapping key to child.\n *\n * @param {*} children `this.props.children`\n * @return {object} Mapping of key to child\n */\n\nexport function getChildMapping(children, mapFn) {\n  var mapper = function mapper(child) {\n    return mapFn && isValidElement(child) ? mapFn(child) : child;\n  };\n\n  var result = Object.create(null);\n  if (children) Children.map(children, function (c) {\n    return c;\n  }).forEach(function (child) {\n    // run the map function here instead so that the key is the computed one\n    result[child.key] = mapper(child);\n  });\n  return result;\n}\n/**\n * When you're adding or removing children some may be added or removed in the\n * same render pass. We want to show *both* since we want to simultaneously\n * animate elements in and out. This function takes a previous set of keys\n * and a new set of keys and merges them with its best guess of the correct\n * ordering. In the future we may expose some of the utilities in\n * ReactMultiChild to make this easy, but for now React itself does not\n * directly have this concept of the union of prevChildren and nextChildren\n * so we implement it here.\n *\n * @param {object} prev prev children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @param {object} next next children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @return {object} a key set that contains all keys in `prev` and all keys\n * in `next` in a reasonable order.\n */\n\nexport function mergeChildMappings(prev, next) {\n  prev = prev || {};\n  next = next || {};\n\n  function getValueForKey(key) {\n    return key in next ? next[key] : prev[key];\n  } // For each key of `next`, the list of keys to insert before that key in\n  // the combined list\n\n\n  var nextKeysPending = Object.create(null);\n  var pendingKeys = [];\n\n  for (var prevKey in prev) {\n    if (prevKey in next) {\n      if (pendingKeys.length) {\n        nextKeysPending[prevKey] = pendingKeys;\n        pendingKeys = [];\n      }\n    } else {\n      pendingKeys.push(prevKey);\n    }\n  }\n\n  var i;\n  var childMapping = {};\n\n  for (var nextKey in next) {\n    if (nextKeysPending[nextKey]) {\n      for (i = 0; i < nextKeysPending[nextKey].length; i++) {\n        var pendingNextKey = nextKeysPending[nextKey][i];\n        childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);\n      }\n    }\n\n    childMapping[nextKey] = getValueForKey(nextKey);\n  } // Finally, add the keys which didn't appear before any key in `next`\n\n\n  for (i = 0; i < pendingKeys.length; i++) {\n    childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);\n  }\n\n  return childMapping;\n}\n\nfunction getProp(child, prop, props) {\n  return props[prop] != null ? props[prop] : child.props[prop];\n}\n\nexport function getInitialChildMapping(props, onExited) {\n  return getChildMapping(props.children, function (child) {\n    return cloneElement(child, {\n      onExited: onExited.bind(null, child),\n      in: true,\n      appear: getProp(child, 'appear', props),\n      enter: getProp(child, 'enter', props),\n      exit: getProp(child, 'exit', props)\n    });\n  });\n}\nexport function getNextChildMapping(nextProps, prevChildMapping, onExited) {\n  var nextChildMapping = getChildMapping(nextProps.children);\n  var children = mergeChildMappings(prevChildMapping, nextChildMapping);\n  Object.keys(children).forEach(function (key) {\n    var child = children[key];\n    if (!isValidElement(child)) return;\n    var hasPrev = (key in prevChildMapping);\n    var hasNext = (key in nextChildMapping);\n    var prevChild = prevChildMapping[key];\n    var isLeaving = isValidElement(prevChild) && !prevChild.props.in; // item is new (entering)\n\n    if (hasNext && (!hasPrev || isLeaving)) {\n      // console.log('entering', key)\n      children[key] = cloneElement(child, {\n        onExited: onExited.bind(null, child),\n        in: true,\n        exit: getProp(child, 'exit', nextProps),\n        enter: getProp(child, 'enter', nextProps)\n      });\n    } else if (!hasNext && hasPrev && !isLeaving) {\n      // item is old (exiting)\n      // console.log('leaving', key)\n      children[key] = cloneElement(child, {\n        in: false\n      });\n    } else if (hasNext && hasPrev && isValidElement(prevChild)) {\n      // item hasn't changed transition states\n      // copy over the last transition props;\n      // console.log('unchanged', key)\n      children[key] = cloneElement(child, {\n        onExited: onExited.bind(null, child),\n        in: prevChild.props.in,\n        exit: getProp(child, 'exit', nextProps),\n        enter: getProp(child, 'enter', nextProps)\n      });\n    }\n  });\n  return children;\n}","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport TransitionGroupContext from './TransitionGroupContext';\nimport { getChildMapping, getInitialChildMapping, getNextChildMapping } from './utils/ChildMapping';\n\nvar values = Object.values || function (obj) {\n  return Object.keys(obj).map(function (k) {\n    return obj[k];\n  });\n};\n\nvar defaultProps = {\n  component: 'div',\n  childFactory: function childFactory(child) {\n    return child;\n  }\n};\n/**\n * The `<TransitionGroup>` component manages a set of transition components\n * (`<Transition>` and `<CSSTransition>`) in a list. Like with the transition\n * components, `<TransitionGroup>` is a state machine for managing the mounting\n * and unmounting of components over time.\n *\n * Consider the example below. As items are removed or added to the TodoList the\n * `in` prop is toggled automatically by the `<TransitionGroup>`.\n *\n * Note that `<TransitionGroup>`  does not define any animation behavior!\n * Exactly _how_ a list item animates is up to the individual transition\n * component. This means you can mix and match animations across different list\n * items.\n */\n\nvar TransitionGroup = /*#__PURE__*/function (_React$Component) {\n  _inheritsLoose(TransitionGroup, _React$Component);\n\n  function TransitionGroup(props, context) {\n    var _this;\n\n    _this = _React$Component.call(this, props, context) || this;\n\n    var handleExited = _this.handleExited.bind(_assertThisInitialized(_this)); // Initial children should all be entering, dependent on appear\n\n\n    _this.state = {\n      contextValue: {\n        isMounting: true\n      },\n      handleExited: handleExited,\n      firstRender: true\n    };\n    return _this;\n  }\n\n  var _proto = TransitionGroup.prototype;\n\n  _proto.componentDidMount = function componentDidMount() {\n    this.mounted = true;\n    this.setState({\n      contextValue: {\n        isMounting: false\n      }\n    });\n  };\n\n  _proto.componentWillUnmount = function componentWillUnmount() {\n    this.mounted = false;\n  };\n\n  TransitionGroup.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, _ref) {\n    var prevChildMapping = _ref.children,\n        handleExited = _ref.handleExited,\n        firstRender = _ref.firstRender;\n    return {\n      children: firstRender ? getInitialChildMapping(nextProps, handleExited) : getNextChildMapping(nextProps, prevChildMapping, handleExited),\n      firstRender: false\n    };\n  } // node is `undefined` when user provided `nodeRef` prop\n  ;\n\n  _proto.handleExited = function handleExited(child, node) {\n    var currentChildMapping = getChildMapping(this.props.children);\n    if (child.key in currentChildMapping) return;\n\n    if (child.props.onExited) {\n      child.props.onExited(node);\n    }\n\n    if (this.mounted) {\n      this.setState(function (state) {\n        var children = _extends({}, state.children);\n\n        delete children[child.key];\n        return {\n          children: children\n        };\n      });\n    }\n  };\n\n  _proto.render = function render() {\n    var _this$props = this.props,\n        Component = _this$props.component,\n        childFactory = _this$props.childFactory,\n        props = _objectWithoutPropertiesLoose(_this$props, [\"component\", \"childFactory\"]);\n\n    var contextValue = this.state.contextValue;\n    var children = values(this.state.children).map(childFactory);\n    delete props.appear;\n    delete props.enter;\n    delete props.exit;\n\n    if (Component === null) {\n      return /*#__PURE__*/React.createElement(TransitionGroupContext.Provider, {\n        value: contextValue\n      }, children);\n    }\n\n    return /*#__PURE__*/React.createElement(TransitionGroupContext.Provider, {\n      value: contextValue\n    }, /*#__PURE__*/React.createElement(Component, props, children));\n  };\n\n  return TransitionGroup;\n}(React.Component);\n\nTransitionGroup.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /**\n   * `<TransitionGroup>` renders a `<div>` by default. You can change this\n   * behavior by providing a `component` prop.\n   * If you use React v16+ and would like to avoid a wrapping `<div>` element\n   * you can pass in `component={null}`. This is useful if the wrapping div\n   * borks your css styles.\n   */\n  component: PropTypes.any,\n\n  /**\n   * A set of `<Transition>` components, that are toggled `in` and out as they\n   * leave. the `<TransitionGroup>` will inject specific transition props, so\n   * remember to spread them through if you are wrapping the `<Transition>` as\n   * with our `<Fade>` example.\n   *\n   * While this component is meant for multiple `Transition` or `CSSTransition`\n   * children, sometimes you may want to have a single transition child with\n   * content that you want to be transitioned out and in when you change it\n   * (e.g. routes, images etc.) In that case you can change the `key` prop of\n   * the transition child as you change its content, this will cause\n   * `TransitionGroup` to transition the child out and back in.\n   */\n  children: PropTypes.node,\n\n  /**\n   * A convenience prop that enables or disables appear animations\n   * for all children. Note that specifying this will override any defaults set\n   * on individual children Transitions.\n   */\n  appear: PropTypes.bool,\n\n  /**\n   * A convenience prop that enables or disables enter animations\n   * for all children. Note that specifying this will override any defaults set\n   * on individual children Transitions.\n   */\n  enter: PropTypes.bool,\n\n  /**\n   * A convenience prop that enables or disables exit animations\n   * for all children. Note that specifying this will override any defaults set\n   * on individual children Transitions.\n   */\n  exit: PropTypes.bool,\n\n  /**\n   * You may need to apply reactive updates to a child as it is exiting.\n   * This is generally done by using `cloneElement` however in the case of an exiting\n   * child the element has already been removed and not accessible to the consumer.\n   *\n   * If you do need to update a child as it leaves you can provide a `childFactory`\n   * to wrap every child, even the ones that are leaving.\n   *\n   * @type Function(child: ReactElement) -> ReactElement\n   */\n  childFactory: PropTypes.func\n} : {};\nTransitionGroup.defaultProps = defaultProps;\nexport default TransitionGroup;","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 _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport TransitionGroup from './TransitionGroup';\n/**\n * The `<ReplaceTransition>` component is a specialized `Transition` component\n * that animates between two children.\n *\n * ```jsx\n * <ReplaceTransition in>\n *   <Fade><div>I appear first</div></Fade>\n *   <Fade><div>I replace the above</div></Fade>\n * </ReplaceTransition>\n * ```\n */\n\nvar ReplaceTransition = /*#__PURE__*/function (_React$Component) {\n  _inheritsLoose(ReplaceTransition, _React$Component);\n\n  function ReplaceTransition() {\n    var _this;\n\n    for (var _len = arguments.length, _args = new Array(_len), _key = 0; _key < _len; _key++) {\n      _args[_key] = arguments[_key];\n    }\n\n    _this = _React$Component.call.apply(_React$Component, [this].concat(_args)) || this;\n\n    _this.handleEnter = function () {\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.handleLifecycle('onEnter', 0, args);\n    };\n\n    _this.handleEntering = function () {\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.handleLifecycle('onEntering', 0, args);\n    };\n\n    _this.handleEntered = function () {\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.handleLifecycle('onEntered', 0, args);\n    };\n\n    _this.handleExit = function () {\n      for (var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {\n        args[_key5] = arguments[_key5];\n      }\n\n      return _this.handleLifecycle('onExit', 1, args);\n    };\n\n    _this.handleExiting = function () {\n      for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {\n        args[_key6] = arguments[_key6];\n      }\n\n      return _this.handleLifecycle('onExiting', 1, args);\n    };\n\n    _this.handleExited = function () {\n      for (var _len7 = arguments.length, args = new Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {\n        args[_key7] = arguments[_key7];\n      }\n\n      return _this.handleLifecycle('onExited', 1, args);\n    };\n\n    return _this;\n  }\n\n  var _proto = ReplaceTransition.prototype;\n\n  _proto.handleLifecycle = function handleLifecycle(handler, idx, originalArgs) {\n    var _child$props;\n\n    var children = this.props.children;\n    var child = React.Children.toArray(children)[idx];\n    if (child.props[handler]) (_child$props = child.props)[handler].apply(_child$props, originalArgs);\n\n    if (this.props[handler]) {\n      var maybeNode = child.props.nodeRef ? undefined : ReactDOM.findDOMNode(this);\n      this.props[handler](maybeNode);\n    }\n  };\n\n  _proto.render = function render() {\n    var _this$props = this.props,\n        children = _this$props.children,\n        inProp = _this$props.in,\n        props = _objectWithoutPropertiesLoose(_this$props, [\"children\", \"in\"]);\n\n    var _React$Children$toArr = React.Children.toArray(children),\n        first = _React$Children$toArr[0],\n        second = _React$Children$toArr[1];\n\n    delete props.onEnter;\n    delete props.onEntering;\n    delete props.onEntered;\n    delete props.onExit;\n    delete props.onExiting;\n    delete props.onExited;\n    return /*#__PURE__*/React.createElement(TransitionGroup, props, inProp ? React.cloneElement(first, {\n      key: 'first',\n      onEnter: this.handleEnter,\n      onEntering: this.handleEntering,\n      onEntered: this.handleEntered\n    }) : React.cloneElement(second, {\n      key: 'second',\n      onEnter: this.handleExit,\n      onEntering: this.handleExiting,\n      onEntered: this.handleExited\n    }));\n  };\n\n  return ReplaceTransition;\n}(React.Component);\n\nReplaceTransition.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  in: PropTypes.bool.isRequired,\n  children: function children(props, propName) {\n    if (React.Children.count(props[propName]) !== 2) return new Error(\"\\\"\" + propName + \"\\\" must be exactly two transition components.\");\n    return null;\n  }\n} : {};\nexport default ReplaceTransition;","import _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\n\nvar _leaveRenders, _enterRenders;\n\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { ENTERED, ENTERING, EXITING } from './Transition';\nimport TransitionGroupContext from './TransitionGroupContext';\n\nfunction areChildrenDifferent(oldChildren, newChildren) {\n  if (oldChildren === newChildren) return false;\n\n  if (React.isValidElement(oldChildren) && React.isValidElement(newChildren) && oldChildren.key != null && oldChildren.key === newChildren.key) {\n    return false;\n  }\n\n  return true;\n}\n/**\n * Enum of modes for SwitchTransition component\n * @enum { string }\n */\n\n\nexport var modes = {\n  out: 'out-in',\n  in: 'in-out'\n};\n\nvar callHook = function callHook(element, name, cb) {\n  return function () {\n    var _element$props;\n\n    element.props[name] && (_element$props = element.props)[name].apply(_element$props, arguments);\n    cb();\n  };\n};\n\nvar leaveRenders = (_leaveRenders = {}, _leaveRenders[modes.out] = function (_ref) {\n  var current = _ref.current,\n      changeState = _ref.changeState;\n  return React.cloneElement(current, {\n    in: false,\n    onExited: callHook(current, 'onExited', function () {\n      changeState(ENTERING, null);\n    })\n  });\n}, _leaveRenders[modes.in] = function (_ref2) {\n  var current = _ref2.current,\n      changeState = _ref2.changeState,\n      children = _ref2.children;\n  return [current, React.cloneElement(children, {\n    in: true,\n    onEntered: callHook(children, 'onEntered', function () {\n      changeState(ENTERING);\n    })\n  })];\n}, _leaveRenders);\nvar enterRenders = (_enterRenders = {}, _enterRenders[modes.out] = function (_ref3) {\n  var children = _ref3.children,\n      changeState = _ref3.changeState;\n  return React.cloneElement(children, {\n    in: true,\n    onEntered: callHook(children, 'onEntered', function () {\n      changeState(ENTERED, React.cloneElement(children, {\n        in: true\n      }));\n    })\n  });\n}, _enterRenders[modes.in] = function (_ref4) {\n  var current = _ref4.current,\n      children = _ref4.children,\n      changeState = _ref4.changeState;\n  return [React.cloneElement(current, {\n    in: false,\n    onExited: callHook(current, 'onExited', function () {\n      changeState(ENTERED, React.cloneElement(children, {\n        in: true\n      }));\n    })\n  }), React.cloneElement(children, {\n    in: true\n  })];\n}, _enterRenders);\n/**\n * A transition component inspired by the [vue transition modes](https://vuejs.org/v2/guide/transitions.html#Transition-Modes).\n * You can use it when you want to control the render between state transitions.\n * Based on the selected mode and the child's key which is the `Transition` or `CSSTransition` component, the `SwitchTransition` makes a consistent transition between them.\n *\n * If the `out-in` mode is selected, the `SwitchTransition` waits until the old child leaves and then inserts a new child.\n * If the `in-out` mode is selected, the `SwitchTransition` inserts a new child first, waits for the new child to enter and then removes the old child.\n *\n * **Note**: If you want the animation to happen simultaneously\n * (that is, to have the old child removed and a new child inserted **at the same time**),\n * you should use\n * [`TransitionGroup`](https://reactcommunity.org/react-transition-group/transition-group)\n * instead.\n *\n * ```jsx\n * function App() {\n *  const [state, setState] = useState(false);\n *  return (\n *    <SwitchTransition>\n *      <CSSTransition\n *        key={state ? \"Goodbye, world!\" : \"Hello, world!\"}\n *        addEndListener={(node, done) => node.addEventListener(\"transitionend\", done, false)}\n *        classNames='fade'\n *      >\n *        <button onClick={() => setState(state => !state)}>\n *          {state ? \"Goodbye, world!\" : \"Hello, world!\"}\n *        </button>\n *      </CSSTransition>\n *    </SwitchTransition>\n *  );\n * }\n * ```\n *\n * ```css\n * .fade-enter{\n *    opacity: 0;\n * }\n * .fade-exit{\n *    opacity: 1;\n * }\n * .fade-enter-active{\n *    opacity: 1;\n * }\n * .fade-exit-active{\n *    opacity: 0;\n * }\n * .fade-enter-active,\n * .fade-exit-active{\n *    transition: opacity 500ms;\n * }\n * ```\n */\n\nvar SwitchTransition = /*#__PURE__*/function (_React$Component) {\n  _inheritsLoose(SwitchTransition, _React$Component);\n\n  function SwitchTransition() {\n    var _this;\n\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n    _this.state = {\n      status: ENTERED,\n      current: null\n    };\n    _this.appeared = false;\n\n    _this.changeState = function (status, current) {\n      if (current === void 0) {\n        current = _this.state.current;\n      }\n\n      _this.setState({\n        status: status,\n        current: current\n      });\n    };\n\n    return _this;\n  }\n\n  var _proto = SwitchTransition.prototype;\n\n  _proto.componentDidMount = function componentDidMount() {\n    this.appeared = true;\n  };\n\n  SwitchTransition.getDerivedStateFromProps = function getDerivedStateFromProps(props, state) {\n    if (props.children == null) {\n      return {\n        current: null\n      };\n    }\n\n    if (state.status === ENTERING && props.mode === modes.in) {\n      return {\n        status: ENTERING\n      };\n    }\n\n    if (state.current && areChildrenDifferent(state.current, props.children)) {\n      return {\n        status: EXITING\n      };\n    }\n\n    return {\n      current: React.cloneElement(props.children, {\n        in: true\n      })\n    };\n  };\n\n  _proto.render = function render() {\n    var _this$props = this.props,\n        children = _this$props.children,\n        mode = _this$props.mode,\n        _this$state = this.state,\n        status = _this$state.status,\n        current = _this$state.current;\n    var data = {\n      children: children,\n      current: current,\n      changeState: this.changeState,\n      status: status\n    };\n    var component;\n\n    switch (status) {\n      case ENTERING:\n        component = enterRenders[mode](data);\n        break;\n\n      case EXITING:\n        component = leaveRenders[mode](data);\n        break;\n\n      case ENTERED:\n        component = current;\n    }\n\n    return /*#__PURE__*/React.createElement(TransitionGroupContext.Provider, {\n      value: {\n        isMounting: !this.appeared\n      }\n    }, component);\n  };\n\n  return SwitchTransition;\n}(React.Component);\n\nSwitchTransition.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /**\n   * Transition modes.\n   * `out-in`: Current element transitions out first, then when complete, the new element transitions in.\n   * `in-out`: New element transitions in first, then when complete, the current element transitions out.\n   *\n   * @type {'out-in'|'in-out'}\n   */\n  mode: PropTypes.oneOf([modes.in, modes.out]),\n\n  /**\n   * Any `Transition` or `CSSTransition` component.\n   */\n  children: PropTypes.oneOfType([PropTypes.element.isRequired])\n} : {};\nSwitchTransition.defaultProps = {\n  mode: modes.out\n};\nexport default SwitchTransition;","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","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","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.ToastContainer = undefined;\n\nvar _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; };\n\nvar _core = require('@emotion/core');\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactTransitionGroup = require('react-transition-group');\n\nvar _ToastElement = require('./ToastElement');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n/** @jsx jsx */\n\nvar placements = {\n  'top-left': { top: 0, left: 0 },\n  'top-center': { top: 0, left: '50%', transform: 'translateX(-50%)' },\n  'top-right': { top: 0, right: 0 },\n  'bottom-left': { bottom: 0, left: 0 },\n  'bottom-center': { bottom: 0, left: '50%', transform: 'translateX(-50%)' },\n  'bottom-right': { bottom: 0, right: 0 }\n};\n\nvar ToastContainer = function ToastContainer(_ref) {\n  var hasToasts = _ref.hasToasts,\n      placement = _ref.placement,\n      props = _objectWithoutProperties(_ref, ['hasToasts', 'placement']);\n\n  return (0, _core.jsx)('div', _extends({\n    className: 'react-toast-notifications__container',\n    css: _extends({\n      boxSizing: 'border-box',\n      maxHeight: '100%',\n      maxWidth: '100%',\n      overflow: 'hidden',\n      padding: _ToastElement.gutter,\n      pointerEvents: hasToasts ? null : 'none',\n      position: 'fixed',\n      zIndex: 1000\n    }, placements[placement])\n  }, props));\n};\nexports.ToastContainer = ToastContainer;","'use strict';\n\nmodule.exports = function bind(fn, thisArg) {\n  return function wrap() {\n    var args = new Array(arguments.length);\n    for (var i = 0; i < args.length; i++) {\n      args[i] = arguments[i];\n    }\n    return fn.apply(thisArg, args);\n  };\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction encode(val) {\n  return encodeURIComponent(val).\n    replace(/%3A/gi, ':').\n    replace(/%24/g, '$').\n    replace(/%2C/gi, ',').\n    replace(/%20/g, '+').\n    replace(/%5B/gi, '[').\n    replace(/%5D/gi, ']');\n}\n\n/**\n * Build a URL by appending params to the end\n *\n * @param {string} url The base of the url (e.g., http://www.google.com)\n * @param {object} [params] The params to be appended\n * @returns {string} The formatted url\n */\nmodule.exports = function buildURL(url, params, paramsSerializer) {\n  /*eslint no-param-reassign:0*/\n  if (!params) {\n    return url;\n  }\n\n  var serializedParams;\n  if (paramsSerializer) {\n    serializedParams = paramsSerializer(params);\n  } else if (utils.isURLSearchParams(params)) {\n    serializedParams = params.toString();\n  } else {\n    var parts = [];\n\n    utils.forEach(params, function serialize(val, key) {\n      if (val === null || typeof val === 'undefined') {\n        return;\n      }\n\n      if (utils.isArray(val)) {\n        key = key + '[]';\n      } else {\n        val = [val];\n      }\n\n      utils.forEach(val, function parseValue(v) {\n        if (utils.isDate(v)) {\n          v = v.toISOString();\n        } else if (utils.isObject(v)) {\n          v = JSON.stringify(v);\n        }\n        parts.push(encode(key) + '=' + encode(v));\n      });\n    });\n\n    serializedParams = parts.join('&');\n  }\n\n  if (serializedParams) {\n    var hashmarkIndex = url.indexOf('#');\n    if (hashmarkIndex !== -1) {\n      url = url.slice(0, hashmarkIndex);\n    }\n\n    url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;\n  }\n\n  return url;\n};\n","'use strict';\n\nmodule.exports = function isCancel(value) {\n  return !!(value && value.__CANCEL__);\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar normalizeHeaderName = require('./helpers/normalizeHeaderName');\n\nvar DEFAULT_CONTENT_TYPE = {\n  'Content-Type': 'application/x-www-form-urlencoded'\n};\n\nfunction setContentTypeIfUnset(headers, value) {\n  if (!utils.isUndefined(headers) && utils.isUndefined(headers['Content-Type'])) {\n    headers['Content-Type'] = value;\n  }\n}\n\nfunction getDefaultAdapter() {\n  var adapter;\n  if (typeof XMLHttpRequest !== 'undefined') {\n    // For browsers use XHR adapter\n    adapter = require('./adapters/xhr');\n  } else if (typeof process !== 'undefined' && Object.prototype.toString.call(process) === '[object process]') {\n    // For node use HTTP adapter\n    adapter = require('./adapters/http');\n  }\n  return adapter;\n}\n\nvar defaults = {\n  adapter: getDefaultAdapter(),\n\n  transformRequest: [function transformRequest(data, headers) {\n    normalizeHeaderName(headers, 'Accept');\n    normalizeHeaderName(headers, 'Content-Type');\n    if (utils.isFormData(data) ||\n      utils.isArrayBuffer(data) ||\n      utils.isBuffer(data) ||\n      utils.isStream(data) ||\n      utils.isFile(data) ||\n      utils.isBlob(data)\n    ) {\n      return data;\n    }\n    if (utils.isArrayBufferView(data)) {\n      return data.buffer;\n    }\n    if (utils.isURLSearchParams(data)) {\n      setContentTypeIfUnset(headers, 'application/x-www-form-urlencoded;charset=utf-8');\n      return data.toString();\n    }\n    if (utils.isObject(data)) {\n      setContentTypeIfUnset(headers, 'application/json;charset=utf-8');\n      return JSON.stringify(data);\n    }\n    return data;\n  }],\n\n  transformResponse: [function transformResponse(data) {\n    /*eslint no-param-reassign:0*/\n    if (typeof data === 'string') {\n      try {\n        data = JSON.parse(data);\n      } catch (e) { /* Ignore */ }\n    }\n    return data;\n  }],\n\n  /**\n   * A timeout in milliseconds to abort a request. If set to 0 (default) a\n   * timeout is not created.\n   */\n  timeout: 0,\n\n  xsrfCookieName: 'XSRF-TOKEN',\n  xsrfHeaderName: 'X-XSRF-TOKEN',\n\n  maxContentLength: -1,\n  maxBodyLength: -1,\n\n  validateStatus: function validateStatus(status) {\n    return status >= 200 && status < 300;\n  }\n};\n\ndefaults.headers = {\n  common: {\n    'Accept': 'application/json, text/plain, */*'\n  }\n};\n\nutils.forEach(['delete', 'get', 'head'], function forEachMethodNoData(method) {\n  defaults.headers[method] = {};\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n  defaults.headers[method] = utils.merge(DEFAULT_CONTENT_TYPE);\n});\n\nmodule.exports = defaults;\n","'use strict';\n\nvar utils = require('./../utils');\nvar settle = require('./../core/settle');\nvar cookies = require('./../helpers/cookies');\nvar buildURL = require('./../helpers/buildURL');\nvar buildFullPath = require('../core/buildFullPath');\nvar parseHeaders = require('./../helpers/parseHeaders');\nvar isURLSameOrigin = require('./../helpers/isURLSameOrigin');\nvar createError = require('../core/createError');\n\nmodule.exports = function xhrAdapter(config) {\n  return new Promise(function dispatchXhrRequest(resolve, reject) {\n    var requestData = config.data;\n    var requestHeaders = config.headers;\n\n    if (utils.isFormData(requestData)) {\n      delete requestHeaders['Content-Type']; // Let the browser set it\n    }\n\n    var request = new XMLHttpRequest();\n\n    // HTTP basic authentication\n    if (config.auth) {\n      var username = config.auth.username || '';\n      var password = config.auth.password ? unescape(encodeURIComponent(config.auth.password)) : '';\n      requestHeaders.Authorization = 'Basic ' + btoa(username + ':' + password);\n    }\n\n    var fullPath = buildFullPath(config.baseURL, config.url);\n    request.open(config.method.toUpperCase(), buildURL(fullPath, config.params, config.paramsSerializer), true);\n\n    // Set the request timeout in MS\n    request.timeout = config.timeout;\n\n    // Listen for ready state\n    request.onreadystatechange = function handleLoad() {\n      if (!request || request.readyState !== 4) {\n        return;\n      }\n\n      // The request errored out and we didn't get a response, this will be\n      // handled by onerror instead\n      // With one exception: request that using file: protocol, most browsers\n      // will return status as 0 even though it's a successful request\n      if (request.status === 0 && !(request.responseURL && request.responseURL.indexOf('file:') === 0)) {\n        return;\n      }\n\n      // Prepare the response\n      var responseHeaders = 'getAllResponseHeaders' in request ? parseHeaders(request.getAllResponseHeaders()) : null;\n      var responseData = !config.responseType || config.responseType === 'text' ? request.responseText : request.response;\n      var response = {\n        data: responseData,\n        status: request.status,\n        statusText: request.statusText,\n        headers: responseHeaders,\n        config: config,\n        request: request\n      };\n\n      settle(resolve, reject, response);\n\n      // Clean up request\n      request = null;\n    };\n\n    // Handle browser request cancellation (as opposed to a manual cancellation)\n    request.onabort = function handleAbort() {\n      if (!request) {\n        return;\n      }\n\n      reject(createError('Request aborted', config, 'ECONNABORTED', request));\n\n      // Clean up request\n      request = null;\n    };\n\n    // Handle low level network errors\n    request.onerror = function handleError() {\n      // Real errors are hidden from us by the browser\n      // onerror should only fire if it's a network error\n      reject(createError('Network Error', config, null, request));\n\n      // Clean up request\n      request = null;\n    };\n\n    // Handle timeout\n    request.ontimeout = function handleTimeout() {\n      var timeoutErrorMessage = 'timeout of ' + config.timeout + 'ms exceeded';\n      if (config.timeoutErrorMessage) {\n        timeoutErrorMessage = config.timeoutErrorMessage;\n      }\n      reject(createError(timeoutErrorMessage, config, 'ECONNABORTED',\n        request));\n\n      // Clean up request\n      request = null;\n    };\n\n    // Add xsrf header\n    // This is only done if running in a standard browser environment.\n    // Specifically not if we're in a web worker, or react-native.\n    if (utils.isStandardBrowserEnv()) {\n      // Add xsrf header\n      var xsrfValue = (config.withCredentials || isURLSameOrigin(fullPath)) && config.xsrfCookieName ?\n        cookies.read(config.xsrfCookieName) :\n        undefined;\n\n      if (xsrfValue) {\n        requestHeaders[config.xsrfHeaderName] = xsrfValue;\n      }\n    }\n\n    // Add headers to the request\n    if ('setRequestHeader' in request) {\n      utils.forEach(requestHeaders, function setRequestHeader(val, key) {\n        if (typeof requestData === 'undefined' && key.toLowerCase() === 'content-type') {\n          // Remove Content-Type if data is undefined\n          delete requestHeaders[key];\n        } else {\n          // Otherwise add header to the request\n          request.setRequestHeader(key, val);\n        }\n      });\n    }\n\n    // Add withCredentials to request if needed\n    if (!utils.isUndefined(config.withCredentials)) {\n      request.withCredentials = !!config.withCredentials;\n    }\n\n    // Add responseType to request if needed\n    if (config.responseType) {\n      try {\n        request.responseType = config.responseType;\n      } catch (e) {\n        // Expected DOMException thrown by browsers not compatible XMLHttpRequest Level 2.\n        // But, this can be suppressed for 'json' type as it can be parsed by default 'transformResponse' function.\n        if (config.responseType !== 'json') {\n          throw e;\n        }\n      }\n    }\n\n    // Handle progress if needed\n    if (typeof config.onDownloadProgress === 'function') {\n      request.addEventListener('progress', config.onDownloadProgress);\n    }\n\n    // Not all browsers support upload events\n    if (typeof config.onUploadProgress === 'function' && request.upload) {\n      request.upload.addEventListener('progress', config.onUploadProgress);\n    }\n\n    if (config.cancelToken) {\n      // Handle cancellation\n      config.cancelToken.promise.then(function onCanceled(cancel) {\n        if (!request) {\n          return;\n        }\n\n        request.abort();\n        reject(cancel);\n        // Clean up request\n        request = null;\n      });\n    }\n\n    if (!requestData) {\n      requestData = null;\n    }\n\n    // Send the request\n    request.send(requestData);\n  });\n};\n","'use strict';\n\nvar enhanceError = require('./enhanceError');\n\n/**\n * Create an Error with the specified message, config, error code, request and response.\n *\n * @param {string} message The error message.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The created error.\n */\nmodule.exports = function createError(message, config, code, request, response) {\n  var error = new Error(message);\n  return enhanceError(error, config, code, request, response);\n};\n","'use strict';\n\nvar utils = require('../utils');\n\n/**\n * Config-specific merge-function which creates a new config-object\n * by merging two configuration objects together.\n *\n * @param {Object} config1\n * @param {Object} config2\n * @returns {Object} New object resulting from merging config2 to config1\n */\nmodule.exports = function mergeConfig(config1, config2) {\n  // eslint-disable-next-line no-param-reassign\n  config2 = config2 || {};\n  var config = {};\n\n  var valueFromConfig2Keys = ['url', 'method', 'data'];\n  var mergeDeepPropertiesKeys = ['headers', 'auth', 'proxy', 'params'];\n  var defaultToConfig2Keys = [\n    'baseURL', 'transformRequest', 'transformResponse', 'paramsSerializer',\n    'timeout', 'timeoutMessage', 'withCredentials', 'adapter', 'responseType', 'xsrfCookieName',\n    'xsrfHeaderName', 'onUploadProgress', 'onDownloadProgress', 'decompress',\n    'maxContentLength', 'maxBodyLength', 'maxRedirects', 'transport', 'httpAgent',\n    'httpsAgent', 'cancelToken', 'socketPath', 'responseEncoding'\n  ];\n  var directMergeKeys = ['validateStatus'];\n\n  function getMergedValue(target, source) {\n    if (utils.isPlainObject(target) && utils.isPlainObject(source)) {\n      return utils.merge(target, source);\n    } else if (utils.isPlainObject(source)) {\n      return utils.merge({}, source);\n    } else if (utils.isArray(source)) {\n      return source.slice();\n    }\n    return source;\n  }\n\n  function mergeDeepProperties(prop) {\n    if (!utils.isUndefined(config2[prop])) {\n      config[prop] = getMergedValue(config1[prop], config2[prop]);\n    } else if (!utils.isUndefined(config1[prop])) {\n      config[prop] = getMergedValue(undefined, config1[prop]);\n    }\n  }\n\n  utils.forEach(valueFromConfig2Keys, function valueFromConfig2(prop) {\n    if (!utils.isUndefined(config2[prop])) {\n      config[prop] = getMergedValue(undefined, config2[prop]);\n    }\n  });\n\n  utils.forEach(mergeDeepPropertiesKeys, mergeDeepProperties);\n\n  utils.forEach(defaultToConfig2Keys, function defaultToConfig2(prop) {\n    if (!utils.isUndefined(config2[prop])) {\n      config[prop] = getMergedValue(undefined, config2[prop]);\n    } else if (!utils.isUndefined(config1[prop])) {\n      config[prop] = getMergedValue(undefined, config1[prop]);\n    }\n  });\n\n  utils.forEach(directMergeKeys, function merge(prop) {\n    if (prop in config2) {\n      config[prop] = getMergedValue(config1[prop], config2[prop]);\n    } else if (prop in config1) {\n      config[prop] = getMergedValue(undefined, config1[prop]);\n    }\n  });\n\n  var axiosKeys = valueFromConfig2Keys\n    .concat(mergeDeepPropertiesKeys)\n    .concat(defaultToConfig2Keys)\n    .concat(directMergeKeys);\n\n  var otherKeys = Object\n    .keys(config1)\n    .concat(Object.keys(config2))\n    .filter(function filterAxiosKeys(key) {\n      return axiosKeys.indexOf(key) === -1;\n    });\n\n  utils.forEach(otherKeys, mergeDeepProperties);\n\n  return config;\n};\n","'use strict';\n\n/**\n * A `Cancel` is an object that is thrown when an operation is canceled.\n *\n * @class\n * @param {string=} message The message.\n */\nfunction Cancel(message) {\n  this.message = message;\n}\n\nCancel.prototype.toString = function toString() {\n  return 'Cancel' + (this.message ? ': ' + this.message : '');\n};\n\nCancel.prototype.__CANCEL__ = true;\n\nmodule.exports = Cancel;\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","/*\n\nBased off glamor's StyleSheet, thanks Sunil ❤️\n\nhigh performance StyleSheet for css-in-js systems\n\n- uses multiple style tags behind the scenes for millions of rules\n- uses `insertRule` for appending in production for *much* faster performance\n\n// usage\n\nimport { StyleSheet } from '@emotion/sheet'\n\nlet styleSheet = new StyleSheet({ key: '', container: document.head })\n\nstyleSheet.insert('#box { border: 1px solid red; }')\n- appends a css rule into the stylesheet\n\nstyleSheet.flush()\n- empties the stylesheet of all its contents\n\n*/\n// $FlowFixMe\nfunction sheetForTag(tag) {\n  if (tag.sheet) {\n    // $FlowFixMe\n    return tag.sheet;\n  } // this weirdness brought to you by firefox\n\n  /* istanbul ignore next */\n\n\n  for (var i = 0; i < document.styleSheets.length; i++) {\n    if (document.styleSheets[i].ownerNode === tag) {\n      // $FlowFixMe\n      return document.styleSheets[i];\n    }\n  }\n}\n\nfunction createStyleElement(options) {\n  var tag = document.createElement('style');\n  tag.setAttribute('data-emotion', options.key);\n\n  if (options.nonce !== undefined) {\n    tag.setAttribute('nonce', options.nonce);\n  }\n\n  tag.appendChild(document.createTextNode(''));\n  return tag;\n}\n\nvar StyleSheet =\n/*#__PURE__*/\nfunction () {\n  function StyleSheet(options) {\n    this.isSpeedy = options.speedy === undefined ? process.env.NODE_ENV === 'production' : options.speedy;\n    this.tags = [];\n    this.ctr = 0;\n    this.nonce = options.nonce; // key is the value of the data-emotion attribute, it's used to identify different sheets\n\n    this.key = options.key;\n    this.container = options.container;\n    this.before = null;\n  }\n\n  var _proto = StyleSheet.prototype;\n\n  _proto.insert = function insert(rule) {\n    // the max length is how many rules we have per style tag, it's 65000 in speedy mode\n    // it's 1 in dev because we insert source maps that map a single rule to a location\n    // and you can only have one source map per style tag\n    if (this.ctr % (this.isSpeedy ? 65000 : 1) === 0) {\n      var _tag = createStyleElement(this);\n\n      var before;\n\n      if (this.tags.length === 0) {\n        before = this.before;\n      } else {\n        before = this.tags[this.tags.length - 1].nextSibling;\n      }\n\n      this.container.insertBefore(_tag, before);\n      this.tags.push(_tag);\n    }\n\n    var tag = this.tags[this.tags.length - 1];\n\n    if (this.isSpeedy) {\n      var sheet = sheetForTag(tag);\n\n      try {\n        // this is a really hot path\n        // we check the second character first because having \"i\"\n        // as the second character will happen less often than\n        // having \"@\" as the first character\n        var isImportRule = rule.charCodeAt(1) === 105 && rule.charCodeAt(0) === 64; // this is the ultrafast version, works across browsers\n        // the big drawback is that the css won't be editable in devtools\n\n        sheet.insertRule(rule, // we need to insert @import rules before anything else\n        // otherwise there will be an error\n        // technically this means that the @import rules will\n        // _usually_(not always since there could be multiple style tags)\n        // be the first ones in prod and generally later in dev\n        // this shouldn't really matter in the real world though\n        // @import is generally only used for font faces from google fonts and etc.\n        // so while this could be technically correct then it would be slower and larger\n        // for a tiny bit of correctness that won't matter in the real world\n        isImportRule ? 0 : sheet.cssRules.length);\n      } catch (e) {\n        if (process.env.NODE_ENV !== 'production') {\n          console.warn(\"There was a problem inserting the following rule: \\\"\" + rule + \"\\\"\", e);\n        }\n      }\n    } else {\n      tag.appendChild(document.createTextNode(rule));\n    }\n\n    this.ctr++;\n  };\n\n  _proto.flush = function flush() {\n    // $FlowFixMe\n    this.tags.forEach(function (tag) {\n      return tag.parentNode.removeChild(tag);\n    });\n    this.tags = [];\n    this.ctr = 0;\n  };\n\n  return StyleSheet;\n}();\n\nexport { StyleSheet };\n","function stylis_min (W) {\n  function M(d, c, e, h, a) {\n    for (var m = 0, b = 0, v = 0, n = 0, q, g, x = 0, K = 0, k, u = k = q = 0, l = 0, r = 0, I = 0, t = 0, B = e.length, J = B - 1, y, f = '', p = '', F = '', G = '', C; l < B;) {\n      g = e.charCodeAt(l);\n      l === J && 0 !== b + n + v + m && (0 !== b && (g = 47 === b ? 10 : 47), n = v = m = 0, B++, J++);\n\n      if (0 === b + n + v + m) {\n        if (l === J && (0 < r && (f = f.replace(N, '')), 0 < f.trim().length)) {\n          switch (g) {\n            case 32:\n            case 9:\n            case 59:\n            case 13:\n            case 10:\n              break;\n\n            default:\n              f += e.charAt(l);\n          }\n\n          g = 59;\n        }\n\n        switch (g) {\n          case 123:\n            f = f.trim();\n            q = f.charCodeAt(0);\n            k = 1;\n\n            for (t = ++l; l < B;) {\n              switch (g = e.charCodeAt(l)) {\n                case 123:\n                  k++;\n                  break;\n\n                case 125:\n                  k--;\n                  break;\n\n                case 47:\n                  switch (g = e.charCodeAt(l + 1)) {\n                    case 42:\n                    case 47:\n                      a: {\n                        for (u = l + 1; u < J; ++u) {\n                          switch (e.charCodeAt(u)) {\n                            case 47:\n                              if (42 === g && 42 === e.charCodeAt(u - 1) && l + 2 !== u) {\n                                l = u + 1;\n                                break a;\n                              }\n\n                              break;\n\n                            case 10:\n                              if (47 === g) {\n                                l = u + 1;\n                                break a;\n                              }\n\n                          }\n                        }\n\n                        l = u;\n                      }\n\n                  }\n\n                  break;\n\n                case 91:\n                  g++;\n\n                case 40:\n                  g++;\n\n                case 34:\n                case 39:\n                  for (; l++ < J && e.charCodeAt(l) !== g;) {\n                  }\n\n              }\n\n              if (0 === k) break;\n              l++;\n            }\n\n            k = e.substring(t, l);\n            0 === q && (q = (f = f.replace(ca, '').trim()).charCodeAt(0));\n\n            switch (q) {\n              case 64:\n                0 < r && (f = f.replace(N, ''));\n                g = f.charCodeAt(1);\n\n                switch (g) {\n                  case 100:\n                  case 109:\n                  case 115:\n                  case 45:\n                    r = c;\n                    break;\n\n                  default:\n                    r = O;\n                }\n\n                k = M(c, r, k, g, a + 1);\n                t = k.length;\n                0 < A && (r = X(O, f, I), C = H(3, k, r, c, D, z, t, g, a, h), f = r.join(''), void 0 !== C && 0 === (t = (k = C.trim()).length) && (g = 0, k = ''));\n                if (0 < t) switch (g) {\n                  case 115:\n                    f = f.replace(da, ea);\n\n                  case 100:\n                  case 109:\n                  case 45:\n                    k = f + '{' + k + '}';\n                    break;\n\n                  case 107:\n                    f = f.replace(fa, '$1 $2');\n                    k = f + '{' + k + '}';\n                    k = 1 === w || 2 === w && L('@' + k, 3) ? '@-webkit-' + k + '@' + k : '@' + k;\n                    break;\n\n                  default:\n                    k = f + k, 112 === h && (k = (p += k, ''));\n                } else k = '';\n                break;\n\n              default:\n                k = M(c, X(c, f, I), k, h, a + 1);\n            }\n\n            F += k;\n            k = I = r = u = q = 0;\n            f = '';\n            g = e.charCodeAt(++l);\n            break;\n\n          case 125:\n          case 59:\n            f = (0 < r ? f.replace(N, '') : f).trim();\n            if (1 < (t = f.length)) switch (0 === u && (q = f.charCodeAt(0), 45 === q || 96 < q && 123 > q) && (t = (f = f.replace(' ', ':')).length), 0 < A && void 0 !== (C = H(1, f, c, d, D, z, p.length, h, a, h)) && 0 === (t = (f = C.trim()).length) && (f = '\\x00\\x00'), q = f.charCodeAt(0), g = f.charCodeAt(1), q) {\n              case 0:\n                break;\n\n              case 64:\n                if (105 === g || 99 === g) {\n                  G += f + e.charAt(l);\n                  break;\n                }\n\n              default:\n                58 !== f.charCodeAt(t - 1) && (p += P(f, q, g, f.charCodeAt(2)));\n            }\n            I = r = u = q = 0;\n            f = '';\n            g = e.charCodeAt(++l);\n        }\n      }\n\n      switch (g) {\n        case 13:\n        case 10:\n          47 === b ? b = 0 : 0 === 1 + q && 107 !== h && 0 < f.length && (r = 1, f += '\\x00');\n          0 < A * Y && H(0, f, c, d, D, z, p.length, h, a, h);\n          z = 1;\n          D++;\n          break;\n\n        case 59:\n        case 125:\n          if (0 === b + n + v + m) {\n            z++;\n            break;\n          }\n\n        default:\n          z++;\n          y = e.charAt(l);\n\n          switch (g) {\n            case 9:\n            case 32:\n              if (0 === n + m + b) switch (x) {\n                case 44:\n                case 58:\n                case 9:\n                case 32:\n                  y = '';\n                  break;\n\n                default:\n                  32 !== g && (y = ' ');\n              }\n              break;\n\n            case 0:\n              y = '\\\\0';\n              break;\n\n            case 12:\n              y = '\\\\f';\n              break;\n\n            case 11:\n              y = '\\\\v';\n              break;\n\n            case 38:\n              0 === n + b + m && (r = I = 1, y = '\\f' + y);\n              break;\n\n            case 108:\n              if (0 === n + b + m + E && 0 < u) switch (l - u) {\n                case 2:\n                  112 === x && 58 === e.charCodeAt(l - 3) && (E = x);\n\n                case 8:\n                  111 === K && (E = K);\n              }\n              break;\n\n            case 58:\n              0 === n + b + m && (u = l);\n              break;\n\n            case 44:\n              0 === b + v + n + m && (r = 1, y += '\\r');\n              break;\n\n            case 34:\n            case 39:\n              0 === b && (n = n === g ? 0 : 0 === n ? g : n);\n              break;\n\n            case 91:\n              0 === n + b + v && m++;\n              break;\n\n            case 93:\n              0 === n + b + v && m--;\n              break;\n\n            case 41:\n              0 === n + b + m && v--;\n              break;\n\n            case 40:\n              if (0 === n + b + m) {\n                if (0 === q) switch (2 * x + 3 * K) {\n                  case 533:\n                    break;\n\n                  default:\n                    q = 1;\n                }\n                v++;\n              }\n\n              break;\n\n            case 64:\n              0 === b + v + n + m + u + k && (k = 1);\n              break;\n\n            case 42:\n            case 47:\n              if (!(0 < n + m + v)) switch (b) {\n                case 0:\n                  switch (2 * g + 3 * e.charCodeAt(l + 1)) {\n                    case 235:\n                      b = 47;\n                      break;\n\n                    case 220:\n                      t = l, b = 42;\n                  }\n\n                  break;\n\n                case 42:\n                  47 === g && 42 === x && t + 2 !== l && (33 === e.charCodeAt(t + 2) && (p += e.substring(t, l + 1)), y = '', b = 0);\n              }\n          }\n\n          0 === b && (f += y);\n      }\n\n      K = x;\n      x = g;\n      l++;\n    }\n\n    t = p.length;\n\n    if (0 < t) {\n      r = c;\n      if (0 < A && (C = H(2, p, r, d, D, z, t, h, a, h), void 0 !== C && 0 === (p = C).length)) return G + p + F;\n      p = r.join(',') + '{' + p + '}';\n\n      if (0 !== w * E) {\n        2 !== w || L(p, 2) || (E = 0);\n\n        switch (E) {\n          case 111:\n            p = p.replace(ha, ':-moz-$1') + p;\n            break;\n\n          case 112:\n            p = p.replace(Q, '::-webkit-input-$1') + p.replace(Q, '::-moz-$1') + p.replace(Q, ':-ms-input-$1') + p;\n        }\n\n        E = 0;\n      }\n    }\n\n    return G + p + F;\n  }\n\n  function X(d, c, e) {\n    var h = c.trim().split(ia);\n    c = h;\n    var a = h.length,\n        m = d.length;\n\n    switch (m) {\n      case 0:\n      case 1:\n        var b = 0;\n\n        for (d = 0 === m ? '' : d[0] + ' '; b < a; ++b) {\n          c[b] = Z(d, c[b], e).trim();\n        }\n\n        break;\n\n      default:\n        var v = b = 0;\n\n        for (c = []; b < a; ++b) {\n          for (var n = 0; n < m; ++n) {\n            c[v++] = Z(d[n] + ' ', h[b], e).trim();\n          }\n        }\n\n    }\n\n    return c;\n  }\n\n  function Z(d, c, e) {\n    var h = c.charCodeAt(0);\n    33 > h && (h = (c = c.trim()).charCodeAt(0));\n\n    switch (h) {\n      case 38:\n        return c.replace(F, '$1' + d.trim());\n\n      case 58:\n        return d.trim() + c.replace(F, '$1' + d.trim());\n\n      default:\n        if (0 < 1 * e && 0 < c.indexOf('\\f')) return c.replace(F, (58 === d.charCodeAt(0) ? '' : '$1') + d.trim());\n    }\n\n    return d + c;\n  }\n\n  function P(d, c, e, h) {\n    var a = d + ';',\n        m = 2 * c + 3 * e + 4 * h;\n\n    if (944 === m) {\n      d = a.indexOf(':', 9) + 1;\n      var b = a.substring(d, a.length - 1).trim();\n      b = a.substring(0, d).trim() + b + ';';\n      return 1 === w || 2 === w && L(b, 1) ? '-webkit-' + b + b : b;\n    }\n\n    if (0 === w || 2 === w && !L(a, 1)) return a;\n\n    switch (m) {\n      case 1015:\n        return 97 === a.charCodeAt(10) ? '-webkit-' + a + a : a;\n\n      case 951:\n        return 116 === a.charCodeAt(3) ? '-webkit-' + a + a : a;\n\n      case 963:\n        return 110 === a.charCodeAt(5) ? '-webkit-' + a + a : a;\n\n      case 1009:\n        if (100 !== a.charCodeAt(4)) break;\n\n      case 969:\n      case 942:\n        return '-webkit-' + a + a;\n\n      case 978:\n        return '-webkit-' + a + '-moz-' + a + a;\n\n      case 1019:\n      case 983:\n        return '-webkit-' + a + '-moz-' + a + '-ms-' + a + a;\n\n      case 883:\n        if (45 === a.charCodeAt(8)) return '-webkit-' + a + a;\n        if (0 < a.indexOf('image-set(', 11)) return a.replace(ja, '$1-webkit-$2') + a;\n        break;\n\n      case 932:\n        if (45 === a.charCodeAt(4)) switch (a.charCodeAt(5)) {\n          case 103:\n            return '-webkit-box-' + a.replace('-grow', '') + '-webkit-' + a + '-ms-' + a.replace('grow', 'positive') + a;\n\n          case 115:\n            return '-webkit-' + a + '-ms-' + a.replace('shrink', 'negative') + a;\n\n          case 98:\n            return '-webkit-' + a + '-ms-' + a.replace('basis', 'preferred-size') + a;\n        }\n        return '-webkit-' + a + '-ms-' + a + a;\n\n      case 964:\n        return '-webkit-' + a + '-ms-flex-' + a + a;\n\n      case 1023:\n        if (99 !== a.charCodeAt(8)) break;\n        b = a.substring(a.indexOf(':', 15)).replace('flex-', '').replace('space-between', 'justify');\n        return '-webkit-box-pack' + b + '-webkit-' + a + '-ms-flex-pack' + b + a;\n\n      case 1005:\n        return ka.test(a) ? a.replace(aa, ':-webkit-') + a.replace(aa, ':-moz-') + a : a;\n\n      case 1e3:\n        b = a.substring(13).trim();\n        c = b.indexOf('-') + 1;\n\n        switch (b.charCodeAt(0) + b.charCodeAt(c)) {\n          case 226:\n            b = a.replace(G, 'tb');\n            break;\n\n          case 232:\n            b = a.replace(G, 'tb-rl');\n            break;\n\n          case 220:\n            b = a.replace(G, 'lr');\n            break;\n\n          default:\n            return a;\n        }\n\n        return '-webkit-' + a + '-ms-' + b + a;\n\n      case 1017:\n        if (-1 === a.indexOf('sticky', 9)) break;\n\n      case 975:\n        c = (a = d).length - 10;\n        b = (33 === a.charCodeAt(c) ? a.substring(0, c) : a).substring(d.indexOf(':', 7) + 1).trim();\n\n        switch (m = b.charCodeAt(0) + (b.charCodeAt(7) | 0)) {\n          case 203:\n            if (111 > b.charCodeAt(8)) break;\n\n          case 115:\n            a = a.replace(b, '-webkit-' + b) + ';' + a;\n            break;\n\n          case 207:\n          case 102:\n            a = a.replace(b, '-webkit-' + (102 < m ? 'inline-' : '') + 'box') + ';' + a.replace(b, '-webkit-' + b) + ';' + a.replace(b, '-ms-' + b + 'box') + ';' + a;\n        }\n\n        return a + ';';\n\n      case 938:\n        if (45 === a.charCodeAt(5)) switch (a.charCodeAt(6)) {\n          case 105:\n            return b = a.replace('-items', ''), '-webkit-' + a + '-webkit-box-' + b + '-ms-flex-' + b + a;\n\n          case 115:\n            return '-webkit-' + a + '-ms-flex-item-' + a.replace(ba, '') + a;\n\n          default:\n            return '-webkit-' + a + '-ms-flex-line-pack' + a.replace('align-content', '').replace(ba, '') + a;\n        }\n        break;\n\n      case 973:\n      case 989:\n        if (45 !== a.charCodeAt(3) || 122 === a.charCodeAt(4)) break;\n\n      case 931:\n      case 953:\n        if (!0 === la.test(d)) return 115 === (b = d.substring(d.indexOf(':') + 1)).charCodeAt(0) ? P(d.replace('stretch', 'fill-available'), c, e, h).replace(':fill-available', ':stretch') : a.replace(b, '-webkit-' + b) + a.replace(b, '-moz-' + b.replace('fill-', '')) + a;\n        break;\n\n      case 962:\n        if (a = '-webkit-' + a + (102 === a.charCodeAt(5) ? '-ms-' + a : '') + a, 211 === e + h && 105 === a.charCodeAt(13) && 0 < a.indexOf('transform', 10)) return a.substring(0, a.indexOf(';', 27) + 1).replace(ma, '$1-webkit-$2') + a;\n    }\n\n    return a;\n  }\n\n  function L(d, c) {\n    var e = d.indexOf(1 === c ? ':' : '{'),\n        h = d.substring(0, 3 !== c ? e : 10);\n    e = d.substring(e + 1, d.length - 1);\n    return R(2 !== c ? h : h.replace(na, '$1'), e, c);\n  }\n\n  function ea(d, c) {\n    var e = P(c, c.charCodeAt(0), c.charCodeAt(1), c.charCodeAt(2));\n    return e !== c + ';' ? e.replace(oa, ' or ($1)').substring(4) : '(' + c + ')';\n  }\n\n  function H(d, c, e, h, a, m, b, v, n, q) {\n    for (var g = 0, x = c, w; g < A; ++g) {\n      switch (w = S[g].call(B, d, x, e, h, a, m, b, v, n, q)) {\n        case void 0:\n        case !1:\n        case !0:\n        case null:\n          break;\n\n        default:\n          x = w;\n      }\n    }\n\n    if (x !== c) return x;\n  }\n\n  function T(d) {\n    switch (d) {\n      case void 0:\n      case null:\n        A = S.length = 0;\n        break;\n\n      default:\n        if ('function' === typeof d) S[A++] = d;else if ('object' === typeof d) for (var c = 0, e = d.length; c < e; ++c) {\n          T(d[c]);\n        } else Y = !!d | 0;\n    }\n\n    return T;\n  }\n\n  function U(d) {\n    d = d.prefix;\n    void 0 !== d && (R = null, d ? 'function' !== typeof d ? w = 1 : (w = 2, R = d) : w = 0);\n    return U;\n  }\n\n  function B(d, c) {\n    var e = d;\n    33 > e.charCodeAt(0) && (e = e.trim());\n    V = e;\n    e = [V];\n\n    if (0 < A) {\n      var h = H(-1, c, e, e, D, z, 0, 0, 0, 0);\n      void 0 !== h && 'string' === typeof h && (c = h);\n    }\n\n    var a = M(O, e, c, 0, 0);\n    0 < A && (h = H(-2, a, e, e, D, z, a.length, 0, 0, 0), void 0 !== h && (a = h));\n    V = '';\n    E = 0;\n    z = D = 1;\n    return a;\n  }\n\n  var ca = /^\\0+/g,\n      N = /[\\0\\r\\f]/g,\n      aa = /: */g,\n      ka = /zoo|gra/,\n      ma = /([,: ])(transform)/g,\n      ia = /,\\r+?/g,\n      F = /([\\t\\r\\n ])*\\f?&/g,\n      fa = /@(k\\w+)\\s*(\\S*)\\s*/,\n      Q = /::(place)/g,\n      ha = /:(read-only)/g,\n      G = /[svh]\\w+-[tblr]{2}/,\n      da = /\\(\\s*(.*)\\s*\\)/g,\n      oa = /([\\s\\S]*?);/g,\n      ba = /-self|flex-/g,\n      na = /[^]*?(:[rp][el]a[\\w-]+)[^]*/,\n      la = /stretch|:\\s*\\w+\\-(?:conte|avail)/,\n      ja = /([^-])(image-set\\()/,\n      z = 1,\n      D = 1,\n      E = 0,\n      w = 1,\n      O = [],\n      S = [],\n      A = 0,\n      R = null,\n      Y = 0,\n      V = '';\n  B.use = T;\n  B.set = U;\n  void 0 !== W && U(W);\n  return B;\n}\n\nexport default stylis_min;\n","import { StyleSheet } from '@emotion/sheet';\nimport Stylis from '@emotion/stylis';\nimport '@emotion/weak-memoize';\n\n// https://github.com/thysultan/stylis.js/tree/master/plugins/rule-sheet\n// inlined to avoid umd wrapper and peerDep warnings/installing stylis\n// since we use stylis after closure compiler\nvar delimiter = '/*|*/';\nvar needle = delimiter + '}';\n\nfunction toSheet(block) {\n  if (block) {\n    Sheet.current.insert(block + '}');\n  }\n}\n\nvar Sheet = {\n  current: null\n};\nvar ruleSheet = function ruleSheet(context, content, selectors, parents, line, column, length, ns, depth, at) {\n  switch (context) {\n    // property\n    case 1:\n      {\n        switch (content.charCodeAt(0)) {\n          case 64:\n            {\n              // @import\n              Sheet.current.insert(content + ';');\n              return '';\n            }\n          // charcode for l\n\n          case 108:\n            {\n              // charcode for b\n              // this ignores label\n              if (content.charCodeAt(2) === 98) {\n                return '';\n              }\n            }\n        }\n\n        break;\n      }\n    // selector\n\n    case 2:\n      {\n        if (ns === 0) return content + delimiter;\n        break;\n      }\n    // at-rule\n\n    case 3:\n      {\n        switch (ns) {\n          // @font-face, @page\n          case 102:\n          case 112:\n            {\n              Sheet.current.insert(selectors[0] + content);\n              return '';\n            }\n\n          default:\n            {\n              return content + (at === 0 ? delimiter : '');\n            }\n        }\n      }\n\n    case -2:\n      {\n        content.split(needle).forEach(toSheet);\n      }\n  }\n};\n\nvar createCache = function createCache(options) {\n  if (options === undefined) options = {};\n  var key = options.key || 'css';\n  var stylisOptions;\n\n  if (options.prefix !== undefined) {\n    stylisOptions = {\n      prefix: options.prefix\n    };\n  }\n\n  var stylis = new Stylis(stylisOptions);\n\n  if (process.env.NODE_ENV !== 'production') {\n    // $FlowFixMe\n    if (/[^a-z-]/.test(key)) {\n      throw new Error(\"Emotion key must only contain lower case alphabetical characters and - but \\\"\" + key + \"\\\" was passed\");\n    }\n  }\n\n  var inserted = {}; // $FlowFixMe\n\n  var container;\n\n  {\n    container = options.container || document.head;\n    var nodes = document.querySelectorAll(\"style[data-emotion-\" + key + \"]\");\n    Array.prototype.forEach.call(nodes, function (node) {\n      var attrib = node.getAttribute(\"data-emotion-\" + key); // $FlowFixMe\n\n      attrib.split(' ').forEach(function (id) {\n        inserted[id] = true;\n      });\n\n      if (node.parentNode !== container) {\n        container.appendChild(node);\n      }\n    });\n  }\n\n  var _insert;\n\n  {\n    stylis.use(options.stylisPlugins)(ruleSheet);\n\n    _insert = function insert(selector, serialized, sheet, shouldCache) {\n      var name = serialized.name;\n      Sheet.current = sheet;\n\n      if (process.env.NODE_ENV !== 'production' && serialized.map !== undefined) {\n        var map = serialized.map;\n        Sheet.current = {\n          insert: function insert(rule) {\n            sheet.insert(rule + map);\n          }\n        };\n      }\n\n      stylis(selector, serialized.styles);\n\n      if (shouldCache) {\n        cache.inserted[name] = true;\n      }\n    };\n  }\n\n  if (process.env.NODE_ENV !== 'production') {\n    // https://esbench.com/bench/5bf7371a4cd7e6009ef61d0a\n    var commentStart = /\\/\\*/g;\n    var commentEnd = /\\*\\//g;\n    stylis.use(function (context, content) {\n      switch (context) {\n        case -1:\n          {\n            while (commentStart.test(content)) {\n              commentEnd.lastIndex = commentStart.lastIndex;\n\n              if (commentEnd.test(content)) {\n                commentStart.lastIndex = commentEnd.lastIndex;\n                continue;\n              }\n\n              throw new Error('Your styles have an unterminated comment (\"/*\" without corresponding \"*/\").');\n            }\n\n            commentStart.lastIndex = 0;\n            break;\n          }\n      }\n    });\n    stylis.use(function (context, content, selectors) {\n      switch (context) {\n        case -1:\n          {\n            var flag = 'emotion-disable-server-rendering-unsafe-selector-warning-please-do-not-use-this-the-warning-exists-for-a-reason';\n            var unsafePseudoClasses = content.match(/(:first|:nth|:nth-last)-child/g);\n\n            if (unsafePseudoClasses && cache.compat !== true) {\n              unsafePseudoClasses.forEach(function (unsafePseudoClass) {\n                var ignoreRegExp = new RegExp(unsafePseudoClass + \".*\\\\/\\\\* \" + flag + \" \\\\*\\\\/\");\n                var ignore = ignoreRegExp.test(content);\n\n                if (unsafePseudoClass && !ignore) {\n                  console.error(\"The pseudo class \\\"\" + unsafePseudoClass + \"\\\" is potentially unsafe when doing server-side rendering. Try changing it to \\\"\" + unsafePseudoClass.split('-child')[0] + \"-of-type\\\".\");\n                }\n              });\n            }\n\n            break;\n          }\n      }\n    });\n  }\n\n  var cache = {\n    key: key,\n    sheet: new StyleSheet({\n      key: key,\n      container: container,\n      nonce: options.nonce,\n      speedy: options.speedy\n    }),\n    nonce: options.nonce,\n    inserted: inserted,\n    registered: {},\n    insert: _insert\n  };\n  return cache;\n};\n\nexport default createCache;\n","var isBrowser = \"object\" !== 'undefined';\nfunction getRegisteredStyles(registered, registeredStyles, classNames) {\n  var rawClassName = '';\n  classNames.split(' ').forEach(function (className) {\n    if (registered[className] !== undefined) {\n      registeredStyles.push(registered[className]);\n    } else {\n      rawClassName += className + \" \";\n    }\n  });\n  return rawClassName;\n}\nvar insertStyles = function insertStyles(cache, serialized, isStringTag) {\n  var className = cache.key + \"-\" + serialized.name;\n\n  if ( // we only need to add the styles to the registered cache if the\n  // class name could be used further down\n  // the tree but if it's a string tag, we know it won't\n  // so we don't have to add it to registered cache.\n  // this improves memory usage since we can avoid storing the whole style string\n  (isStringTag === false || // we need to always store it if we're in compat mode and\n  // in node since emotion-server relies on whether a style is in\n  // the registered cache to know whether a style is global or not\n  // also, note that this check will be dead code eliminated in the browser\n  isBrowser === false && cache.compat !== undefined) && cache.registered[className] === undefined) {\n    cache.registered[className] = serialized.styles;\n  }\n\n  if (cache.inserted[serialized.name] === undefined) {\n    var current = serialized;\n\n    do {\n      var maybeStyles = cache.insert(\".\" + className, current, cache.sheet, true);\n\n      current = current.next;\n    } while (current !== undefined);\n  }\n};\n\nexport { getRegisteredStyles, insertStyles };\n","/* eslint-disable */\n// Inspired by https://github.com/garycourt/murmurhash-js\n// Ported from https://github.com/aappleby/smhasher/blob/61a0530f28277f2e850bfc39600ce61d02b518de/src/MurmurHash2.cpp#L37-L86\nfunction murmur2(str) {\n  // 'm' and 'r' are mixing constants generated offline.\n  // They're not really 'magic', they just happen to work well.\n  // const m = 0x5bd1e995;\n  // const r = 24;\n  // Initialize the hash\n  var h = 0; // Mix 4 bytes at a time into the hash\n\n  var k,\n      i = 0,\n      len = str.length;\n\n  for (; len >= 4; ++i, len -= 4) {\n    k = str.charCodeAt(i) & 0xff | (str.charCodeAt(++i) & 0xff) << 8 | (str.charCodeAt(++i) & 0xff) << 16 | (str.charCodeAt(++i) & 0xff) << 24;\n    k =\n    /* Math.imul(k, m): */\n    (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16);\n    k ^=\n    /* k >>> r: */\n    k >>> 24;\n    h =\n    /* Math.imul(k, m): */\n    (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16) ^\n    /* Math.imul(h, m): */\n    (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n  } // Handle the last few bytes of the input array\n\n\n  switch (len) {\n    case 3:\n      h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\n\n    case 2:\n      h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\n\n    case 1:\n      h ^= str.charCodeAt(i) & 0xff;\n      h =\n      /* Math.imul(h, m): */\n      (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n  } // Do a few final mixes of the hash to ensure the last few\n  // bytes are well-incorporated.\n\n\n  h ^= h >>> 13;\n  h =\n  /* Math.imul(h, m): */\n  (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n  return ((h ^ h >>> 15) >>> 0).toString(36);\n}\n\nexport default murmur2;\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","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","import hashString from '@emotion/hash';\nimport unitless from '@emotion/unitless';\nimport memoize from '@emotion/memoize';\n\nvar ILLEGAL_ESCAPE_SEQUENCE_ERROR = \"You have illegal escape sequence in your template literal, most likely inside content's property value.\\nBecause you write your CSS inside a JavaScript string you actually have to do double escaping, so for example \\\"content: '\\\\00d7';\\\" should become \\\"content: '\\\\\\\\00d7';\\\".\\nYou can read more about this here:\\nhttps://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals#ES2018_revision_of_illegal_escape_sequences\";\nvar UNDEFINED_AS_OBJECT_KEY_ERROR = \"You have passed in falsy value as style object's key (can happen when in example you pass unexported component as computed key).\";\nvar hyphenateRegex = /[A-Z]|^ms/g;\nvar animationRegex = /_EMO_([^_]+?)_([^]*?)_EMO_/g;\n\nvar isCustomProperty = function isCustomProperty(property) {\n  return property.charCodeAt(1) === 45;\n};\n\nvar isProcessableValue = function isProcessableValue(value) {\n  return value != null && typeof value !== 'boolean';\n};\n\nvar processStyleName = memoize(function (styleName) {\n  return isCustomProperty(styleName) ? styleName : styleName.replace(hyphenateRegex, '-$&').toLowerCase();\n});\n\nvar processStyleValue = function processStyleValue(key, value) {\n  switch (key) {\n    case 'animation':\n    case 'animationName':\n      {\n        if (typeof value === 'string') {\n          return value.replace(animationRegex, function (match, p1, p2) {\n            cursor = {\n              name: p1,\n              styles: p2,\n              next: cursor\n            };\n            return p1;\n          });\n        }\n      }\n  }\n\n  if (unitless[key] !== 1 && !isCustomProperty(key) && typeof value === 'number' && value !== 0) {\n    return value + 'px';\n  }\n\n  return value;\n};\n\nif (process.env.NODE_ENV !== 'production') {\n  var contentValuePattern = /(attr|calc|counters?|url)\\(/;\n  var contentValues = ['normal', 'none', 'counter', 'open-quote', 'close-quote', 'no-open-quote', 'no-close-quote', 'initial', 'inherit', 'unset'];\n  var oldProcessStyleValue = processStyleValue;\n  var msPattern = /^-ms-/;\n  var hyphenPattern = /-(.)/g;\n  var hyphenatedCache = {};\n\n  processStyleValue = function processStyleValue(key, value) {\n    if (key === 'content') {\n      if (typeof value !== 'string' || contentValues.indexOf(value) === -1 && !contentValuePattern.test(value) && (value.charAt(0) !== value.charAt(value.length - 1) || value.charAt(0) !== '\"' && value.charAt(0) !== \"'\")) {\n        console.error(\"You seem to be using a value for 'content' without quotes, try replacing it with `content: '\\\"\" + value + \"\\\"'`\");\n      }\n    }\n\n    var processed = oldProcessStyleValue(key, value);\n\n    if (processed !== '' && !isCustomProperty(key) && key.indexOf('-') !== -1 && hyphenatedCache[key] === undefined) {\n      hyphenatedCache[key] = true;\n      console.error(\"Using kebab-case for css properties in objects is not supported. Did you mean \" + key.replace(msPattern, 'ms-').replace(hyphenPattern, function (str, _char) {\n        return _char.toUpperCase();\n      }) + \"?\");\n    }\n\n    return processed;\n  };\n}\n\nvar shouldWarnAboutInterpolatingClassNameFromCss = true;\n\nfunction handleInterpolation(mergedProps, registered, interpolation, couldBeSelectorInterpolation) {\n  if (interpolation == null) {\n    return '';\n  }\n\n  if (interpolation.__emotion_styles !== undefined) {\n    if (process.env.NODE_ENV !== 'production' && interpolation.toString() === 'NO_COMPONENT_SELECTOR') {\n      throw new Error('Component selectors can only be used in conjunction with babel-plugin-emotion.');\n    }\n\n    return interpolation;\n  }\n\n  switch (typeof interpolation) {\n    case 'boolean':\n      {\n        return '';\n      }\n\n    case 'object':\n      {\n        if (interpolation.anim === 1) {\n          cursor = {\n            name: interpolation.name,\n            styles: interpolation.styles,\n            next: cursor\n          };\n          return interpolation.name;\n        }\n\n        if (interpolation.styles !== undefined) {\n          var next = interpolation.next;\n\n          if (next !== undefined) {\n            // not the most efficient thing ever but this is a pretty rare case\n            // and there will be very few iterations of this generally\n            while (next !== undefined) {\n              cursor = {\n                name: next.name,\n                styles: next.styles,\n                next: cursor\n              };\n              next = next.next;\n            }\n          }\n\n          var styles = interpolation.styles + \";\";\n\n          if (process.env.NODE_ENV !== 'production' && interpolation.map !== undefined) {\n            styles += interpolation.map;\n          }\n\n          return styles;\n        }\n\n        return createStringFromObject(mergedProps, registered, interpolation);\n      }\n\n    case 'function':\n      {\n        if (mergedProps !== undefined) {\n          var previousCursor = cursor;\n          var result = interpolation(mergedProps);\n          cursor = previousCursor;\n          return handleInterpolation(mergedProps, registered, result, couldBeSelectorInterpolation);\n        } else if (process.env.NODE_ENV !== 'production') {\n          console.error('Functions that are interpolated in css calls will be stringified.\\n' + 'If you want to have a css call based on props, create a function that returns a css call like this\\n' + 'let dynamicStyle = (props) => css`color: ${props.color}`\\n' + 'It can be called directly with props or interpolated in a styled call like this\\n' + \"let SomeComponent = styled('div')`${dynamicStyle}`\");\n        }\n\n        break;\n      }\n\n    case 'string':\n      if (process.env.NODE_ENV !== 'production') {\n        var matched = [];\n        var replaced = interpolation.replace(animationRegex, function (match, p1, p2) {\n          var fakeVarName = \"animation\" + matched.length;\n          matched.push(\"const \" + fakeVarName + \" = keyframes`\" + p2.replace(/^@keyframes animation-\\w+/, '') + \"`\");\n          return \"${\" + fakeVarName + \"}\";\n        });\n\n        if (matched.length) {\n          console.error('`keyframes` output got interpolated into plain string, please wrap it with `css`.\\n\\n' + 'Instead of doing this:\\n\\n' + [].concat(matched, [\"`\" + replaced + \"`\"]).join('\\n') + '\\n\\nYou should wrap it with `css` like this:\\n\\n' + (\"css`\" + replaced + \"`\"));\n        }\n      }\n\n      break;\n  } // finalize string values (regular strings and functions interpolated into css calls)\n\n\n  if (registered == null) {\n    return interpolation;\n  }\n\n  var cached = registered[interpolation];\n\n  if (process.env.NODE_ENV !== 'production' && couldBeSelectorInterpolation && shouldWarnAboutInterpolatingClassNameFromCss && cached !== undefined) {\n    console.error('Interpolating a className from css`` is not recommended and will cause problems with composition.\\n' + 'Interpolating a className from css`` will be completely unsupported in a future major version of Emotion');\n    shouldWarnAboutInterpolatingClassNameFromCss = false;\n  }\n\n  return cached !== undefined && !couldBeSelectorInterpolation ? cached : interpolation;\n}\n\nfunction createStringFromObject(mergedProps, registered, obj) {\n  var string = '';\n\n  if (Array.isArray(obj)) {\n    for (var i = 0; i < obj.length; i++) {\n      string += handleInterpolation(mergedProps, registered, obj[i], false);\n    }\n  } else {\n    for (var _key in obj) {\n      var value = obj[_key];\n\n      if (typeof value !== 'object') {\n        if (registered != null && registered[value] !== undefined) {\n          string += _key + \"{\" + registered[value] + \"}\";\n        } else if (isProcessableValue(value)) {\n          string += processStyleName(_key) + \":\" + processStyleValue(_key, value) + \";\";\n        }\n      } else {\n        if (_key === 'NO_COMPONENT_SELECTOR' && process.env.NODE_ENV !== 'production') {\n          throw new Error('Component selectors can only be used in conjunction with babel-plugin-emotion.');\n        }\n\n        if (Array.isArray(value) && typeof value[0] === 'string' && (registered == null || registered[value[0]] === undefined)) {\n          for (var _i = 0; _i < value.length; _i++) {\n            if (isProcessableValue(value[_i])) {\n              string += processStyleName(_key) + \":\" + processStyleValue(_key, value[_i]) + \";\";\n            }\n          }\n        } else {\n          var interpolated = handleInterpolation(mergedProps, registered, value, false);\n\n          switch (_key) {\n            case 'animation':\n            case 'animationName':\n              {\n                string += processStyleName(_key) + \":\" + interpolated + \";\";\n                break;\n              }\n\n            default:\n              {\n                if (process.env.NODE_ENV !== 'production' && _key === 'undefined') {\n                  console.error(UNDEFINED_AS_OBJECT_KEY_ERROR);\n                }\n\n                string += _key + \"{\" + interpolated + \"}\";\n              }\n          }\n        }\n      }\n    }\n  }\n\n  return string;\n}\n\nvar labelPattern = /label:\\s*([^\\s;\\n{]+)\\s*;/g;\nvar sourceMapPattern;\n\nif (process.env.NODE_ENV !== 'production') {\n  sourceMapPattern = /\\/\\*#\\ssourceMappingURL=data:application\\/json;\\S+\\s+\\*\\//;\n} // this is the cursor for keyframes\n// keyframes are stored on the SerializedStyles object as a linked list\n\n\nvar cursor;\nvar serializeStyles = function serializeStyles(args, registered, mergedProps) {\n  if (args.length === 1 && typeof args[0] === 'object' && args[0] !== null && args[0].styles !== undefined) {\n    return args[0];\n  }\n\n  var stringMode = true;\n  var styles = '';\n  cursor = undefined;\n  var strings = args[0];\n\n  if (strings == null || strings.raw === undefined) {\n    stringMode = false;\n    styles += handleInterpolation(mergedProps, registered, strings, false);\n  } else {\n    if (process.env.NODE_ENV !== 'production' && strings[0] === undefined) {\n      console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);\n    }\n\n    styles += strings[0];\n  } // we start at 1 since we've already handled the first arg\n\n\n  for (var i = 1; i < args.length; i++) {\n    styles += handleInterpolation(mergedProps, registered, args[i], styles.charCodeAt(styles.length - 1) === 46);\n\n    if (stringMode) {\n      if (process.env.NODE_ENV !== 'production' && strings[i] === undefined) {\n        console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);\n      }\n\n      styles += strings[i];\n    }\n  }\n\n  var sourceMap;\n\n  if (process.env.NODE_ENV !== 'production') {\n    styles = styles.replace(sourceMapPattern, function (match) {\n      sourceMap = match;\n      return '';\n    });\n  } // using a global regex with .exec is stateful so lastIndex has to be reset each time\n\n\n  labelPattern.lastIndex = 0;\n  var identifierName = '';\n  var match; // https://esbench.com/bench/5b809c2cf2949800a0f61fb5\n\n  while ((match = labelPattern.exec(styles)) !== null) {\n    identifierName += '-' + // $FlowFixMe we know it's not null\n    match[1];\n  }\n\n  var name = hashString(styles) + identifierName;\n\n  if (process.env.NODE_ENV !== 'production') {\n    // $FlowFixMe SerializedStyles type doesn't have toString property (and we don't want to add it)\n    return {\n      name: name,\n      styles: styles,\n      map: sourceMap,\n      next: cursor,\n      toString: function toString() {\n        return \"You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).\";\n      }\n    };\n  }\n\n  return {\n    name: name,\n    styles: styles,\n    next: cursor\n  };\n};\n\nexport { serializeStyles };\n","import '@babel/runtime/helpers/inheritsLoose';\nimport { createContext, forwardRef, createElement } from 'react';\nimport createCache from '@emotion/cache';\nimport { getRegisteredStyles, insertStyles } from '@emotion/utils';\nimport { serializeStyles } from '@emotion/serialize';\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nvar EmotionCacheContext = /*#__PURE__*/createContext( // we're doing this to avoid preconstruct's dead code elimination in this one case\n// because this module is primarily intended for the browser and node\n// but it's also required in react native and similar environments sometimes\n// and we could have a special build just for that\n// but this is much easier and the native packages\n// might use a different theme context in the future anyway\ntypeof HTMLElement !== 'undefined' ? createCache() : null);\nvar ThemeContext = /*#__PURE__*/createContext({});\nvar CacheProvider = EmotionCacheContext.Provider;\n\nvar withEmotionCache = function withEmotionCache(func) {\n  var render = function render(props, ref) {\n    return /*#__PURE__*/createElement(EmotionCacheContext.Consumer, null, function (cache) {\n      return func(props, cache, ref);\n    });\n  }; // $FlowFixMe\n\n\n  return /*#__PURE__*/forwardRef(render);\n};\n\n// thus we only need to replace what is a valid character for JS, but not for CSS\n\nvar sanitizeIdentifier = function sanitizeIdentifier(identifier) {\n  return identifier.replace(/\\$/g, '-');\n};\n\nvar typePropName = '__EMOTION_TYPE_PLEASE_DO_NOT_USE__';\nvar labelPropName = '__EMOTION_LABEL_PLEASE_DO_NOT_USE__';\nvar createEmotionProps = function createEmotionProps(type, props) {\n  if (process.env.NODE_ENV !== 'production' && typeof props.css === 'string' && // check if there is a css declaration\n  props.css.indexOf(':') !== -1) {\n    throw new Error(\"Strings are not allowed as css prop values, please wrap it in a css template literal from '@emotion/css' like this: css`\" + props.css + \"`\");\n  }\n\n  var newProps = {};\n\n  for (var key in props) {\n    if (hasOwnProperty.call(props, key)) {\n      newProps[key] = props[key];\n    }\n  }\n\n  newProps[typePropName] = type; // TODO: check if this still works with all of those different JSX functions\n\n  if (process.env.NODE_ENV !== 'production') {\n    var error = new Error();\n\n    if (error.stack) {\n      // chrome\n      var match = error.stack.match(/at (?:Object\\.|Module\\.|)(?:jsx|createEmotionProps).*\\n\\s+at (?:Object\\.|)([A-Z][A-Za-z$]+) /);\n\n      if (!match) {\n        // safari and firefox\n        match = error.stack.match(/.*\\n([A-Z][A-Za-z$]+)@/);\n      }\n\n      if (match) {\n        newProps[labelPropName] = sanitizeIdentifier(match[1]);\n      }\n    }\n  }\n\n  return newProps;\n};\n\nvar render = function render(cache, props, theme, ref) {\n  var cssProp = theme === null ? props.css : props.css(theme); // so that using `css` from `emotion` and passing the result to the css prop works\n  // not passing the registered cache to serializeStyles because it would\n  // make certain babel optimisations not possible\n\n  if (typeof cssProp === 'string' && cache.registered[cssProp] !== undefined) {\n    cssProp = cache.registered[cssProp];\n  }\n\n  var type = props[typePropName];\n  var registeredStyles = [cssProp];\n  var className = '';\n\n  if (typeof props.className === 'string') {\n    className = getRegisteredStyles(cache.registered, registeredStyles, props.className);\n  } else if (props.className != null) {\n    className = props.className + \" \";\n  }\n\n  var serialized = serializeStyles(registeredStyles);\n\n  if (process.env.NODE_ENV !== 'production' && serialized.name.indexOf('-') === -1) {\n    var labelFromStack = props[labelPropName];\n\n    if (labelFromStack) {\n      serialized = serializeStyles([serialized, 'label:' + labelFromStack + ';']);\n    }\n  }\n\n  var rules = insertStyles(cache, serialized, typeof type === 'string');\n  className += cache.key + \"-\" + serialized.name;\n  var newProps = {};\n\n  for (var key in props) {\n    if (hasOwnProperty.call(props, key) && key !== 'css' && key !== typePropName && (process.env.NODE_ENV === 'production' || key !== labelPropName)) {\n      newProps[key] = props[key];\n    }\n  }\n\n  newProps.ref = ref;\n  newProps.className = className;\n  var ele = /*#__PURE__*/createElement(type, newProps);\n\n  return ele;\n}; // eslint-disable-next-line no-undef\n\n\nvar Emotion = /* #__PURE__ */withEmotionCache(function (props, cache, ref) {\n  if (typeof props.css === 'function') {\n    return /*#__PURE__*/createElement(ThemeContext.Consumer, null, function (theme) {\n      return render(cache, props, theme, ref);\n    });\n  }\n\n  return render(cache, props, null, ref);\n});\n\nif (process.env.NODE_ENV !== 'production') {\n  Emotion.displayName = 'EmotionCssPropInternal';\n}\n\nexport { CacheProvider as C, Emotion as E, ThemeContext as T, createEmotionProps as c, hasOwnProperty as h, withEmotionCache as w };\n","import { serializeStyles } from '@emotion/serialize';\n\nfunction css() {\n  for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n    args[_key] = arguments[_key];\n  }\n\n  return serializeStyles(args);\n}\n\nexport default css;\n","import _inheritsLoose from '@babel/runtime/helpers/esm/inheritsLoose';\nimport { createElement, Component } from 'react';\nimport '@emotion/cache';\nimport { h as hasOwnProperty, E as Emotion, c as createEmotionProps, w as withEmotionCache, T as ThemeContext } from './emotion-element-57a3a7a3.browser.esm.js';\nexport { C as CacheProvider, T as ThemeContext, w as withEmotionCache } from './emotion-element-57a3a7a3.browser.esm.js';\nimport { insertStyles, getRegisteredStyles } from '@emotion/utils';\nimport { serializeStyles } from '@emotion/serialize';\nimport { StyleSheet } from '@emotion/sheet';\nimport css from '@emotion/css';\nexport { default as css } from '@emotion/css';\n\nvar jsx = function jsx(type, props) {\n  var args = arguments;\n\n  if (props == null || !hasOwnProperty.call(props, 'css')) {\n    // $FlowFixMe\n    return createElement.apply(undefined, args);\n  }\n\n  var argsLength = args.length;\n  var createElementArgArray = new Array(argsLength);\n  createElementArgArray[0] = Emotion;\n  createElementArgArray[1] = createEmotionProps(type, props);\n\n  for (var i = 2; i < argsLength; i++) {\n    createElementArgArray[i] = args[i];\n  } // $FlowFixMe\n\n\n  return createElement.apply(null, createElementArgArray);\n};\n\nvar warnedAboutCssPropForGlobal = false;\nvar Global = /* #__PURE__ */withEmotionCache(function (props, cache) {\n  if (process.env.NODE_ENV !== 'production' && !warnedAboutCssPropForGlobal && ( // check for className as well since the user is\n  // probably using the custom createElement which\n  // means it will be turned into a className prop\n  // $FlowFixMe I don't really want to add it to the type since it shouldn't be used\n  props.className || props.css)) {\n    console.error(\"It looks like you're using the css prop on Global, did you mean to use the styles prop instead?\");\n    warnedAboutCssPropForGlobal = true;\n  }\n\n  var styles = props.styles;\n\n  if (typeof styles === 'function') {\n    return /*#__PURE__*/createElement(ThemeContext.Consumer, null, function (theme) {\n      var serialized = serializeStyles([styles(theme)]);\n      return /*#__PURE__*/createElement(InnerGlobal, {\n        serialized: serialized,\n        cache: cache\n      });\n    });\n  }\n\n  var serialized = serializeStyles([styles]);\n  return /*#__PURE__*/createElement(InnerGlobal, {\n    serialized: serialized,\n    cache: cache\n  });\n});\n\n// maintain place over rerenders.\n// initial render from browser, insertBefore context.sheet.tags[0] or if a style hasn't been inserted there yet, appendChild\n// initial client-side render from SSR, use place of hydrating tag\nvar InnerGlobal = /*#__PURE__*/function (_React$Component) {\n  _inheritsLoose(InnerGlobal, _React$Component);\n\n  function InnerGlobal(props, context, updater) {\n    return _React$Component.call(this, props, context, updater) || this;\n  }\n\n  var _proto = InnerGlobal.prototype;\n\n  _proto.componentDidMount = function componentDidMount() {\n    this.sheet = new StyleSheet({\n      key: this.props.cache.key + \"-global\",\n      nonce: this.props.cache.sheet.nonce,\n      container: this.props.cache.sheet.container\n    }); // $FlowFixMe\n\n    var node = document.querySelector(\"style[data-emotion-\" + this.props.cache.key + \"=\\\"\" + this.props.serialized.name + \"\\\"]\");\n\n    if (node !== null) {\n      this.sheet.tags.push(node);\n    }\n\n    if (this.props.cache.sheet.tags.length) {\n      this.sheet.before = this.props.cache.sheet.tags[0];\n    }\n\n    this.insertStyles();\n  };\n\n  _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n    if (prevProps.serialized.name !== this.props.serialized.name) {\n      this.insertStyles();\n    }\n  };\n\n  _proto.insertStyles = function insertStyles$1() {\n    if (this.props.serialized.next !== undefined) {\n      // insert keyframes\n      insertStyles(this.props.cache, this.props.serialized.next, true);\n    }\n\n    if (this.sheet.tags.length) {\n      // if this doesn't exist then it will be null so the style element will be appended\n      var element = this.sheet.tags[this.sheet.tags.length - 1].nextElementSibling;\n      this.sheet.before = element;\n      this.sheet.flush();\n    }\n\n    this.props.cache.insert(\"\", this.props.serialized, this.sheet, false);\n  };\n\n  _proto.componentWillUnmount = function componentWillUnmount() {\n    this.sheet.flush();\n  };\n\n  _proto.render = function render() {\n\n    return null;\n  };\n\n  return InnerGlobal;\n}(Component);\n\nvar keyframes = function keyframes() {\n  var insertable = css.apply(void 0, arguments);\n  var name = \"animation-\" + insertable.name; // $FlowFixMe\n\n  return {\n    name: name,\n    styles: \"@keyframes \" + name + \"{\" + insertable.styles + \"}\",\n    anim: 1,\n    toString: function toString() {\n      return \"_EMO_\" + this.name + \"_\" + this.styles + \"_EMO_\";\n    }\n  };\n};\n\nvar classnames = function classnames(args) {\n  var len = args.length;\n  var i = 0;\n  var cls = '';\n\n  for (; i < len; i++) {\n    var arg = args[i];\n    if (arg == null) continue;\n    var toAdd = void 0;\n\n    switch (typeof arg) {\n      case 'boolean':\n        break;\n\n      case 'object':\n        {\n          if (Array.isArray(arg)) {\n            toAdd = classnames(arg);\n          } else {\n            toAdd = '';\n\n            for (var k in arg) {\n              if (arg[k] && k) {\n                toAdd && (toAdd += ' ');\n                toAdd += k;\n              }\n            }\n          }\n\n          break;\n        }\n\n      default:\n        {\n          toAdd = arg;\n        }\n    }\n\n    if (toAdd) {\n      cls && (cls += ' ');\n      cls += toAdd;\n    }\n  }\n\n  return cls;\n};\n\nfunction merge(registered, css, className) {\n  var registeredStyles = [];\n  var rawClassName = getRegisteredStyles(registered, registeredStyles, className);\n\n  if (registeredStyles.length < 2) {\n    return className;\n  }\n\n  return rawClassName + css(registeredStyles);\n}\n\nvar ClassNames = withEmotionCache(function (props, context) {\n  return /*#__PURE__*/createElement(ThemeContext.Consumer, null, function (theme) {\n    var hasRendered = false;\n\n    var css = function css() {\n      if (hasRendered && process.env.NODE_ENV !== 'production') {\n        throw new Error('css can only be used during render');\n      }\n\n      for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n        args[_key] = arguments[_key];\n      }\n\n      var serialized = serializeStyles(args, context.registered);\n\n      {\n        insertStyles(context, serialized, false);\n      }\n\n      return context.key + \"-\" + serialized.name;\n    };\n\n    var cx = function cx() {\n      if (hasRendered && process.env.NODE_ENV !== 'production') {\n        throw new Error('cx can only be used during render');\n      }\n\n      for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n        args[_key2] = arguments[_key2];\n      }\n\n      return merge(context.registered, css, classnames(args));\n    };\n\n    var content = {\n      css: css,\n      cx: cx,\n      theme: theme\n    };\n    var ele = props.children(content);\n    hasRendered = true;\n\n    return ele;\n  });\n});\n\nexport { ClassNames, Global, jsx as createElement, jsx, keyframes };\n","'use strict';\n\nexports.decode = exports.parse = require('./decode');\nexports.encode = exports.stringify = require('./encode');\n","!function(e,t){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=t(require(\"axios\")):\"function\"==typeof define&&define.amd?define([\"axios\"],t):\"object\"==typeof exports?exports[\"axios-auth-refresh\"]=t(require(\"axios\")):e[\"axios-auth-refresh\"]=t(e.axios)}(this,(function(e){return function(e){var t={};function r(n){if(t[n])return t[n].exports;var o=t[n]={i:n,l:!1,exports:{}};return e[n].call(o.exports,o,o.exports,r),o.l=!0,o.exports}return r.m=e,r.c=t,r.d=function(e,t,n){r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},r.r=function(e){\"undefined\"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:\"Module\"}),Object.defineProperty(e,\"__esModule\",{value:!0})},r.t=function(e,t){if(1&t&&(e=r(e)),8&t)return e;if(4&t&&\"object\"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(r.r(n),Object.defineProperty(n,\"default\",{enumerable:!0,value:e}),2&t&&\"string\"!=typeof e)for(var o in e)r.d(n,o,function(t){return e[t]}.bind(null,o));return n},r.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(t,\"a\",t),t},r.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},r.p=\"\",r(r.s=0)}([function(e,t,r){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0});var n=r(1),o={skipInstances:[],refreshCall:void 0,requestQueueInterceptorId:void 0};t.default=function(e,t,r){if(void 0===r&&(r={}),\"function\"!=typeof t)throw new Error(\"axios-auth-refresh requires `refreshAuthCall` to be a function that returns a promise.\");return e.interceptors.response.use((function(e){return e}),(function(s){if(r=n.mergeOptions(n.defaultOptions,r),!n.shouldInterceptError(s,r,e,o))return Promise.reject(s);r.pauseInstanceWhileRefreshing&&o.skipInstances.push(e);var u=n.createRefreshCall(s,t,o);return n.createRequestQueueInterceptor(e,o,r),u.finally((function(){return n.unsetCache(e,o)})).catch((function(e){return Promise.reject(e)})).then((function(){return n.resendFailedRequest(s,n.getRetryInstance(e,r))}))}))}},function(e,t,r){\"use strict\";var n=this&&this.__assign||function(){return(n=Object.assign||function(e){for(var t,r=1,n=arguments.length;r<n;r++)for(var o in t=arguments[r])Object.prototype.hasOwnProperty.call(t,o)&&(e[o]=t[o]);return e}).apply(this,arguments)};Object.defineProperty(t,\"__esModule\",{value:!0}),t.resendFailedRequest=t.getRetryInstance=t.unsetCache=t.createRequestQueueInterceptor=t.createRefreshCall=t.shouldInterceptError=t.mergeOptions=t.defaultOptions=void 0;var o=r(2);t.defaultOptions={statusCodes:[401],pauseInstanceWhileRefreshing:!1},t.mergeOptions=function(e,t){return n(n(n({},e),{pauseInstanceWhileRefreshing:t.skipWhileRefreshing}),t)},t.shouldInterceptError=function(e,t,r,n){var o,s;return!!e&&(!(null===(o=e.config)||void 0===o?void 0:o.skipAuthRefresh)&&(!!(t.interceptNetworkError&&!e.response&&0===e.request.status||e.response&&(null===(s=t.statusCodes)||void 0===s?void 0:s.includes(parseInt(e.response.status))))&&(e.response||(e.response={config:e.config}),!t.pauseInstanceWhileRefreshing||!n.skipInstances.includes(r))))},t.createRefreshCall=function(e,t,r){return r.refreshCall||(r.refreshCall=t(e),\"function\"==typeof r.refreshCall.then)?r.refreshCall:(console.warn(\"axios-auth-refresh requires `refreshTokenCall` to return a promise.\"),Promise.reject())},t.createRequestQueueInterceptor=function(e,t,r){return void 0===t.requestQueueInterceptorId&&(t.requestQueueInterceptorId=e.interceptors.request.use((function(e){return t.refreshCall.catch((function(){throw new o.default.Cancel(\"Request call failed\")})).then((function(){return r.onRetry?r.onRetry(e):e}))}))),t.requestQueueInterceptorId},t.unsetCache=function(e,t){e.interceptors.request.eject(t.requestQueueInterceptorId),t.requestQueueInterceptorId=void 0,t.refreshCall=void 0,t.skipInstances=t.skipInstances.filter((function(t){return t!==e}))},t.getRetryInstance=function(e,t){return t.retryInstance||e},t.resendFailedRequest=function(e,t){return e.config.skipAuthRefresh=!0,t(e.response.config)}},function(t,r){t.exports=e}])}));","\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n    var extendStatics = function (d, b) {\n        extendStatics = Object.setPrototypeOf ||\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n        return extendStatics(d, b);\n    };\n    return function (d, b) {\n        extendStatics(d, b);\n        function __() { this.constructor = d; }\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n    };\n})();\nvar __assign = (this && this.__assign) || function () {\n    __assign = Object.assign || function(t) {\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\n            s = arguments[i];\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n                t[p] = s[p];\n        }\n        return t;\n    };\n    return __assign.apply(this, arguments);\n};\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\n}) : (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n    o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n    if (mod && mod.__esModule) return mod;\n    var result = {};\n    if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n    __setModuleDefault(result, mod);\n    return result;\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n    return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar React = __importStar(require(\"react\"));\nvar react_fast_compare_1 = __importDefault(require(\"react-fast-compare\"));\nvar AnnounceKit = /** @class */ (function (_super) {\n    __extends(AnnounceKit, _super);\n    function AnnounceKit(props) {\n        var _this = _super.call(this, props) || this;\n        _this.selector = \".ak-\" + Math.random().toString(36).substring(10);\n        _this.widgetHandlers = [];\n        return _this;\n    }\n    AnnounceKit.prototype.shouldComponentUpdate = function (props) {\n        var oldProps = {\n            data: this.props.data,\n            user: this.props.user,\n            lang: this.props.lang,\n        };\n        var newProps = {\n            data: props.data,\n            user: props.user,\n            lang: props.lang,\n        };\n        return !react_fast_compare_1.default(oldProps, newProps);\n    };\n    AnnounceKit.prototype.componentDidUpdate = function (prevProps) {\n        var oldProps = {\n            data: this.props.data,\n            user: this.props.user,\n            lang: this.props.lang,\n        };\n        var newProps = {\n            data: prevProps.data,\n            user: prevProps.user,\n            lang: prevProps.lang,\n        };\n        if (!react_fast_compare_1.default(oldProps, newProps)) {\n            if (this.widgetInstance) {\n                this.widgetInstance.destroy();\n                this.loaded();\n            }\n        }\n    };\n    AnnounceKit.prototype.componentDidMount = function () {\n        var _a;\n        if (!window[\"announcekit\"]) {\n            window[\"announcekit\"] = window[\"announcekit\"] || {\n                queue: [],\n                push: function (x) {\n                    window[\"announcekit\"].queue.push(x);\n                },\n                on: function (n, x) {\n                    window[\"announcekit\"].queue.push([n, x]);\n                },\n            };\n            var scripttag = document.createElement(\"script\");\n            scripttag[\"async\"] = true;\n            scripttag[\"src\"] = \"https://cdn.announcekit.app/widget-v2.js\";\n            var scr = document.getElementsByTagName(\"script\")[0];\n            (_a = scr === null || scr === void 0 ? void 0 : scr.parentNode) === null || _a === void 0 ? void 0 : _a.insertBefore(scripttag, scr);\n        }\n        this.loaded();\n    };\n    AnnounceKit.prototype.loaded = function () {\n        var _this = this;\n        var style = this.props.widgetStyle;\n        var styleParams = {\n            badge: {\n                style: style,\n            },\n            line: {\n                style: style,\n            },\n            float: {\n                style: style,\n            },\n        };\n        if (this.props.floatWidget) {\n            delete styleParams.badge;\n            delete styleParams.line;\n            this.selector = null;\n        }\n        this.name = Math.random().toString(36).substring(10);\n        window[\"announcekit\"].push(__assign(__assign({ widget: this.props.widget, name: this.name, version: 2, framework: \"react\", framework_version: \"2.0.0\", selector: this.selector, embed: this.props.embedWidget }, styleParams), { onInit: function (_widget) {\n                if (_widget.conf.name !== _this.name) {\n                    return _widget.destroy();\n                }\n                var ann = window[\"announcekit\"];\n                _this.widgetInstance = _widget;\n                if (_this.props.catchClick) {\n                    var elem = document.querySelector(_this.props.catchClick);\n                    if (elem)\n                        elem.addEventListener(\"click\", function () { return _widget.open(); });\n                }\n                _this.widgetHandlers.forEach(function (h) { return h(_widget); });\n                _this.widgetHandlers = [];\n                ann.on(\"widget-open\", function (_a) {\n                    var widget = _a.widget;\n                    if (widget === _widget && _this.props.onWidgetOpen) {\n                        _this.props.onWidgetOpen({ widget: widget });\n                    }\n                });\n                ann.on(\"widget-close\", function (_a) {\n                    var widget = _a.widget;\n                    if (widget === _widget && _this.props.onWidgetClose) {\n                        _this.props.onWidgetClose({ widget: widget });\n                    }\n                });\n                ann.on(\"widget-resize\", function (_a) {\n                    var widget = _a.widget, size = _a.size;\n                    if (widget === _widget && _this.props.onWidgetResize) {\n                        _this.props.onWidgetResize({ widget: widget, size: size });\n                    }\n                });\n                ann.on(\"widget-unread\", function (_a) {\n                    var widget = _a.widget, unread = _a.unread;\n                    if (widget === _widget && _this.props.onWidgetUnread) {\n                        _this.props.onWidgetUnread({ widget: widget, unread: unread });\n                    }\n                });\n            }, data: this.props.data, user: this.props.user, lang: this.props.lang }));\n    };\n    AnnounceKit.prototype.withWidget = function (fn) {\n        var _this = this;\n        return new Promise(function (res) {\n            if (_this.widgetInstance) {\n                return res(fn(_this.widgetInstance));\n            }\n            else {\n                _this.widgetHandlers.push(function (widget) {\n                    res(fn(widget));\n                });\n            }\n        });\n    };\n    AnnounceKit.prototype.open = function () {\n        return this.withWidget(function (widget) { return widget.open(); });\n    };\n    AnnounceKit.prototype.close = function () {\n        return this.withWidget(function (widget) { return widget.close(); });\n    };\n    AnnounceKit.prototype.instance = function () {\n        return this.withWidget(function (widget) { return widget; });\n    };\n    AnnounceKit.prototype.unread = function () {\n        return this.withWidget(function (widget) { return widget.state.ui.unreadCount; });\n    };\n    AnnounceKit.prototype.render = function () {\n        return (React.createElement(\"div\", { style: { display: \"inline\" }, className: this.selector ? this.selector.slice(1) : \"\" }, this.props.children));\n    };\n    return AnnounceKit;\n}(React.Component));\nexports.default = AnnounceKit;\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","'use strict';\nvar strictUriEncode = require('strict-uri-encode');\nvar objectAssign = require('object-assign');\n\nfunction encoderForArrayFormat(opts) {\n\tswitch (opts.arrayFormat) {\n\t\tcase 'index':\n\t\t\treturn function (key, value, index) {\n\t\t\t\treturn value === null ? [\n\t\t\t\t\tencode(key, opts),\n\t\t\t\t\t'[',\n\t\t\t\t\tindex,\n\t\t\t\t\t']'\n\t\t\t\t].join('') : [\n\t\t\t\t\tencode(key, opts),\n\t\t\t\t\t'[',\n\t\t\t\t\tencode(index, opts),\n\t\t\t\t\t']=',\n\t\t\t\t\tencode(value, opts)\n\t\t\t\t].join('');\n\t\t\t};\n\n\t\tcase 'bracket':\n\t\t\treturn function (key, value) {\n\t\t\t\treturn value === null ? encode(key, opts) : [\n\t\t\t\t\tencode(key, opts),\n\t\t\t\t\t'[]=',\n\t\t\t\t\tencode(value, opts)\n\t\t\t\t].join('');\n\t\t\t};\n\n\t\tdefault:\n\t\t\treturn function (key, value) {\n\t\t\t\treturn value === null ? encode(key, opts) : [\n\t\t\t\t\tencode(key, opts),\n\t\t\t\t\t'=',\n\t\t\t\t\tencode(value, opts)\n\t\t\t\t].join('');\n\t\t\t};\n\t}\n}\n\nfunction parserForArrayFormat(opts) {\n\tvar result;\n\n\tswitch (opts.arrayFormat) {\n\t\tcase 'index':\n\t\t\treturn function (key, value, accumulator) {\n\t\t\t\tresult = /\\[(\\d*)\\]$/.exec(key);\n\n\t\t\t\tkey = key.replace(/\\[\\d*\\]$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = {};\n\t\t\t\t}\n\n\t\t\t\taccumulator[key][result[1]] = value;\n\t\t\t};\n\n\t\tcase 'bracket':\n\t\t\treturn function (key, value, accumulator) {\n\t\t\t\tresult = /(\\[\\])$/.exec(key);\n\t\t\t\tkey = key.replace(/\\[\\]$/, '');\n\n\t\t\t\tif (!result) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t} else if (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = [value];\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\n\t\tdefault:\n\t\t\treturn function (key, value, accumulator) {\n\t\t\t\tif (accumulator[key] === undefined) {\n\t\t\t\t\taccumulator[key] = value;\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\taccumulator[key] = [].concat(accumulator[key], value);\n\t\t\t};\n\t}\n}\n\nfunction encode(value, opts) {\n\tif (opts.encode) {\n\t\treturn opts.strict ? strictUriEncode(value) : encodeURIComponent(value);\n\t}\n\n\treturn value;\n}\n\nfunction keysSorter(input) {\n\tif (Array.isArray(input)) {\n\t\treturn input.sort();\n\t} else if (typeof input === 'object') {\n\t\treturn keysSorter(Object.keys(input)).sort(function (a, b) {\n\t\t\treturn Number(a) - Number(b);\n\t\t}).map(function (key) {\n\t\t\treturn input[key];\n\t\t});\n\t}\n\n\treturn input;\n}\n\nexports.extract = function (str) {\n\treturn str.split('?')[1] || '';\n};\n\nexports.parse = function (str, opts) {\n\topts = objectAssign({arrayFormat: 'none'}, opts);\n\n\tvar formatter = parserForArrayFormat(opts);\n\n\t// Create an object with no prototype\n\t// https://github.com/sindresorhus/query-string/issues/47\n\tvar ret = Object.create(null);\n\n\tif (typeof str !== 'string') {\n\t\treturn ret;\n\t}\n\n\tstr = str.trim().replace(/^(\\?|#|&)/, '');\n\n\tif (!str) {\n\t\treturn ret;\n\t}\n\n\tstr.split('&').forEach(function (param) {\n\t\tvar parts = param.replace(/\\+/g, ' ').split('=');\n\t\t// Firefox (pre 40) decodes `%3D` to `=`\n\t\t// https://github.com/sindresorhus/query-string/pull/37\n\t\tvar key = parts.shift();\n\t\tvar val = parts.length > 0 ? parts.join('=') : undefined;\n\n\t\t// missing `=` should be `null`:\n\t\t// http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n\t\tval = val === undefined ? null : decodeURIComponent(val);\n\n\t\tformatter(decodeURIComponent(key), val, ret);\n\t});\n\n\treturn Object.keys(ret).sort().reduce(function (result, key) {\n\t\tvar val = ret[key];\n\t\tif (Boolean(val) && typeof val === 'object' && !Array.isArray(val)) {\n\t\t\t// Sort object keys, not values\n\t\t\tresult[key] = keysSorter(val);\n\t\t} else {\n\t\t\tresult[key] = val;\n\t\t}\n\n\t\treturn result;\n\t}, Object.create(null));\n};\n\nexports.stringify = function (obj, opts) {\n\tvar defaults = {\n\t\tencode: true,\n\t\tstrict: true,\n\t\tarrayFormat: 'none'\n\t};\n\n\topts = objectAssign(defaults, opts);\n\n\tvar formatter = encoderForArrayFormat(opts);\n\n\treturn obj ? Object.keys(obj).sort().map(function (key) {\n\t\tvar val = obj[key];\n\n\t\tif (val === undefined) {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (val === null) {\n\t\t\treturn encode(key, opts);\n\t\t}\n\n\t\tif (Array.isArray(val)) {\n\t\t\tvar result = [];\n\n\t\t\tval.slice().forEach(function (val2) {\n\t\t\t\tif (val2 === undefined) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tresult.push(formatter(key, val2, result.length));\n\t\t\t});\n\n\t\t\treturn result.join('&');\n\t\t}\n\n\t\treturn encode(key, opts) + '=' + encode(val, opts);\n\t}).filter(function (x) {\n\t\treturn x.length > 0;\n\t}).join('&') : '';\n};\n","import objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nexport default function _objectWithoutProperties(source, excluded) {\n  if (source == null) return {};\n  var target = objectWithoutPropertiesLoose(source, excluded);\n  var key, i;\n\n  if (Object.getOwnPropertySymbols) {\n    var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n\n    for (i = 0; i < sourceSymbolKeys.length; i++) {\n      key = sourceSymbolKeys[i];\n      if (excluded.indexOf(key) >= 0) continue;\n      if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n      target[key] = source[key];\n    }\n  }\n\n  return target;\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}","/** @license React v17.0.1\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.1\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.1\";\n","function _inheritsLoose(subClass, superClass) {\n  subClass.prototype = Object.create(superClass.prototype);\n  subClass.prototype.constructor = subClass;\n  subClass.__proto__ = superClass;\n}\n\nmodule.exports = _inheritsLoose;","/**\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    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\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.1\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.1\",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.1\";\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","/** @license React v0.20.1\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\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.CloseIcon = exports.InfoIcon = exports.FlameIcon = exports.CheckIcon = exports.AlertIcon = undefined;\n\nvar _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; };\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction getDefaultProps(width) {\n  return {\n    'aria-hidden': true,\n    height: 16,\n    width: width,\n    viewBox: '0 0 ' + width + ' 16',\n    style: {\n      display: 'inline-block',\n      verticalAlign: 'text-top',\n      fill: 'currentColor'\n    }\n  };\n}\n\nvar AlertIcon = exports.AlertIcon = function AlertIcon(props) {\n  return _react2.default.createElement(\n    'svg',\n    _extends({}, getDefaultProps(16), props),\n    _react2.default.createElement('path', {\n      fillRule: 'evenodd',\n      d: 'M8.893 1.5c-.183-.31-.52-.5-.887-.5s-.703.19-.886.5L.138 13.499a.98.98 0 0 0 0 1.001c.193.31.53.501.886.501h13.964c.367 0 .704-.19.877-.5a1.03 1.03 0 0 0 .01-1.002L8.893 1.5zm.133 11.497H6.987v-2.003h2.039v2.003zm0-3.004H6.987V5.987h2.039v4.006z'\n    })\n  );\n};\nvar CheckIcon = exports.CheckIcon = function CheckIcon(props) {\n  return _react2.default.createElement(\n    'svg',\n    _extends({}, getDefaultProps(12), props),\n    _react2.default.createElement('path', { fillRule: 'evenodd', d: 'M12 5.5l-8 8-4-4L1.5 8 4 10.5 10.5 4 12 5.5z' })\n  );\n};\nvar FlameIcon = exports.FlameIcon = function FlameIcon(props) {\n  return _react2.default.createElement(\n    'svg',\n    _extends({}, getDefaultProps(12), props),\n    _react2.default.createElement('path', {\n      fillRule: 'evenodd',\n      d: 'M5.05.01c.81 2.17.41 3.38-.52 4.31C3.55 5.37 1.98 6.15.9 7.68c-1.45 2.05-1.7 6.53 3.53 7.7-2.2-1.16-2.67-4.52-.3-6.61-.61 2.03.53 3.33 1.94 2.86 1.39-.47 2.3.53 2.27 1.67-.02.78-.31 1.44-1.13 1.81 3.42-.59 4.78-3.42 4.78-5.56 0-2.84-2.53-3.22-1.25-5.61-1.52.13-2.03 1.13-1.89 2.75.09 1.08-1.02 1.8-1.86 1.33-.67-.41-.66-1.19-.06-1.78C8.18 5.01 8.68 2.15 5.05.02L5.03 0l.02.01z'\n    })\n  );\n};\nvar InfoIcon = exports.InfoIcon = function InfoIcon(props) {\n  return _react2.default.createElement(\n    'svg',\n    _extends({}, getDefaultProps(14), props),\n    _react2.default.createElement('path', {\n      fillRule: 'evenodd',\n      d: 'M6.3 5.71a.942.942 0 0 1-.28-.7c0-.28.09-.52.28-.7.19-.18.42-.28.7-.28.28 0 .52.09.7.28.18.19.28.42.28.7 0 .28-.09.52-.28.7a1 1 0 0 1-.7.3c-.28 0-.52-.11-.7-.3zM8 8.01c-.02-.25-.11-.48-.31-.69-.2-.19-.42-.3-.69-.31H6c-.27.02-.48.13-.69.31-.2.2-.3.44-.31.69h1v3c.02.27.11.5.31.69.2.2.42.31.69.31h1c.27 0 .48-.11.69-.31.2-.19.3-.42.31-.69H8V8v.01zM7 2.32C3.86 2.32 1.3 4.86 1.3 8c0 3.14 2.56 5.7 5.7 5.7s5.7-2.55 5.7-5.7c0-3.15-2.56-5.69-5.7-5.69v.01zM7 1c3.86 0 7 3.14 7 7s-3.14 7-7 7-7-3.12-7-7 3.14-7 7-7z'\n    })\n  );\n};\nvar CloseIcon = exports.CloseIcon = function CloseIcon(props) {\n  return _react2.default.createElement(\n    'svg',\n    _extends({}, getDefaultProps(14), props),\n    _react2.default.createElement('path', {\n      fillRule: 'evenodd',\n      d: 'M7.71 8.23l3.75 3.75-1.48 1.48-3.75-3.75-3.75 3.75L1 11.98l3.75-3.75L1 4.48 2.48 3l3.75 3.75L9.98 3l1.48 1.48-3.75 3.75z'\n    })\n  );\n};","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\n// Reds\nvar R50 = exports.R50 = '#FFEBE6';\nvar R75 = exports.R75 = '#FFBDAD';\nvar R100 = exports.R100 = '#FF8F73';\nvar R200 = exports.R200 = '#FF7452';\nvar R300 = exports.R300 = '#FF5630';\nvar R400 = exports.R400 = '#DE350B';\nvar R500 = exports.R500 = '#BF2600';\n\n// Yellows\nvar Y50 = exports.Y50 = '#FFFAE6';\nvar Y75 = exports.Y75 = '#FFF0B3';\nvar Y100 = exports.Y100 = '#FFE380';\nvar Y200 = exports.Y200 = '#FFC400';\nvar Y300 = exports.Y300 = '#FFAB00';\nvar Y400 = exports.Y400 = '#FF991F';\nvar Y500 = exports.Y500 = '#FF8B00';\n\n// Greens\nvar G50 = exports.G50 = '#E3FCEF';\nvar G75 = exports.G75 = '#ABF5D1';\nvar G100 = exports.G100 = '#79F2C0';\nvar G200 = exports.G200 = '#57D9A3';\nvar G300 = exports.G300 = '#36B37E';\nvar G400 = exports.G400 = '#00875A';\nvar G500 = exports.G500 = '#006644';\n\n// Blues\nvar B50 = exports.B50 = '#DEEBFF';\nvar B75 = exports.B75 = '#B3D4FF';\nvar B100 = exports.B100 = '#4C9AFF';\nvar B200 = exports.B200 = '#2684FF';\nvar B300 = exports.B300 = '#0065FF';\nvar B400 = exports.B400 = '#0052CC';\nvar B500 = exports.B500 = '#0747A6';\n\n// Purples\nvar P50 = exports.P50 = '#EAE6FF';\nvar P75 = exports.P75 = '#C0B6F2';\nvar P100 = exports.P100 = '#998DD9';\nvar P200 = exports.P200 = '#8777D9';\nvar P300 = exports.P300 = '#6554C0';\nvar P400 = exports.P400 = '#5243AA';\nvar P500 = exports.P500 = '#403294';\n\n// Teals\nvar T50 = exports.T50 = '#E6FCFF';\nvar T75 = exports.T75 = '#B3F5FF';\nvar T100 = exports.T100 = '#79E2F2';\nvar T200 = exports.T200 = '#00C7E6';\nvar T300 = exports.T300 = '#00B8D9';\nvar T400 = exports.T400 = '#00A3BF';\nvar T500 = exports.T500 = '#008DA6';\n\n// Neutrals\nvar N0 = exports.N0 = '#FFFFFF';\nvar N10 = exports.N10 = '#FAFBFC';\nvar N20 = exports.N20 = '#F4F5F7';\nvar N30 = exports.N30 = '#EBECF0';\nvar N40 = exports.N40 = '#DFE1E6';\nvar N50 = exports.N50 = '#C1C7D0';\nvar N60 = exports.N60 = '#B3BAC5';\nvar N70 = exports.N70 = '#A5ADBA';\nvar N80 = exports.N80 = '#97A0AF';\nvar N90 = exports.N90 = '#8993A4';\nvar N100 = exports.N100 = '#7A869A';\nvar N200 = exports.N200 = '#6B778C';\nvar N300 = exports.N300 = '#5E6C84';\nvar N400 = exports.N400 = '#505F79';\nvar N500 = exports.N500 = '#42526E';\nvar N600 = exports.N600 = '#344563';\nvar N700 = exports.N700 = '#253858';\nvar N800 = exports.N800 = '#172B4D';\n\n// ATTENTION: update the tints if you update this\nvar N900 = exports.N900 = '#091E42';\n\n// Each tint is made of N900 and an alpha channel\nvar N10A = exports.N10A = 'rgba(9, 30, 66, 0.02)';\nvar N20A = exports.N20A = 'rgba(9, 30, 66, 0.04)';\nvar N30A = exports.N30A = 'rgba(9, 30, 66, 0.08)';\nvar N40A = exports.N40A = 'rgba(9, 30, 66, 0.13)';\nvar N50A = exports.N50A = 'rgba(9, 30, 66, 0.25)';\nvar N60A = exports.N60A = 'rgba(9, 30, 66, 0.31)';\nvar N70A = exports.N70A = 'rgba(9, 30, 66, 0.36)';\nvar N80A = exports.N80A = 'rgba(9, 30, 66, 0.42)';\nvar N90A = exports.N90A = 'rgba(9, 30, 66, 0.48)';\nvar N100A = exports.N100A = 'rgba(9, 30, 66, 0.54)';\nvar N200A = exports.N200A = 'rgba(9, 30, 66, 0.60)';\nvar N300A = exports.N300A = 'rgba(9, 30, 66, 0.66)';\nvar N400A = exports.N400A = 'rgba(9, 30, 66, 0.71)';\nvar N500A = exports.N500A = 'rgba(9, 30, 66, 0.77)';\nvar N600A = exports.N600A = 'rgba(9, 30, 66, 0.82)';\nvar N700A = exports.N700A = 'rgba(9, 30, 66, 0.89)';\nvar N800A = exports.N800A = 'rgba(9, 30, 66, 0.95)';","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.useToasts = exports.withToastManager = exports.ToastConsumer = exports.ToastProvider = undefined;\n\nvar _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; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactDom = require('react-dom');\n\nvar _reactTransitionGroup = require('react-transition-group');\n\nvar _ToastController = require('./ToastController');\n\nvar _ToastContainer = require('./ToastContainer');\n\nvar _ToastElement = require('./ToastElement');\n\nvar _utils = require('./utils');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar defaultComponents = { Toast: _ToastElement.DefaultToast, ToastContainer: _ToastContainer.ToastContainer };\n\n// $FlowFixMe `createContext`\nvar ToastContext = _react2.default.createContext();\nvar Consumer = ToastContext.Consumer,\n    Provider = ToastContext.Provider;\n\n\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\n\n// Provider\n// ==============================\n\nvar ToastProvider = exports.ToastProvider = function (_Component) {\n  _inherits(ToastProvider, _Component);\n\n  function ToastProvider() {\n    var _ref;\n\n    var _temp, _this, _ret;\n\n    _classCallCheck(this, ToastProvider);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = ToastProvider.__proto__ || Object.getPrototypeOf(ToastProvider)).call.apply(_ref, [this].concat(args))), _this), _this.state = { toasts: [] }, _this.has = function (id) {\n      if (!_this.state.toasts.length) {\n        return false;\n      }\n\n      return Boolean(_this.state.toasts.filter(function (t) {\n        return t.id === id;\n      }).length);\n    }, _this.onDismiss = function (id) {\n      var cb = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _utils.NOOP;\n      return function () {\n        cb(id);\n        _this.remove(id);\n      };\n    }, _this.add = function (content) {\n      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n      var cb = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _utils.NOOP;\n\n      var id = options.id ? options.id : (0, _utils.generateUEID)();\n      var callback = function callback() {\n        return cb(id);\n      };\n\n      // bail if a toast exists with this ID\n      if (_this.has(id)) {\n        return;\n      }\n\n      // update the toast stack\n      _this.setState(function (state) {\n        var newToast = _extends({ content: content, id: id }, options);\n        var toasts = [].concat(_toConsumableArray(state.toasts), [newToast]);\n\n        return { toasts: toasts };\n      }, callback);\n\n      // consumer may want to do something with the generated ID (and not use the callback)\n      return id;\n    }, _this.remove = function (id) {\n      var cb = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _utils.NOOP;\n\n      var callback = function callback() {\n        return cb(id);\n      };\n\n      // bail if NO toasts exists with this ID\n      if (!_this.has(id)) {\n        return;\n      }\n\n      _this.setState(function (state) {\n        var toasts = state.toasts.filter(function (t) {\n          return t.id !== id;\n        });\n        return { toasts: toasts };\n      }, callback);\n    }, _this.removeAll = function () {\n      if (!_this.state.toasts.length) {\n        return;\n      }\n\n      _this.state.toasts.forEach(function (t) {\n        return _this.remove(t.id);\n      });\n    }, _this.update = function (id) {\n      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n      var cb = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _utils.NOOP;\n\n      var callback = function callback() {\n        return cb(id);\n      };\n\n      // bail if NO toasts exists with this ID\n      if (!_this.has(id)) {\n        return;\n      }\n\n      // update the toast stack\n      _this.setState(function (state) {\n        var old = state.toasts;\n        var i = old.findIndex(function (t) {\n          return t.id === id;\n        });\n        var updatedToast = _extends({}, old[i], options);\n        var toasts = [].concat(_toConsumableArray(old.slice(0, i)), [updatedToast], _toConsumableArray(old.slice(i + 1)));\n\n        return { toasts: toasts };\n      }, callback);\n    }, _temp), _possibleConstructorReturn(_this, _ret);\n  }\n\n  // Internal Helpers\n  // ------------------------------\n\n  // Public API\n  // ------------------------------\n\n  _createClass(ToastProvider, [{\n    key: 'render',\n    value: function render() {\n      var _this2 = this;\n\n      var _props = this.props,\n          inheritedAutoDismiss = _props.autoDismiss,\n          autoDismissTimeout = _props.autoDismissTimeout,\n          children = _props.children,\n          components = _props.components,\n          placement = _props.placement,\n          portalTargetSelector = _props.portalTargetSelector,\n          transitionDuration = _props.transitionDuration;\n\n      var _defaultComponents$co = _extends({}, defaultComponents, components),\n          Toast = _defaultComponents$co.Toast,\n          ToastContainer = _defaultComponents$co.ToastContainer;\n\n      var add = this.add,\n          remove = this.remove,\n          removeAll = this.removeAll,\n          update = this.update;\n\n      var toasts = Object.freeze(this.state.toasts);\n\n      var hasToasts = Boolean(toasts.length);\n      var portalTarget = canUseDOM ? portalTargetSelector ? document.querySelector(portalTargetSelector) : document.body : null; // appease flow\n\n      return _react2.default.createElement(\n        Provider,\n        { value: { add: add, remove: remove, removeAll: removeAll, update: update, toasts: toasts } },\n        children,\n        portalTarget ? (0, _reactDom.createPortal)(_react2.default.createElement(\n          ToastContainer,\n          { placement: placement, hasToasts: hasToasts },\n          _react2.default.createElement(\n            _reactTransitionGroup.TransitionGroup,\n            { component: null },\n            toasts.map(function (_ref2) {\n              var appearance = _ref2.appearance,\n                  autoDismiss = _ref2.autoDismiss,\n                  content = _ref2.content,\n                  id = _ref2.id,\n                  onDismiss = _ref2.onDismiss,\n                  unknownConsumerProps = _objectWithoutProperties(_ref2, ['appearance', 'autoDismiss', 'content', 'id', 'onDismiss']);\n\n              return _react2.default.createElement(\n                _reactTransitionGroup.Transition,\n                {\n                  appear: true,\n                  key: id,\n                  mountOnEnter: true,\n                  timeout: transitionDuration,\n                  unmountOnExit: true\n                },\n                function (transitionState) {\n                  return _react2.default.createElement(\n                    _ToastController.ToastController,\n                    _extends({\n                      appearance: appearance,\n                      autoDismiss: autoDismiss !== undefined ? autoDismiss : inheritedAutoDismiss,\n                      autoDismissTimeout: autoDismissTimeout,\n                      component: Toast,\n                      key: id,\n                      onDismiss: _this2.onDismiss(id, onDismiss),\n                      placement: placement,\n                      transitionDuration: transitionDuration,\n                      transitionState: transitionState\n                    }, unknownConsumerProps),\n                    content\n                  );\n                }\n              );\n            })\n          )\n        ), portalTarget) : _react2.default.createElement(ToastContainer, { placement: placement, hasToasts: hasToasts }) // keep ReactDOM.hydrate happy\n\n      );\n    }\n  }]);\n\n  return ToastProvider;\n}(_react.Component);\n\nToastProvider.defaultProps = {\n  autoDismiss: false,\n  autoDismissTimeout: 5000,\n  components: defaultComponents,\n  placement: 'top-right',\n  transitionDuration: 220\n};\nvar ToastConsumer = exports.ToastConsumer = function ToastConsumer(_ref3) {\n  var children = _ref3.children;\n  return _react2.default.createElement(\n    Consumer,\n    null,\n    function (context) {\n      return children(context);\n    }\n  );\n};\n\nvar withToastManager = exports.withToastManager = function withToastManager(Comp\n// $FlowFixMe `forwardRef`\n) {\n  return _react2.default.forwardRef(function (props, ref) {\n    return _react2.default.createElement(\n      ToastConsumer,\n      null,\n      function (context) {\n        return _react2.default.createElement(Comp, _extends({ toastManager: context }, props, { ref: ref }));\n      }\n    );\n  });\n};\n\nvar useToasts = exports.useToasts = function useToasts() {\n  var ctx = (0, _react.useContext)(ToastContext);\n\n  if (!ctx) {\n    throw Error('The `useToasts` hook must be called from a descendent of the `ToastProvider`.');\n  }\n\n  return {\n    addToast: ctx.add,\n    removeToast: ctx.remove,\n    removeAllToasts: ctx.removeAll,\n    updateToast: ctx.update,\n    toastStack: ctx.toasts\n  };\n};","'use strict';\n\nObject.defineProperty(exports, \"__esModule\", {\n  value: true\n});\nexports.ToastController = undefined;\n\nvar _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; };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nvar _react = require('react');\n\nvar _react2 = _interopRequireDefault(_react);\n\nvar _reactTransitionGroup = require('react-transition-group');\n\nvar _utils = require('./utils');\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar defaultAutoDismissTimeout = 5000;\n\nvar TimerType = {\n  clear: _utils.NOOP,\n  pause: _utils.NOOP,\n  resume: _utils.NOOP\n};\n\nfunction Timer(callback, delay) {\n  var timerId = void 0;\n  var start = delay;\n  var remaining = delay;\n\n  this.clear = function () {\n    clearTimeout(timerId);\n  };\n\n  this.pause = function () {\n    clearTimeout(timerId);\n    remaining -= Date.now() - start;\n  };\n\n  this.resume = function () {\n    start = Date.now();\n    clearTimeout(timerId);\n    timerId = setTimeout(callback, remaining);\n  };\n\n  this.resume();\n}\n\nvar ToastController = exports.ToastController = function (_Component) {\n  _inherits(ToastController, _Component);\n\n  function ToastController() {\n    var _ref;\n\n    var _temp, _this, _ret;\n\n    _classCallCheck(this, ToastController);\n\n    for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = ToastController.__proto__ || Object.getPrototypeOf(ToastController)).call.apply(_ref, [this].concat(args))), _this), _this.state = {\n      isRunning: Boolean(_this.props.autoDismiss)\n    }, _this.startTimer = function () {\n      var _this$props = _this.props,\n          autoDismiss = _this$props.autoDismiss,\n          autoDismissTimeout = _this$props.autoDismissTimeout,\n          onDismiss = _this$props.onDismiss;\n\n\n      if (!autoDismiss) return;\n\n      _this.setState({ isRunning: true });\n      _this.timeout = new Timer(onDismiss, autoDismissTimeout);\n    }, _this.clearTimer = function () {\n      if (_this.timeout) _this.timeout.clear();\n    }, _this.onMouseEnter = function () {\n      _this.setState({ isRunning: false }, function () {\n        if (_this.timeout) _this.timeout.pause();\n      });\n    }, _this.onMouseLeave = function () {\n      _this.setState({ isRunning: true }, function () {\n        if (_this.timeout) _this.timeout.resume();\n      });\n    }, _temp), _possibleConstructorReturn(_this, _ret);\n  }\n\n  _createClass(ToastController, [{\n    key: 'componentDidMount',\n    value: function componentDidMount() {\n      this.startTimer();\n    }\n  }, {\n    key: 'componentDidUpdate',\n    value: function componentDidUpdate(prevProps) {\n      if (prevProps.autoDismiss !== this.props.autoDismiss) {\n        var startOrClear = this.props.autoDismiss ? this.startTimer : this.clearTimer;\n\n        startOrClear();\n      }\n    }\n  }, {\n    key: 'componentWillUnmount',\n    value: function componentWillUnmount() {\n      this.clearTimer();\n    }\n  }, {\n    key: 'render',\n    value: function render() {\n      var _props = this.props,\n          autoDismiss = _props.autoDismiss,\n          autoDismissTimeout = _props.autoDismissTimeout,\n          Toast = _props.component,\n          props = _objectWithoutProperties(_props, ['autoDismiss', 'autoDismissTimeout', 'component']);\n\n      var isRunning = this.state.isRunning;\n\n      // NOTE: conditions here so methods can be clean\n\n      var handleMouseEnter = autoDismiss ? this.onMouseEnter : _utils.NOOP;\n      var handleMouseLeave = autoDismiss ? this.onMouseLeave : _utils.NOOP;\n\n      return _react2.default.createElement(Toast, _extends({\n        autoDismiss: autoDismiss,\n        autoDismissTimeout: autoDismissTimeout,\n        isRunning: isRunning,\n        onMouseEnter: handleMouseEnter,\n        onMouseLeave: handleMouseLeave\n      }, props));\n    }\n  }]);\n\n  return ToastController;\n}(_react.Component);\n\nToastController.defaultProps = {\n  autoDismiss: false\n};","/**\n * Copyright (c) 2014-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\nvar runtime = (function (exports) {\n  \"use strict\";\n\n  var Op = Object.prototype;\n  var hasOwn = Op.hasOwnProperty;\n  var undefined; // More compressible than void 0.\n  var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n  var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n  var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n  var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n  function wrap(innerFn, outerFn, self, tryLocsList) {\n    // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n    var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n    var generator = Object.create(protoGenerator.prototype);\n    var context = new Context(tryLocsList || []);\n\n    // The ._invoke method unifies the implementations of the .next,\n    // .throw, and .return methods.\n    generator._invoke = makeInvokeMethod(innerFn, self, context);\n\n    return generator;\n  }\n  exports.wrap = wrap;\n\n  // Try/catch helper to minimize deoptimizations. Returns a completion\n  // record like context.tryEntries[i].completion. This interface could\n  // have been (and was previously) designed to take a closure to be\n  // invoked without arguments, but in all the cases we care about we\n  // already have an existing method we want to call, so there's no need\n  // to create a new function object. We can even get away with assuming\n  // the method takes exactly one argument, since that happens to be true\n  // in every case, so we don't have to touch the arguments object. The\n  // only additional allocation required is the completion record, which\n  // has a stable shape and so hopefully should be cheap to allocate.\n  function tryCatch(fn, obj, arg) {\n    try {\n      return { type: \"normal\", arg: fn.call(obj, arg) };\n    } catch (err) {\n      return { type: \"throw\", arg: err };\n    }\n  }\n\n  var GenStateSuspendedStart = \"suspendedStart\";\n  var GenStateSuspendedYield = \"suspendedYield\";\n  var GenStateExecuting = \"executing\";\n  var GenStateCompleted = \"completed\";\n\n  // Returning this object from the innerFn has the same effect as\n  // breaking out of the dispatch switch statement.\n  var ContinueSentinel = {};\n\n  // Dummy constructor functions that we use as the .constructor and\n  // .constructor.prototype properties for functions that return Generator\n  // objects. For full spec compliance, you may wish to configure your\n  // minifier not to mangle the names of these two functions.\n  function Generator() {}\n  function GeneratorFunction() {}\n  function GeneratorFunctionPrototype() {}\n\n  // This is a polyfill for %IteratorPrototype% for environments that\n  // don't natively support it.\n  var IteratorPrototype = {};\n  IteratorPrototype[iteratorSymbol] = function () {\n    return this;\n  };\n\n  var getProto = Object.getPrototypeOf;\n  var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n  if (NativeIteratorPrototype &&\n      NativeIteratorPrototype !== Op &&\n      hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n    // This environment has a native %IteratorPrototype%; use it instead\n    // of the polyfill.\n    IteratorPrototype = NativeIteratorPrototype;\n  }\n\n  var Gp = GeneratorFunctionPrototype.prototype =\n    Generator.prototype = Object.create(IteratorPrototype);\n  GeneratorFunction.prototype = Gp.constructor = GeneratorFunctionPrototype;\n  GeneratorFunctionPrototype.constructor = GeneratorFunction;\n  GeneratorFunctionPrototype[toStringTagSymbol] =\n    GeneratorFunction.displayName = \"GeneratorFunction\";\n\n  // Helper for defining the .next, .throw, and .return methods of the\n  // Iterator interface in terms of a single ._invoke method.\n  function defineIteratorMethods(prototype) {\n    [\"next\", \"throw\", \"return\"].forEach(function(method) {\n      prototype[method] = function(arg) {\n        return this._invoke(method, arg);\n      };\n    });\n  }\n\n  exports.isGeneratorFunction = function(genFun) {\n    var ctor = typeof genFun === \"function\" && genFun.constructor;\n    return ctor\n      ? ctor === GeneratorFunction ||\n        // For the native GeneratorFunction constructor, the best we can\n        // do is to check its .name property.\n        (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n      : false;\n  };\n\n  exports.mark = function(genFun) {\n    if (Object.setPrototypeOf) {\n      Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n    } else {\n      genFun.__proto__ = GeneratorFunctionPrototype;\n      if (!(toStringTagSymbol in genFun)) {\n        genFun[toStringTagSymbol] = \"GeneratorFunction\";\n      }\n    }\n    genFun.prototype = Object.create(Gp);\n    return genFun;\n  };\n\n  // Within the body of any async function, `await x` is transformed to\n  // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n  // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n  // meant to be awaited.\n  exports.awrap = function(arg) {\n    return { __await: arg };\n  };\n\n  function AsyncIterator(generator, PromiseImpl) {\n    function invoke(method, arg, resolve, reject) {\n      var record = tryCatch(generator[method], generator, arg);\n      if (record.type === \"throw\") {\n        reject(record.arg);\n      } else {\n        var result = record.arg;\n        var value = result.value;\n        if (value &&\n            typeof value === \"object\" &&\n            hasOwn.call(value, \"__await\")) {\n          return PromiseImpl.resolve(value.__await).then(function(value) {\n            invoke(\"next\", value, resolve, reject);\n          }, function(err) {\n            invoke(\"throw\", err, resolve, reject);\n          });\n        }\n\n        return PromiseImpl.resolve(value).then(function(unwrapped) {\n          // When a yielded Promise is resolved, its final value becomes\n          // the .value of the Promise<{value,done}> result for the\n          // current iteration.\n          result.value = unwrapped;\n          resolve(result);\n        }, function(error) {\n          // If a rejected Promise was yielded, throw the rejection back\n          // into the async generator function so it can be handled there.\n          return invoke(\"throw\", error, resolve, reject);\n        });\n      }\n    }\n\n    var previousPromise;\n\n    function enqueue(method, arg) {\n      function callInvokeWithMethodAndArg() {\n        return new PromiseImpl(function(resolve, reject) {\n          invoke(method, arg, resolve, reject);\n        });\n      }\n\n      return previousPromise =\n        // If enqueue has been called before, then we want to wait until\n        // all previous Promises have been resolved before calling invoke,\n        // so that results are always delivered in the correct order. If\n        // enqueue has not been called before, then it is important to\n        // call invoke immediately, without waiting on a callback to fire,\n        // so that the async generator function has the opportunity to do\n        // any necessary setup in a predictable way. This predictability\n        // is why the Promise constructor synchronously invokes its\n        // executor callback, and why async functions synchronously\n        // execute code before the first await. Since we implement simple\n        // async functions in terms of async generators, it is especially\n        // important to get this right, even though it requires care.\n        previousPromise ? previousPromise.then(\n          callInvokeWithMethodAndArg,\n          // Avoid propagating failures to Promises returned by later\n          // invocations of the iterator.\n          callInvokeWithMethodAndArg\n        ) : callInvokeWithMethodAndArg();\n    }\n\n    // Define the unified helper method that is used to implement .next,\n    // .throw, and .return (see defineIteratorMethods).\n    this._invoke = enqueue;\n  }\n\n  defineIteratorMethods(AsyncIterator.prototype);\n  AsyncIterator.prototype[asyncIteratorSymbol] = function () {\n    return this;\n  };\n  exports.AsyncIterator = AsyncIterator;\n\n  // Note that simple async functions are implemented on top of\n  // AsyncIterator objects; they just return a Promise for the value of\n  // the final result produced by the iterator.\n  exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n    if (PromiseImpl === void 0) PromiseImpl = Promise;\n\n    var iter = new AsyncIterator(\n      wrap(innerFn, outerFn, self, tryLocsList),\n      PromiseImpl\n    );\n\n    return exports.isGeneratorFunction(outerFn)\n      ? iter // If outerFn is a generator, return the full iterator.\n      : iter.next().then(function(result) {\n          return result.done ? result.value : iter.next();\n        });\n  };\n\n  function makeInvokeMethod(innerFn, self, context) {\n    var state = GenStateSuspendedStart;\n\n    return function invoke(method, arg) {\n      if (state === GenStateExecuting) {\n        throw new Error(\"Generator is already running\");\n      }\n\n      if (state === GenStateCompleted) {\n        if (method === \"throw\") {\n          throw arg;\n        }\n\n        // Be forgiving, per 25.3.3.3.3 of the spec:\n        // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n        return doneResult();\n      }\n\n      context.method = method;\n      context.arg = arg;\n\n      while (true) {\n        var delegate = context.delegate;\n        if (delegate) {\n          var delegateResult = maybeInvokeDelegate(delegate, context);\n          if (delegateResult) {\n            if (delegateResult === ContinueSentinel) continue;\n            return delegateResult;\n          }\n        }\n\n        if (context.method === \"next\") {\n          // Setting context._sent for legacy support of Babel's\n          // function.sent implementation.\n          context.sent = context._sent = context.arg;\n\n        } else if (context.method === \"throw\") {\n          if (state === GenStateSuspendedStart) {\n            state = GenStateCompleted;\n            throw context.arg;\n          }\n\n          context.dispatchException(context.arg);\n\n        } else if (context.method === \"return\") {\n          context.abrupt(\"return\", context.arg);\n        }\n\n        state = GenStateExecuting;\n\n        var record = tryCatch(innerFn, self, context);\n        if (record.type === \"normal\") {\n          // If an exception is thrown from innerFn, we leave state ===\n          // GenStateExecuting and loop back for another invocation.\n          state = context.done\n            ? GenStateCompleted\n            : GenStateSuspendedYield;\n\n          if (record.arg === ContinueSentinel) {\n            continue;\n          }\n\n          return {\n            value: record.arg,\n            done: context.done\n          };\n\n        } else if (record.type === \"throw\") {\n          state = GenStateCompleted;\n          // Dispatch the exception by looping back around to the\n          // context.dispatchException(context.arg) call above.\n          context.method = \"throw\";\n          context.arg = record.arg;\n        }\n      }\n    };\n  }\n\n  // Call delegate.iterator[context.method](context.arg) and handle the\n  // result, either by returning a { value, done } result from the\n  // delegate iterator, or by modifying context.method and context.arg,\n  // setting context.delegate to null, and returning the ContinueSentinel.\n  function maybeInvokeDelegate(delegate, context) {\n    var method = delegate.iterator[context.method];\n    if (method === undefined) {\n      // A .throw or .return when the delegate iterator has no .throw\n      // method always terminates the yield* loop.\n      context.delegate = null;\n\n      if (context.method === \"throw\") {\n        // Note: [\"return\"] must be used for ES3 parsing compatibility.\n        if (delegate.iterator[\"return\"]) {\n          // If the delegate iterator has a return method, give it a\n          // chance to clean up.\n          context.method = \"return\";\n          context.arg = undefined;\n          maybeInvokeDelegate(delegate, context);\n\n          if (context.method === \"throw\") {\n            // If maybeInvokeDelegate(context) changed context.method from\n            // \"return\" to \"throw\", let that override the TypeError below.\n            return ContinueSentinel;\n          }\n        }\n\n        context.method = \"throw\";\n        context.arg = new TypeError(\n          \"The iterator does not provide a 'throw' method\");\n      }\n\n      return ContinueSentinel;\n    }\n\n    var record = tryCatch(method, delegate.iterator, context.arg);\n\n    if (record.type === \"throw\") {\n      context.method = \"throw\";\n      context.arg = record.arg;\n      context.delegate = null;\n      return ContinueSentinel;\n    }\n\n    var info = record.arg;\n\n    if (! info) {\n      context.method = \"throw\";\n      context.arg = new TypeError(\"iterator result is not an object\");\n      context.delegate = null;\n      return ContinueSentinel;\n    }\n\n    if (info.done) {\n      // Assign the result of the finished delegate to the temporary\n      // variable specified by delegate.resultName (see delegateYield).\n      context[delegate.resultName] = info.value;\n\n      // Resume execution at the desired location (see delegateYield).\n      context.next = delegate.nextLoc;\n\n      // If context.method was \"throw\" but the delegate handled the\n      // exception, let the outer generator proceed normally. If\n      // context.method was \"next\", forget context.arg since it has been\n      // \"consumed\" by the delegate iterator. If context.method was\n      // \"return\", allow the original .return call to continue in the\n      // outer generator.\n      if (context.method !== \"return\") {\n        context.method = \"next\";\n        context.arg = undefined;\n      }\n\n    } else {\n      // Re-yield the result returned by the delegate method.\n      return info;\n    }\n\n    // The delegate iterator is finished, so forget it and continue with\n    // the outer generator.\n    context.delegate = null;\n    return ContinueSentinel;\n  }\n\n  // Define Generator.prototype.{next,throw,return} in terms of the\n  // unified ._invoke helper method.\n  defineIteratorMethods(Gp);\n\n  Gp[toStringTagSymbol] = \"Generator\";\n\n  // A Generator should always return itself as the iterator object when the\n  // @@iterator function is called on it. Some browsers' implementations of the\n  // iterator prototype chain incorrectly implement this, causing the Generator\n  // object to not be returned from this call. This ensures that doesn't happen.\n  // See https://github.com/facebook/regenerator/issues/274 for more details.\n  Gp[iteratorSymbol] = function() {\n    return this;\n  };\n\n  Gp.toString = function() {\n    return \"[object Generator]\";\n  };\n\n  function pushTryEntry(locs) {\n    var entry = { tryLoc: locs[0] };\n\n    if (1 in locs) {\n      entry.catchLoc = locs[1];\n    }\n\n    if (2 in locs) {\n      entry.finallyLoc = locs[2];\n      entry.afterLoc = locs[3];\n    }\n\n    this.tryEntries.push(entry);\n  }\n\n  function resetTryEntry(entry) {\n    var record = entry.completion || {};\n    record.type = \"normal\";\n    delete record.arg;\n    entry.completion = record;\n  }\n\n  function Context(tryLocsList) {\n    // The root entry object (effectively a try statement without a catch\n    // or a finally block) gives us a place to store values thrown from\n    // locations where there is no enclosing try statement.\n    this.tryEntries = [{ tryLoc: \"root\" }];\n    tryLocsList.forEach(pushTryEntry, this);\n    this.reset(true);\n  }\n\n  exports.keys = function(object) {\n    var keys = [];\n    for (var key in object) {\n      keys.push(key);\n    }\n    keys.reverse();\n\n    // Rather than returning an object with a next method, we keep\n    // things simple and return the next function itself.\n    return function next() {\n      while (keys.length) {\n        var key = keys.pop();\n        if (key in object) {\n          next.value = key;\n          next.done = false;\n          return next;\n        }\n      }\n\n      // To avoid creating an additional object, we just hang the .value\n      // and .done properties off the next function object itself. This\n      // also ensures that the minifier will not anonymize the function.\n      next.done = true;\n      return next;\n    };\n  };\n\n  function values(iterable) {\n    if (iterable) {\n      var iteratorMethod = iterable[iteratorSymbol];\n      if (iteratorMethod) {\n        return iteratorMethod.call(iterable);\n      }\n\n      if (typeof iterable.next === \"function\") {\n        return iterable;\n      }\n\n      if (!isNaN(iterable.length)) {\n        var i = -1, next = function next() {\n          while (++i < iterable.length) {\n            if (hasOwn.call(iterable, i)) {\n              next.value = iterable[i];\n              next.done = false;\n              return next;\n            }\n          }\n\n          next.value = undefined;\n          next.done = true;\n\n          return next;\n        };\n\n        return next.next = next;\n      }\n    }\n\n    // Return an iterator with no values.\n    return { next: doneResult };\n  }\n  exports.values = values;\n\n  function doneResult() {\n    return { value: undefined, done: true };\n  }\n\n  Context.prototype = {\n    constructor: Context,\n\n    reset: function(skipTempReset) {\n      this.prev = 0;\n      this.next = 0;\n      // Resetting context._sent for legacy support of Babel's\n      // function.sent implementation.\n      this.sent = this._sent = undefined;\n      this.done = false;\n      this.delegate = null;\n\n      this.method = \"next\";\n      this.arg = undefined;\n\n      this.tryEntries.forEach(resetTryEntry);\n\n      if (!skipTempReset) {\n        for (var name in this) {\n          // Not sure about the optimal order of these conditions:\n          if (name.charAt(0) === \"t\" &&\n              hasOwn.call(this, name) &&\n              !isNaN(+name.slice(1))) {\n            this[name] = undefined;\n          }\n        }\n      }\n    },\n\n    stop: function() {\n      this.done = true;\n\n      var rootEntry = this.tryEntries[0];\n      var rootRecord = rootEntry.completion;\n      if (rootRecord.type === \"throw\") {\n        throw rootRecord.arg;\n      }\n\n      return this.rval;\n    },\n\n    dispatchException: function(exception) {\n      if (this.done) {\n        throw exception;\n      }\n\n      var context = this;\n      function handle(loc, caught) {\n        record.type = \"throw\";\n        record.arg = exception;\n        context.next = loc;\n\n        if (caught) {\n          // If the dispatched exception was caught by a catch block,\n          // then let that catch block handle the exception normally.\n          context.method = \"next\";\n          context.arg = undefined;\n        }\n\n        return !! caught;\n      }\n\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        var record = entry.completion;\n\n        if (entry.tryLoc === \"root\") {\n          // Exception thrown outside of any try block that could handle\n          // it, so set the completion value of the entire function to\n          // throw the exception.\n          return handle(\"end\");\n        }\n\n        if (entry.tryLoc <= this.prev) {\n          var hasCatch = hasOwn.call(entry, \"catchLoc\");\n          var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n          if (hasCatch && hasFinally) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            } else if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else if (hasCatch) {\n            if (this.prev < entry.catchLoc) {\n              return handle(entry.catchLoc, true);\n            }\n\n          } else if (hasFinally) {\n            if (this.prev < entry.finallyLoc) {\n              return handle(entry.finallyLoc);\n            }\n\n          } else {\n            throw new Error(\"try statement without catch or finally\");\n          }\n        }\n      }\n    },\n\n    abrupt: function(type, arg) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc <= this.prev &&\n            hasOwn.call(entry, \"finallyLoc\") &&\n            this.prev < entry.finallyLoc) {\n          var finallyEntry = entry;\n          break;\n        }\n      }\n\n      if (finallyEntry &&\n          (type === \"break\" ||\n           type === \"continue\") &&\n          finallyEntry.tryLoc <= arg &&\n          arg <= finallyEntry.finallyLoc) {\n        // Ignore the finally entry if control is not jumping to a\n        // location outside the try/catch block.\n        finallyEntry = null;\n      }\n\n      var record = finallyEntry ? finallyEntry.completion : {};\n      record.type = type;\n      record.arg = arg;\n\n      if (finallyEntry) {\n        this.method = \"next\";\n        this.next = finallyEntry.finallyLoc;\n        return ContinueSentinel;\n      }\n\n      return this.complete(record);\n    },\n\n    complete: function(record, afterLoc) {\n      if (record.type === \"throw\") {\n        throw record.arg;\n      }\n\n      if (record.type === \"break\" ||\n          record.type === \"continue\") {\n        this.next = record.arg;\n      } else if (record.type === \"return\") {\n        this.rval = this.arg = record.arg;\n        this.method = \"return\";\n        this.next = \"end\";\n      } else if (record.type === \"normal\" && afterLoc) {\n        this.next = afterLoc;\n      }\n\n      return ContinueSentinel;\n    },\n\n    finish: function(finallyLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.finallyLoc === finallyLoc) {\n          this.complete(entry.completion, entry.afterLoc);\n          resetTryEntry(entry);\n          return ContinueSentinel;\n        }\n      }\n    },\n\n    \"catch\": function(tryLoc) {\n      for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n        var entry = this.tryEntries[i];\n        if (entry.tryLoc === tryLoc) {\n          var record = entry.completion;\n          if (record.type === \"throw\") {\n            var thrown = record.arg;\n            resetTryEntry(entry);\n          }\n          return thrown;\n        }\n      }\n\n      // The context.catch method must only be called with a location\n      // argument that corresponds to a known catch block.\n      throw new Error(\"illegal catch attempt\");\n    },\n\n    delegateYield: function(iterable, resultName, nextLoc) {\n      this.delegate = {\n        iterator: values(iterable),\n        resultName: resultName,\n        nextLoc: nextLoc\n      };\n\n      if (this.method === \"next\") {\n        // Deliberately forget the last sent value so that we don't\n        // accidentally pass it on to the delegate.\n        this.arg = undefined;\n      }\n\n      return ContinueSentinel;\n    }\n  };\n\n  // Regardless of whether this script is executing as a CommonJS module\n  // or not, return the runtime object so that we can declare the variable\n  // regeneratorRuntime in the outer scope, which allows this module to be\n  // injected easily by `bin/regenerator --include-runtime script.js`.\n  return exports;\n\n}(\n  // If this script is executing as a CommonJS module, use module.exports\n  // as the regeneratorRuntime namespace. Otherwise create a new empty\n  // object. Either way, the resulting object will be used to initialize\n  // the regeneratorRuntime variable at the top of this file.\n  typeof module === \"object\" ? module.exports : {}\n));\n\ntry {\n  regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n  // This module should not be running in strict mode, so the above\n  // assignment should always work unless something is misconfigured. Just\n  // in case runtime.js accidentally runs in strict mode, we can escape\n  // strict mode using a global Function call. This could conceivably fail\n  // if a Content Security Policy forbids using Function, but in that case\n  // the proper solution is to fix the accidental strict mode problem. If\n  // you've misconfigured your bundler to force strict mode and applied a\n  // CSP to forbid Function, and you're not willing to fix either of those\n  // problems, please detail your unique predicament in a GitHub issue.\n  Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n}\n","module.exports = function(module) {\n\tif (!module.webpackPolyfill) {\n\t\tmodule.deprecate = function() {};\n\t\tmodule.paths = [];\n\t\t// module.parent = undefined by default\n\t\tif (!module.children) module.children = [];\n\t\tObject.defineProperty(module, \"loaded\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.l;\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(module, \"id\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.i;\n\t\t\t}\n\t\t});\n\t\tmodule.webpackPolyfill = 1;\n\t}\n\treturn module;\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n// If obj.hasOwnProperty has been overridden, then calling\n// obj.hasOwnProperty(prop) will break.\n// See: https://github.com/joyent/node/issues/1707\nfunction hasOwnProperty(obj, prop) {\n  return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nmodule.exports = function(qs, sep, eq, options) {\n  sep = sep || '&';\n  eq = eq || '=';\n  var obj = {};\n\n  if (typeof qs !== 'string' || qs.length === 0) {\n    return obj;\n  }\n\n  var regexp = /\\+/g;\n  qs = qs.split(sep);\n\n  var maxKeys = 1000;\n  if (options && typeof options.maxKeys === 'number') {\n    maxKeys = options.maxKeys;\n  }\n\n  var len = qs.length;\n  // maxKeys <= 0 means that we should not limit keys count\n  if (maxKeys > 0 && len > maxKeys) {\n    len = maxKeys;\n  }\n\n  for (var i = 0; i < len; ++i) {\n    var x = qs[i].replace(regexp, '%20'),\n        idx = x.indexOf(eq),\n        kstr, vstr, k, v;\n\n    if (idx >= 0) {\n      kstr = x.substr(0, idx);\n      vstr = x.substr(idx + 1);\n    } else {\n      kstr = x;\n      vstr = '';\n    }\n\n    k = decodeURIComponent(kstr);\n    v = decodeURIComponent(vstr);\n\n    if (!hasOwnProperty(obj, k)) {\n      obj[k] = v;\n    } else if (isArray(obj[k])) {\n      obj[k].push(v);\n    } else {\n      obj[k] = [obj[k], v];\n    }\n  }\n\n  return obj;\n};\n\nvar isArray = Array.isArray || function (xs) {\n  return Object.prototype.toString.call(xs) === '[object Array]';\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar stringifyPrimitive = function(v) {\n  switch (typeof v) {\n    case 'string':\n      return v;\n\n    case 'boolean':\n      return v ? 'true' : 'false';\n\n    case 'number':\n      return isFinite(v) ? v : '';\n\n    default:\n      return '';\n  }\n};\n\nmodule.exports = function(obj, sep, eq, name) {\n  sep = sep || '&';\n  eq = eq || '=';\n  if (obj === null) {\n    obj = undefined;\n  }\n\n  if (typeof obj === 'object') {\n    return map(objectKeys(obj), function(k) {\n      var ks = encodeURIComponent(stringifyPrimitive(k)) + eq;\n      if (isArray(obj[k])) {\n        return map(obj[k], function(v) {\n          return ks + encodeURIComponent(stringifyPrimitive(v));\n        }).join(sep);\n      } else {\n        return ks + encodeURIComponent(stringifyPrimitive(obj[k]));\n      }\n    }).join(sep);\n\n  }\n\n  if (!name) return '';\n  return encodeURIComponent(stringifyPrimitive(name)) + eq +\n         encodeURIComponent(stringifyPrimitive(obj));\n};\n\nvar isArray = Array.isArray || function (xs) {\n  return Object.prototype.toString.call(xs) === '[object Array]';\n};\n\nfunction map (xs, f) {\n  if (xs.map) return xs.map(f);\n  var res = [];\n  for (var i = 0; i < xs.length; i++) {\n    res.push(f(xs[i], i));\n  }\n  return res;\n}\n\nvar objectKeys = Object.keys || function (obj) {\n  var res = [];\n  for (var key in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, key)) res.push(key);\n  }\n  return res;\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar bind = require('./helpers/bind');\nvar Axios = require('./core/Axios');\nvar mergeConfig = require('./core/mergeConfig');\nvar defaults = require('./defaults');\n\n/**\n * Create an instance of Axios\n *\n * @param {Object} defaultConfig The default config for the instance\n * @return {Axios} A new instance of Axios\n */\nfunction createInstance(defaultConfig) {\n  var context = new Axios(defaultConfig);\n  var instance = bind(Axios.prototype.request, context);\n\n  // Copy axios.prototype to instance\n  utils.extend(instance, Axios.prototype, context);\n\n  // Copy context to instance\n  utils.extend(instance, context);\n\n  return instance;\n}\n\n// Create the default instance to be exported\nvar axios = createInstance(defaults);\n\n// Expose Axios class to allow class inheritance\naxios.Axios = Axios;\n\n// Factory for creating new instances\naxios.create = function create(instanceConfig) {\n  return createInstance(mergeConfig(axios.defaults, instanceConfig));\n};\n\n// Expose Cancel & CancelToken\naxios.Cancel = require('./cancel/Cancel');\naxios.CancelToken = require('./cancel/CancelToken');\naxios.isCancel = require('./cancel/isCancel');\n\n// Expose all/spread\naxios.all = function all(promises) {\n  return Promise.all(promises);\n};\naxios.spread = require('./helpers/spread');\n\n// Expose isAxiosError\naxios.isAxiosError = require('./helpers/isAxiosError');\n\nmodule.exports = axios;\n\n// Allow use of default import syntax in TypeScript\nmodule.exports.default = axios;\n","'use strict';\n\nvar utils = require('./../utils');\nvar buildURL = require('../helpers/buildURL');\nvar InterceptorManager = require('./InterceptorManager');\nvar dispatchRequest = require('./dispatchRequest');\nvar mergeConfig = require('./mergeConfig');\n\n/**\n * Create a new instance of Axios\n *\n * @param {Object} instanceConfig The default config for the instance\n */\nfunction Axios(instanceConfig) {\n  this.defaults = instanceConfig;\n  this.interceptors = {\n    request: new InterceptorManager(),\n    response: new InterceptorManager()\n  };\n}\n\n/**\n * Dispatch a request\n *\n * @param {Object} config The config specific for this request (merged with this.defaults)\n */\nAxios.prototype.request = function request(config) {\n  /*eslint no-param-reassign:0*/\n  // Allow for axios('example/url'[, config]) a la fetch API\n  if (typeof config === 'string') {\n    config = arguments[1] || {};\n    config.url = arguments[0];\n  } else {\n    config = config || {};\n  }\n\n  config = mergeConfig(this.defaults, config);\n\n  // Set config.method\n  if (config.method) {\n    config.method = config.method.toLowerCase();\n  } else if (this.defaults.method) {\n    config.method = this.defaults.method.toLowerCase();\n  } else {\n    config.method = 'get';\n  }\n\n  // Hook up interceptors middleware\n  var chain = [dispatchRequest, undefined];\n  var promise = Promise.resolve(config);\n\n  this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) {\n    chain.unshift(interceptor.fulfilled, interceptor.rejected);\n  });\n\n  this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) {\n    chain.push(interceptor.fulfilled, interceptor.rejected);\n  });\n\n  while (chain.length) {\n    promise = promise.then(chain.shift(), chain.shift());\n  }\n\n  return promise;\n};\n\nAxios.prototype.getUri = function getUri(config) {\n  config = mergeConfig(this.defaults, config);\n  return buildURL(config.url, config.params, config.paramsSerializer).replace(/^\\?/, '');\n};\n\n// Provide aliases for supported request methods\nutils.forEach(['delete', 'get', 'head', 'options'], function forEachMethodNoData(method) {\n  /*eslint func-names:0*/\n  Axios.prototype[method] = function(url, config) {\n    return this.request(mergeConfig(config || {}, {\n      method: method,\n      url: url,\n      data: (config || {}).data\n    }));\n  };\n});\n\nutils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {\n  /*eslint func-names:0*/\n  Axios.prototype[method] = function(url, data, config) {\n    return this.request(mergeConfig(config || {}, {\n      method: method,\n      url: url,\n      data: data\n    }));\n  };\n});\n\nmodule.exports = Axios;\n","'use strict';\n\nvar utils = require('./../utils');\n\nfunction InterceptorManager() {\n  this.handlers = [];\n}\n\n/**\n * Add a new interceptor to the stack\n *\n * @param {Function} fulfilled The function to handle `then` for a `Promise`\n * @param {Function} rejected The function to handle `reject` for a `Promise`\n *\n * @return {Number} An ID used to remove interceptor later\n */\nInterceptorManager.prototype.use = function use(fulfilled, rejected) {\n  this.handlers.push({\n    fulfilled: fulfilled,\n    rejected: rejected\n  });\n  return this.handlers.length - 1;\n};\n\n/**\n * Remove an interceptor from the stack\n *\n * @param {Number} id The ID that was returned by `use`\n */\nInterceptorManager.prototype.eject = function eject(id) {\n  if (this.handlers[id]) {\n    this.handlers[id] = null;\n  }\n};\n\n/**\n * Iterate over all the registered interceptors\n *\n * This method is particularly useful for skipping over any\n * interceptors that may have become `null` calling `eject`.\n *\n * @param {Function} fn The function to call for each interceptor\n */\nInterceptorManager.prototype.forEach = function forEach(fn) {\n  utils.forEach(this.handlers, function forEachHandler(h) {\n    if (h !== null) {\n      fn(h);\n    }\n  });\n};\n\nmodule.exports = InterceptorManager;\n","'use strict';\n\nvar utils = require('./../utils');\nvar transformData = require('./transformData');\nvar isCancel = require('../cancel/isCancel');\nvar defaults = require('../defaults');\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nfunction throwIfCancellationRequested(config) {\n  if (config.cancelToken) {\n    config.cancelToken.throwIfRequested();\n  }\n}\n\n/**\n * Dispatch a request to the server using the configured adapter.\n *\n * @param {object} config The config that is to be used for the request\n * @returns {Promise} The Promise to be fulfilled\n */\nmodule.exports = function dispatchRequest(config) {\n  throwIfCancellationRequested(config);\n\n  // Ensure headers exist\n  config.headers = config.headers || {};\n\n  // Transform request data\n  config.data = transformData(\n    config.data,\n    config.headers,\n    config.transformRequest\n  );\n\n  // Flatten headers\n  config.headers = utils.merge(\n    config.headers.common || {},\n    config.headers[config.method] || {},\n    config.headers\n  );\n\n  utils.forEach(\n    ['delete', 'get', 'head', 'post', 'put', 'patch', 'common'],\n    function cleanHeaderConfig(method) {\n      delete config.headers[method];\n    }\n  );\n\n  var adapter = config.adapter || defaults.adapter;\n\n  return adapter(config).then(function onAdapterResolution(response) {\n    throwIfCancellationRequested(config);\n\n    // Transform response data\n    response.data = transformData(\n      response.data,\n      response.headers,\n      config.transformResponse\n    );\n\n    return response;\n  }, function onAdapterRejection(reason) {\n    if (!isCancel(reason)) {\n      throwIfCancellationRequested(config);\n\n      // Transform response data\n      if (reason && reason.response) {\n        reason.response.data = transformData(\n          reason.response.data,\n          reason.response.headers,\n          config.transformResponse\n        );\n      }\n    }\n\n    return Promise.reject(reason);\n  });\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\n/**\n * Transform the data for a request or a response\n *\n * @param {Object|String} data The data to be transformed\n * @param {Array} headers The headers for the request or response\n * @param {Array|Function} fns A single function or Array of functions\n * @returns {*} The resulting transformed data\n */\nmodule.exports = function transformData(data, headers, fns) {\n  /*eslint no-param-reassign:0*/\n  utils.forEach(fns, function transform(fn) {\n    data = fn(data, headers);\n  });\n\n  return data;\n};\n","'use strict';\n\nvar utils = require('../utils');\n\nmodule.exports = function normalizeHeaderName(headers, normalizedName) {\n  utils.forEach(headers, function processHeader(value, name) {\n    if (name !== normalizedName && name.toUpperCase() === normalizedName.toUpperCase()) {\n      headers[normalizedName] = value;\n      delete headers[name];\n    }\n  });\n};\n","'use strict';\n\nvar createError = require('./createError');\n\n/**\n * Resolve or reject a Promise based on response status.\n *\n * @param {Function} resolve A function that resolves the promise.\n * @param {Function} reject A function that rejects the promise.\n * @param {object} response The response.\n */\nmodule.exports = function settle(resolve, reject, response) {\n  var validateStatus = response.config.validateStatus;\n  if (!response.status || !validateStatus || validateStatus(response.status)) {\n    resolve(response);\n  } else {\n    reject(createError(\n      'Request failed with status code ' + response.status,\n      response.config,\n      null,\n      response.request,\n      response\n    ));\n  }\n};\n","'use strict';\n\n/**\n * Update an Error with the specified config, error code, and response.\n *\n * @param {Error} error The error to update.\n * @param {Object} config The config.\n * @param {string} [code] The error code (for example, 'ECONNABORTED').\n * @param {Object} [request] The request.\n * @param {Object} [response] The response.\n * @returns {Error} The error.\n */\nmodule.exports = function enhanceError(error, config, code, request, response) {\n  error.config = config;\n  if (code) {\n    error.code = code;\n  }\n\n  error.request = request;\n  error.response = response;\n  error.isAxiosError = true;\n\n  error.toJSON = function toJSON() {\n    return {\n      // Standard\n      message: this.message,\n      name: this.name,\n      // Microsoft\n      description: this.description,\n      number: this.number,\n      // Mozilla\n      fileName: this.fileName,\n      lineNumber: this.lineNumber,\n      columnNumber: this.columnNumber,\n      stack: this.stack,\n      // Axios\n      config: this.config,\n      code: this.code\n    };\n  };\n  return error;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n  utils.isStandardBrowserEnv() ?\n\n  // Standard browser envs support document.cookie\n    (function standardBrowserEnv() {\n      return {\n        write: function write(name, value, expires, path, domain, secure) {\n          var cookie = [];\n          cookie.push(name + '=' + encodeURIComponent(value));\n\n          if (utils.isNumber(expires)) {\n            cookie.push('expires=' + new Date(expires).toGMTString());\n          }\n\n          if (utils.isString(path)) {\n            cookie.push('path=' + path);\n          }\n\n          if (utils.isString(domain)) {\n            cookie.push('domain=' + domain);\n          }\n\n          if (secure === true) {\n            cookie.push('secure');\n          }\n\n          document.cookie = cookie.join('; ');\n        },\n\n        read: function read(name) {\n          var match = document.cookie.match(new RegExp('(^|;\\\\s*)(' + name + ')=([^;]*)'));\n          return (match ? decodeURIComponent(match[3]) : null);\n        },\n\n        remove: function remove(name) {\n          this.write(name, '', Date.now() - 86400000);\n        }\n      };\n    })() :\n\n  // Non standard browser env (web workers, react-native) lack needed support.\n    (function nonStandardBrowserEnv() {\n      return {\n        write: function write() {},\n        read: function read() { return null; },\n        remove: function remove() {}\n      };\n    })()\n);\n","'use strict';\n\nvar isAbsoluteURL = require('../helpers/isAbsoluteURL');\nvar combineURLs = require('../helpers/combineURLs');\n\n/**\n * Creates a new URL by combining the baseURL with the requestedURL,\n * only when the requestedURL is not already an absolute URL.\n * If the requestURL is absolute, this function returns the requestedURL untouched.\n *\n * @param {string} baseURL The base URL\n * @param {string} requestedURL Absolute or relative URL to combine\n * @returns {string} The combined full path\n */\nmodule.exports = function buildFullPath(baseURL, requestedURL) {\n  if (baseURL && !isAbsoluteURL(requestedURL)) {\n    return combineURLs(baseURL, requestedURL);\n  }\n  return requestedURL;\n};\n","'use strict';\n\n/**\n * Determines whether the specified URL is absolute\n *\n * @param {string} url The URL to test\n * @returns {boolean} True if the specified URL is absolute, otherwise false\n */\nmodule.exports = function isAbsoluteURL(url) {\n  // A URL is considered absolute if it begins with \"<scheme>://\" or \"//\" (protocol-relative URL).\n  // RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed\n  // by any combination of letters, digits, plus, period, or hyphen.\n  return /^([a-z][a-z\\d\\+\\-\\.]*:)?\\/\\//i.test(url);\n};\n","'use strict';\n\n/**\n * Creates a new URL by combining the specified URLs\n *\n * @param {string} baseURL The base URL\n * @param {string} relativeURL The relative URL\n * @returns {string} The combined URL\n */\nmodule.exports = function combineURLs(baseURL, relativeURL) {\n  return relativeURL\n    ? baseURL.replace(/\\/+$/, '') + '/' + relativeURL.replace(/^\\/+/, '')\n    : baseURL;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\n// Headers whose duplicates are ignored by node\n// c.f. https://nodejs.org/api/http.html#http_message_headers\nvar ignoreDuplicateOf = [\n  'age', 'authorization', 'content-length', 'content-type', 'etag',\n  'expires', 'from', 'host', 'if-modified-since', 'if-unmodified-since',\n  'last-modified', 'location', 'max-forwards', 'proxy-authorization',\n  'referer', 'retry-after', 'user-agent'\n];\n\n/**\n * Parse headers into an object\n *\n * ```\n * Date: Wed, 27 Aug 2014 08:58:49 GMT\n * Content-Type: application/json\n * Connection: keep-alive\n * Transfer-Encoding: chunked\n * ```\n *\n * @param {String} headers Headers needing to be parsed\n * @returns {Object} Headers parsed into an object\n */\nmodule.exports = function parseHeaders(headers) {\n  var parsed = {};\n  var key;\n  var val;\n  var i;\n\n  if (!headers) { return parsed; }\n\n  utils.forEach(headers.split('\\n'), function parser(line) {\n    i = line.indexOf(':');\n    key = utils.trim(line.substr(0, i)).toLowerCase();\n    val = utils.trim(line.substr(i + 1));\n\n    if (key) {\n      if (parsed[key] && ignoreDuplicateOf.indexOf(key) >= 0) {\n        return;\n      }\n      if (key === 'set-cookie') {\n        parsed[key] = (parsed[key] ? parsed[key] : []).concat([val]);\n      } else {\n        parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;\n      }\n    }\n  });\n\n  return parsed;\n};\n","'use strict';\n\nvar utils = require('./../utils');\n\nmodule.exports = (\n  utils.isStandardBrowserEnv() ?\n\n  // Standard browser envs have full support of the APIs needed to test\n  // whether the request URL is of the same origin as current location.\n    (function standardBrowserEnv() {\n      var msie = /(msie|trident)/i.test(navigator.userAgent);\n      var urlParsingNode = document.createElement('a');\n      var originURL;\n\n      /**\n    * Parse a URL to discover it's components\n    *\n    * @param {String} url The URL to be parsed\n    * @returns {Object}\n    */\n      function resolveURL(url) {\n        var href = url;\n\n        if (msie) {\n        // IE needs attribute set twice to normalize properties\n          urlParsingNode.setAttribute('href', href);\n          href = urlParsingNode.href;\n        }\n\n        urlParsingNode.setAttribute('href', href);\n\n        // urlParsingNode provides the UrlUtils interface - http://url.spec.whatwg.org/#urlutils\n        return {\n          href: urlParsingNode.href,\n          protocol: urlParsingNode.protocol ? urlParsingNode.protocol.replace(/:$/, '') : '',\n          host: urlParsingNode.host,\n          search: urlParsingNode.search ? urlParsingNode.search.replace(/^\\?/, '') : '',\n          hash: urlParsingNode.hash ? urlParsingNode.hash.replace(/^#/, '') : '',\n          hostname: urlParsingNode.hostname,\n          port: urlParsingNode.port,\n          pathname: (urlParsingNode.pathname.charAt(0) === '/') ?\n            urlParsingNode.pathname :\n            '/' + urlParsingNode.pathname\n        };\n      }\n\n      originURL = resolveURL(window.location.href);\n\n      /**\n    * Determine if a URL shares the same origin as the current location\n    *\n    * @param {String} requestURL The URL to test\n    * @returns {boolean} True if URL shares the same origin, otherwise false\n    */\n      return function isURLSameOrigin(requestURL) {\n        var parsed = (utils.isString(requestURL)) ? resolveURL(requestURL) : requestURL;\n        return (parsed.protocol === originURL.protocol &&\n            parsed.host === originURL.host);\n      };\n    })() :\n\n  // Non standard browser envs (web workers, react-native) lack needed support.\n    (function nonStandardBrowserEnv() {\n      return function isURLSameOrigin() {\n        return true;\n      };\n    })()\n);\n","'use strict';\n\nvar Cancel = require('./Cancel');\n\n/**\n * A `CancelToken` is an object that can be used to request cancellation of an operation.\n *\n * @class\n * @param {Function} executor The executor function.\n */\nfunction CancelToken(executor) {\n  if (typeof executor !== 'function') {\n    throw new TypeError('executor must be a function.');\n  }\n\n  var resolvePromise;\n  this.promise = new Promise(function promiseExecutor(resolve) {\n    resolvePromise = resolve;\n  });\n\n  var token = this;\n  executor(function cancel(message) {\n    if (token.reason) {\n      // Cancellation has already been requested\n      return;\n    }\n\n    token.reason = new Cancel(message);\n    resolvePromise(token.reason);\n  });\n}\n\n/**\n * Throws a `Cancel` if cancellation has been requested.\n */\nCancelToken.prototype.throwIfRequested = function throwIfRequested() {\n  if (this.reason) {\n    throw this.reason;\n  }\n};\n\n/**\n * Returns an object that contains a new `CancelToken` and a function that, when called,\n * cancels the `CancelToken`.\n */\nCancelToken.source = function source() {\n  var cancel;\n  var token = new CancelToken(function executor(c) {\n    cancel = c;\n  });\n  return {\n    token: token,\n    cancel: cancel\n  };\n};\n\nmodule.exports = CancelToken;\n","'use strict';\n\n/**\n * Syntactic sugar for invoking a function and expanding an array for arguments.\n *\n * Common use case would be to use `Function.prototype.apply`.\n *\n *  ```js\n *  function f(x, y, z) {}\n *  var args = [1, 2, 3];\n *  f.apply(null, args);\n *  ```\n *\n * With `spread` this example can be re-written.\n *\n *  ```js\n *  spread(function(x, y, z) {})([1, 2, 3]);\n *  ```\n *\n * @param {Function} callback\n * @returns {Function}\n */\nmodule.exports = function spread(callback) {\n  return function wrap(arr) {\n    return callback.apply(null, arr);\n  };\n};\n","'use strict';\n\n/**\n * Determines whether the payload is an error thrown by Axios\n *\n * @param {*} payload The value to test\n * @returns {boolean} True if the payload is an error thrown by Axios, otherwise false\n */\nmodule.exports = function isAxiosError(payload) {\n  return (typeof payload === 'object') && (payload.isAxiosError === true);\n};\n","import firebase from '@firebase/app';(function() {/*\n\n Copyright The Closure Library Authors.\n SPDX-License-Identifier: Apache-2.0\n*/\nvar k,aa=\"function\"==typeof Object.defineProperties?Object.defineProperty:function(a,b,c){a!=Array.prototype&&a!=Object.prototype&&(a[b]=c.value)};function ba(a){a=[\"object\"==typeof window&&window,\"object\"==typeof self&&self,\"object\"==typeof global&&global,a];for(var b=0;b<a.length;++b){var c=a[b];if(c&&c.Math==Math)return c}return globalThis}var ca=ba(this);\nfunction da(a,b){if(b){var c=ca;a=a.split(\".\");for(var d=0;d<a.length-1;d++){var e=a[d];e in c||(c[e]={});c=c[e]}a=a[a.length-1];d=c[a];b=b(d);b!=d&&null!=b&&aa(c,a,{configurable:!0,writable:!0,value:b})}}function ea(a){var b=0;return function(){return b<a.length?{done:!1,value:a[b++]}:{done:!0}}}function fa(a){var b=\"undefined\"!=typeof Symbol&&Symbol.iterator&&a[Symbol.iterator];return b?b.call(a):{next:ea(a)}}\nda(\"Promise\",function(a){function b(g){this.b=0;this.c=void 0;this.a=[];var h=this.f();try{g(h.resolve,h.reject)}catch(m){h.reject(m)}}function c(){this.a=null}function d(g){return g instanceof b?g:new b(function(h){h(g)})}if(a)return a;c.prototype.b=function(g){if(null==this.a){this.a=[];var h=this;this.c(function(){h.g()})}this.a.push(g)};var e=ca.setTimeout;c.prototype.c=function(g){e(g,0)};c.prototype.g=function(){for(;this.a&&this.a.length;){var g=this.a;this.a=[];for(var h=0;h<g.length;++h){var m=\ng[h];g[h]=null;try{m()}catch(p){this.f(p)}}}this.a=null};c.prototype.f=function(g){this.c(function(){throw g;})};b.prototype.f=function(){function g(p){return function(v){m||(m=!0,p.call(h,v))}}var h=this,m=!1;return{resolve:g(this.m),reject:g(this.g)}};b.prototype.m=function(g){if(g===this)this.g(new TypeError(\"A Promise cannot resolve to itself\"));else if(g instanceof b)this.s(g);else{a:switch(typeof g){case \"object\":var h=null!=g;break a;case \"function\":h=!0;break a;default:h=!1}h?this.v(g):this.h(g)}};\nb.prototype.v=function(g){var h=void 0;try{h=g.then}catch(m){this.g(m);return}\"function\"==typeof h?this.u(h,g):this.h(g)};b.prototype.g=function(g){this.i(2,g)};b.prototype.h=function(g){this.i(1,g)};b.prototype.i=function(g,h){if(0!=this.b)throw Error(\"Cannot settle(\"+g+\", \"+h+\"): Promise already settled in state\"+this.b);this.b=g;this.c=h;this.l()};b.prototype.l=function(){if(null!=this.a){for(var g=0;g<this.a.length;++g)f.b(this.a[g]);this.a=null}};var f=new c;b.prototype.s=function(g){var h=this.f();\ng.Qa(h.resolve,h.reject)};b.prototype.u=function(g,h){var m=this.f();try{g.call(h,m.resolve,m.reject)}catch(p){m.reject(p)}};b.prototype.then=function(g,h){function m(A,Q){return\"function\"==typeof A?function(ya){try{p(A(ya))}catch(Ad){v(Ad)}}:Q}var p,v,B=new b(function(A,Q){p=A;v=Q});this.Qa(m(g,p),m(h,v));return B};b.prototype.catch=function(g){return this.then(void 0,g)};b.prototype.Qa=function(g,h){function m(){switch(p.b){case 1:g(p.c);break;case 2:h(p.c);break;default:throw Error(\"Unexpected state: \"+\np.b);}}var p=this;null==this.a?f.b(m):this.a.push(m)};b.resolve=d;b.reject=function(g){return new b(function(h,m){m(g)})};b.race=function(g){return new b(function(h,m){for(var p=fa(g),v=p.next();!v.done;v=p.next())d(v.value).Qa(h,m)})};b.all=function(g){var h=fa(g),m=h.next();return m.done?d([]):new b(function(p,v){function B(ya){return function(Ad){A[ya]=Ad;Q--;0==Q&&p(A)}}var A=[],Q=0;do A.push(void 0),Q++,d(m.value).Qa(B(A.length-1),v),m=h.next();while(!m.done)})};return b});\nvar ha=ha||{},l=this||self,ia=/^[\\w+/_-]+[=]{0,2}$/,ja=null;function ka(a){return(a=a.querySelector&&a.querySelector(\"script[nonce]\"))&&(a=a.nonce||a.getAttribute(\"nonce\"))&&ia.test(a)?a:\"\"}function la(){}function ma(a){var b=typeof a;return\"object\"!=b?b:a?Array.isArray(a)?\"array\":b:\"null\"}function na(a){var b=ma(a);return\"array\"==b||\"object\"==b&&\"number\"==typeof a.length}function oa(a){return\"function\"==ma(a)}function n(a){var b=typeof a;return\"object\"==b&&null!=a||\"function\"==b}\nfunction pa(a){return Object.prototype.hasOwnProperty.call(a,qa)&&a[qa]||(a[qa]=++ra)}var qa=\"closure_uid_\"+(1E9*Math.random()>>>0),ra=0;function sa(a,b,c){return a.call.apply(a.bind,arguments)}function ta(a,b,c){if(!a)throw Error();if(2<arguments.length){var d=Array.prototype.slice.call(arguments,2);return function(){var e=Array.prototype.slice.call(arguments);Array.prototype.unshift.apply(e,d);return a.apply(b,e)}}return function(){return a.apply(b,arguments)}}\nfunction q(a,b,c){Function.prototype.bind&&-1!=Function.prototype.bind.toString().indexOf(\"native code\")?q=sa:q=ta;return q.apply(null,arguments)}function ua(a,b){var c=Array.prototype.slice.call(arguments,1);return function(){var d=c.slice();d.push.apply(d,arguments);return a.apply(this,d)}}var va=Date.now;function r(a,b){function c(){}c.prototype=b.prototype;a.ab=b.prototype;a.prototype=new c;a.prototype.constructor=a}function wa(a){return a};/*\n\n Copyright 2017 Google Inc.\n\n Licensed under the Apache License, Version 2.0 (the \"License\");\n you may not use this file except in compliance with the License.\n You may obtain a copy of the License at\n\n   http://www.apache.org/licenses/LICENSE-2.0\n\n Unless required by applicable law or agreed to in writing, software\n distributed under the License is distributed on an \"AS IS\" BASIS,\n WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n See the License for the specific language governing permissions and\n limitations under the License.\n*/\nfunction t(a,b,c){this.code=xa+a;this.message=b||za[a]||\"\";this.a=c||null}r(t,Error);t.prototype.w=function(){var a={code:this.code,message:this.message};this.a&&(a.serverResponse=this.a);return a};t.prototype.toJSON=function(){return this.w()};function Aa(a){var b=a&&a.code;return b?new t(b.substring(xa.length),a.message,a.serverResponse):null}\nvar xa=\"auth/\",za={\"admin-restricted-operation\":\"This operation is restricted to administrators only.\",\"argument-error\":\"\",\"app-not-authorized\":\"This app, identified by the domain where it's hosted, is not authorized to use Firebase Authentication with the provided API key. Review your key configuration in the Google API console.\",\"app-not-installed\":\"The requested mobile application corresponding to the identifier (Android package name or iOS bundle ID) provided is not installed on this device.\",\n\"captcha-check-failed\":\"The reCAPTCHA response token provided is either invalid, expired, already used or the domain associated with it does not match the list of whitelisted domains.\",\"code-expired\":\"The SMS code has expired. Please re-send the verification code to try again.\",\"cordova-not-ready\":\"Cordova framework is not ready.\",\"cors-unsupported\":\"This browser is not supported.\",\"credential-already-in-use\":\"This credential is already associated with a different user account.\",\"custom-token-mismatch\":\"The custom token corresponds to a different audience.\",\n\"requires-recent-login\":\"This operation is sensitive and requires recent authentication. Log in again before retrying this request.\",\"dynamic-link-not-activated\":\"Please activate Dynamic Links in the Firebase Console and agree to the terms and conditions.\",\"email-change-needs-verification\":\"Multi-factor users must always have a verified email.\",\"email-already-in-use\":\"The email address is already in use by another account.\",\"expired-action-code\":\"The action code has expired. \",\"cancelled-popup-request\":\"This operation has been cancelled due to another conflicting popup being opened.\",\n\"internal-error\":\"An internal error has occurred.\",\"invalid-app-credential\":\"The phone verification request contains an invalid application verifier. The reCAPTCHA token response is either invalid or expired.\",\"invalid-app-id\":\"The mobile app identifier is not registed for the current project.\",\"invalid-user-token\":\"This user's credential isn't valid for this project. This can happen if the user's token has been tampered with, or if the user isn't for the project associated with this API key.\",\"invalid-auth-event\":\"An internal error has occurred.\",\n\"invalid-verification-code\":\"The SMS verification code used to create the phone auth credential is invalid. Please resend the verification code sms and be sure use the verification code provided by the user.\",\"invalid-continue-uri\":\"The continue URL provided in the request is invalid.\",\"invalid-cordova-configuration\":\"The following Cordova plugins must be installed to enable OAuth sign-in: cordova-plugin-buildinfo, cordova-universal-links-plugin, cordova-plugin-browsertab, cordova-plugin-inappbrowser and cordova-plugin-customurlscheme.\",\n\"invalid-custom-token\":\"The custom token format is incorrect. Please check the documentation.\",\"invalid-dynamic-link-domain\":\"The provided dynamic link domain is not configured or authorized for the current project.\",\"invalid-email\":\"The email address is badly formatted.\",\"invalid-api-key\":\"Your API key is invalid, please check you have copied it correctly.\",\"invalid-cert-hash\":\"The SHA-1 certificate hash provided is invalid.\",\"invalid-credential\":\"The supplied auth credential is malformed or has expired.\",\n\"invalid-message-payload\":\"The email template corresponding to this action contains invalid characters in its message. Please fix by going to the Auth email templates section in the Firebase Console.\",\"invalid-multi-factor-session\":\"The request does not contain a valid proof of first factor successful sign-in.\",\"invalid-oauth-provider\":\"EmailAuthProvider is not supported for this operation. This operation only supports OAuth providers.\",\"invalid-oauth-client-id\":\"The OAuth client ID provided is either invalid or does not match the specified API key.\",\n\"unauthorized-domain\":\"This domain is not authorized for OAuth operations for your Firebase project. Edit the list of authorized domains from the Firebase console.\",\"invalid-action-code\":\"The action code is invalid. This can happen if the code is malformed, expired, or has already been used.\",\"wrong-password\":\"The password is invalid or the user does not have a password.\",\"invalid-persistence-type\":\"The specified persistence type is invalid. It can only be local, session or none.\",\"invalid-phone-number\":\"The format of the phone number provided is incorrect. Please enter the phone number in a format that can be parsed into E.164 format. E.164 phone numbers are written in the format [+][country code][subscriber number including area code].\",\n\"invalid-provider-id\":\"The specified provider ID is invalid.\",\"invalid-recipient-email\":\"The email corresponding to this action failed to send as the provided recipient email address is invalid.\",\"invalid-sender\":\"The email template corresponding to this action contains an invalid sender email or name. Please fix by going to the Auth email templates section in the Firebase Console.\",\"invalid-verification-id\":\"The verification ID used to create the phone auth credential is invalid.\",\"invalid-tenant-id\":\"The Auth instance's tenant ID is invalid.\",\n\"multi-factor-info-not-found\":\"The user does not have a second factor matching the identifier provided.\",\"multi-factor-auth-required\":\"Proof of ownership of a second factor is required to complete sign-in.\",\"missing-android-pkg-name\":\"An Android Package Name must be provided if the Android App is required to be installed.\",\"auth-domain-config-required\":\"Be sure to include authDomain when calling firebase.initializeApp(), by following the instructions in the Firebase console.\",\"missing-app-credential\":\"The phone verification request is missing an application verifier assertion. A reCAPTCHA response token needs to be provided.\",\n\"missing-verification-code\":\"The phone auth credential was created with an empty SMS verification code.\",\"missing-continue-uri\":\"A continue URL must be provided in the request.\",\"missing-iframe-start\":\"An internal error has occurred.\",\"missing-ios-bundle-id\":\"An iOS Bundle ID must be provided if an App Store ID is provided.\",\"missing-multi-factor-info\":\"No second factor identifier is provided.\",\"missing-multi-factor-session\":\"The request is missing proof of first factor successful sign-in.\",\"missing-or-invalid-nonce\":\"The request does not contain a valid nonce. This can occur if the SHA-256 hash of the provided raw nonce does not match the hashed nonce in the ID token payload.\",\n\"missing-phone-number\":\"To send verification codes, provide a phone number for the recipient.\",\"missing-verification-id\":\"The phone auth credential was created with an empty verification ID.\",\"app-deleted\":\"This instance of FirebaseApp has been deleted.\",\"account-exists-with-different-credential\":\"An account already exists with the same email address but different sign-in credentials. Sign in using a provider associated with this email address.\",\"network-request-failed\":\"A network error (such as timeout, interrupted connection or unreachable host) has occurred.\",\n\"no-auth-event\":\"An internal error has occurred.\",\"no-such-provider\":\"User was not linked to an account with the given provider.\",\"null-user\":\"A null user object was provided as the argument for an operation which requires a non-null user object.\",\"operation-not-allowed\":\"The given sign-in provider is disabled for this Firebase project. Enable it in the Firebase console, under the sign-in method tab of the Auth section.\",\"operation-not-supported-in-this-environment\":'This operation is not supported in the environment this application is running on. \"location.protocol\" must be http, https or chrome-extension and web storage must be enabled.',\n\"popup-blocked\":\"Unable to establish a connection with the popup. It may have been blocked by the browser.\",\"popup-closed-by-user\":\"The popup has been closed by the user before finalizing the operation.\",\"provider-already-linked\":\"User can only be linked to one identity for the given provider.\",\"quota-exceeded\":\"The project's quota for this operation has been exceeded.\",\"redirect-cancelled-by-user\":\"The redirect operation has been cancelled by the user before finalizing.\",\"redirect-operation-pending\":\"A redirect sign-in operation is already pending.\",\n\"rejected-credential\":\"The request contains malformed or mismatching credentials.\",\"second-factor-already-in-use\":\"The second factor is already enrolled on this account.\",\"maximum-second-factor-count-exceeded\":\"The maximum allowed number of second factors on a user has been exceeded.\",\"tenant-id-mismatch\":\"The provided tenant ID does not match the Auth instance's tenant ID\",timeout:\"The operation has timed out.\",\"user-token-expired\":\"The user's credential is no longer valid. The user must sign in again.\",\n\"too-many-requests\":\"We have blocked all requests from this device due to unusual activity. Try again later.\",\"unauthorized-continue-uri\":\"The domain of the continue URL is not whitelisted.  Please whitelist the domain in the Firebase console.\",\"unsupported-first-factor\":\"Enrolling a second factor or signing in with a multi-factor account requires sign-in with a supported first factor.\",\"unsupported-persistence-type\":\"The current environment does not support the specified persistence type.\",\"unsupported-tenant-operation\":\"This operation is not supported in a multi-tenant context.\",\n\"unverified-email\":\"The operation requires a verified email.\",\"user-cancelled\":\"The user did not grant your application the permissions it requested.\",\"user-not-found\":\"There is no user record corresponding to this identifier. The user may have been deleted.\",\"user-disabled\":\"The user account has been disabled by an administrator.\",\"user-mismatch\":\"The supplied credentials do not correspond to the previously signed in user.\",\"user-signed-out\":\"\",\"weak-password\":\"The password must be 6 characters long or more.\",\n\"web-storage-unsupported\":\"This browser is not supported or 3rd party cookies and data may be disabled.\"};/*\n\n Copyright 2017 Google LLC\n\n Licensed under the Apache License, Version 2.0 (the \"License\");\n you may not use this file except in compliance with the License.\n You may obtain a copy of the License at\n\n   http://www.apache.org/licenses/LICENSE-2.0\n\n Unless required by applicable law or agreed to in writing, software\n distributed under the License is distributed on an \"AS IS\" BASIS,\n WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n See the License for the specific language governing permissions and\n limitations under the License.\n*/\nvar Ba={ld:{Ta:\"https://staging-identitytoolkit.sandbox.googleapis.com/identitytoolkit/v3/relyingparty/\",Za:\"https://staging-securetoken.sandbox.googleapis.com/v1/token\",Wa:\"https://staging-identitytoolkit.sandbox.googleapis.com/v2/\",id:\"b\"},sd:{Ta:\"https://www.googleapis.com/identitytoolkit/v3/relyingparty/\",Za:\"https://securetoken.googleapis.com/v1/token\",Wa:\"https://identitytoolkit.googleapis.com/v2/\",id:\"p\"},ud:{Ta:\"https://staging-www.sandbox.googleapis.com/identitytoolkit/v3/relyingparty/\",\nZa:\"https://staging-securetoken.sandbox.googleapis.com/v1/token\",Wa:\"https://staging-identitytoolkit.sandbox.googleapis.com/v2/\",id:\"s\"},vd:{Ta:\"https://www-googleapis-test.sandbox.google.com/identitytoolkit/v3/relyingparty/\",Za:\"https://test-securetoken.sandbox.googleapis.com/v1/token\",Wa:\"https://test-identitytoolkit.sandbox.googleapis.com/v2/\",id:\"t\"}};\nfunction Ca(a){for(var b in Ba)if(Ba[b].id===a)return a=Ba[b],{firebaseEndpoint:a.Ta,secureTokenEndpoint:a.Za,identityPlatformEndpoint:a.Wa};return null}var Da;Da=Ca(\"__EID__\")?\"__EID__\":void 0;function Ea(a){if(!a)return!1;try{return!!a.$goog_Thenable}catch(b){return!1}};function u(a){if(Error.captureStackTrace)Error.captureStackTrace(this,u);else{var b=Error().stack;b&&(this.stack=b)}a&&(this.message=String(a))}r(u,Error);u.prototype.name=\"CustomError\";function Fa(a,b){a=a.split(\"%s\");for(var c=\"\",d=a.length-1,e=0;e<d;e++)c+=a[e]+(e<b.length?b[e]:\"%s\");u.call(this,c+a[d])}r(Fa,u);Fa.prototype.name=\"AssertionError\";function Ga(a,b){throw new Fa(\"Failure\"+(a?\": \"+a:\"\"),Array.prototype.slice.call(arguments,1));};function Ha(a,b){this.c=a;this.f=b;this.b=0;this.a=null}Ha.prototype.get=function(){if(0<this.b){this.b--;var a=this.a;this.a=a.next;a.next=null}else a=this.c();return a};function Ia(a,b){a.f(b);100>a.b&&(a.b++,b.next=a.a,a.a=b)};function Ja(){this.b=this.a=null}var La=new Ha(function(){return new Ka},function(a){a.reset()});Ja.prototype.add=function(a,b){var c=La.get();c.set(a,b);this.b?this.b.next=c:this.a=c;this.b=c};function Ma(){var a=Na,b=null;a.a&&(b=a.a,a.a=a.a.next,a.a||(a.b=null),b.next=null);return b}function Ka(){this.next=this.b=this.a=null}Ka.prototype.set=function(a,b){this.a=a;this.b=b;this.next=null};Ka.prototype.reset=function(){this.next=this.b=this.a=null};var Oa=Array.prototype.indexOf?function(a,b){return Array.prototype.indexOf.call(a,b,void 0)}:function(a,b){if(\"string\"===typeof a)return\"string\"!==typeof b||1!=b.length?-1:a.indexOf(b,0);for(var c=0;c<a.length;c++)if(c in a&&a[c]===b)return c;return-1},w=Array.prototype.forEach?function(a,b,c){Array.prototype.forEach.call(a,b,c)}:function(a,b,c){for(var d=a.length,e=\"string\"===typeof a?a.split(\"\"):a,f=0;f<d;f++)f in e&&b.call(c,e[f],f,a)};\nfunction Pa(a,b){for(var c=\"string\"===typeof a?a.split(\"\"):a,d=a.length-1;0<=d;--d)d in c&&b.call(void 0,c[d],d,a)}\nvar Qa=Array.prototype.filter?function(a,b){return Array.prototype.filter.call(a,b,void 0)}:function(a,b){for(var c=a.length,d=[],e=0,f=\"string\"===typeof a?a.split(\"\"):a,g=0;g<c;g++)if(g in f){var h=f[g];b.call(void 0,h,g,a)&&(d[e++]=h)}return d},Ra=Array.prototype.map?function(a,b){return Array.prototype.map.call(a,b,void 0)}:function(a,b){for(var c=a.length,d=Array(c),e=\"string\"===typeof a?a.split(\"\"):a,f=0;f<c;f++)f in e&&(d[f]=b.call(void 0,e[f],f,a));return d},Sa=Array.prototype.some?function(a,\nb){return Array.prototype.some.call(a,b,void 0)}:function(a,b){for(var c=a.length,d=\"string\"===typeof a?a.split(\"\"):a,e=0;e<c;e++)if(e in d&&b.call(void 0,d[e],e,a))return!0;return!1};function Ta(a){a:{var b=Ua;for(var c=a.length,d=\"string\"===typeof a?a.split(\"\"):a,e=0;e<c;e++)if(e in d&&b.call(void 0,d[e],e,a)){b=e;break a}b=-1}return 0>b?null:\"string\"===typeof a?a.charAt(b):a[b]}function Va(a,b){return 0<=Oa(a,b)}\nfunction Wa(a,b){b=Oa(a,b);var c;(c=0<=b)&&Array.prototype.splice.call(a,b,1);return c}function Xa(a,b){var c=0;Pa(a,function(d,e){b.call(void 0,d,e,a)&&1==Array.prototype.splice.call(a,e,1).length&&c++})}function Ya(a){return Array.prototype.concat.apply([],arguments)}function Za(a){var b=a.length;if(0<b){for(var c=Array(b),d=0;d<b;d++)c[d]=a[d];return c}return[]};var $a=String.prototype.trim?function(a){return a.trim()}:function(a){return/^[\\s\\xa0]*([\\s\\S]*?)[\\s\\xa0]*$/.exec(a)[1]},ab=/&/g,bb=/</g,cb=/>/g,db=/\"/g,eb=/'/g,fb=/\\x00/g,gb=/[\\x00&<>\"']/;function x(a,b){return-1!=a.indexOf(b)}function hb(a,b){return a<b?-1:a>b?1:0};var ib;a:{var jb=l.navigator;if(jb){var kb=jb.userAgent;if(kb){ib=kb;break a}}ib=\"\"}function y(a){return x(ib,a)};function lb(a,b){for(var c in a)b.call(void 0,a[c],c,a)}function mb(a){for(var b in a)return!1;return!0}function nb(a){var b={},c;for(c in a)b[c]=a[c];return b}var ob=\"constructor hasOwnProperty isPrototypeOf propertyIsEnumerable toLocaleString toString valueOf\".split(\" \");function z(a,b){for(var c,d,e=1;e<arguments.length;e++){d=arguments[e];for(c in d)a[c]=d[c];for(var f=0;f<ob.length;f++)c=ob[f],Object.prototype.hasOwnProperty.call(d,c)&&(a[c]=d[c])}};function pb(a,b){a:{try{var c=a&&a.ownerDocument,d=c&&(c.defaultView||c.parentWindow);d=d||l;if(d.Element&&d.Location){var e=d;break a}}catch(g){}e=null}if(e&&\"undefined\"!=typeof e[b]&&(!a||!(a instanceof e[b])&&(a instanceof e.Location||a instanceof e.Element))){if(n(a))try{var f=a.constructor.displayName||a.constructor.name||Object.prototype.toString.call(a)}catch(g){f=\"<object could not be stringified>\"}else f=void 0===a?\"undefined\":null===a?\"null\":typeof a;Ga(\"Argument is not a %s (or a non-Element, non-Location mock); got: %s\",\nb,f)}};function qb(a,b){this.a=a===rb&&b||\"\";this.b=sb}qb.prototype.sa=!0;qb.prototype.ra=function(){return this.a};qb.prototype.toString=function(){return\"Const{\"+this.a+\"}\"};function tb(a){if(a instanceof qb&&a.constructor===qb&&a.b===sb)return a.a;Ga(\"expected object of type Const, got '\"+a+\"'\");return\"type_error:Const\"}var sb={},rb={};var ub;function vb(){if(void 0===ub){var a=null,b=l.trustedTypes;if(b&&b.createPolicy){try{a=b.createPolicy(\"goog#html\",{createHTML:wa,createScript:wa,createScriptURL:wa})}catch(c){l.console&&l.console.error(c.message)}ub=a}else ub=a}return ub};function wb(a,b){this.a=b===xb?a:\"\"}wb.prototype.sa=!0;wb.prototype.ra=function(){return this.a.toString()};wb.prototype.toString=function(){return\"TrustedResourceUrl{\"+this.a+\"}\"};function yb(a){if(a instanceof wb&&a.constructor===wb)return a.a;Ga(\"expected object of type TrustedResourceUrl, got '\"+a+\"' of type \"+ma(a));return\"type_error:TrustedResourceUrl\"}\nfunction zb(a,b){var c=tb(a);if(!Ab.test(c))throw Error(\"Invalid TrustedResourceUrl format: \"+c);a=c.replace(Bb,function(d,e){if(!Object.prototype.hasOwnProperty.call(b,e))throw Error('Found marker, \"'+e+'\", in format string, \"'+c+'\", but no valid label mapping found in args: '+JSON.stringify(b));d=b[e];return d instanceof qb?tb(d):encodeURIComponent(String(d))});return Cb(a)}var Bb=/%{(\\w+)}/g,Ab=/^((https:)?\\/\\/[0-9a-z.:[\\]-]+\\/|\\/[^/\\\\]|[^:/\\\\%]+\\/|[^:/\\\\%]*[?#]|about:blank#)/i,xb={};\nfunction Cb(a){var b=vb();a=b?b.createScriptURL(a):a;return new wb(a,xb)};function C(a,b){this.a=b===Db?a:\"\"}C.prototype.sa=!0;C.prototype.ra=function(){return this.a.toString()};C.prototype.toString=function(){return\"SafeUrl{\"+this.a+\"}\"};function Eb(a){if(a instanceof C&&a.constructor===C)return a.a;Ga(\"expected object of type SafeUrl, got '\"+a+\"' of type \"+ma(a));return\"type_error:SafeUrl\"}\nvar Fb=/^(?:audio\\/(?:3gpp2|3gpp|aac|L16|midi|mp3|mp4|mpeg|oga|ogg|opus|x-m4a|x-matroska|x-wav|wav|webm)|font\\/\\w+|image\\/(?:bmp|gif|jpeg|jpg|png|tiff|webp|x-icon)|text\\/csv|video\\/(?:mpeg|mp4|ogg|webm|quicktime|x-matroska))(?:;\\w+=(?:\\w+|\"[\\w;,= ]+\"))*$/i,Gb=/^data:(.*);base64,[a-z0-9+\\/]+=*$/i,Hb=/^(?:(?:https?|mailto|ftp):|[^:/?#]*(?:[/?#]|$))/i;\nfunction Ib(a){if(a instanceof C)return a;a=\"object\"==typeof a&&a.sa?a.ra():String(a);if(Hb.test(a))a=new C(a,Db);else{a=String(a);a=a.replace(/(%0A|%0D)/g,\"\");var b=a.match(Gb);a=b&&Fb.test(b[1])?new C(a,Db):null}return a}function Jb(a){if(a instanceof C)return a;a=\"object\"==typeof a&&a.sa?a.ra():String(a);Hb.test(a)||(a=\"about:invalid#zClosurez\");return new C(a,Db)}var Db={},Kb=new C(\"about:invalid#zClosurez\",Db);function Lb(a,b,c){this.a=c===Mb?a:\"\"}Lb.prototype.sa=!0;Lb.prototype.ra=function(){return this.a.toString()};Lb.prototype.toString=function(){return\"SafeHtml{\"+this.a+\"}\"};function Nb(a){if(a instanceof Lb&&a.constructor===Lb)return a.a;Ga(\"expected object of type SafeHtml, got '\"+a+\"' of type \"+ma(a));return\"type_error:SafeHtml\"}var Mb={};function Ob(a,b){pb(a,\"HTMLScriptElement\");a.src=yb(b);(b=a.ownerDocument&&a.ownerDocument.defaultView)&&b!=l?b=ka(b.document):(null===ja&&(ja=ka(l.document)),b=ja);b&&a.setAttribute(\"nonce\",b)}function Pb(a,b,c,d){a=a instanceof C?a:Jb(a);b=b||l;c=c instanceof qb?tb(c):c||\"\";return b.open(Eb(a),c,d,void 0)};function Qb(a,b){for(var c=a.split(\"%s\"),d=\"\",e=Array.prototype.slice.call(arguments,1);e.length&&1<c.length;)d+=c.shift()+e.shift();return d+c.join(\"%s\")}function Rb(a){gb.test(a)&&(-1!=a.indexOf(\"&\")&&(a=a.replace(ab,\"&amp;\")),-1!=a.indexOf(\"<\")&&(a=a.replace(bb,\"&lt;\")),-1!=a.indexOf(\">\")&&(a=a.replace(cb,\"&gt;\")),-1!=a.indexOf('\"')&&(a=a.replace(db,\"&quot;\")),-1!=a.indexOf(\"'\")&&(a=a.replace(eb,\"&#39;\")),-1!=a.indexOf(\"\\x00\")&&(a=a.replace(fb,\"&#0;\")));return a};function Sb(a){Sb[\" \"](a);return a}Sb[\" \"]=la;function Tb(a,b){var c=Ub;return Object.prototype.hasOwnProperty.call(c,a)?c[a]:c[a]=b(a)};var Vb=y(\"Opera\"),Wb=y(\"Trident\")||y(\"MSIE\"),Xb=y(\"Edge\"),Yb=Xb||Wb,Zb=y(\"Gecko\")&&!(x(ib.toLowerCase(),\"webkit\")&&!y(\"Edge\"))&&!(y(\"Trident\")||y(\"MSIE\"))&&!y(\"Edge\"),$b=x(ib.toLowerCase(),\"webkit\")&&!y(\"Edge\");function ac(){var a=l.document;return a?a.documentMode:void 0}var bc;\na:{var cc=\"\",dc=function(){var a=ib;if(Zb)return/rv:([^\\);]+)(\\)|;)/.exec(a);if(Xb)return/Edge\\/([\\d\\.]+)/.exec(a);if(Wb)return/\\b(?:MSIE|rv)[: ]([^\\);]+)(\\)|;)/.exec(a);if($b)return/WebKit\\/(\\S+)/.exec(a);if(Vb)return/(?:Version)[ \\/]?(\\S+)/.exec(a)}();dc&&(cc=dc?dc[1]:\"\");if(Wb){var ec=ac();if(null!=ec&&ec>parseFloat(cc)){bc=String(ec);break a}}bc=cc}var Ub={};\nfunction fc(a){return Tb(a,function(){for(var b=0,c=$a(String(bc)).split(\".\"),d=$a(String(a)).split(\".\"),e=Math.max(c.length,d.length),f=0;0==b&&f<e;f++){var g=c[f]||\"\",h=d[f]||\"\";do{g=/(\\d*)(\\D*)(.*)/.exec(g)||[\"\",\"\",\"\",\"\"];h=/(\\d*)(\\D*)(.*)/.exec(h)||[\"\",\"\",\"\",\"\"];if(0==g[0].length&&0==h[0].length)break;b=hb(0==g[1].length?0:parseInt(g[1],10),0==h[1].length?0:parseInt(h[1],10))||hb(0==g[2].length,0==h[2].length)||hb(g[2],h[2]);g=g[3];h=h[3]}while(0==b)}return 0<=b})}var gc;\nif(l.document&&Wb){var hc=ac();gc=hc?hc:parseInt(bc,10)||void 0}else gc=void 0;var ic=gc;try{(new self.OffscreenCanvas(0,0)).getContext(\"2d\")}catch(a){}var jc=!Wb||9<=Number(ic);function kc(a){var b=document;return\"string\"===typeof a?b.getElementById(a):a}function lc(a,b){lb(b,function(c,d){c&&\"object\"==typeof c&&c.sa&&(c=c.ra());\"style\"==d?a.style.cssText=c:\"class\"==d?a.className=c:\"for\"==d?a.htmlFor=c:mc.hasOwnProperty(d)?a.setAttribute(mc[d],c):0==d.lastIndexOf(\"aria-\",0)||0==d.lastIndexOf(\"data-\",0)?a.setAttribute(d,c):a[d]=c})}\nvar mc={cellpadding:\"cellPadding\",cellspacing:\"cellSpacing\",colspan:\"colSpan\",frameborder:\"frameBorder\",height:\"height\",maxlength:\"maxLength\",nonce:\"nonce\",role:\"role\",rowspan:\"rowSpan\",type:\"type\",usemap:\"useMap\",valign:\"vAlign\",width:\"width\"};\nfunction nc(a,b,c){var d=arguments,e=document,f=String(d[0]),g=d[1];if(!jc&&g&&(g.name||g.type)){f=[\"<\",f];g.name&&f.push(' name=\"',Rb(g.name),'\"');if(g.type){f.push(' type=\"',Rb(g.type),'\"');var h={};z(h,g);delete h.type;g=h}f.push(\">\");f=f.join(\"\")}f=oc(e,f);g&&(\"string\"===typeof g?f.className=g:Array.isArray(g)?f.className=g.join(\" \"):lc(f,g));2<d.length&&pc(e,f,d);return f}\nfunction pc(a,b,c){function d(h){h&&b.appendChild(\"string\"===typeof h?a.createTextNode(h):h)}for(var e=2;e<c.length;e++){var f=c[e];if(!na(f)||n(f)&&0<f.nodeType)d(f);else{a:{if(f&&\"number\"==typeof f.length){if(n(f)){var g=\"function\"==typeof f.item||\"string\"==typeof f.item;break a}if(oa(f)){g=\"function\"==typeof f.item;break a}}g=!1}w(g?Za(f):f,d)}}}function oc(a,b){b=String(b);\"application/xhtml+xml\"===a.contentType&&(b=b.toLowerCase());return a.createElement(b)};function qc(a){l.setTimeout(function(){throw a;},0)}var rc;\nfunction sc(){var a=l.MessageChannel;\"undefined\"===typeof a&&\"undefined\"!==typeof window&&window.postMessage&&window.addEventListener&&!y(\"Presto\")&&(a=function(){var e=oc(document,\"IFRAME\");e.style.display=\"none\";document.documentElement.appendChild(e);var f=e.contentWindow;e=f.document;e.open();e.close();var g=\"callImmediate\"+Math.random(),h=\"file:\"==f.location.protocol?\"*\":f.location.protocol+\"//\"+f.location.host;e=q(function(m){if((\"*\"==h||m.origin==h)&&m.data==g)this.port1.onmessage()},this);\nf.addEventListener(\"message\",e,!1);this.port1={};this.port2={postMessage:function(){f.postMessage(g,h)}}});if(\"undefined\"!==typeof a&&!y(\"Trident\")&&!y(\"MSIE\")){var b=new a,c={},d=c;b.port1.onmessage=function(){if(void 0!==c.next){c=c.next;var e=c.Gb;c.Gb=null;e()}};return function(e){d.next={Gb:e};d=d.next;b.port2.postMessage(0)}}return function(e){l.setTimeout(e,0)}};function tc(a,b){uc||vc();wc||(uc(),wc=!0);Na.add(a,b)}var uc;function vc(){if(l.Promise&&l.Promise.resolve){var a=l.Promise.resolve(void 0);uc=function(){a.then(xc)}}else uc=function(){var b=xc;!oa(l.setImmediate)||l.Window&&l.Window.prototype&&!y(\"Edge\")&&l.Window.prototype.setImmediate==l.setImmediate?(rc||(rc=sc()),rc(b)):l.setImmediate(b)}}var wc=!1,Na=new Ja;function xc(){for(var a;a=Ma();){try{a.a.call(a.b)}catch(b){qc(b)}Ia(La,a)}wc=!1};function D(a,b){this.a=yc;this.i=void 0;this.f=this.b=this.c=null;this.g=this.h=!1;if(a!=la)try{var c=this;a.call(b,function(d){zc(c,Ac,d)},function(d){if(!(d instanceof Bc))try{if(d instanceof Error)throw d;throw Error(\"Promise rejected.\");}catch(e){}zc(c,Cc,d)})}catch(d){zc(this,Cc,d)}}var yc=0,Ac=2,Cc=3;function Dc(){this.next=this.f=this.b=this.g=this.a=null;this.c=!1}Dc.prototype.reset=function(){this.f=this.b=this.g=this.a=null;this.c=!1};var Ec=new Ha(function(){return new Dc},function(a){a.reset()});\nfunction Fc(a,b,c){var d=Ec.get();d.g=a;d.b=b;d.f=c;return d}function E(a){if(a instanceof D)return a;var b=new D(la);zc(b,Ac,a);return b}function F(a){return new D(function(b,c){c(a)})}function Gc(a,b,c){Hc(a,b,c,null)||tc(ua(b,a))}function Ic(a){return new D(function(b,c){var d=a.length,e=[];if(d)for(var f=function(p,v){d--;e[p]=v;0==d&&b(e)},g=function(p){c(p)},h=0,m;h<a.length;h++)m=a[h],Gc(m,ua(f,h),g);else b(e)})}\nfunction Jc(a){return new D(function(b){var c=a.length,d=[];if(c)for(var e=function(h,m,p){c--;d[h]=m?{Pb:!0,value:p}:{Pb:!1,reason:p};0==c&&b(d)},f=0,g;f<a.length;f++)g=a[f],Gc(g,ua(e,f,!0),ua(e,f,!1));else b(d)})}D.prototype.then=function(a,b,c){return Kc(this,oa(a)?a:null,oa(b)?b:null,c)};D.prototype.$goog_Thenable=!0;k=D.prototype;k.oa=function(a,b){a=Fc(a,a,b);a.c=!0;Lc(this,a);return this};k.o=function(a,b){return Kc(this,null,a,b)};\nk.cancel=function(a){if(this.a==yc){var b=new Bc(a);tc(function(){Mc(this,b)},this)}};function Mc(a,b){if(a.a==yc)if(a.c){var c=a.c;if(c.b){for(var d=0,e=null,f=null,g=c.b;g&&(g.c||(d++,g.a==a&&(e=g),!(e&&1<d)));g=g.next)e||(f=g);e&&(c.a==yc&&1==d?Mc(c,b):(f?(d=f,d.next==c.f&&(c.f=d),d.next=d.next.next):Nc(c),Oc(c,e,Cc,b)))}a.c=null}else zc(a,Cc,b)}function Lc(a,b){a.b||a.a!=Ac&&a.a!=Cc||Pc(a);a.f?a.f.next=b:a.b=b;a.f=b}\nfunction Kc(a,b,c,d){var e=Fc(null,null,null);e.a=new D(function(f,g){e.g=b?function(h){try{var m=b.call(d,h);f(m)}catch(p){g(p)}}:f;e.b=c?function(h){try{var m=c.call(d,h);void 0===m&&h instanceof Bc?g(h):f(m)}catch(p){g(p)}}:g});e.a.c=a;Lc(a,e);return e.a}k.$c=function(a){this.a=yc;zc(this,Ac,a)};k.ad=function(a){this.a=yc;zc(this,Cc,a)};\nfunction zc(a,b,c){a.a==yc&&(a===c&&(b=Cc,c=new TypeError(\"Promise cannot resolve to itself\")),a.a=1,Hc(c,a.$c,a.ad,a)||(a.i=c,a.a=b,a.c=null,Pc(a),b!=Cc||c instanceof Bc||Qc(a,c)))}function Hc(a,b,c,d){if(a instanceof D)return Lc(a,Fc(b||la,c||null,d)),!0;if(Ea(a))return a.then(b,c,d),!0;if(n(a))try{var e=a.then;if(oa(e))return Rc(a,e,b,c,d),!0}catch(f){return c.call(d,f),!0}return!1}\nfunction Rc(a,b,c,d,e){function f(m){h||(h=!0,d.call(e,m))}function g(m){h||(h=!0,c.call(e,m))}var h=!1;try{b.call(a,g,f)}catch(m){f(m)}}function Pc(a){a.h||(a.h=!0,tc(a.gc,a))}function Nc(a){var b=null;a.b&&(b=a.b,a.b=b.next,b.next=null);a.b||(a.f=null);return b}k.gc=function(){for(var a;a=Nc(this);)Oc(this,a,this.a,this.i);this.h=!1};\nfunction Oc(a,b,c,d){if(c==Cc&&b.b&&!b.c)for(;a&&a.g;a=a.c)a.g=!1;if(b.a)b.a.c=null,Sc(b,c,d);else try{b.c?b.g.call(b.f):Sc(b,c,d)}catch(e){Tc.call(null,e)}Ia(Ec,b)}function Sc(a,b,c){b==Ac?a.g.call(a.f,c):a.b&&a.b.call(a.f,c)}function Qc(a,b){a.g=!0;tc(function(){a.g&&Tc.call(null,b)})}var Tc=qc;function Bc(a){u.call(this,a)}r(Bc,u);Bc.prototype.name=\"cancel\";function Uc(){0!=Vc&&(Wc[pa(this)]=this);this.xa=this.xa;this.pa=this.pa}var Vc=0,Wc={};Uc.prototype.xa=!1;function Xc(a){if(!a.xa&&(a.xa=!0,a.Da(),0!=Vc)){var b=pa(a);if(0!=Vc&&a.pa&&0<a.pa.length)throw Error(a+\" did not empty its onDisposeCallbacks queue. This probably means it overrode dispose() or disposeInternal() without calling the superclass' method.\");delete Wc[b]}}Uc.prototype.Da=function(){if(this.pa)for(;this.pa.length;)this.pa.shift()()};var Yc=Object.freeze||function(a){return a};var Zc=!Wb||9<=Number(ic),$c=Wb&&!fc(\"9\"),ad=function(){if(!l.addEventListener||!Object.defineProperty)return!1;var a=!1,b=Object.defineProperty({},\"passive\",{get:function(){a=!0}});try{l.addEventListener(\"test\",la,b),l.removeEventListener(\"test\",la,b)}catch(c){}return a}();function G(a,b){this.type=a;this.b=this.target=b;this.defaultPrevented=!1}G.prototype.preventDefault=function(){this.defaultPrevented=!0};function bd(a,b){G.call(this,a?a.type:\"\");this.relatedTarget=this.b=this.target=null;this.button=this.screenY=this.screenX=this.clientY=this.clientX=0;this.key=\"\";this.metaKey=this.shiftKey=this.altKey=this.ctrlKey=!1;this.pointerId=0;this.pointerType=\"\";this.a=null;if(a){var c=this.type=a.type,d=a.changedTouches&&a.changedTouches.length?a.changedTouches[0]:null;this.target=a.target||a.srcElement;this.b=b;if(b=a.relatedTarget){if(Zb){a:{try{Sb(b.nodeName);var e=!0;break a}catch(f){}e=!1}e||(b=null)}}else\"mouseover\"==\nc?b=a.fromElement:\"mouseout\"==c&&(b=a.toElement);this.relatedTarget=b;d?(this.clientX=void 0!==d.clientX?d.clientX:d.pageX,this.clientY=void 0!==d.clientY?d.clientY:d.pageY,this.screenX=d.screenX||0,this.screenY=d.screenY||0):(this.clientX=void 0!==a.clientX?a.clientX:a.pageX,this.clientY=void 0!==a.clientY?a.clientY:a.pageY,this.screenX=a.screenX||0,this.screenY=a.screenY||0);this.button=a.button;this.key=a.key||\"\";this.ctrlKey=a.ctrlKey;this.altKey=a.altKey;this.shiftKey=a.shiftKey;this.metaKey=\na.metaKey;this.pointerId=a.pointerId||0;this.pointerType=\"string\"===typeof a.pointerType?a.pointerType:cd[a.pointerType]||\"\";this.a=a;a.defaultPrevented&&this.preventDefault()}}r(bd,G);var cd=Yc({2:\"touch\",3:\"pen\",4:\"mouse\"});bd.prototype.preventDefault=function(){bd.ab.preventDefault.call(this);var a=this.a;if(a.preventDefault)a.preventDefault();else if(a.returnValue=!1,$c)try{if(a.ctrlKey||112<=a.keyCode&&123>=a.keyCode)a.keyCode=-1}catch(b){}};bd.prototype.g=function(){return this.a};var dd=\"closure_listenable_\"+(1E6*Math.random()|0),ed=0;function fd(a,b,c,d,e){this.listener=a;this.proxy=null;this.src=b;this.type=c;this.capture=!!d;this.Va=e;this.key=++ed;this.va=this.Pa=!1}function gd(a){a.va=!0;a.listener=null;a.proxy=null;a.src=null;a.Va=null};function hd(a){this.src=a;this.a={};this.b=0}hd.prototype.add=function(a,b,c,d,e){var f=a.toString();a=this.a[f];a||(a=this.a[f]=[],this.b++);var g=id(a,b,d,e);-1<g?(b=a[g],c||(b.Pa=!1)):(b=new fd(b,this.src,f,!!d,e),b.Pa=c,a.push(b));return b};function jd(a,b){var c=b.type;c in a.a&&Wa(a.a[c],b)&&(gd(b),0==a.a[c].length&&(delete a.a[c],a.b--))}function id(a,b,c,d){for(var e=0;e<a.length;++e){var f=a[e];if(!f.va&&f.listener==b&&f.capture==!!c&&f.Va==d)return e}return-1};var kd=\"closure_lm_\"+(1E6*Math.random()|0),ld={},md=0;function nd(a,b,c,d,e){if(d&&d.once)od(a,b,c,d,e);else if(Array.isArray(b))for(var f=0;f<b.length;f++)nd(a,b[f],c,d,e);else c=pd(c),a&&a[dd]?qd(a,b,c,n(d)?!!d.capture:!!d,e):rd(a,b,c,!1,d,e)}\nfunction rd(a,b,c,d,e,f){if(!b)throw Error(\"Invalid event type\");var g=n(e)?!!e.capture:!!e,h=sd(a);h||(a[kd]=h=new hd(a));c=h.add(b,c,d,g,f);if(!c.proxy){d=td();c.proxy=d;d.src=a;d.listener=c;if(a.addEventListener)ad||(e=g),void 0===e&&(e=!1),a.addEventListener(b.toString(),d,e);else if(a.attachEvent)a.attachEvent(ud(b.toString()),d);else if(a.addListener&&a.removeListener)a.addListener(d);else throw Error(\"addEventListener and attachEvent are unavailable.\");md++}}\nfunction td(){var a=vd,b=Zc?function(c){return a.call(b.src,b.listener,c)}:function(c){c=a.call(b.src,b.listener,c);if(!c)return c};return b}function od(a,b,c,d,e){if(Array.isArray(b))for(var f=0;f<b.length;f++)od(a,b[f],c,d,e);else c=pd(c),a&&a[dd]?wd(a,b,c,n(d)?!!d.capture:!!d,e):rd(a,b,c,!0,d,e)}\nfunction xd(a,b,c,d,e){if(Array.isArray(b))for(var f=0;f<b.length;f++)xd(a,b[f],c,d,e);else(d=n(d)?!!d.capture:!!d,c=pd(c),a&&a[dd])?(a=a.v,b=String(b).toString(),b in a.a&&(f=a.a[b],c=id(f,c,d,e),-1<c&&(gd(f[c]),Array.prototype.splice.call(f,c,1),0==f.length&&(delete a.a[b],a.b--)))):a&&(a=sd(a))&&(b=a.a[b.toString()],a=-1,b&&(a=id(b,c,d,e)),(c=-1<a?b[a]:null)&&yd(c))}\nfunction yd(a){if(\"number\"!==typeof a&&a&&!a.va){var b=a.src;if(b&&b[dd])jd(b.v,a);else{var c=a.type,d=a.proxy;b.removeEventListener?b.removeEventListener(c,d,a.capture):b.detachEvent?b.detachEvent(ud(c),d):b.addListener&&b.removeListener&&b.removeListener(d);md--;(c=sd(b))?(jd(c,a),0==c.b&&(c.src=null,b[kd]=null)):gd(a)}}}function ud(a){return a in ld?ld[a]:ld[a]=\"on\"+a}\nfunction zd(a,b,c,d){var e=!0;if(a=sd(a))if(b=a.a[b.toString()])for(b=b.concat(),a=0;a<b.length;a++){var f=b[a];f&&f.capture==c&&!f.va&&(f=Bd(f,d),e=e&&!1!==f)}return e}function Bd(a,b){var c=a.listener,d=a.Va||a.src;a.Pa&&yd(a);return c.call(d,b)}\nfunction vd(a,b){if(a.va)return!0;if(!Zc){if(!b)a:{b=[\"window\",\"event\"];for(var c=l,d=0;d<b.length;d++)if(c=c[b[d]],null==c){b=null;break a}b=c}d=b;b=new bd(d,this);c=!0;if(!(0>d.keyCode||void 0!=d.returnValue)){a:{var e=!1;if(0==d.keyCode)try{d.keyCode=-1;break a}catch(g){e=!0}if(e||void 0==d.returnValue)d.returnValue=!0}d=[];for(e=b.b;e;e=e.parentNode)d.push(e);a=a.type;for(e=d.length-1;0<=e;e--){b.b=d[e];var f=zd(d[e],a,!0,b);c=c&&f}for(e=0;e<d.length;e++)b.b=d[e],f=zd(d[e],a,!1,b),c=c&&f}return c}return Bd(a,\nnew bd(b,this))}function sd(a){a=a[kd];return a instanceof hd?a:null}var Cd=\"__closure_events_fn_\"+(1E9*Math.random()>>>0);function pd(a){if(oa(a))return a;a[Cd]||(a[Cd]=function(b){return a.handleEvent(b)});return a[Cd]};function H(){Uc.call(this);this.v=new hd(this);this.ac=this;this.gb=null}r(H,Uc);H.prototype[dd]=!0;H.prototype.addEventListener=function(a,b,c,d){nd(this,a,b,c,d)};H.prototype.removeEventListener=function(a,b,c,d){xd(this,a,b,c,d)};\nH.prototype.dispatchEvent=function(a){var b,c=this.gb;if(c)for(b=[];c;c=c.gb)b.push(c);c=this.ac;var d=a.type||a;if(\"string\"===typeof a)a=new G(a,c);else if(a instanceof G)a.target=a.target||c;else{var e=a;a=new G(d,c);z(a,e)}e=!0;if(b)for(var f=b.length-1;0<=f;f--){var g=a.b=b[f];e=Dd(g,d,!0,a)&&e}g=a.b=c;e=Dd(g,d,!0,a)&&e;e=Dd(g,d,!1,a)&&e;if(b)for(f=0;f<b.length;f++)g=a.b=b[f],e=Dd(g,d,!1,a)&&e;return e};\nH.prototype.Da=function(){H.ab.Da.call(this);if(this.v){var a=this.v,b=0,c;for(c in a.a){for(var d=a.a[c],e=0;e<d.length;e++)++b,gd(d[e]);delete a.a[c];a.b--}}this.gb=null};function qd(a,b,c,d,e){a.v.add(String(b),c,!1,d,e)}function wd(a,b,c,d,e){a.v.add(String(b),c,!0,d,e)}\nfunction Dd(a,b,c,d){b=a.v.a[String(b)];if(!b)return!0;b=b.concat();for(var e=!0,f=0;f<b.length;++f){var g=b[f];if(g&&!g.va&&g.capture==c){var h=g.listener,m=g.Va||g.src;g.Pa&&jd(a.v,g);e=!1!==h.call(m,d)&&e}}return e&&!d.defaultPrevented};function Ed(a,b,c){if(oa(a))c&&(a=q(a,c));else if(a&&\"function\"==typeof a.handleEvent)a=q(a.handleEvent,a);else throw Error(\"Invalid listener argument\");return 2147483647<Number(b)?-1:l.setTimeout(a,b||0)}function Fd(a){var b=null;return(new D(function(c,d){b=Ed(function(){c(void 0)},a);-1==b&&d(Error(\"Failed to schedule timer.\"))})).o(function(c){l.clearTimeout(b);throw c;})};function Gd(a){if(a.W&&\"function\"==typeof a.W)return a.W();if(\"string\"===typeof a)return a.split(\"\");if(na(a)){for(var b=[],c=a.length,d=0;d<c;d++)b.push(a[d]);return b}b=[];c=0;for(d in a)b[c++]=a[d];return b}function Hd(a){if(a.Y&&\"function\"==typeof a.Y)return a.Y();if(!a.W||\"function\"!=typeof a.W){if(na(a)||\"string\"===typeof a){var b=[];a=a.length;for(var c=0;c<a;c++)b.push(c);return b}b=[];c=0;for(var d in a)b[c++]=d;return b}}\nfunction Id(a,b){if(a.forEach&&\"function\"==typeof a.forEach)a.forEach(b,void 0);else if(na(a)||\"string\"===typeof a)w(a,b,void 0);else for(var c=Hd(a),d=Gd(a),e=d.length,f=0;f<e;f++)b.call(void 0,d[f],c&&c[f],a)};function Jd(a,b){this.b={};this.a=[];this.c=0;var c=arguments.length;if(1<c){if(c%2)throw Error(\"Uneven number of arguments\");for(var d=0;d<c;d+=2)this.set(arguments[d],arguments[d+1])}else if(a)if(a instanceof Jd)for(c=a.Y(),d=0;d<c.length;d++)this.set(c[d],a.get(c[d]));else for(d in a)this.set(d,a[d])}k=Jd.prototype;k.W=function(){Kd(this);for(var a=[],b=0;b<this.a.length;b++)a.push(this.b[this.a[b]]);return a};k.Y=function(){Kd(this);return this.a.concat()};\nk.clear=function(){this.b={};this.c=this.a.length=0};function Kd(a){if(a.c!=a.a.length){for(var b=0,c=0;b<a.a.length;){var d=a.a[b];Ld(a.b,d)&&(a.a[c++]=d);b++}a.a.length=c}if(a.c!=a.a.length){var e={};for(c=b=0;b<a.a.length;)d=a.a[b],Ld(e,d)||(a.a[c++]=d,e[d]=1),b++;a.a.length=c}}k.get=function(a,b){return Ld(this.b,a)?this.b[a]:b};k.set=function(a,b){Ld(this.b,a)||(this.c++,this.a.push(a));this.b[a]=b};\nk.forEach=function(a,b){for(var c=this.Y(),d=0;d<c.length;d++){var e=c[d],f=this.get(e);a.call(b,f,e,this)}};function Ld(a,b){return Object.prototype.hasOwnProperty.call(a,b)};var Md=/^(?:([^:/?#.]+):)?(?:\\/\\/(?:([^\\\\/?#]*)@)?([^\\\\/?#]*?)(?::([0-9]+))?(?=[\\\\/?#]|$))?([^?#]+)?(?:\\?([^#]*))?(?:#([\\s\\S]*))?$/;function Nd(a,b){if(a){a=a.split(\"&\");for(var c=0;c<a.length;c++){var d=a[c].indexOf(\"=\"),e=null;if(0<=d){var f=a[c].substring(0,d);e=a[c].substring(d+1)}else f=a[c];b(f,e?decodeURIComponent(e.replace(/\\+/g,\" \")):\"\")}}};function Od(a,b){this.a=this.l=this.c=\"\";this.g=null;this.h=this.f=\"\";this.i=!1;var c;a instanceof Od?(this.i=void 0!==b?b:a.i,Pd(this,a.c),this.l=a.l,this.a=a.a,Qd(this,a.g),this.f=a.f,Rd(this,Sd(a.b)),this.h=a.h):a&&(c=String(a).match(Md))?(this.i=!!b,Pd(this,c[1]||\"\",!0),this.l=Td(c[2]||\"\"),this.a=Td(c[3]||\"\",!0),Qd(this,c[4]),this.f=Td(c[5]||\"\",!0),Rd(this,c[6]||\"\",!0),this.h=Td(c[7]||\"\")):(this.i=!!b,this.b=new Ud(null,this.i))}\nOd.prototype.toString=function(){var a=[],b=this.c;b&&a.push(Vd(b,Wd,!0),\":\");var c=this.a;if(c||\"file\"==b)a.push(\"//\"),(b=this.l)&&a.push(Vd(b,Wd,!0),\"@\"),a.push(encodeURIComponent(String(c)).replace(/%25([0-9a-fA-F]{2})/g,\"%$1\")),c=this.g,null!=c&&a.push(\":\",String(c));if(c=this.f)this.a&&\"/\"!=c.charAt(0)&&a.push(\"/\"),a.push(Vd(c,\"/\"==c.charAt(0)?Xd:Yd,!0));(c=this.b.toString())&&a.push(\"?\",c);(c=this.h)&&a.push(\"#\",Vd(c,Zd));return a.join(\"\")};\nOd.prototype.resolve=function(a){var b=new Od(this),c=!!a.c;c?Pd(b,a.c):c=!!a.l;c?b.l=a.l:c=!!a.a;c?b.a=a.a:c=null!=a.g;var d=a.f;if(c)Qd(b,a.g);else if(c=!!a.f){if(\"/\"!=d.charAt(0))if(this.a&&!this.f)d=\"/\"+d;else{var e=b.f.lastIndexOf(\"/\");-1!=e&&(d=b.f.substr(0,e+1)+d)}e=d;if(\"..\"==e||\".\"==e)d=\"\";else if(x(e,\"./\")||x(e,\"/.\")){d=0==e.lastIndexOf(\"/\",0);e=e.split(\"/\");for(var f=[],g=0;g<e.length;){var h=e[g++];\".\"==h?d&&g==e.length&&f.push(\"\"):\"..\"==h?((1<f.length||1==f.length&&\"\"!=f[0])&&f.pop(),\nd&&g==e.length&&f.push(\"\")):(f.push(h),d=!0)}d=f.join(\"/\")}else d=e}c?b.f=d:c=\"\"!==a.b.toString();c?Rd(b,Sd(a.b)):c=!!a.h;c&&(b.h=a.h);return b};function Pd(a,b,c){a.c=c?Td(b,!0):b;a.c&&(a.c=a.c.replace(/:$/,\"\"))}function Qd(a,b){if(b){b=Number(b);if(isNaN(b)||0>b)throw Error(\"Bad port number \"+b);a.g=b}else a.g=null}function Rd(a,b,c){b instanceof Ud?(a.b=b,$d(a.b,a.i)):(c||(b=Vd(b,ae)),a.b=new Ud(b,a.i))}function I(a,b,c){a.b.set(b,c)}function be(a,b){return a.b.get(b)}\nfunction J(a){return a instanceof Od?new Od(a):new Od(a,void 0)}function ce(a,b,c,d){var e=new Od(null,void 0);a&&Pd(e,a);b&&(e.a=b);c&&Qd(e,c);d&&(e.f=d);return e}function Td(a,b){return a?b?decodeURI(a.replace(/%25/g,\"%2525\")):decodeURIComponent(a):\"\"}function Vd(a,b,c){return\"string\"===typeof a?(a=encodeURI(a).replace(b,de),c&&(a=a.replace(/%25([0-9a-fA-F]{2})/g,\"%$1\")),a):null}function de(a){a=a.charCodeAt(0);return\"%\"+(a>>4&15).toString(16)+(a&15).toString(16)}\nvar Wd=/[#\\/\\?@]/g,Yd=/[#\\?:]/g,Xd=/[#\\?]/g,ae=/[#\\?@]/g,Zd=/#/g;function Ud(a,b){this.b=this.a=null;this.c=a||null;this.f=!!b}function ee(a){a.a||(a.a=new Jd,a.b=0,a.c&&Nd(a.c,function(b,c){a.add(decodeURIComponent(b.replace(/\\+/g,\" \")),c)}))}function fe(a){var b=Hd(a);if(\"undefined\"==typeof b)throw Error(\"Keys are undefined\");var c=new Ud(null,void 0);a=Gd(a);for(var d=0;d<b.length;d++){var e=b[d],f=a[d];Array.isArray(f)?ge(c,e,f):c.add(e,f)}return c}k=Ud.prototype;\nk.add=function(a,b){ee(this);this.c=null;a=he(this,a);var c=this.a.get(a);c||this.a.set(a,c=[]);c.push(b);this.b+=1;return this};function ie(a,b){ee(a);b=he(a,b);Ld(a.a.b,b)&&(a.c=null,a.b-=a.a.get(b).length,a=a.a,Ld(a.b,b)&&(delete a.b[b],a.c--,a.a.length>2*a.c&&Kd(a)))}k.clear=function(){this.a=this.c=null;this.b=0};function je(a,b){ee(a);b=he(a,b);return Ld(a.a.b,b)}k.forEach=function(a,b){ee(this);this.a.forEach(function(c,d){w(c,function(e){a.call(b,e,d,this)},this)},this)};\nk.Y=function(){ee(this);for(var a=this.a.W(),b=this.a.Y(),c=[],d=0;d<b.length;d++)for(var e=a[d],f=0;f<e.length;f++)c.push(b[d]);return c};k.W=function(a){ee(this);var b=[];if(\"string\"===typeof a)je(this,a)&&(b=Ya(b,this.a.get(he(this,a))));else{a=this.a.W();for(var c=0;c<a.length;c++)b=Ya(b,a[c])}return b};k.set=function(a,b){ee(this);this.c=null;a=he(this,a);je(this,a)&&(this.b-=this.a.get(a).length);this.a.set(a,[b]);this.b+=1;return this};\nk.get=function(a,b){if(!a)return b;a=this.W(a);return 0<a.length?String(a[0]):b};function ge(a,b,c){ie(a,b);0<c.length&&(a.c=null,a.a.set(he(a,b),Za(c)),a.b+=c.length)}k.toString=function(){if(this.c)return this.c;if(!this.a)return\"\";for(var a=[],b=this.a.Y(),c=0;c<b.length;c++){var d=b[c],e=encodeURIComponent(String(d));d=this.W(d);for(var f=0;f<d.length;f++){var g=e;\"\"!==d[f]&&(g+=\"=\"+encodeURIComponent(String(d[f])));a.push(g)}}return this.c=a.join(\"&\")};\nfunction Sd(a){var b=new Ud;b.c=a.c;a.a&&(b.a=new Jd(a.a),b.b=a.b);return b}function he(a,b){b=String(b);a.f&&(b=b.toLowerCase());return b}function $d(a,b){b&&!a.f&&(ee(a),a.c=null,a.a.forEach(function(c,d){var e=d.toLowerCase();d!=e&&(ie(this,d),ge(this,e,c))},a));a.f=b};function ke(a){var b=[];le(new me,a,b);return b.join(\"\")}function me(){}\nfunction le(a,b,c){if(null==b)c.push(\"null\");else{if(\"object\"==typeof b){if(Array.isArray(b)){var d=b;b=d.length;c.push(\"[\");for(var e=\"\",f=0;f<b;f++)c.push(e),le(a,d[f],c),e=\",\";c.push(\"]\");return}if(b instanceof String||b instanceof Number||b instanceof Boolean)b=b.valueOf();else{c.push(\"{\");e=\"\";for(d in b)Object.prototype.hasOwnProperty.call(b,d)&&(f=b[d],\"function\"!=typeof f&&(c.push(e),ne(d,c),c.push(\":\"),le(a,f,c),e=\",\"));c.push(\"}\");return}}switch(typeof b){case \"string\":ne(b,c);break;case \"number\":c.push(isFinite(b)&&\n!isNaN(b)?String(b):\"null\");break;case \"boolean\":c.push(String(b));break;case \"function\":c.push(\"null\");break;default:throw Error(\"Unknown type: \"+typeof b);}}}var oe={'\"':'\\\\\"',\"\\\\\":\"\\\\\\\\\",\"/\":\"\\\\/\",\"\\b\":\"\\\\b\",\"\\f\":\"\\\\f\",\"\\n\":\"\\\\n\",\"\\r\":\"\\\\r\",\"\\t\":\"\\\\t\",\"\\x0B\":\"\\\\u000b\"},pe=/\\uffff/.test(\"\\uffff\")?/[\\\\\"\\x00-\\x1f\\x7f-\\uffff]/g:/[\\\\\"\\x00-\\x1f\\x7f-\\xff]/g;\nfunction ne(a,b){b.push('\"',a.replace(pe,function(c){var d=oe[c];d||(d=\"\\\\u\"+(c.charCodeAt(0)|65536).toString(16).substr(1),oe[c]=d);return d}),'\"')};function qe(){var a=K();return Wb&&!!ic&&11==ic||/Edge\\/\\d+/.test(a)}function re(){return l.window&&l.window.location.href||self&&self.location&&self.location.href||\"\"}function se(a,b){b=b||l.window;var c=\"about:blank\";a&&(c=Eb(Ib(a)||Kb));b.location.href=c}function te(a,b){var c=[],d;for(d in a)d in b?typeof a[d]!=typeof b[d]?c.push(d):\"object\"==typeof a[d]&&null!=a[d]&&null!=b[d]?0<te(a[d],b[d]).length&&c.push(d):a[d]!==b[d]&&c.push(d):c.push(d);for(d in b)d in a||c.push(d);return c}\nfunction ue(){var a=K();a=ve(a)!=we?null:(a=a.match(/\\sChrome\\/(\\d+)/i))&&2==a.length?parseInt(a[1],10):null;return a&&30>a?!1:!Wb||!ic||9<ic}function xe(a){a=(a||K()).toLowerCase();return a.match(/android/)||a.match(/webos/)||a.match(/iphone|ipad|ipod/)||a.match(/blackberry/)||a.match(/windows phone/)||a.match(/iemobile/)?!0:!1}function ye(a){a=a||l.window;try{a.close()}catch(b){}}\nfunction ze(a,b,c){var d=Math.floor(1E9*Math.random()).toString();b=b||500;c=c||600;var e=(window.screen.availHeight-c)/2,f=(window.screen.availWidth-b)/2;b={width:b,height:c,top:0<e?e:0,left:0<f?f:0,location:!0,resizable:!0,statusbar:!0,toolbar:!1};c=K().toLowerCase();d&&(b.target=d,x(c,\"crios/\")&&(b.target=\"_blank\"));ve(K())==Ae&&(a=a||\"http://localhost\",b.scrollbars=!0);c=a||\"\";(a=b)||(a={});d=window;b=c instanceof C?c:Ib(\"undefined\"!=typeof c.href?c.href:String(c))||Kb;c=a.target||c.target;e=\n[];for(g in a)switch(g){case \"width\":case \"height\":case \"top\":case \"left\":e.push(g+\"=\"+a[g]);break;case \"target\":case \"noopener\":case \"noreferrer\":break;default:e.push(g+\"=\"+(a[g]?1:0))}var g=e.join(\",\");if((y(\"iPhone\")&&!y(\"iPod\")&&!y(\"iPad\")||y(\"iPad\")||y(\"iPod\"))&&d.navigator&&d.navigator.standalone&&c&&\"_self\"!=c)g=oc(document,\"A\"),pb(g,\"HTMLAnchorElement\"),b=b instanceof C?b:Jb(b),g.href=Eb(b),g.setAttribute(\"target\",c),a.noreferrer&&g.setAttribute(\"rel\",\"noreferrer\"),a=document.createEvent(\"MouseEvent\"),\na.initMouseEvent(\"click\",!0,!0,d,1),g.dispatchEvent(a),g={};else if(a.noreferrer){if(g=Pb(\"\",d,c,g),a=Eb(b),g&&(Yb&&x(a,\";\")&&(a=\"'\"+a.replace(/'/g,\"%27\")+\"'\"),g.opener=null,a='<meta name=\"referrer\" content=\"no-referrer\"><meta http-equiv=\"refresh\" content=\"0; url='+Rb(a)+'\">',a=(d=vb())?d.createHTML(a):a,a=new Lb(a,null,Mb),d=g.document))d.write(Nb(a)),d.close()}else(g=Pb(b,d,c,g))&&a.noopener&&(g.opener=null);if(g)try{g.focus()}catch(h){}return g}\nfunction Be(a){return new D(function(b){function c(){Fd(2E3).then(function(){if(!a||a.closed)b();else return c()})}return c()})}var Ce=/^\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}$/,De=/^[^@]+@[^@]+$/;function Ee(){var a=null;return(new D(function(b){\"complete\"==l.document.readyState?b():(a=function(){b()},od(window,\"load\",a))})).o(function(b){xd(window,\"load\",a);throw b;})}\nfunction Fe(){return Ge(void 0)?Ee().then(function(){return new D(function(a,b){var c=l.document,d=setTimeout(function(){b(Error(\"Cordova framework is not ready.\"))},1E3);c.addEventListener(\"deviceready\",function(){clearTimeout(d);a()},!1)})}):F(Error(\"Cordova must run in an Android or iOS file scheme.\"))}function Ge(a){a=a||K();return!(\"file:\"!==He()&&\"ionic:\"!==He()||!a.toLowerCase().match(/iphone|ipad|ipod|android/))}function Ie(){var a=l.window;try{return!(!a||a==a.top)}catch(b){return!1}}\nfunction Je(){return\"undefined\"!==typeof l.WorkerGlobalScope&&\"function\"===typeof l.importScripts}function Ke(){return firebase.INTERNAL.hasOwnProperty(\"reactNative\")?\"ReactNative\":firebase.INTERNAL.hasOwnProperty(\"node\")?\"Node\":Je()?\"Worker\":\"Browser\"}function Le(){var a=Ke();return\"ReactNative\"===a||\"Node\"===a}function Me(){for(var a=50,b=[];0<a;)b.push(\"1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ\".charAt(Math.floor(62*Math.random()))),a--;return b.join(\"\")}\nvar Ae=\"Firefox\",we=\"Chrome\";\nfunction ve(a){var b=a.toLowerCase();if(x(b,\"opera/\")||x(b,\"opr/\")||x(b,\"opios/\"))return\"Opera\";if(x(b,\"iemobile\"))return\"IEMobile\";if(x(b,\"msie\")||x(b,\"trident/\"))return\"IE\";if(x(b,\"edge/\"))return\"Edge\";if(x(b,\"firefox/\"))return Ae;if(x(b,\"silk/\"))return\"Silk\";if(x(b,\"blackberry\"))return\"Blackberry\";if(x(b,\"webos\"))return\"Webos\";if(!x(b,\"safari/\")||x(b,\"chrome/\")||x(b,\"crios/\")||x(b,\"android\"))if(!x(b,\"chrome/\")&&!x(b,\"crios/\")||x(b,\"edge/\")){if(x(b,\"android\"))return\"Android\";if((a=a.match(/([a-zA-Z\\d\\.]+)\\/[a-zA-Z\\d\\.]*$/))&&\n2==a.length)return a[1]}else return we;else return\"Safari\";return\"Other\"}var Ne={md:\"FirebaseCore-web\",od:\"FirebaseUI-web\"};function Oe(a,b){b=b||[];var c=[],d={},e;for(e in Ne)d[Ne[e]]=!0;for(e=0;e<b.length;e++)\"undefined\"!==typeof d[b[e]]&&(delete d[b[e]],c.push(b[e]));c.sort();b=c;b.length||(b=[\"FirebaseCore-web\"]);c=Ke();\"Browser\"===c?(d=K(),c=ve(d)):\"Worker\"===c&&(d=K(),c=ve(d)+\"-\"+c);return c+\"/JsCore/\"+a+\"/\"+b.join(\",\")}function K(){return l.navigator&&l.navigator.userAgent||\"\"}\nfunction L(a,b){a=a.split(\".\");b=b||l;for(var c=0;c<a.length&&\"object\"==typeof b&&null!=b;c++)b=b[a[c]];c!=a.length&&(b=void 0);return b}function Pe(){try{var a=l.localStorage,b=Qe();if(a)return a.setItem(b,\"1\"),a.removeItem(b),qe()?!!l.indexedDB:!0}catch(c){return Je()&&!!l.indexedDB}return!1}function Re(){return(Se()||\"chrome-extension:\"===He()||Ge())&&!Le()&&Pe()&&!Je()}function Se(){return\"http:\"===He()||\"https:\"===He()}function He(){return l.location&&l.location.protocol||null}\nfunction Te(a){a=a||K();return xe(a)||ve(a)==Ae?!1:!0}function Ue(a){return\"undefined\"===typeof a?null:ke(a)}function Ve(a){var b={},c;for(c in a)a.hasOwnProperty(c)&&null!==a[c]&&void 0!==a[c]&&(b[c]=a[c]);return b}function We(a){if(null!==a)return JSON.parse(a)}function Qe(a){return a?a:Math.floor(1E9*Math.random()).toString()}function Xe(a){a=a||K();return\"Safari\"==ve(a)||a.toLowerCase().match(/iphone|ipad|ipod/)?!1:!0}\nfunction Ye(){var a=l.___jsl;if(a&&a.H)for(var b in a.H)if(a.H[b].r=a.H[b].r||[],a.H[b].L=a.H[b].L||[],a.H[b].r=a.H[b].L.concat(),a.CP)for(var c=0;c<a.CP.length;c++)a.CP[c]=null}function Ze(a,b){if(a>b)throw Error(\"Short delay should be less than long delay!\");this.a=a;this.c=b;a=K();b=Ke();this.b=xe(a)||\"ReactNative\"===b}\nZe.prototype.get=function(){var a=l.navigator;return(a&&\"boolean\"===typeof a.onLine&&(Se()||\"chrome-extension:\"===He()||\"undefined\"!==typeof a.connection)?a.onLine:1)?this.b?this.c:this.a:Math.min(5E3,this.a)};function $e(){var a=l.document;return a&&\"undefined\"!==typeof a.visibilityState?\"visible\"==a.visibilityState:!0}\nfunction af(){var a=l.document,b=null;return $e()||!a?E():(new D(function(c){b=function(){$e()&&(a.removeEventListener(\"visibilitychange\",b,!1),c())};a.addEventListener(\"visibilitychange\",b,!1)})).o(function(c){a.removeEventListener(\"visibilitychange\",b,!1);throw c;})}function bf(a){try{var b=new Date(parseInt(a,10));if(!isNaN(b.getTime())&&!/[^0-9]/.test(a))return b.toUTCString()}catch(c){}return null}function cf(){return!(!L(\"fireauth.oauthhelper\",l)&&!L(\"fireauth.iframe\",l))}\nfunction df(){var a=l.navigator;return a&&a.serviceWorker&&a.serviceWorker.controller||null}function ef(){var a=l.navigator;return a&&a.serviceWorker?E().then(function(){return a.serviceWorker.ready}).then(function(b){return b.active||null}).o(function(){return null}):E(null)};var ff={};function gf(a){ff[a]||(ff[a]=!0,\"undefined\"!==typeof console&&\"function\"===typeof console.warn&&console.warn(a))};var hf;try{var jf={};Object.defineProperty(jf,\"abcd\",{configurable:!0,enumerable:!0,value:1});Object.defineProperty(jf,\"abcd\",{configurable:!0,enumerable:!0,value:2});hf=2==jf.abcd}catch(a){hf=!1}function M(a,b,c){hf?Object.defineProperty(a,b,{configurable:!0,enumerable:!0,value:c}):a[b]=c}function N(a,b){if(b)for(var c in b)b.hasOwnProperty(c)&&M(a,c,b[c])}function kf(a){var b={};N(b,a);return b}function lf(a){var b={},c;for(c in a)a.hasOwnProperty(c)&&(b[c]=a[c]);return b}\nfunction mf(a,b){if(!b||!b.length)return!0;if(!a)return!1;for(var c=0;c<b.length;c++){var d=a[b[c]];if(void 0===d||null===d||\"\"===d)return!1}return!0}function nf(a){var b=a;if(\"object\"==typeof a&&null!=a){b=\"length\"in a?[]:{};for(var c in a)M(b,c,nf(a[c]))}return b};/*\n\n Copyright 2019 Google Inc.\n\n Licensed under the Apache License, Version 2.0 (the \"License\");\n you may not use this file except in compliance with the License.\n You may obtain a copy of the License at\n\n   http://www.apache.org/licenses/LICENSE-2.0\n\n Unless required by applicable law or agreed to in writing, software\n distributed under the License is distributed on an \"AS IS\" BASIS,\n WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n See the License for the specific language governing permissions and\n limitations under the License.\n*/\nfunction of(a){var b=a&&(a[pf]?\"phone\":null);if(b&&a&&a[qf]){M(this,\"uid\",a[qf]);M(this,\"displayName\",a[rf]||null);var c=null;a[sf]&&(c=(new Date(a[sf])).toUTCString());M(this,\"enrollmentTime\",c);M(this,\"factorId\",b)}else throw new t(\"internal-error\",\"Internal assert: invalid MultiFactorInfo object\");}of.prototype.w=function(){return{uid:this.uid,displayName:this.displayName,factorId:this.factorId,enrollmentTime:this.enrollmentTime}};function tf(a){try{var b=new uf(a)}catch(c){b=null}return b}\nvar rf=\"displayName\",sf=\"enrolledAt\",qf=\"mfaEnrollmentId\",pf=\"phoneInfo\";function uf(a){of.call(this,a);M(this,\"phoneNumber\",a[pf])}r(uf,of);uf.prototype.w=function(){var a=uf.ab.w.call(this);a.phoneNumber=this.phoneNumber;return a};function vf(a){var b={},c=a[wf],d=a[xf],e=a[yf];a=tf(a[zf]);if(!e||e!=Af&&e!=Bf&&!c||e==Bf&&!d||e==Cf&&!a)throw Error(\"Invalid checkActionCode response!\");e==Bf?(b[Df]=c||null,b[Ef]=c||null,b[Ff]=d):(b[Df]=d||null,b[Ef]=d||null,b[Ff]=c||null);b[Gf]=a||null;M(this,Hf,e);M(this,If,nf(b))}\nvar Cf=\"REVERT_SECOND_FACTOR_ADDITION\",Af=\"EMAIL_SIGNIN\",Bf=\"VERIFY_AND_CHANGE_EMAIL\",wf=\"email\",zf=\"mfaInfo\",xf=\"newEmail\",yf=\"requestType\",Ff=\"email\",Df=\"fromEmail\",Gf=\"multiFactorInfo\",Ef=\"previousEmail\",If=\"data\",Hf=\"operation\";function Jf(a){a=J(a);var b=be(a,Kf)||null,c=be(a,Lf)||null,d=be(a,Mf)||null;d=d?Nf[d]||null:null;if(!b||!c||!d)throw new t(\"argument-error\",Kf+\", \"+Lf+\"and \"+Mf+\" are required in a valid action code URL.\");N(this,{apiKey:b,operation:d,code:c,continueUrl:be(a,Of)||null,languageCode:be(a,Pf)||null,tenantId:be(a,Qf)||null})}\nvar Kf=\"apiKey\",Lf=\"oobCode\",Of=\"continueUrl\",Pf=\"languageCode\",Mf=\"mode\",Qf=\"tenantId\",Nf={recoverEmail:\"RECOVER_EMAIL\",resetPassword:\"PASSWORD_RESET\",revertSecondFactorAddition:Cf,signIn:Af,verifyAndChangeEmail:Bf,verifyEmail:\"VERIFY_EMAIL\"};function Rf(a){try{return new Jf(a)}catch(b){return null}};function Sf(a){var b=a[Tf];if(\"undefined\"===typeof b)throw new t(\"missing-continue-uri\");if(\"string\"!==typeof b||\"string\"===typeof b&&!b.length)throw new t(\"invalid-continue-uri\");this.h=b;this.b=this.a=null;this.g=!1;var c=a[Uf];if(c&&\"object\"===typeof c){b=c[Vf];var d=c[Wf];c=c[Xf];if(\"string\"===typeof b&&b.length){this.a=b;if(\"undefined\"!==typeof d&&\"boolean\"!==typeof d)throw new t(\"argument-error\",Wf+\" property must be a boolean when specified.\");this.g=!!d;if(\"undefined\"!==typeof c&&(\"string\"!==\ntypeof c||\"string\"===typeof c&&!c.length))throw new t(\"argument-error\",Xf+\" property must be a non empty string when specified.\");this.b=c||null}else{if(\"undefined\"!==typeof b)throw new t(\"argument-error\",Vf+\" property must be a non empty string when specified.\");if(\"undefined\"!==typeof d||\"undefined\"!==typeof c)throw new t(\"missing-android-pkg-name\");}}else if(\"undefined\"!==typeof c)throw new t(\"argument-error\",Uf+\" property must be a non null object when specified.\");this.f=null;if((b=a[Yf])&&\"object\"===\ntypeof b)if(b=b[Zf],\"string\"===typeof b&&b.length)this.f=b;else{if(\"undefined\"!==typeof b)throw new t(\"argument-error\",Zf+\" property must be a non empty string when specified.\");}else if(\"undefined\"!==typeof b)throw new t(\"argument-error\",Yf+\" property must be a non null object when specified.\");b=a[$f];if(\"undefined\"!==typeof b&&\"boolean\"!==typeof b)throw new t(\"argument-error\",$f+\" property must be a boolean when specified.\");this.c=!!b;a=a[ag];if(\"undefined\"!==typeof a&&(\"string\"!==typeof a||\"string\"===\ntypeof a&&!a.length))throw new t(\"argument-error\",ag+\" property must be a non empty string when specified.\");this.i=a||null}var Uf=\"android\",ag=\"dynamicLinkDomain\",$f=\"handleCodeInApp\",Yf=\"iOS\",Tf=\"url\",Wf=\"installApp\",Xf=\"minimumVersion\",Vf=\"packageName\",Zf=\"bundleId\";\nfunction bg(a){var b={};b.continueUrl=a.h;b.canHandleCodeInApp=a.c;if(b.androidPackageName=a.a)b.androidMinimumVersion=a.b,b.androidInstallApp=a.g;b.iOSBundleId=a.f;b.dynamicLinkDomain=a.i;for(var c in b)null===b[c]&&delete b[c];return b};function cg(a){return Ra(a,function(b){b=b.toString(16);return 1<b.length?b:\"0\"+b}).join(\"\")};var dg=null;function eg(a){var b=[];fg(a,function(c){b.push(c)});return b}function fg(a,b){function c(m){for(;d<a.length;){var p=a.charAt(d++),v=dg[p];if(null!=v)return v;if(!/^[\\s\\xa0]*$/.test(p))throw Error(\"Unknown base64 encoding at char: \"+p);}return m}gg();for(var d=0;;){var e=c(-1),f=c(0),g=c(64),h=c(64);if(64===h&&-1===e)break;b(e<<2|f>>4);64!=g&&(b(f<<4&240|g>>2),64!=h&&b(g<<6&192|h))}}\nfunction gg(){if(!dg){dg={};for(var a=\"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789\".split(\"\"),b=[\"+/=\",\"+/\",\"-_=\",\"-_.\",\"-_\"],c=0;5>c;c++)for(var d=a.concat(b[c].split(\"\")),e=0;e<d.length;e++){var f=d[e];void 0===dg[f]&&(dg[f]=e)}}};function hg(a){var b=ig(a);if(!(b&&b.sub&&b.iss&&b.aud&&b.exp))throw Error(\"Invalid JWT\");this.h=a;this.a=b.exp;this.i=b.sub;a=Date.now()/1E3;this.g=b.iat||(a>this.a?this.a:a);this.b=b.provider_id||b.firebase&&b.firebase.sign_in_provider||null;this.f=b.firebase&&b.firebase.tenant||null;this.c=!!b.is_anonymous||\"anonymous\"==this.b}hg.prototype.T=function(){return this.f};hg.prototype.l=function(){return this.c};hg.prototype.toString=function(){return this.h};\nfunction jg(a){try{return new hg(a)}catch(b){return null}}\nfunction ig(a){if(!a)return null;a=a.split(\".\");if(3!=a.length)return null;a=a[1];for(var b=(4-a.length%4)%4,c=0;c<b;c++)a+=\".\";try{var d=eg(a);a=[];for(c=b=0;b<d.length;){var e=d[b++];if(128>e)a[c++]=String.fromCharCode(e);else if(191<e&&224>e){var f=d[b++];a[c++]=String.fromCharCode((e&31)<<6|f&63)}else if(239<e&&365>e){f=d[b++];var g=d[b++],h=d[b++],m=((e&7)<<18|(f&63)<<12|(g&63)<<6|h&63)-65536;a[c++]=String.fromCharCode(55296+(m>>10));a[c++]=String.fromCharCode(56320+(m&1023))}else f=d[b++],g=\nd[b++],a[c++]=String.fromCharCode((e&15)<<12|(f&63)<<6|g&63)}return JSON.parse(a.join(\"\"))}catch(p){}return null};var kg=\"oauth_consumer_key oauth_nonce oauth_signature oauth_signature_method oauth_timestamp oauth_token oauth_version\".split(\" \"),lg=[\"client_id\",\"response_type\",\"scope\",\"redirect_uri\",\"state\"],mg={nd:{Ja:\"locale\",ua:700,ta:600,fa:\"facebook.com\",Xa:lg},pd:{Ja:null,ua:500,ta:750,fa:\"github.com\",Xa:lg},qd:{Ja:\"hl\",ua:515,ta:680,fa:\"google.com\",Xa:lg},wd:{Ja:\"lang\",ua:485,ta:705,fa:\"twitter.com\",Xa:kg},kd:{Ja:\"locale\",ua:640,ta:600,fa:\"apple.com\",Xa:[]}};\nfunction ng(a){for(var b in mg)if(mg[b].fa==a)return mg[b];return null};function og(a){var b={};b[\"facebook.com\"]=pg;b[\"google.com\"]=qg;b[\"github.com\"]=rg;b[\"twitter.com\"]=sg;var c=a&&a[tg];try{if(c)return b[c]?new b[c](a):new ug(a);if(\"undefined\"!==typeof a[vg])return new wg(a)}catch(d){}return null}var vg=\"idToken\",tg=\"providerId\";\nfunction wg(a){var b=a[tg];if(!b&&a[vg]){var c=jg(a[vg]);c&&c.b&&(b=c.b)}if(!b)throw Error(\"Invalid additional user info!\");if(\"anonymous\"==b||\"custom\"==b)b=null;c=!1;\"undefined\"!==typeof a.isNewUser?c=!!a.isNewUser:\"identitytoolkit#SignupNewUserResponse\"===a.kind&&(c=!0);M(this,\"providerId\",b);M(this,\"isNewUser\",c)}function ug(a){wg.call(this,a);a=We(a.rawUserInfo||\"{}\");M(this,\"profile\",nf(a||{}))}r(ug,wg);\nfunction pg(a){ug.call(this,a);if(\"facebook.com\"!=this.providerId)throw Error(\"Invalid provider ID!\");}r(pg,ug);function rg(a){ug.call(this,a);if(\"github.com\"!=this.providerId)throw Error(\"Invalid provider ID!\");M(this,\"username\",this.profile&&this.profile.login||null)}r(rg,ug);function qg(a){ug.call(this,a);if(\"google.com\"!=this.providerId)throw Error(\"Invalid provider ID!\");}r(qg,ug);\nfunction sg(a){ug.call(this,a);if(\"twitter.com\"!=this.providerId)throw Error(\"Invalid provider ID!\");M(this,\"username\",a.screenName||null)}r(sg,ug);function xg(a){var b=J(a),c=be(b,\"link\"),d=be(J(c),\"link\");b=be(b,\"deep_link_id\");return be(J(b),\"link\")||b||d||c||a};function yg(a,b){if(!a&&!b)throw new t(\"internal-error\",\"Internal assert: no raw session string available\");if(a&&b)throw new t(\"internal-error\",\"Internal assert: unable to determine the session type\");this.a=a||null;this.b=b||null;this.type=this.a?zg:Ag}var zg=\"enroll\",Ag=\"signin\";yg.prototype.Ha=function(){return this.a?E(this.a):E(this.b)};yg.prototype.w=function(){return this.type==zg?{multiFactorSession:{idToken:this.a}}:{multiFactorSession:{pendingCredential:this.b}}};function Bg(){}Bg.prototype.ka=function(){};Bg.prototype.b=function(){};Bg.prototype.c=function(){};Bg.prototype.w=function(){};function Cg(a,b){return a.then(function(c){if(c[Dg]){var d=jg(c[Dg]);if(!d||b!=d.i)throw new t(\"user-mismatch\");return c}throw new t(\"user-mismatch\");}).o(function(c){throw c&&c.code&&c.code==xa+\"user-not-found\"?new t(\"user-mismatch\"):c;})}\nfunction Eg(a,b){if(b)this.a=b;else throw new t(\"internal-error\",\"failed to construct a credential\");M(this,\"providerId\",a);M(this,\"signInMethod\",a)}Eg.prototype.ka=function(a){return Fg(a,Gg(this))};Eg.prototype.b=function(a,b){var c=Gg(this);c.idToken=b;return Hg(a,c)};Eg.prototype.c=function(a,b){return Cg(Ig(a,Gg(this)),b)};function Gg(a){return{pendingToken:a.a,requestUri:\"http://localhost\"}}Eg.prototype.w=function(){return{providerId:this.providerId,signInMethod:this.signInMethod,pendingToken:this.a}};\nfunction Jg(a){if(a&&a.providerId&&a.signInMethod&&0==a.providerId.indexOf(\"saml.\")&&a.pendingToken)try{return new Eg(a.providerId,a.pendingToken)}catch(b){}return null}\nfunction Kg(a,b,c){this.a=null;if(b.idToken||b.accessToken)b.idToken&&M(this,\"idToken\",b.idToken),b.accessToken&&M(this,\"accessToken\",b.accessToken),b.nonce&&!b.pendingToken&&M(this,\"nonce\",b.nonce),b.pendingToken&&(this.a=b.pendingToken);else if(b.oauthToken&&b.oauthTokenSecret)M(this,\"accessToken\",b.oauthToken),M(this,\"secret\",b.oauthTokenSecret);else throw new t(\"internal-error\",\"failed to construct a credential\");M(this,\"providerId\",a);M(this,\"signInMethod\",c)}\nKg.prototype.ka=function(a){return Fg(a,Lg(this))};Kg.prototype.b=function(a,b){var c=Lg(this);c.idToken=b;return Hg(a,c)};Kg.prototype.c=function(a,b){var c=Lg(this);return Cg(Ig(a,c),b)};\nfunction Lg(a){var b={};a.idToken&&(b.id_token=a.idToken);a.accessToken&&(b.access_token=a.accessToken);a.secret&&(b.oauth_token_secret=a.secret);b.providerId=a.providerId;a.nonce&&!a.a&&(b.nonce=a.nonce);b={postBody:fe(b).toString(),requestUri:\"http://localhost\"};a.a&&(delete b.postBody,b.pendingToken=a.a);return b}\nKg.prototype.w=function(){var a={providerId:this.providerId,signInMethod:this.signInMethod};this.idToken&&(a.oauthIdToken=this.idToken);this.accessToken&&(a.oauthAccessToken=this.accessToken);this.secret&&(a.oauthTokenSecret=this.secret);this.nonce&&(a.nonce=this.nonce);this.a&&(a.pendingToken=this.a);return a};\nfunction Mg(a){if(a&&a.providerId&&a.signInMethod){var b={idToken:a.oauthIdToken,accessToken:a.oauthTokenSecret?null:a.oauthAccessToken,oauthTokenSecret:a.oauthTokenSecret,oauthToken:a.oauthTokenSecret&&a.oauthAccessToken,nonce:a.nonce,pendingToken:a.pendingToken};try{return new Kg(a.providerId,b,a.signInMethod)}catch(c){}}return null}function Ng(a,b){this.Qc=b||[];N(this,{providerId:a,isOAuthProvider:!0});this.Ib={};this.pb=(ng(a)||{}).Ja||null;this.ob=null}\nNg.prototype.Ka=function(a){this.Ib=nb(a);return this};function Og(a){if(\"string\"!==typeof a||0!=a.indexOf(\"saml.\"))throw new t(\"argument-error\",'SAML provider IDs must be prefixed with \"saml.\"');Ng.call(this,a,[])}r(Og,Ng);function Pg(a){Ng.call(this,a,lg);this.a=[]}r(Pg,Ng);Pg.prototype.Ca=function(a){Va(this.a,a)||this.a.push(a);return this};Pg.prototype.Qb=function(){return Za(this.a)};\nPg.prototype.credential=function(a,b){var c;n(a)?c={idToken:a.idToken||null,accessToken:a.accessToken||null,nonce:a.rawNonce||null}:c={idToken:a||null,accessToken:b||null};if(!c.idToken&&!c.accessToken)throw new t(\"argument-error\",\"credential failed: must provide the ID token and/or the access token.\");return new Kg(this.providerId,c,this.providerId)};function Qg(){Pg.call(this,\"facebook.com\")}r(Qg,Pg);M(Qg,\"PROVIDER_ID\",\"facebook.com\");M(Qg,\"FACEBOOK_SIGN_IN_METHOD\",\"facebook.com\");\nfunction Rg(a){if(!a)throw new t(\"argument-error\",\"credential failed: expected 1 argument (the OAuth access token).\");var b=a;n(a)&&(b=a.accessToken);return(new Qg).credential({accessToken:b})}function Sg(){Pg.call(this,\"github.com\")}r(Sg,Pg);M(Sg,\"PROVIDER_ID\",\"github.com\");M(Sg,\"GITHUB_SIGN_IN_METHOD\",\"github.com\");\nfunction Tg(a){if(!a)throw new t(\"argument-error\",\"credential failed: expected 1 argument (the OAuth access token).\");var b=a;n(a)&&(b=a.accessToken);return(new Sg).credential({accessToken:b})}function Ug(){Pg.call(this,\"google.com\");this.Ca(\"profile\")}r(Ug,Pg);M(Ug,\"PROVIDER_ID\",\"google.com\");M(Ug,\"GOOGLE_SIGN_IN_METHOD\",\"google.com\");function Vg(a,b){var c=a;n(a)&&(c=a.idToken,b=a.accessToken);return(new Ug).credential({idToken:c,accessToken:b})}function Wg(){Ng.call(this,\"twitter.com\",kg)}\nr(Wg,Ng);M(Wg,\"PROVIDER_ID\",\"twitter.com\");M(Wg,\"TWITTER_SIGN_IN_METHOD\",\"twitter.com\");function Xg(a,b){var c=a;n(c)||(c={oauthToken:a,oauthTokenSecret:b});if(!c.oauthToken||!c.oauthTokenSecret)throw new t(\"argument-error\",\"credential failed: expected 2 arguments (the OAuth access token and secret).\");return new Kg(\"twitter.com\",c,\"twitter.com\")}\nfunction Yg(a,b,c){this.a=a;this.f=b;M(this,\"providerId\",\"password\");M(this,\"signInMethod\",c===Zg.EMAIL_LINK_SIGN_IN_METHOD?Zg.EMAIL_LINK_SIGN_IN_METHOD:Zg.EMAIL_PASSWORD_SIGN_IN_METHOD)}Yg.prototype.ka=function(a){return this.signInMethod==Zg.EMAIL_LINK_SIGN_IN_METHOD?O(a,$g,{email:this.a,oobCode:this.f}):O(a,ah,{email:this.a,password:this.f})};\nYg.prototype.b=function(a,b){return this.signInMethod==Zg.EMAIL_LINK_SIGN_IN_METHOD?O(a,bh,{idToken:b,email:this.a,oobCode:this.f}):O(a,ch,{idToken:b,email:this.a,password:this.f})};Yg.prototype.c=function(a,b){return Cg(this.ka(a),b)};Yg.prototype.w=function(){return{email:this.a,password:this.f,signInMethod:this.signInMethod}};function dh(a){return a&&a.email&&a.password?new Yg(a.email,a.password,a.signInMethod):null}function Zg(){N(this,{providerId:\"password\",isOAuthProvider:!1})}\nfunction eh(a,b){b=fh(b);if(!b)throw new t(\"argument-error\",\"Invalid email link!\");return new Yg(a,b.code,Zg.EMAIL_LINK_SIGN_IN_METHOD)}function fh(a){a=xg(a);return(a=Rf(a))&&a.operation===Af?a:null}N(Zg,{PROVIDER_ID:\"password\"});N(Zg,{EMAIL_LINK_SIGN_IN_METHOD:\"emailLink\"});N(Zg,{EMAIL_PASSWORD_SIGN_IN_METHOD:\"password\"});function gh(a){if(!(a.eb&&a.cb||a.La&&a.ea))throw new t(\"internal-error\");this.a=a;M(this,\"providerId\",\"phone\");this.fa=\"phone\";M(this,\"signInMethod\",\"phone\")}\ngh.prototype.ka=function(a){return a.fb(hh(this))};gh.prototype.b=function(a,b){var c=hh(this);c.idToken=b;return O(a,ih,c)};gh.prototype.c=function(a,b){var c=hh(this);c.operation=\"REAUTH\";a=O(a,jh,c);return Cg(a,b)};gh.prototype.w=function(){var a={providerId:\"phone\"};this.a.eb&&(a.verificationId=this.a.eb);this.a.cb&&(a.verificationCode=this.a.cb);this.a.La&&(a.temporaryProof=this.a.La);this.a.ea&&(a.phoneNumber=this.a.ea);return a};\nfunction kh(a){if(a&&\"phone\"===a.providerId&&(a.verificationId&&a.verificationCode||a.temporaryProof&&a.phoneNumber)){var b={};w([\"verificationId\",\"verificationCode\",\"temporaryProof\",\"phoneNumber\"],function(c){a[c]&&(b[c]=a[c])});return new gh(b)}return null}function hh(a){return a.a.La&&a.a.ea?{temporaryProof:a.a.La,phoneNumber:a.a.ea}:{sessionInfo:a.a.eb,code:a.a.cb}}\nfunction lh(a){try{this.a=a||firebase.auth()}catch(b){throw new t(\"argument-error\",\"Either an instance of firebase.auth.Auth must be passed as an argument to the firebase.auth.PhoneAuthProvider constructor, or the default firebase App instance must be initialized via firebase.initializeApp().\");}N(this,{providerId:\"phone\",isOAuthProvider:!1})}\nlh.prototype.fb=function(a,b){var c=this.a.a;return E(b.verify()).then(function(d){if(\"string\"!==typeof d)throw new t(\"argument-error\",\"An implementation of firebase.auth.ApplicationVerifier.prototype.verify() must return a firebase.Promise that resolves with a string.\");switch(b.type){case \"recaptcha\":var e=n(a)?a.session:null,f=n(a)?a.phoneNumber:a,g;e&&e.type==zg?g=e.Ha().then(function(h){return mh(c,{idToken:h,phoneEnrollmentInfo:{phoneNumber:f,recaptchaToken:d}})}):e&&e.type==Ag?g=e.Ha().then(function(h){return nh(c,\n{mfaPendingCredential:h,mfaEnrollmentId:a.multiFactorHint&&a.multiFactorHint.uid||a.multiFactorUid,phoneSignInInfo:{recaptchaToken:d}})}):g=oh(c,{phoneNumber:f,recaptchaToken:d});return g.then(function(h){\"function\"===typeof b.reset&&b.reset();return h},function(h){\"function\"===typeof b.reset&&b.reset();throw h;});default:throw new t(\"argument-error\",'Only firebase.auth.ApplicationVerifiers with type=\"recaptcha\" are currently supported.');}})};\nfunction ph(a,b){if(!a)throw new t(\"missing-verification-id\");if(!b)throw new t(\"missing-verification-code\");return new gh({eb:a,cb:b})}N(lh,{PROVIDER_ID:\"phone\"});N(lh,{PHONE_SIGN_IN_METHOD:\"phone\"});\nfunction qh(a){if(a.temporaryProof&&a.phoneNumber)return new gh({La:a.temporaryProof,ea:a.phoneNumber});var b=a&&a.providerId;if(!b||\"password\"===b)return null;var c=a&&a.oauthAccessToken,d=a&&a.oauthTokenSecret,e=a&&a.nonce,f=a&&a.oauthIdToken,g=a&&a.pendingToken;try{switch(b){case \"google.com\":return Vg(f,c);case \"facebook.com\":return Rg(c);case \"github.com\":return Tg(c);case \"twitter.com\":return Xg(c,d);default:return c||d||f||g?g?0==b.indexOf(\"saml.\")?new Eg(b,g):new Kg(b,{pendingToken:g,idToken:a.oauthIdToken,\naccessToken:a.oauthAccessToken},b):(new Pg(b)).credential({idToken:f,accessToken:c,rawNonce:e}):null}}catch(h){return null}}function rh(a){if(!a.isOAuthProvider)throw new t(\"invalid-oauth-provider\");};function sh(a,b,c,d,e,f,g){this.c=a;this.b=b||null;this.g=c||null;this.f=d||null;this.i=f||null;this.h=g||null;this.a=e||null;if(this.g||this.a){if(this.g&&this.a)throw new t(\"invalid-auth-event\");if(this.g&&!this.f)throw new t(\"invalid-auth-event\");}else throw new t(\"invalid-auth-event\");}sh.prototype.getUid=function(){var a=[];a.push(this.c);this.b&&a.push(this.b);this.f&&a.push(this.f);this.h&&a.push(this.h);return a.join(\"-\")};sh.prototype.T=function(){return this.h};\nsh.prototype.w=function(){return{type:this.c,eventId:this.b,urlResponse:this.g,sessionId:this.f,postBody:this.i,tenantId:this.h,error:this.a&&this.a.w()}};function th(a){a=a||{};return a.type?new sh(a.type,a.eventId,a.urlResponse,a.sessionId,a.error&&Aa(a.error),a.postBody,a.tenantId):null};/*\n\n Copyright 2018 Google Inc.\n\n Licensed under the Apache License, Version 2.0 (the \"License\");\n you may not use this file except in compliance with the License.\n You may obtain a copy of the License at\n\n   http://www.apache.org/licenses/LICENSE-2.0\n\n Unless required by applicable law or agreed to in writing, software\n distributed under the License is distributed on an \"AS IS\" BASIS,\n WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n See the License for the specific language governing permissions and\n limitations under the License.\n*/\nfunction uh(){this.b=null;this.a=[]}var vh=null;function wh(a){var b=vh;b.a.push(a);b.b||(b.b=function(c){for(var d=0;d<b.a.length;d++)b.a[d](c)},a=L(\"universalLinks.subscribe\",l),\"function\"===typeof a&&a(null,b.b))};function xh(a){var b=\"unauthorized-domain\",c=void 0,d=J(a);a=d.a;d=d.c;\"chrome-extension\"==d?c=Qb(\"This chrome extension ID (chrome-extension://%s) is not authorized to run this operation. Add it to the OAuth redirect domains list in the Firebase console -> Auth section -> Sign in method tab.\",a):\"http\"==d||\"https\"==d?c=Qb(\"This domain (%s) is not authorized to run this operation. Add it to the OAuth redirect domains list in the Firebase console -> Auth section -> Sign in method tab.\",a):b=\"operation-not-supported-in-this-environment\";\nt.call(this,b,c)}r(xh,t);function yh(a,b,c){t.call(this,a,c);a=b||{};a.Jb&&M(this,\"email\",a.Jb);a.ea&&M(this,\"phoneNumber\",a.ea);a.credential&&M(this,\"credential\",a.credential);a.Zb&&M(this,\"tenantId\",a.Zb)}r(yh,t);yh.prototype.w=function(){var a={code:this.code,message:this.message};this.email&&(a.email=this.email);this.phoneNumber&&(a.phoneNumber=this.phoneNumber);this.tenantId&&(a.tenantId=this.tenantId);var b=this.credential&&this.credential.w();b&&z(a,b);return a};yh.prototype.toJSON=function(){return this.w()};\nfunction zh(a){if(a.code){var b=a.code||\"\";0==b.indexOf(xa)&&(b=b.substring(xa.length));var c={credential:qh(a),Zb:a.tenantId};if(a.email)c.Jb=a.email;else if(a.phoneNumber)c.ea=a.phoneNumber;else if(!c.credential)return new t(b,a.message||void 0);return new yh(b,c,a.message)}return null};function Ah(){}Ah.prototype.c=null;function Bh(a){return a.c||(a.c=a.b())};var Ch;function Dh(){}r(Dh,Ah);Dh.prototype.a=function(){var a=Eh(this);return a?new ActiveXObject(a):new XMLHttpRequest};Dh.prototype.b=function(){var a={};Eh(this)&&(a[0]=!0,a[1]=!0);return a};\nfunction Eh(a){if(!a.f&&\"undefined\"==typeof XMLHttpRequest&&\"undefined\"!=typeof ActiveXObject){for(var b=[\"MSXML2.XMLHTTP.6.0\",\"MSXML2.XMLHTTP.3.0\",\"MSXML2.XMLHTTP\",\"Microsoft.XMLHTTP\"],c=0;c<b.length;c++){var d=b[c];try{return new ActiveXObject(d),a.f=d}catch(e){}}throw Error(\"Could not create ActiveXObject. ActiveX might be disabled, or MSXML might not be installed\");}return a.f}Ch=new Dh;function Fh(){}r(Fh,Ah);Fh.prototype.a=function(){var a=new XMLHttpRequest;if(\"withCredentials\"in a)return a;if(\"undefined\"!=typeof XDomainRequest)return new Gh;throw Error(\"Unsupported browser\");};Fh.prototype.b=function(){return{}};\nfunction Gh(){this.a=new XDomainRequest;this.readyState=0;this.onreadystatechange=null;this.responseType=this.responseText=this.response=\"\";this.status=-1;this.statusText=\"\";this.a.onload=q(this.qc,this);this.a.onerror=q(this.Sb,this);this.a.onprogress=q(this.rc,this);this.a.ontimeout=q(this.vc,this)}k=Gh.prototype;k.open=function(a,b,c){if(null!=c&&!c)throw Error(\"Only async requests are supported.\");this.a.open(a,b)};\nk.send=function(a){if(a)if(\"string\"==typeof a)this.a.send(a);else throw Error(\"Only string data is supported\");else this.a.send()};k.abort=function(){this.a.abort()};k.setRequestHeader=function(){};k.getResponseHeader=function(a){return\"content-type\"==a.toLowerCase()?this.a.contentType:\"\"};k.qc=function(){this.status=200;this.response=this.responseText=this.a.responseText;Hh(this,4)};k.Sb=function(){this.status=500;this.response=this.responseText=\"\";Hh(this,4)};k.vc=function(){this.Sb()};\nk.rc=function(){this.status=200;Hh(this,1)};function Hh(a,b){a.readyState=b;if(a.onreadystatechange)a.onreadystatechange()}k.getAllResponseHeaders=function(){return\"content-type: \"+this.a.contentType};function Ih(a,b,c){this.reset(a,b,c,void 0,void 0)}Ih.prototype.a=null;var Jh=0;Ih.prototype.reset=function(a,b,c,d,e){\"number\"==typeof e||Jh++;d||va();delete this.a};function Kh(a){this.f=a;this.b=this.c=this.a=null}function Lh(a,b){this.name=a;this.value=b}Lh.prototype.toString=function(){return this.name};var Mh=new Lh(\"SEVERE\",1E3),Nh=new Lh(\"WARNING\",900),Oh=new Lh(\"CONFIG\",700),Ph=new Lh(\"FINE\",500);function Qh(a){if(a.c)return a.c;if(a.a)return Qh(a.a);Ga(\"Root logger has no level set.\");return null}Kh.prototype.log=function(a,b,c){if(a.value>=Qh(this).value)for(oa(b)&&(b=b()),a=new Ih(a,String(b),this.f),c&&(a.a=c),c=this;c;)c=c.a};var Rh={},Sh=null;\nfunction Th(a){Sh||(Sh=new Kh(\"\"),Rh[\"\"]=Sh,Sh.c=Oh);var b;if(!(b=Rh[a])){b=new Kh(a);var c=a.lastIndexOf(\".\"),d=a.substr(c+1);c=Th(a.substr(0,c));c.b||(c.b={});c.b[d]=b;b.a=c;Rh[a]=b}return b};function Uh(a,b){a&&a.log(Ph,b,void 0)};function Vh(a){this.f=a}r(Vh,Ah);Vh.prototype.a=function(){return new Wh(this.f)};Vh.prototype.b=function(a){return function(){return a}}({});function Wh(a){H.call(this);this.u=a;this.h=void 0;this.readyState=Xh;this.status=0;this.responseType=this.responseText=this.response=this.statusText=\"\";this.onreadystatechange=null;this.l=new Headers;this.b=null;this.s=\"GET\";this.f=\"\";this.a=!1;this.i=Th(\"goog.net.FetchXmlHttp\");this.m=this.c=this.g=null}r(Wh,H);var Xh=0;k=Wh.prototype;\nk.open=function(a,b){if(this.readyState!=Xh)throw this.abort(),Error(\"Error reopening a connection\");this.s=a;this.f=b;this.readyState=1;Yh(this)};k.send=function(a){if(1!=this.readyState)throw this.abort(),Error(\"need to call open() first. \");this.a=!0;var b={headers:this.l,method:this.s,credentials:this.h,cache:void 0};a&&(b.body=a);this.u.fetch(new Request(this.f,b)).then(this.uc.bind(this),this.Ua.bind(this))};\nk.abort=function(){this.response=this.responseText=\"\";this.l=new Headers;this.status=0;this.c&&this.c.cancel(\"Request was aborted.\");1<=this.readyState&&this.a&&4!=this.readyState&&(this.a=!1,Zh(this));this.readyState=Xh};\nk.uc=function(a){this.a&&(this.g=a,this.b||(this.status=this.g.status,this.statusText=this.g.statusText,this.b=a.headers,this.readyState=2,Yh(this)),this.a&&(this.readyState=3,Yh(this),this.a&&(\"arraybuffer\"===this.responseType?a.arrayBuffer().then(this.sc.bind(this),this.Ua.bind(this)):\"undefined\"!==typeof l.ReadableStream&&\"body\"in a?(this.response=this.responseText=\"\",this.c=a.body.getReader(),this.m=new TextDecoder,$h(this)):a.text().then(this.tc.bind(this),this.Ua.bind(this)))))};\nfunction $h(a){a.c.read().then(a.pc.bind(a)).catch(a.Ua.bind(a))}k.pc=function(a){if(this.a){var b=this.m.decode(a.value?a.value:new Uint8Array(0),{stream:!a.done});b&&(this.response=this.responseText+=b);a.done?Zh(this):Yh(this);3==this.readyState&&$h(this)}};k.tc=function(a){this.a&&(this.response=this.responseText=a,Zh(this))};k.sc=function(a){this.a&&(this.response=a,Zh(this))};k.Ua=function(a){var b=this.i;b&&b.log(Nh,\"Failed to fetch url \"+this.f,a instanceof Error?a:Error(a));this.a&&Zh(this)};\nfunction Zh(a){a.readyState=4;a.g=null;a.c=null;a.m=null;Yh(a)}k.setRequestHeader=function(a,b){this.l.append(a,b)};k.getResponseHeader=function(a){return this.b?this.b.get(a.toLowerCase())||\"\":((a=this.i)&&a.log(Nh,\"Attempting to get response header but no headers have been received for url: \"+this.f,void 0),\"\")};\nk.getAllResponseHeaders=function(){if(!this.b){var a=this.i;a&&a.log(Nh,\"Attempting to get all response headers but no headers have been received for url: \"+this.f,void 0);return\"\"}a=[];for(var b=this.b.entries(),c=b.next();!c.done;)c=c.value,a.push(c[0]+\": \"+c[1]),c=b.next();return a.join(\"\\r\\n\")};function Yh(a){a.onreadystatechange&&a.onreadystatechange.call(a)}Object.defineProperty(Wh.prototype,\"withCredentials\",{get:function(){return\"include\"===this.h},set:function(a){this.h=a?\"include\":\"same-origin\"}});function ai(a){H.call(this);this.headers=new Jd;this.D=a||null;this.c=!1;this.C=this.a=null;this.h=this.R=this.l=\"\";this.f=this.O=this.i=this.J=!1;this.g=0;this.s=null;this.m=bi;this.u=this.S=!1}r(ai,H);var bi=\"\";ai.prototype.b=Th(\"goog.net.XhrIo\");var ci=/^https?$/i,di=[\"POST\",\"PUT\"];\nfunction ei(a,b,c,d,e){if(a.a)throw Error(\"[goog.net.XhrIo] Object is active with another request=\"+a.l+\"; newUri=\"+b);c=c?c.toUpperCase():\"GET\";a.l=b;a.h=\"\";a.R=c;a.J=!1;a.c=!0;a.a=a.D?a.D.a():Ch.a();a.C=a.D?Bh(a.D):Bh(Ch);a.a.onreadystatechange=q(a.Vb,a);try{Uh(a.b,fi(a,\"Opening Xhr\")),a.O=!0,a.a.open(c,String(b),!0),a.O=!1}catch(g){Uh(a.b,fi(a,\"Error opening Xhr: \"+g.message));gi(a,g);return}b=d||\"\";var f=new Jd(a.headers);e&&Id(e,function(g,h){f.set(h,g)});e=Ta(f.Y());d=l.FormData&&b instanceof\nl.FormData;!Va(di,c)||e||d||f.set(\"Content-Type\",\"application/x-www-form-urlencoded;charset=utf-8\");f.forEach(function(g,h){this.a.setRequestHeader(h,g)},a);a.m&&(a.a.responseType=a.m);\"withCredentials\"in a.a&&a.a.withCredentials!==a.S&&(a.a.withCredentials=a.S);try{hi(a),0<a.g&&(a.u=ii(a.a),Uh(a.b,fi(a,\"Will abort after \"+a.g+\"ms if incomplete, xhr2 \"+a.u)),a.u?(a.a.timeout=a.g,a.a.ontimeout=q(a.Ma,a)):a.s=Ed(a.Ma,a.g,a)),Uh(a.b,fi(a,\"Sending request\")),a.i=!0,a.a.send(b),a.i=!1}catch(g){Uh(a.b,\nfi(a,\"Send error: \"+g.message)),gi(a,g)}}function ii(a){return Wb&&fc(9)&&\"number\"===typeof a.timeout&&void 0!==a.ontimeout}function Ua(a){return\"content-type\"==a.toLowerCase()}k=ai.prototype;k.Ma=function(){\"undefined\"!=typeof ha&&this.a&&(this.h=\"Timed out after \"+this.g+\"ms, aborting\",Uh(this.b,fi(this,this.h)),this.dispatchEvent(\"timeout\"),this.abort(8))};function gi(a,b){a.c=!1;a.a&&(a.f=!0,a.a.abort(),a.f=!1);a.h=b;ji(a);ki(a)}\nfunction ji(a){a.J||(a.J=!0,a.dispatchEvent(\"complete\"),a.dispatchEvent(\"error\"))}k.abort=function(){this.a&&this.c&&(Uh(this.b,fi(this,\"Aborting\")),this.c=!1,this.f=!0,this.a.abort(),this.f=!1,this.dispatchEvent(\"complete\"),this.dispatchEvent(\"abort\"),ki(this))};k.Da=function(){this.a&&(this.c&&(this.c=!1,this.f=!0,this.a.abort(),this.f=!1),ki(this,!0));ai.ab.Da.call(this)};k.Vb=function(){this.xa||(this.O||this.i||this.f?li(this):this.Jc())};k.Jc=function(){li(this)};\nfunction li(a){if(a.c&&\"undefined\"!=typeof ha)if(a.C[1]&&4==mi(a)&&2==ni(a))Uh(a.b,fi(a,\"Local request error detected and ignored\"));else if(a.i&&4==mi(a))Ed(a.Vb,0,a);else if(a.dispatchEvent(\"readystatechange\"),4==mi(a)){Uh(a.b,fi(a,\"Request complete\"));a.c=!1;try{var b=ni(a);a:switch(b){case 200:case 201:case 202:case 204:case 206:case 304:case 1223:var c=!0;break a;default:c=!1}var d;if(!(d=c)){var e;if(e=0===b){var f=String(a.l).match(Md)[1]||null;if(!f&&l.self&&l.self.location){var g=l.self.location.protocol;\nf=g.substr(0,g.length-1)}e=!ci.test(f?f.toLowerCase():\"\")}d=e}if(d)a.dispatchEvent(\"complete\"),a.dispatchEvent(\"success\");else{try{var h=2<mi(a)?a.a.statusText:\"\"}catch(m){Uh(a.b,\"Can not get status: \"+m.message),h=\"\"}a.h=h+\" [\"+ni(a)+\"]\";ji(a)}}finally{ki(a)}}}function ki(a,b){if(a.a){hi(a);var c=a.a,d=a.C[0]?la:null;a.a=null;a.C=null;b||a.dispatchEvent(\"ready\");try{c.onreadystatechange=d}catch(e){(a=a.b)&&a.log(Mh,\"Problem encountered resetting onreadystatechange: \"+e.message,void 0)}}}\nfunction hi(a){a.a&&a.u&&(a.a.ontimeout=null);a.s&&(l.clearTimeout(a.s),a.s=null)}function mi(a){return a.a?a.a.readyState:0}function ni(a){try{return 2<mi(a)?a.a.status:-1}catch(b){return-1}}function oi(a){try{return a.a?a.a.responseText:\"\"}catch(b){return Uh(a.b,\"Can not get responseText: \"+b.message),\"\"}}\nk.getResponse=function(){try{if(!this.a)return null;if(\"response\"in this.a)return this.a.response;switch(this.m){case bi:case \"text\":return this.a.responseText;case \"arraybuffer\":if(\"mozResponseArrayBuffer\"in this.a)return this.a.mozResponseArrayBuffer}var a=this.b;a&&a.log(Mh,\"Response type \"+this.m+\" is not supported on this browser\",void 0);return null}catch(b){return Uh(this.b,\"Can not get response: \"+b.message),null}};function fi(a,b){return b+\" [\"+a.R+\" \"+a.l+\" \"+ni(a)+\"]\"};/*\n Portions of this code are from MochiKit, received by\n The Closure Authors under the MIT license. All other code is Copyright\n 2005-2009 The Closure Authors. All Rights Reserved.\n*/\nfunction pi(a){var b=qi;this.g=[];this.u=b;this.s=a||null;this.f=this.a=!1;this.c=void 0;this.v=this.C=this.i=!1;this.h=0;this.b=null;this.l=0}pi.prototype.cancel=function(a){if(this.a)this.c instanceof pi&&this.c.cancel();else{if(this.b){var b=this.b;delete this.b;a?b.cancel(a):(b.l--,0>=b.l&&b.cancel())}this.u?this.u.call(this.s,this):this.v=!0;this.a||(a=new ri(this),si(this),ti(this,!1,a))}};pi.prototype.m=function(a,b){this.i=!1;ti(this,a,b)};function ti(a,b,c){a.a=!0;a.c=c;a.f=!b;ui(a)}\nfunction si(a){if(a.a){if(!a.v)throw new vi(a);a.v=!1}}function wi(a,b){xi(a,null,b,void 0)}function xi(a,b,c,d){a.g.push([b,c,d]);a.a&&ui(a)}pi.prototype.then=function(a,b,c){var d,e,f=new D(function(g,h){d=g;e=h});xi(this,d,function(g){g instanceof ri?f.cancel():e(g)});return f.then(a,b,c)};pi.prototype.$goog_Thenable=!0;function yi(a){return Sa(a.g,function(b){return oa(b[1])})}\nfunction ui(a){if(a.h&&a.a&&yi(a)){var b=a.h,c=zi[b];c&&(l.clearTimeout(c.a),delete zi[b]);a.h=0}a.b&&(a.b.l--,delete a.b);b=a.c;for(var d=c=!1;a.g.length&&!a.i;){var e=a.g.shift(),f=e[0],g=e[1];e=e[2];if(f=a.f?g:f)try{var h=f.call(e||a.s,b);void 0!==h&&(a.f=a.f&&(h==b||h instanceof Error),a.c=b=h);if(Ea(b)||\"function\"===typeof l.Promise&&b instanceof l.Promise)d=!0,a.i=!0}catch(m){b=m,a.f=!0,yi(a)||(c=!0)}}a.c=b;d&&(h=q(a.m,a,!0),d=q(a.m,a,!1),b instanceof pi?(xi(b,h,d),b.C=!0):b.then(h,d));c&&(b=\nnew Ai(b),zi[b.a]=b,a.h=b.a)}function vi(){u.call(this)}r(vi,u);vi.prototype.message=\"Deferred has already fired\";vi.prototype.name=\"AlreadyCalledError\";function ri(){u.call(this)}r(ri,u);ri.prototype.message=\"Deferred was canceled\";ri.prototype.name=\"CanceledError\";function Ai(a){this.a=l.setTimeout(q(this.c,this),0);this.b=a}Ai.prototype.c=function(){delete zi[this.a];throw this.b;};var zi={};function Bi(a){var b={},c=b.document||document,d=yb(a).toString(),e=oc(document,\"SCRIPT\"),f={Wb:e,Ma:void 0},g=new pi(f),h=null,m=null!=b.timeout?b.timeout:5E3;0<m&&(h=window.setTimeout(function(){Ci(e,!0);var p=new Di(Ei,\"Timeout reached for loading script \"+d);si(g);ti(g,!1,p)},m),f.Ma=h);e.onload=e.onreadystatechange=function(){e.readyState&&\"loaded\"!=e.readyState&&\"complete\"!=e.readyState||(Ci(e,b.xd||!1,h),si(g),ti(g,!0,null))};e.onerror=function(){Ci(e,!0,h);var p=new Di(Fi,\"Error while loading script \"+\nd);si(g);ti(g,!1,p)};f=b.attributes||{};z(f,{type:\"text/javascript\",charset:\"UTF-8\"});lc(e,f);Ob(e,a);Gi(c).appendChild(e);return g}function Gi(a){var b;return(b=(a||document).getElementsByTagName(\"HEAD\"))&&0!=b.length?b[0]:a.documentElement}function qi(){if(this&&this.Wb){var a=this.Wb;a&&\"SCRIPT\"==a.tagName&&Ci(a,!0,this.Ma)}}\nfunction Ci(a,b,c){null!=c&&l.clearTimeout(c);a.onload=la;a.onerror=la;a.onreadystatechange=la;b&&window.setTimeout(function(){a&&a.parentNode&&a.parentNode.removeChild(a)},0)}var Fi=0,Ei=1;function Di(a,b){var c=\"Jsloader error (code #\"+a+\")\";b&&(c+=\": \"+b);u.call(this,c);this.code=a}r(Di,u);function Hi(a){this.f=a}r(Hi,Ah);Hi.prototype.a=function(){return new this.f};Hi.prototype.b=function(){return{}};\nfunction Ii(a,b,c){this.c=a;a=b||{};this.l=a.secureTokenEndpoint||\"https://securetoken.googleapis.com/v1/token\";this.m=a.secureTokenTimeout||Ji;this.g=nb(a.secureTokenHeaders||Ki);this.h=a.firebaseEndpoint||\"https://www.googleapis.com/identitytoolkit/v3/relyingparty/\";this.i=a.identityPlatformEndpoint||\"https://identitytoolkit.googleapis.com/v2/\";this.v=a.firebaseTimeout||Li;this.a=nb(a.firebaseHeaders||Mi);c&&(this.a[\"X-Client-Version\"]=c,this.g[\"X-Client-Version\"]=c);c=\"Node\"==Ke();c=l.XMLHttpRequest||\nc&&firebase.INTERNAL.node&&firebase.INTERNAL.node.XMLHttpRequest;if(!c&&!Je())throw new t(\"internal-error\",\"The XMLHttpRequest compatibility library was not found.\");this.f=void 0;Je()?this.f=new Vh(self):Le()?this.f=new Hi(c):this.f=new Fh;this.b=null}var Ni,Dg=\"idToken\",Ji=new Ze(3E4,6E4),Ki={\"Content-Type\":\"application/x-www-form-urlencoded\"},Li=new Ze(3E4,6E4),Mi={\"Content-Type\":\"application/json\"};function Oi(a,b){b?a.a[\"X-Firebase-Locale\"]=b:delete a.a[\"X-Firebase-Locale\"]}\nfunction Pi(a,b){b&&(a.l=Qi(\"https://securetoken.googleapis.com/v1/token\",b),a.h=Qi(\"https://www.googleapis.com/identitytoolkit/v3/relyingparty/\",b),a.i=Qi(\"https://identitytoolkit.googleapis.com/v2/\",b))}function Qi(a,b){a=J(a);b=J(b.url);a.f=a.a+a.f;Pd(a,b.c);a.a=b.a;Qd(a,b.g);return a.toString()}function Ri(a,b){b?(a.a[\"X-Client-Version\"]=b,a.g[\"X-Client-Version\"]=b):(delete a.a[\"X-Client-Version\"],delete a.g[\"X-Client-Version\"])}Ii.prototype.T=function(){return this.b};\nfunction Si(a,b,c,d,e,f,g){ue()||Je()?a=q(a.u,a):(Ni||(Ni=new D(function(h,m){Ti(h,m)})),a=q(a.s,a));a(b,c,d,e,f,g)}\nIi.prototype.u=function(a,b,c,d,e,f){if(Je()&&(\"undefined\"===typeof l.fetch||\"undefined\"===typeof l.Headers||\"undefined\"===typeof l.Request))throw new t(\"operation-not-supported-in-this-environment\",\"fetch, Headers and Request native APIs or equivalent Polyfills must be available to support HTTP requests from a Worker environment.\");var g=new ai(this.f);if(f){g.g=Math.max(0,f);var h=setTimeout(function(){g.dispatchEvent(\"timeout\")},f)}qd(g,\"complete\",function(){h&&clearTimeout(h);var m=null;try{m=\nJSON.parse(oi(this))||null}catch(p){m=null}b&&b(m)});wd(g,\"ready\",function(){h&&clearTimeout(h);Xc(this)});wd(g,\"timeout\",function(){h&&clearTimeout(h);Xc(this);b&&b(null)});ei(g,a,c,d,e)};var Ui=new qb(rb,\"https://apis.google.com/js/client.js?onload=%{onload}\"),Vi=\"__fcb\"+Math.floor(1E6*Math.random()).toString();\nfunction Ti(a,b){if(((window.gapi||{}).client||{}).request)a();else{l[Vi]=function(){((window.gapi||{}).client||{}).request?a():b(Error(\"CORS_UNSUPPORTED\"))};var c=zb(Ui,{onload:Vi});wi(Bi(c),function(){b(Error(\"CORS_UNSUPPORTED\"))})}}\nIi.prototype.s=function(a,b,c,d,e){var f=this;Ni.then(function(){window.gapi.client.setApiKey(f.c);var g=window.gapi.auth.getToken();window.gapi.auth.setToken(null);window.gapi.client.request({path:a,method:c,body:d,headers:e,authType:\"none\",callback:function(h){window.gapi.auth.setToken(g);b&&b(h)}})}).o(function(g){b&&b({error:{message:g&&g.message||\"CORS_UNSUPPORTED\"}})})};\nfunction Wi(a,b){return new D(function(c,d){\"refresh_token\"==b.grant_type&&b.refresh_token||\"authorization_code\"==b.grant_type&&b.code?Si(a,a.l+\"?key=\"+encodeURIComponent(a.c),function(e){e?e.error?d(Xi(e)):e.access_token&&e.refresh_token?c(e):d(new t(\"internal-error\")):d(new t(\"network-request-failed\"))},\"POST\",fe(b).toString(),a.g,a.m.get()):d(new t(\"internal-error\"))})}\nfunction Yi(a,b,c,d,e,f,g){var h=J(b+c);I(h,\"key\",a.c);g&&I(h,\"cb\",va().toString());var m=\"GET\"==d;if(m)for(var p in e)e.hasOwnProperty(p)&&I(h,p,e[p]);return new D(function(v,B){Si(a,h.toString(),function(A){A?A.error?B(Xi(A,f||{})):v(A):B(new t(\"network-request-failed\"))},d,m?void 0:ke(Ve(e)),a.a,a.v.get())})}function Zi(a){a=a.email;if(\"string\"!==typeof a||!De.test(a))throw new t(\"invalid-email\");}function $i(a){\"email\"in a&&Zi(a)}\nfunction aj(a,b){return O(a,bj,{identifier:b,continueUri:Se()?re():\"http://localhost\"}).then(function(c){return c.signinMethods||[]})}function cj(a){return O(a,dj,{}).then(function(b){return b.authorizedDomains||[]})}function P(a){if(!a[Dg]){if(a.mfaPendingCredential)throw new t(\"multi-factor-auth-required\",null,nb(a));throw new t(\"internal-error\");}}\nfunction ej(a){if(a.phoneNumber||a.temporaryProof){if(!a.phoneNumber||!a.temporaryProof)throw new t(\"internal-error\");}else{if(!a.sessionInfo)throw new t(\"missing-verification-id\");if(!a.code)throw new t(\"missing-verification-code\");}}Ii.prototype.zb=function(){return O(this,fj,{})};Ii.prototype.Bb=function(a,b){return O(this,gj,{idToken:a,email:b})};Ii.prototype.Cb=function(a,b){return O(this,ch,{idToken:a,password:b})};var hj={displayName:\"DISPLAY_NAME\",photoUrl:\"PHOTO_URL\"};k=Ii.prototype;\nk.Db=function(a,b){var c={idToken:a},d=[];lb(hj,function(e,f){var g=b[f];null===g?d.push(e):f in b&&(c[f]=g)});d.length&&(c.deleteAttribute=d);return O(this,gj,c)};k.vb=function(a,b){a={requestType:\"PASSWORD_RESET\",email:a};z(a,b);return O(this,ij,a)};k.wb=function(a,b){a={requestType:\"EMAIL_SIGNIN\",email:a};z(a,b);return O(this,jj,a)};k.ub=function(a,b){a={requestType:\"VERIFY_EMAIL\",idToken:a};z(a,b);return O(this,kj,a)};\nk.Eb=function(a,b,c){a={requestType:\"VERIFY_AND_CHANGE_EMAIL\",idToken:a,newEmail:b};z(a,c);return O(this,lj,a)};function oh(a,b){return O(a,mj,b)}k.fb=function(a){return O(this,nj,a)};function mh(a,b){return O(a,oj,b).then(function(c){return c.phoneSessionInfo.sessionInfo})}\nfunction pj(a){if(!a.phoneVerificationInfo)throw new t(\"internal-error\");if(!a.phoneVerificationInfo.sessionInfo)throw new t(\"missing-verification-id\");if(!a.phoneVerificationInfo.code)throw new t(\"missing-verification-code\");}function nh(a,b){return O(a,qj,b).then(function(c){return c.phoneResponseInfo.sessionInfo})}function rj(a,b,c){return O(a,sj,{idToken:b,deleteProvider:c})}function tj(a){if(!a.requestUri||!a.sessionId&&!a.postBody&&!a.pendingToken)throw new t(\"internal-error\");}\nfunction uj(a,b){b.oauthIdToken&&b.providerId&&0==b.providerId.indexOf(\"oidc.\")&&!b.pendingToken&&(a.sessionId?b.nonce=a.sessionId:a.postBody&&(a=new Ud(a.postBody),je(a,\"nonce\")&&(b.nonce=a.get(\"nonce\"))));return b}\nfunction vj(a){var b=null;a.needConfirmation?(a.code=\"account-exists-with-different-credential\",b=zh(a)):\"FEDERATED_USER_ID_ALREADY_LINKED\"==a.errorMessage?(a.code=\"credential-already-in-use\",b=zh(a)):\"EMAIL_EXISTS\"==a.errorMessage?(a.code=\"email-already-in-use\",b=zh(a)):a.errorMessage&&(b=wj(a.errorMessage));if(b)throw b;P(a)}function Fg(a,b){b.returnIdpCredential=!0;return O(a,xj,b)}function Hg(a,b){b.returnIdpCredential=!0;return O(a,yj,b)}\nfunction Ig(a,b){b.returnIdpCredential=!0;b.autoCreate=!1;return O(a,zj,b)}function Aj(a){if(!a.oobCode)throw new t(\"invalid-action-code\");}k.nb=function(a,b){return O(this,Bj,{oobCode:a,newPassword:b})};k.Ra=function(a){return O(this,Cj,{oobCode:a})};k.jb=function(a){return O(this,Dj,{oobCode:a})};\nvar Dj={endpoint:\"setAccountInfo\",A:Aj,Z:\"email\",B:!0},Cj={endpoint:\"resetPassword\",A:Aj,G:function(a){var b=a.requestType;if(!b||!a.email&&\"EMAIL_SIGNIN\"!=b&&\"VERIFY_AND_CHANGE_EMAIL\"!=b)throw new t(\"internal-error\");},B:!0},Ej={endpoint:\"signupNewUser\",A:function(a){Zi(a);if(!a.password)throw new t(\"weak-password\");},G:P,V:!0,B:!0},bj={endpoint:\"createAuthUri\",B:!0},Fj={endpoint:\"deleteAccount\",N:[\"idToken\"]},sj={endpoint:\"setAccountInfo\",N:[\"idToken\",\"deleteProvider\"],A:function(a){if(!Array.isArray(a.deleteProvider))throw new t(\"internal-error\");\n}},$g={endpoint:\"emailLinkSignin\",N:[\"email\",\"oobCode\"],A:Zi,G:P,V:!0,B:!0},bh={endpoint:\"emailLinkSignin\",N:[\"idToken\",\"email\",\"oobCode\"],A:Zi,G:P,V:!0},Gj={endpoint:\"accounts/mfaEnrollment:finalize\",N:[\"idToken\",\"phoneVerificationInfo\"],A:pj,G:P,B:!0,Na:!0},Hj={endpoint:\"accounts/mfaSignIn:finalize\",N:[\"mfaPendingCredential\",\"phoneVerificationInfo\"],A:pj,G:P,B:!0,Na:!0},Ij={endpoint:\"getAccountInfo\"},jj={endpoint:\"getOobConfirmationCode\",N:[\"requestType\"],A:function(a){if(\"EMAIL_SIGNIN\"!=a.requestType)throw new t(\"internal-error\");\nZi(a)},Z:\"email\",B:!0},kj={endpoint:\"getOobConfirmationCode\",N:[\"idToken\",\"requestType\"],A:function(a){if(\"VERIFY_EMAIL\"!=a.requestType)throw new t(\"internal-error\");},Z:\"email\",B:!0},lj={endpoint:\"getOobConfirmationCode\",N:[\"idToken\",\"newEmail\",\"requestType\"],A:function(a){if(\"VERIFY_AND_CHANGE_EMAIL\"!=a.requestType)throw new t(\"internal-error\");},Z:\"email\",B:!0},ij={endpoint:\"getOobConfirmationCode\",N:[\"requestType\"],A:function(a){if(\"PASSWORD_RESET\"!=a.requestType)throw new t(\"internal-error\");\nZi(a)},Z:\"email\",B:!0},dj={lb:!0,endpoint:\"getProjectConfig\",Ub:\"GET\"},Jj={lb:!0,endpoint:\"getRecaptchaParam\",Ub:\"GET\",G:function(a){if(!a.recaptchaSiteKey)throw new t(\"internal-error\");}},Bj={endpoint:\"resetPassword\",A:Aj,Z:\"email\",B:!0},mj={endpoint:\"sendVerificationCode\",N:[\"phoneNumber\",\"recaptchaToken\"],Z:\"sessionInfo\",B:!0},gj={endpoint:\"setAccountInfo\",N:[\"idToken\"],A:$i,V:!0},ch={endpoint:\"setAccountInfo\",N:[\"idToken\"],A:function(a){$i(a);if(!a.password)throw new t(\"weak-password\");},G:P,\nV:!0},fj={endpoint:\"signupNewUser\",G:P,V:!0,B:!0},oj={endpoint:\"accounts/mfaEnrollment:start\",N:[\"idToken\",\"phoneEnrollmentInfo\"],A:function(a){if(!a.phoneEnrollmentInfo)throw new t(\"internal-error\");if(!a.phoneEnrollmentInfo.phoneNumber)throw new t(\"missing-phone-number\");if(!a.phoneEnrollmentInfo.recaptchaToken)throw new t(\"missing-app-credential\");},G:function(a){if(!a.phoneSessionInfo||!a.phoneSessionInfo.sessionInfo)throw new t(\"internal-error\");},B:!0,Na:!0},qj={endpoint:\"accounts/mfaSignIn:start\",\nN:[\"mfaPendingCredential\",\"mfaEnrollmentId\",\"phoneSignInInfo\"],A:function(a){if(!a.phoneSignInInfo||!a.phoneSignInInfo.recaptchaToken)throw new t(\"missing-app-credential\");},G:function(a){if(!a.phoneResponseInfo||!a.phoneResponseInfo.sessionInfo)throw new t(\"internal-error\");},B:!0,Na:!0},xj={endpoint:\"verifyAssertion\",A:tj,Ya:uj,G:vj,V:!0,B:!0},zj={endpoint:\"verifyAssertion\",A:tj,Ya:uj,G:function(a){if(a.errorMessage&&\"USER_NOT_FOUND\"==a.errorMessage)throw new t(\"user-not-found\");if(a.errorMessage)throw wj(a.errorMessage);\nP(a)},V:!0,B:!0},yj={endpoint:\"verifyAssertion\",A:function(a){tj(a);if(!a.idToken)throw new t(\"internal-error\");},Ya:uj,G:vj,V:!0},Kj={endpoint:\"verifyCustomToken\",A:function(a){if(!a.token)throw new t(\"invalid-custom-token\");},G:P,V:!0,B:!0},ah={endpoint:\"verifyPassword\",A:function(a){Zi(a);if(!a.password)throw new t(\"wrong-password\");},G:P,V:!0,B:!0},nj={endpoint:\"verifyPhoneNumber\",A:ej,G:P,B:!0},ih={endpoint:\"verifyPhoneNumber\",A:function(a){if(!a.idToken)throw new t(\"internal-error\");ej(a)},\nG:function(a){if(a.temporaryProof)throw a.code=\"credential-already-in-use\",zh(a);P(a)}},jh={Hb:{USER_NOT_FOUND:\"user-not-found\"},endpoint:\"verifyPhoneNumber\",A:ej,G:P,B:!0},Lj={endpoint:\"accounts/mfaEnrollment:withdraw\",N:[\"idToken\",\"mfaEnrollmentId\"],G:function(a){if(!!a[Dg]^!!a.refreshToken)throw new t(\"internal-error\");},B:!0,Na:!0};\nfunction O(a,b,c){if(!mf(c,b.N))return F(new t(\"internal-error\"));var d=!!b.Na,e=b.Ub||\"POST\",f;return E(c).then(b.A).then(function(){b.V&&(c.returnSecureToken=!0);b.B&&a.b&&\"undefined\"===typeof c.tenantId&&(c.tenantId=a.b);return d?Yi(a,a.i,b.endpoint,e,c,b.Hb,b.lb||!1):Yi(a,a.h,b.endpoint,e,c,b.Hb,b.lb||!1)}).then(function(g){f=g;return b.Ya?b.Ya(c,f):f}).then(b.G).then(function(){if(!b.Z)return f;if(!(b.Z in f))throw new t(\"internal-error\");return f[b.Z]})}\nfunction wj(a){return Xi({error:{errors:[{message:a}],code:400,message:a}})}\nfunction Xi(a,b){var c=(a.error&&a.error.errors&&a.error.errors[0]||{}).reason||\"\";var d={keyInvalid:\"invalid-api-key\",ipRefererBlocked:\"app-not-authorized\"};if(c=d[c]?new t(d[c]):null)return c;c=a.error&&a.error.message||\"\";d={INVALID_CUSTOM_TOKEN:\"invalid-custom-token\",CREDENTIAL_MISMATCH:\"custom-token-mismatch\",MISSING_CUSTOM_TOKEN:\"internal-error\",INVALID_IDENTIFIER:\"invalid-email\",MISSING_CONTINUE_URI:\"internal-error\",INVALID_EMAIL:\"invalid-email\",INVALID_PASSWORD:\"wrong-password\",USER_DISABLED:\"user-disabled\",\nMISSING_PASSWORD:\"internal-error\",EMAIL_EXISTS:\"email-already-in-use\",PASSWORD_LOGIN_DISABLED:\"operation-not-allowed\",INVALID_IDP_RESPONSE:\"invalid-credential\",INVALID_PENDING_TOKEN:\"invalid-credential\",FEDERATED_USER_ID_ALREADY_LINKED:\"credential-already-in-use\",MISSING_OR_INVALID_NONCE:\"missing-or-invalid-nonce\",INVALID_MESSAGE_PAYLOAD:\"invalid-message-payload\",INVALID_RECIPIENT_EMAIL:\"invalid-recipient-email\",INVALID_SENDER:\"invalid-sender\",EMAIL_NOT_FOUND:\"user-not-found\",RESET_PASSWORD_EXCEED_LIMIT:\"too-many-requests\",\nEXPIRED_OOB_CODE:\"expired-action-code\",INVALID_OOB_CODE:\"invalid-action-code\",MISSING_OOB_CODE:\"internal-error\",INVALID_PROVIDER_ID:\"invalid-provider-id\",CREDENTIAL_TOO_OLD_LOGIN_AGAIN:\"requires-recent-login\",INVALID_ID_TOKEN:\"invalid-user-token\",TOKEN_EXPIRED:\"user-token-expired\",USER_NOT_FOUND:\"user-token-expired\",CORS_UNSUPPORTED:\"cors-unsupported\",DYNAMIC_LINK_NOT_ACTIVATED:\"dynamic-link-not-activated\",INVALID_APP_ID:\"invalid-app-id\",TOO_MANY_ATTEMPTS_TRY_LATER:\"too-many-requests\",WEAK_PASSWORD:\"weak-password\",\nOPERATION_NOT_ALLOWED:\"operation-not-allowed\",USER_CANCELLED:\"user-cancelled\",CAPTCHA_CHECK_FAILED:\"captcha-check-failed\",INVALID_APP_CREDENTIAL:\"invalid-app-credential\",INVALID_CODE:\"invalid-verification-code\",INVALID_PHONE_NUMBER:\"invalid-phone-number\",INVALID_SESSION_INFO:\"invalid-verification-id\",INVALID_TEMPORARY_PROOF:\"invalid-credential\",MISSING_APP_CREDENTIAL:\"missing-app-credential\",MISSING_CODE:\"missing-verification-code\",MISSING_PHONE_NUMBER:\"missing-phone-number\",MISSING_SESSION_INFO:\"missing-verification-id\",\nQUOTA_EXCEEDED:\"quota-exceeded\",SESSION_EXPIRED:\"code-expired\",REJECTED_CREDENTIAL:\"rejected-credential\",INVALID_CONTINUE_URI:\"invalid-continue-uri\",MISSING_ANDROID_PACKAGE_NAME:\"missing-android-pkg-name\",MISSING_IOS_BUNDLE_ID:\"missing-ios-bundle-id\",UNAUTHORIZED_DOMAIN:\"unauthorized-continue-uri\",INVALID_DYNAMIC_LINK_DOMAIN:\"invalid-dynamic-link-domain\",INVALID_OAUTH_CLIENT_ID:\"invalid-oauth-client-id\",INVALID_CERT_HASH:\"invalid-cert-hash\",UNSUPPORTED_TENANT_OPERATION:\"unsupported-tenant-operation\",\nINVALID_TENANT_ID:\"invalid-tenant-id\",TENANT_ID_MISMATCH:\"tenant-id-mismatch\",ADMIN_ONLY_OPERATION:\"admin-restricted-operation\",INVALID_MFA_PENDING_CREDENTIAL:\"invalid-multi-factor-session\",MFA_ENROLLMENT_NOT_FOUND:\"multi-factor-info-not-found\",MISSING_MFA_PENDING_CREDENTIAL:\"missing-multi-factor-session\",MISSING_MFA_ENROLLMENT_ID:\"missing-multi-factor-info\",EMAIL_CHANGE_NEEDS_VERIFICATION:\"email-change-needs-verification\",SECOND_FACTOR_EXISTS:\"second-factor-already-in-use\",SECOND_FACTOR_LIMIT_EXCEEDED:\"maximum-second-factor-count-exceeded\",\nUNSUPPORTED_FIRST_FACTOR:\"unsupported-first-factor\",UNVERIFIED_EMAIL:\"unverified-email\"};z(d,b||{});b=(b=c.match(/^[^\\s]+\\s*:\\s*([\\s\\S]*)$/))&&1<b.length?b[1]:void 0;for(var e in d)if(0===c.indexOf(e))return new t(d[e],b);!b&&a&&(b=Ue(a));return new t(\"internal-error\",b)};function Mj(a){this.b=a;this.a=null;this.rb=Nj(this)}\nfunction Nj(a){return Oj().then(function(){return new D(function(b,c){L(\"gapi.iframes.getContext\")().open({where:document.body,url:a.b,messageHandlersFilter:L(\"gapi.iframes.CROSS_ORIGIN_IFRAMES_FILTER\"),attributes:{style:{position:\"absolute\",top:\"-100px\",width:\"1px\",height:\"1px\"}},dontclear:!0},function(d){function e(){clearTimeout(f);b()}a.a=d;a.a.restyle({setHideOnLeave:!1});var f=setTimeout(function(){c(Error(\"Network Error\"))},Pj.get());d.ping(e).then(e,function(){c(Error(\"Network Error\"))})})})})}\nfunction Qj(a,b){return a.rb.then(function(){return new D(function(c){a.a.send(b.type,b,c,L(\"gapi.iframes.CROSS_ORIGIN_IFRAMES_FILTER\"))})})}function Rj(a,b){a.rb.then(function(){a.a.register(\"authEvent\",b,L(\"gapi.iframes.CROSS_ORIGIN_IFRAMES_FILTER\"))})}var Sj=new qb(rb,\"https://apis.google.com/js/api.js?onload=%{onload}\"),Tj=new Ze(3E4,6E4),Pj=new Ze(5E3,15E3),Uj=null;\nfunction Oj(){return Uj?Uj:Uj=(new D(function(a,b){function c(){Ye();L(\"gapi.load\")(\"gapi.iframes\",{callback:a,ontimeout:function(){Ye();b(Error(\"Network Error\"))},timeout:Tj.get()})}if(L(\"gapi.iframes.Iframe\"))a();else if(L(\"gapi.load\"))c();else{var d=\"__iframefcb\"+Math.floor(1E6*Math.random()).toString();l[d]=function(){L(\"gapi.load\")?c():b(Error(\"Network Error\"))};d=zb(Sj,{onload:d});E(Bi(d)).o(function(){b(Error(\"Network Error\"))})}})).o(function(a){Uj=null;throw a;})};function Vj(a,b,c,d){this.l=a;this.h=b;this.i=c;this.g=d;this.f=null;this.g?(a=J(this.g.url),a=ce(a.c,a.a,a.g,\"/emulator/auth/iframe\")):a=ce(\"https\",this.l,null,\"/__/auth/iframe\");this.a=a;I(this.a,\"apiKey\",this.h);I(this.a,\"appName\",this.i);this.b=null;this.c=[]}Vj.prototype.toString=function(){this.f?I(this.a,\"v\",this.f):ie(this.a.b,\"v\");this.b?I(this.a,\"eid\",this.b):ie(this.a.b,\"eid\");this.c.length?I(this.a,\"fw\",this.c.join(\",\")):ie(this.a.b,\"fw\");return this.a.toString()};\nfunction Wj(a,b,c,d,e,f){this.u=a;this.s=b;this.c=c;this.m=d;this.v=f;this.i=this.g=this.l=null;this.a=e;this.h=this.f=null}Wj.prototype.yb=function(a){this.h=a;return this};\nWj.prototype.toString=function(){if(this.v){var a=J(this.v.url);a=ce(a.c,a.a,a.g,\"/emulator/auth/handler\")}else a=ce(\"https\",this.u,null,\"/__/auth/handler\");I(a,\"apiKey\",this.s);I(a,\"appName\",this.c);I(a,\"authType\",this.m);if(this.a.isOAuthProvider){var b=this.a;try{var c=firebase.app(this.c).auth().la()}catch(h){c=null}b.ob=c;I(a,\"providerId\",this.a.providerId);c=this.a;b=Ve(c.Ib);for(var d in b)b[d]=b[d].toString();d=c.Qc;b=nb(b);for(var e=0;e<d.length;e++){var f=d[e];f in b&&delete b[f]}c.pb&&\nc.ob&&!b[c.pb]&&(b[c.pb]=c.ob);mb(b)||I(a,\"customParameters\",Ue(b))}\"function\"===typeof this.a.Qb&&(c=this.a.Qb(),c.length&&I(a,\"scopes\",c.join(\",\")));this.l?I(a,\"redirectUrl\",this.l):ie(a.b,\"redirectUrl\");this.g?I(a,\"eventId\",this.g):ie(a.b,\"eventId\");this.i?I(a,\"v\",this.i):ie(a.b,\"v\");if(this.b)for(var g in this.b)this.b.hasOwnProperty(g)&&!be(a,g)&&I(a,g,this.b[g]);this.h?I(a,\"tid\",this.h):ie(a.b,\"tid\");this.f?I(a,\"eid\",this.f):ie(a.b,\"eid\");g=Xj(this.c);g.length&&I(a,\"fw\",g.join(\",\"));return a.toString()};\nfunction Xj(a){try{return firebase.app(a).auth().Ga()}catch(b){return[]}}function Yj(a,b,c,d,e,f){this.s=a;this.g=b;this.b=c;this.f=f;this.c=d||null;this.i=e||null;this.l=this.u=this.C=null;this.h=[];this.m=this.a=null}\nfunction Zj(a){var b=re();return cj(a).then(function(c){a:{var d=J(b),e=d.c;d=d.a;for(var f=0;f<c.length;f++){var g=c[f];var h=d;var m=e;0==g.indexOf(\"chrome-extension://\")?h=J(g).a==h&&\"chrome-extension\"==m:\"http\"!=m&&\"https\"!=m?h=!1:Ce.test(g)?h=h==g:(g=g.split(\".\").join(\"\\\\.\"),h=(new RegExp(\"^(.+\\\\.\"+g+\"|\"+g+\")$\",\"i\")).test(h));if(h){c=!0;break a}}c=!1}if(!c)throw new xh(re());})}\nfunction ak(a){if(a.m)return a.m;a.m=Ee().then(function(){if(!a.u){var b=a.c,c=a.i,d=Xj(a.b),e=new Vj(a.s,a.g,a.b,a.f);e.f=b;e.b=c;e.c=Za(d||[]);a.u=e.toString()}a.v=new Mj(a.u);bk(a)});return a.m}k=Yj.prototype;k.Ob=function(a,b,c){var d=new t(\"popup-closed-by-user\"),e=new t(\"web-storage-unsupported\"),f=this,g=!1;return this.ma().then(function(){ck(f).then(function(h){h||(a&&ye(a),b(e),g=!0)})}).o(function(){}).then(function(){if(!g)return Be(a)}).then(function(){if(!g)return Fd(c).then(function(){b(d)})})};\nk.Xb=function(){var a=K();return!Te(a)&&!Xe(a)};k.Tb=function(){return!1};\nk.Mb=function(a,b,c,d,e,f,g,h){if(!a)return F(new t(\"popup-blocked\"));if(g&&!Te())return this.ma().o(function(p){ye(a);e(p)}),d(),E();this.a||(this.a=Zj(dk(this)));var m=this;return this.a.then(function(){var p=m.ma().o(function(v){ye(a);e(v);throw v;});d();return p}).then(function(){rh(c);if(!g){var p=ek(m.s,m.g,m.b,b,c,null,f,m.c,void 0,m.i,h,m.f);se(p,a)}}).o(function(p){\"auth/network-request-failed\"==p.code&&(m.a=null);throw p;})};\nfunction dk(a){a.l||(a.C=a.c?Oe(a.c,Xj(a.b)):null,a.l=new Ii(a.g,Ca(a.i),a.C),a.f&&Pi(a.l,a.f));return a.l}k.Nb=function(a,b,c,d){this.a||(this.a=Zj(dk(this)));var e=this;return this.a.then(function(){rh(b);var f=ek(e.s,e.g,e.b,a,b,re(),c,e.c,void 0,e.i,d,e.f);se(f)}).o(function(f){\"auth/network-request-failed\"==f.code&&(e.a=null);throw f;})};k.ma=function(){var a=this;return ak(this).then(function(){return a.v.rb}).o(function(){a.a=null;throw new t(\"network-request-failed\");})};k.$b=function(){return!0};\nfunction ek(a,b,c,d,e,f,g,h,m,p,v,B){a=new Wj(a,b,c,d,e,B);a.l=f;a.g=g;a.i=h;a.b=nb(m||null);a.f=p;return a.yb(v).toString()}function bk(a){if(!a.v)throw Error(\"IfcHandler must be initialized!\");Rj(a.v,function(b){var c={};if(b&&b.authEvent){var d=!1;b=th(b.authEvent);for(c=0;c<a.h.length;c++)d=a.h[c](b)||d;c={};c.status=d?\"ACK\":\"ERROR\";return E(c)}c.status=\"ERROR\";return E(c)})}\nfunction ck(a){var b={type:\"webStorageSupport\"};return ak(a).then(function(){return Qj(a.v,b)}).then(function(c){if(c&&c.length&&\"undefined\"!==typeof c[0].webStorageSupport)return c[0].webStorageSupport;throw Error();})}k.Ea=function(a){this.h.push(a)};k.Sa=function(a){Xa(this.h,function(b){return b==a})};function fk(a){this.a=a||firebase.INTERNAL.reactNative&&firebase.INTERNAL.reactNative.AsyncStorage;if(!this.a)throw new t(\"internal-error\",\"The React Native compatibility library was not found.\");this.type=\"asyncStorage\"}k=fk.prototype;k.get=function(a){return E(this.a.getItem(a)).then(function(b){return b&&We(b)})};k.set=function(a,b){return E(this.a.setItem(a,Ue(b)))};k.U=function(a){return E(this.a.removeItem(a))};k.ca=function(){};k.ia=function(){};function gk(a){this.b=a;this.a={};this.f=q(this.c,this)}var hk=[];function ik(){var a=Je()?self:null;w(hk,function(c){c.b==a&&(b=c)});if(!b){var b=new gk(a);hk.push(b)}return b}\ngk.prototype.c=function(a){var b=a.data.eventType,c=a.data.eventId,d=this.a[b];if(d&&0<d.length){a.ports[0].postMessage({status:\"ack\",eventId:c,eventType:b,response:null});var e=[];w(d,function(f){e.push(E().then(function(){return f(a.origin,a.data.data)}))});Jc(e).then(function(f){var g=[];w(f,function(h){g.push({fulfilled:h.Pb,value:h.value,reason:h.reason?h.reason.message:void 0})});w(g,function(h){for(var m in h)\"undefined\"===typeof h[m]&&delete h[m]});a.ports[0].postMessage({status:\"done\",eventId:c,\neventType:b,response:g})})}};function jk(a,b,c){mb(a.a)&&a.b.addEventListener(\"message\",a.f);\"undefined\"===typeof a.a[b]&&(a.a[b]=[]);a.a[b].push(c)};function kk(a){this.a=a}kk.prototype.postMessage=function(a,b){this.a.postMessage(a,b)};function lk(a){this.c=a;this.b=!1;this.a=[]}\nfunction mk(a,b,c,d){var e,f=c||{},g,h,m,p=null;if(a.b)return F(Error(\"connection_unavailable\"));var v=d?800:50,B=\"undefined\"!==typeof MessageChannel?new MessageChannel:null;return(new D(function(A,Q){B?(e=Math.floor(Math.random()*Math.pow(10,20)).toString(),B.port1.start(),h=setTimeout(function(){Q(Error(\"unsupported_event\"))},v),g=function(ya){ya.data.eventId===e&&(\"ack\"===ya.data.status?(clearTimeout(h),m=setTimeout(function(){Q(Error(\"timeout\"))},3E3)):\"done\"===ya.data.status?(clearTimeout(m),\n\"undefined\"!==typeof ya.data.response?A(ya.data.response):Q(Error(\"unknown_error\"))):(clearTimeout(h),clearTimeout(m),Q(Error(\"invalid_response\"))))},p={messageChannel:B,onMessage:g},a.a.push(p),B.port1.addEventListener(\"message\",g),a.c.postMessage({eventType:b,eventId:e,data:f},[B.port2])):Q(Error(\"connection_unavailable\"))})).then(function(A){nk(a,p);return A}).o(function(A){nk(a,p);throw A;})}\nfunction nk(a,b){if(b){var c=b.messageChannel,d=b.onMessage;c&&(c.port1.removeEventListener(\"message\",d),c.port1.close());Xa(a.a,function(e){return e==b})}}lk.prototype.close=function(){for(;0<this.a.length;)nk(this,this.a[0]);this.b=!0};function ok(){if(!pk())throw new t(\"web-storage-unsupported\");this.c={};this.a=[];this.b=0;this.m=l.indexedDB;this.type=\"indexedDB\";this.g=this.v=this.f=this.l=null;this.s=!1;this.h=null;var a=this;Je()&&self?(this.v=ik(),jk(this.v,\"keyChanged\",function(b,c){return qk(a).then(function(d){0<d.length&&w(a.a,function(e){e(d)});return{keyProcessed:Va(d,c.key)}})}),jk(this.v,\"ping\",function(){return E([\"keyChanged\"])})):ef().then(function(b){if(a.h=b)a.g=new lk(new kk(b)),mk(a.g,\"ping\",null,!0).then(function(c){c[0].fulfilled&&\nVa(c[0].value,\"keyChanged\")&&(a.s=!0)}).o(function(){})})}var rk;function sk(a){return new D(function(b,c){var d=a.m.deleteDatabase(\"firebaseLocalStorageDb\");d.onsuccess=function(){b()};d.onerror=function(e){c(Error(e.target.error))}})}\nfunction tk(a){return new D(function(b,c){var d=a.m.open(\"firebaseLocalStorageDb\",1);d.onerror=function(e){try{e.preventDefault()}catch(f){}c(Error(e.target.error))};d.onupgradeneeded=function(e){e=e.target.result;try{e.createObjectStore(\"firebaseLocalStorage\",{keyPath:\"fbase_key\"})}catch(f){c(f)}};d.onsuccess=function(e){e=e.target.result;e.objectStoreNames.contains(\"firebaseLocalStorage\")?b(e):sk(a).then(function(){return tk(a)}).then(function(f){b(f)}).o(function(f){c(f)})}})}\nfunction uk(a){a.i||(a.i=tk(a));return a.i}function vk(a,b){function c(e,f){uk(a).then(b).then(e).o(function(g){if(3<++d)f(g);else return uk(a).then(function(h){h.close();a.i=void 0;return c(e,f)}).o(function(h){f(h)})})}var d=0;return new D(c)}function pk(){try{return!!l.indexedDB}catch(a){return!1}}function wk(a){return a.objectStore(\"firebaseLocalStorage\")}function xk(a,b){return a.transaction([\"firebaseLocalStorage\"],b?\"readwrite\":\"readonly\")}\nfunction yk(a){return new D(function(b,c){a.onsuccess=function(d){d&&d.target?b(d.target.result):b()};a.onerror=function(d){c(d.target.error)}})}k=ok.prototype;k.set=function(a,b){var c=this,d=!1;return vk(this,function(e){e=wk(xk(e,!0));return yk(e.get(a))}).then(function(e){return vk(c,function(f){f=wk(xk(f,!0));if(e)return e.value=b,yk(f.put(e));c.b++;d=!0;var g={};g.fbase_key=a;g.value=b;return yk(f.add(g))})}).then(function(){c.c[a]=b;return zk(c,a)}).oa(function(){d&&c.b--})};\nfunction zk(a,b){return a.g&&a.h&&df()===a.h?mk(a.g,\"keyChanged\",{key:b},a.s).then(function(){}).o(function(){}):E()}k.get=function(a){return vk(this,function(b){return yk(wk(xk(b,!1)).get(a))}).then(function(b){return b&&b.value})};k.U=function(a){var b=this,c=!1;return vk(this,function(d){c=!0;b.b++;return yk(wk(xk(d,!0))[\"delete\"](a))}).then(function(){delete b.c[a];return zk(b,a)}).oa(function(){c&&b.b--})};\nfunction qk(a){return uk(a).then(function(b){var c=wk(xk(b,!1));return c.getAll?yk(c.getAll()):new D(function(d,e){var f=[],g=c.openCursor();g.onsuccess=function(h){(h=h.target.result)?(f.push(h.value),h[\"continue\"]()):d(f)};g.onerror=function(h){e(h.target.error)}})}).then(function(b){var c={},d=[];if(0==a.b){for(d=0;d<b.length;d++)c[b[d].fbase_key]=b[d].value;d=te(a.c,c);a.c=c}return d})}k.ca=function(a){0==this.a.length&&Ak(this);this.a.push(a)};\nk.ia=function(a){Xa(this.a,function(b){return b==a});0==this.a.length&&Bk(this)};function Ak(a){function b(){a.f=setTimeout(function(){a.l=qk(a).then(function(c){0<c.length&&w(a.a,function(d){d(c)})}).then(function(){b()}).o(function(c){\"STOP_EVENT\"!=c.message&&b()})},800)}Bk(a);b()}function Bk(a){a.l&&a.l.cancel(\"STOP_EVENT\");a.f&&(clearTimeout(a.f),a.f=null)};function Ck(a){var b=this,c=null;this.a=[];this.type=\"indexedDB\";this.c=a;this.b=E().then(function(){if(pk()){var d=Qe(),e=\"__sak\"+d;rk||(rk=new ok);c=rk;return c.set(e,d).then(function(){return c.get(e)}).then(function(f){if(f!==d)throw Error(\"indexedDB not supported!\");return c.U(e)}).then(function(){return c}).o(function(){return b.c})}return b.c}).then(function(d){b.type=d.type;d.ca(function(e){w(b.a,function(f){f(e)})});return d})}k=Ck.prototype;k.get=function(a){return this.b.then(function(b){return b.get(a)})};\nk.set=function(a,b){return this.b.then(function(c){return c.set(a,b)})};k.U=function(a){return this.b.then(function(b){return b.U(a)})};k.ca=function(a){this.a.push(a)};k.ia=function(a){Xa(this.a,function(b){return b==a})};function Dk(){this.a={};this.type=\"inMemory\"}k=Dk.prototype;k.get=function(a){return E(this.a[a])};k.set=function(a,b){this.a[a]=b;return E()};k.U=function(a){delete this.a[a];return E()};k.ca=function(){};k.ia=function(){};function Ek(){if(!Fk()){if(\"Node\"==Ke())throw new t(\"internal-error\",\"The LocalStorage compatibility library was not found.\");throw new t(\"web-storage-unsupported\");}this.a=Gk()||firebase.INTERNAL.node.localStorage;this.type=\"localStorage\"}function Gk(){try{var a=l.localStorage,b=Qe();a&&(a.setItem(b,\"1\"),a.removeItem(b));return a}catch(c){return null}}\nfunction Fk(){var a=\"Node\"==Ke();a=Gk()||a&&firebase.INTERNAL.node&&firebase.INTERNAL.node.localStorage;if(!a)return!1;try{return a.setItem(\"__sak\",\"1\"),a.removeItem(\"__sak\"),!0}catch(b){return!1}}k=Ek.prototype;k.get=function(a){var b=this;return E().then(function(){var c=b.a.getItem(a);return We(c)})};k.set=function(a,b){var c=this;return E().then(function(){var d=Ue(b);null===d?c.U(a):c.a.setItem(a,d)})};k.U=function(a){var b=this;return E().then(function(){b.a.removeItem(a)})};\nk.ca=function(a){l.window&&nd(l.window,\"storage\",a)};k.ia=function(a){l.window&&xd(l.window,\"storage\",a)};function Hk(){this.type=\"nullStorage\"}k=Hk.prototype;k.get=function(){return E(null)};k.set=function(){return E()};k.U=function(){return E()};k.ca=function(){};k.ia=function(){};function Ik(){if(!Jk()){if(\"Node\"==Ke())throw new t(\"internal-error\",\"The SessionStorage compatibility library was not found.\");throw new t(\"web-storage-unsupported\");}this.a=Kk()||firebase.INTERNAL.node.sessionStorage;this.type=\"sessionStorage\"}function Kk(){try{var a=l.sessionStorage,b=Qe();a&&(a.setItem(b,\"1\"),a.removeItem(b));return a}catch(c){return null}}\nfunction Jk(){var a=\"Node\"==Ke();a=Kk()||a&&firebase.INTERNAL.node&&firebase.INTERNAL.node.sessionStorage;if(!a)return!1;try{return a.setItem(\"__sak\",\"1\"),a.removeItem(\"__sak\"),!0}catch(b){return!1}}k=Ik.prototype;k.get=function(a){var b=this;return E().then(function(){var c=b.a.getItem(a);return We(c)})};k.set=function(a,b){var c=this;return E().then(function(){var d=Ue(b);null===d?c.U(a):c.a.setItem(a,d)})};k.U=function(a){var b=this;return E().then(function(){b.a.removeItem(a)})};k.ca=function(){};\nk.ia=function(){};function Lk(){var a={};a.Browser=Mk;a.Node=Nk;a.ReactNative=Ok;a.Worker=Pk;this.a=a[Ke()]}var Qk,Mk={F:Ek,bb:Ik},Nk={F:Ek,bb:Ik},Ok={F:fk,bb:Hk},Pk={F:Ek,bb:Hk};var Rk={rd:\"local\",NONE:\"none\",td:\"session\"};function Sk(a){var b=new t(\"invalid-persistence-type\"),c=new t(\"unsupported-persistence-type\");a:{for(d in Rk)if(Rk[d]==a){var d=!0;break a}d=!1}if(!d||\"string\"!==typeof a)throw b;switch(Ke()){case \"ReactNative\":if(\"session\"===a)throw c;break;case \"Node\":if(\"none\"!==a)throw c;break;case \"Worker\":if(\"session\"===a||!pk()&&\"none\"!==a)throw c;break;default:if(!Pe()&&\"none\"!==a)throw c;}}\nfunction Tk(){var a=!Xe(K())&&Ie()?!0:!1,b=Te(),c=Pe();this.m=a;this.h=b;this.l=c;this.a={};Qk||(Qk=new Lk);a=Qk;try{this.g=!qe()&&cf()||!l.indexedDB?new a.a.F:new Ck(Je()?new Dk:new a.a.F)}catch(d){this.g=new Dk,this.h=!0}try{this.i=new a.a.bb}catch(d){this.i=new Dk}this.v=new Dk;this.f=q(this.Yb,this);this.b={}}var Uk;function Vk(){Uk||(Uk=new Tk);return Uk}function Wk(a,b){switch(b){case \"session\":return a.i;case \"none\":return a.v;default:return a.g}}\nfunction Xk(a,b){return\"firebase:\"+a.name+(b?\":\"+b:\"\")}function Yk(a,b,c){var d=Xk(b,c),e=Wk(a,b.F);return a.get(b,c).then(function(f){var g=null;try{g=We(l.localStorage.getItem(d))}catch(h){}if(g&&!f)return l.localStorage.removeItem(d),a.set(b,g,c);g&&f&&\"localStorage\"!=e.type&&l.localStorage.removeItem(d)})}k=Tk.prototype;k.get=function(a,b){return Wk(this,a.F).get(Xk(a,b))};function Zk(a,b,c){c=Xk(b,c);\"local\"==b.F&&(a.b[c]=null);return Wk(a,b.F).U(c)}\nk.set=function(a,b,c){var d=Xk(a,c),e=this,f=Wk(this,a.F);return f.set(d,b).then(function(){return f.get(d)}).then(function(g){\"local\"==a.F&&(e.b[d]=g)})};k.addListener=function(a,b,c){a=Xk(a,b);this.l&&(this.b[a]=l.localStorage.getItem(a));mb(this.a)&&(Wk(this,\"local\").ca(this.f),this.h||(qe()||!cf())&&l.indexedDB||!this.l||$k(this));this.a[a]||(this.a[a]=[]);this.a[a].push(c)};\nk.removeListener=function(a,b,c){a=Xk(a,b);this.a[a]&&(Xa(this.a[a],function(d){return d==c}),0==this.a[a].length&&delete this.a[a]);mb(this.a)&&(Wk(this,\"local\").ia(this.f),al(this))};function $k(a){al(a);a.c=setInterval(function(){for(var b in a.a){var c=l.localStorage.getItem(b),d=a.b[b];c!=d&&(a.b[b]=c,c=new bd({type:\"storage\",key:b,target:window,oldValue:d,newValue:c,a:!0}),a.Yb(c))}},1E3)}function al(a){a.c&&(clearInterval(a.c),a.c=null)}\nk.Yb=function(a){if(a&&a.g){var b=a.a.key;if(null==b)for(var c in this.a){var d=this.b[c];\"undefined\"===typeof d&&(d=null);var e=l.localStorage.getItem(c);e!==d&&(this.b[c]=e,this.mb(c))}else if(0==b.indexOf(\"firebase:\")&&this.a[b]){\"undefined\"!==typeof a.a.a?Wk(this,\"local\").ia(this.f):al(this);if(this.m)if(c=l.localStorage.getItem(b),d=a.a.newValue,d!==c)null!==d?l.localStorage.setItem(b,d):l.localStorage.removeItem(b);else if(this.b[b]===d&&\"undefined\"===typeof a.a.a)return;var f=this;c=function(){if(\"undefined\"!==\ntypeof a.a.a||f.b[b]!==l.localStorage.getItem(b))f.b[b]=l.localStorage.getItem(b),f.mb(b)};Wb&&ic&&10==ic&&l.localStorage.getItem(b)!==a.a.newValue&&a.a.newValue!==a.a.oldValue?setTimeout(c,10):c()}}else w(a,q(this.mb,this))};k.mb=function(a){this.a[a]&&w(this.a[a],function(b){b()})};function bl(a){this.a=a;this.b=Vk()}var cl={name:\"authEvent\",F:\"local\"};function dl(a){return a.b.get(cl,a.a).then(function(b){return th(b)})};function el(){this.a=Vk()};function fl(){this.b=-1};function gl(a,b){this.b=hl;this.f=l.Uint8Array?new Uint8Array(this.b):Array(this.b);this.g=this.c=0;this.a=[];this.i=a;this.h=b;this.l=l.Int32Array?new Int32Array(64):Array(64);void 0===il&&(l.Int32Array?il=new Int32Array(jl):il=jl);this.reset()}var il;r(gl,fl);for(var hl=64,kl=hl-1,ll=[],ml=0;ml<kl;ml++)ll[ml]=0;var nl=Ya(128,ll);gl.prototype.reset=function(){this.g=this.c=0;this.a=l.Int32Array?new Int32Array(this.h):Za(this.h)};\nfunction ol(a){for(var b=a.f,c=a.l,d=0,e=0;e<b.length;)c[d++]=b[e]<<24|b[e+1]<<16|b[e+2]<<8|b[e+3],e=4*d;for(b=16;64>b;b++){e=c[b-15]|0;d=c[b-2]|0;var f=(c[b-16]|0)+((e>>>7|e<<25)^(e>>>18|e<<14)^e>>>3)|0,g=(c[b-7]|0)+((d>>>17|d<<15)^(d>>>19|d<<13)^d>>>10)|0;c[b]=f+g|0}d=a.a[0]|0;e=a.a[1]|0;var h=a.a[2]|0,m=a.a[3]|0,p=a.a[4]|0,v=a.a[5]|0,B=a.a[6]|0;f=a.a[7]|0;for(b=0;64>b;b++){var A=((d>>>2|d<<30)^(d>>>13|d<<19)^(d>>>22|d<<10))+(d&e^d&h^e&h)|0;g=p&v^~p&B;f=f+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<\n7))|0;g=g+(il[b]|0)|0;g=f+(g+(c[b]|0)|0)|0;f=B;B=v;v=p;p=m+g|0;m=h;h=e;e=d;d=g+A|0}a.a[0]=a.a[0]+d|0;a.a[1]=a.a[1]+e|0;a.a[2]=a.a[2]+h|0;a.a[3]=a.a[3]+m|0;a.a[4]=a.a[4]+p|0;a.a[5]=a.a[5]+v|0;a.a[6]=a.a[6]+B|0;a.a[7]=a.a[7]+f|0}\nfunction pl(a,b,c){void 0===c&&(c=b.length);var d=0,e=a.c;if(\"string\"===typeof b)for(;d<c;)a.f[e++]=b.charCodeAt(d++),e==a.b&&(ol(a),e=0);else if(na(b))for(;d<c;){var f=b[d++];if(!(\"number\"==typeof f&&0<=f&&255>=f&&f==(f|0)))throw Error(\"message must be a byte array\");a.f[e++]=f;e==a.b&&(ol(a),e=0)}else throw Error(\"message must be string or array\");a.c=e;a.g+=c}\nvar jl=[1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,\n4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298];function ql(){gl.call(this,8,rl)}r(ql,gl);var rl=[1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225];function sl(a,b,c,d,e,f){this.v=a;this.i=b;this.l=c;this.m=d||null;this.u=e||null;this.s=f;this.h=b+\":\"+c;this.C=new el;this.g=new bl(this.h);this.f=null;this.b=[];this.a=this.c=null}function tl(a){return new t(\"invalid-cordova-configuration\",a)}k=sl.prototype;\nk.ma=function(){return this.Ia?this.Ia:this.Ia=Fe().then(function(){if(\"function\"!==typeof L(\"universalLinks.subscribe\",l))throw tl(\"cordova-universal-links-plugin-fix is not installed\");if(\"undefined\"===typeof L(\"BuildInfo.packageName\",l))throw tl(\"cordova-plugin-buildinfo is not installed\");if(\"function\"!==typeof L(\"cordova.plugins.browsertab.openUrl\",l))throw tl(\"cordova-plugin-browsertab is not installed\");if(\"function\"!==typeof L(\"cordova.InAppBrowser.open\",l))throw tl(\"cordova-plugin-inappbrowser is not installed\");\n},function(){throw new t(\"cordova-not-ready\");})};function ul(){for(var a=20,b=[];0<a;)b.push(\"1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ\".charAt(Math.floor(62*Math.random()))),a--;return b.join(\"\")}function vl(a){var b=new ql;pl(b,a);a=[];var c=8*b.g;56>b.c?pl(b,nl,56-b.c):pl(b,nl,b.b-(b.c-56));for(var d=63;56<=d;d--)b.f[d]=c&255,c/=256;ol(b);for(d=c=0;d<b.i;d++)for(var e=24;0<=e;e-=8)a[c++]=b.a[d]>>e&255;return cg(a)}\nk.Ob=function(a,b){b(new t(\"operation-not-supported-in-this-environment\"));return E()};k.Mb=function(){return F(new t(\"operation-not-supported-in-this-environment\"))};k.$b=function(){return!1};k.Xb=function(){return!0};k.Tb=function(){return!0};\nk.Nb=function(a,b,c,d){if(this.c)return F(new t(\"redirect-operation-pending\"));var e=this,f=l.document,g=null,h=null,m=null,p=null;return this.c=E().then(function(){rh(b);return wl(e)}).then(function(){return xl(e,a,b,c,d)}).then(function(){return(new D(function(v,B){h=function(){var A=L(\"cordova.plugins.browsertab.close\",l);v();\"function\"===typeof A&&A();e.a&&\"function\"===typeof e.a.close&&(e.a.close(),e.a=null);return!1};e.Ea(h);m=function(){g||(g=Fd(2E3).then(function(){B(new t(\"redirect-cancelled-by-user\"))}))};\np=function(){$e()&&m()};f.addEventListener(\"resume\",m,!1);K().toLowerCase().match(/android/)||f.addEventListener(\"visibilitychange\",p,!1)})).o(function(v){return yl(e).then(function(){throw v;})})}).oa(function(){m&&f.removeEventListener(\"resume\",m,!1);p&&f.removeEventListener(\"visibilitychange\",p,!1);g&&g.cancel();h&&e.Sa(h);e.c=null})};\nfunction xl(a,b,c,d,e){var f=ul(),g=new sh(b,d,null,f,new t(\"no-auth-event\"),null,e),h=L(\"BuildInfo.packageName\",l);if(\"string\"!==typeof h)throw new t(\"invalid-cordova-configuration\");var m=L(\"BuildInfo.displayName\",l),p={};if(K().toLowerCase().match(/iphone|ipad|ipod/))p.ibi=h;else if(K().toLowerCase().match(/android/))p.apn=h;else return F(new t(\"operation-not-supported-in-this-environment\"));m&&(p.appDisplayName=m);f=vl(f);p.sessionId=f;var v=ek(a.v,a.i,a.l,b,c,null,d,a.m,p,a.u,e,a.s);return a.ma().then(function(){var B=\na.h;return a.C.a.set(cl,g.w(),B)}).then(function(){var B=L(\"cordova.plugins.browsertab.isAvailable\",l);if(\"function\"!==typeof B)throw new t(\"invalid-cordova-configuration\");var A=null;B(function(Q){if(Q){A=L(\"cordova.plugins.browsertab.openUrl\",l);if(\"function\"!==typeof A)throw new t(\"invalid-cordova-configuration\");A(v)}else{A=L(\"cordova.InAppBrowser.open\",l);if(\"function\"!==typeof A)throw new t(\"invalid-cordova-configuration\");Q=K();a.a=A(v,Q.match(/(iPad|iPhone|iPod).*OS 7_\\d/i)||Q.match(/(iPad|iPhone|iPod).*OS 8_\\d/i)?\n\"_blank\":\"_system\",\"location=yes\")}})})}function zl(a,b){for(var c=0;c<a.b.length;c++)try{a.b[c](b)}catch(d){}}function wl(a){a.f||(a.f=a.ma().then(function(){return new D(function(b){function c(d){b(d);a.Sa(c);return!1}a.Ea(c);Al(a)})}));return a.f}function yl(a){var b=null;return dl(a.g).then(function(c){b=c;c=a.g;return Zk(c.b,cl,c.a)}).then(function(){return b})}\nfunction Al(a){function b(g){d=!0;e&&e.cancel();yl(a).then(function(h){var m=c;if(h&&g&&g.url){var p=null;m=xg(g.url);-1!=m.indexOf(\"/__/auth/callback\")&&(p=J(m),p=We(be(p,\"firebaseError\")||null),p=(p=\"object\"===typeof p?Aa(p):null)?new sh(h.c,h.b,null,null,p,null,h.T()):new sh(h.c,h.b,m,h.f,null,null,h.T()));m=p||c}zl(a,m)})}var c=new sh(\"unknown\",null,null,null,new t(\"no-auth-event\")),d=!1,e=Fd(500).then(function(){return yl(a).then(function(){d||zl(a,c)})}),f=l.handleOpenURL;l.handleOpenURL=function(g){0==\ng.toLowerCase().indexOf(L(\"BuildInfo.packageName\",l).toLowerCase()+\"://\")&&b({url:g});if(\"function\"===typeof f)try{f(g)}catch(h){console.error(h)}};vh||(vh=new uh);wh(b)}k.Ea=function(a){this.b.push(a);wl(this).o(function(b){\"auth/invalid-cordova-configuration\"===b.code&&(b=new sh(\"unknown\",null,null,null,new t(\"no-auth-event\")),a(b))})};k.Sa=function(a){Xa(this.b,function(b){return b==a})};function Bl(a){this.a=a;this.b=Vk()}var Cl={name:\"pendingRedirect\",F:\"session\"};function Dl(a){return a.b.set(Cl,\"pending\",a.a)}function El(a){return Zk(a.b,Cl,a.a)}function Fl(a){return a.b.get(Cl,a.a).then(function(b){return\"pending\"==b})};function Gl(a,b,c,d){this.i={};this.u=0;this.D=a;this.v=b;this.m=c;this.J=d;this.h=[];this.f=!1;this.l=q(this.s,this);this.b=new Hl;this.C=new Il;this.g=new Bl(Jl(this.v,this.m));this.c={};this.c.unknown=this.b;this.c.signInViaRedirect=this.b;this.c.linkViaRedirect=this.b;this.c.reauthViaRedirect=this.b;this.c.signInViaPopup=this.C;this.c.linkViaPopup=this.C;this.c.reauthViaPopup=this.C;this.a=Kl(this.D,this.v,this.m,Da,this.J)}\nfunction Kl(a,b,c,d,e){var f=firebase.SDK_VERSION||null;return Ge()?new sl(a,b,c,f,d,e):new Yj(a,b,c,f,d,e)}Gl.prototype.reset=function(){this.f=!1;this.a.Sa(this.l);this.a=Kl(this.D,this.v,this.m,null,this.J);this.i={}};function Ll(a){a.f||(a.f=!0,a.a.Ea(a.l));var b=a.a;return a.a.ma().o(function(c){a.a==b&&a.reset();throw c;})}\nfunction Ml(a){a.a.Xb()&&Ll(a).o(function(b){var c=new sh(\"unknown\",null,null,null,new t(\"operation-not-supported-in-this-environment\"));Nl(b)&&a.s(c)});a.a.Tb()||Ol(a.b)}function Pl(a,b){Va(a.h,b)||a.h.push(b);a.f||Fl(a.g).then(function(c){c?El(a.g).then(function(){Ll(a).o(function(d){var e=new sh(\"unknown\",null,null,null,new t(\"operation-not-supported-in-this-environment\"));Nl(d)&&a.s(e)})}):Ml(a)}).o(function(){Ml(a)})}function Ql(a,b){Xa(a.h,function(c){return c==b})}\nGl.prototype.s=function(a){if(!a)throw new t(\"invalid-auth-event\");6E5<=va()-this.u&&(this.i={},this.u=0);if(a&&a.getUid()&&this.i.hasOwnProperty(a.getUid()))return!1;for(var b=!1,c=0;c<this.h.length;c++){var d=this.h[c];if(d.Fb(a.c,a.b)){if(b=this.c[a.c])b.h(a,d),a&&(a.f||a.b)&&(this.i[a.getUid()]=!0,this.u=va());b=!0;break}}Ol(this.b);return b};var Rl=new Ze(2E3,1E4),Sl=new Ze(3E4,6E4);Gl.prototype.qa=function(){return this.b.qa()};\nfunction Tl(a,b,c,d,e,f,g){return a.a.Mb(b,c,d,function(){a.f||(a.f=!0,a.a.Ea(a.l))},function(){a.reset()},e,f,g)}function Nl(a){return a&&\"auth/cordova-not-ready\"==a.code?!0:!1}\nfunction Ul(a,b,c,d,e){var f;return Dl(a.g).then(function(){return a.a.Nb(b,c,d,e).o(function(g){if(Nl(g))throw new t(\"operation-not-supported-in-this-environment\");f=g;return El(a.g).then(function(){throw f;})}).then(function(){return a.a.$b()?new D(function(){}):El(a.g).then(function(){return a.qa()}).then(function(){}).o(function(){})})})}function Vl(a,b,c,d,e){return a.a.Ob(d,function(f){b.na(c,null,f,e)},Rl.get())}var Wl={};function Jl(a,b,c){a=a+\":\"+b;c&&(a=a+\":\"+c.url);return a}\nfunction Xl(a,b,c,d){var e=Jl(b,c,d);Wl[e]||(Wl[e]=new Gl(a,b,c,d));return Wl[e]}function Hl(){this.b=null;this.f=[];this.c=[];this.a=null;this.i=this.g=!1}Hl.prototype.reset=function(){this.b=null;this.a&&(this.a.cancel(),this.a=null)};\nHl.prototype.h=function(a,b){if(a){this.reset();this.g=!0;var c=a.c,d=a.b,e=a.a&&\"auth/web-storage-unsupported\"==a.a.code,f=a.a&&\"auth/operation-not-supported-in-this-environment\"==a.a.code;this.i=!(!e&&!f);\"unknown\"!=c||e||f?a.a?(Yl(this,!0,null,a.a),E()):b.Fa(c,d)?Zl(this,a,b):F(new t(\"invalid-auth-event\")):(Yl(this,!1,null,null),E())}else F(new t(\"invalid-auth-event\"))};function Ol(a){a.g||(a.g=!0,Yl(a,!1,null,null))}function $l(a){a.g&&!a.i&&Yl(a,!1,null,null)}\nfunction Zl(a,b,c){c=c.Fa(b.c,b.b);var d=b.g,e=b.f,f=b.i,g=b.T(),h=!!b.c.match(/Redirect$/);c(d,e,g,f).then(function(m){Yl(a,h,m,null)}).o(function(m){Yl(a,h,null,m)})}function am(a,b){a.b=function(){return F(b)};if(a.c.length)for(var c=0;c<a.c.length;c++)a.c[c](b)}function bm(a,b){a.b=function(){return E(b)};if(a.f.length)for(var c=0;c<a.f.length;c++)a.f[c](b)}function Yl(a,b,c,d){b?d?am(a,d):bm(a,c):bm(a,{user:null});a.f=[];a.c=[]}\nHl.prototype.qa=function(){var a=this;return new D(function(b,c){a.b?a.b().then(b,c):(a.f.push(b),a.c.push(c),cm(a))})};function cm(a){var b=new t(\"timeout\");a.a&&a.a.cancel();a.a=Fd(Sl.get()).then(function(){a.b||(a.g=!0,Yl(a,!0,null,b))})}function Il(){}Il.prototype.h=function(a,b){if(a){var c=a.c,d=a.b;a.a?(b.na(a.c,null,a.a,a.b),E()):b.Fa(c,d)?dm(a,b):F(new t(\"invalid-auth-event\"))}else F(new t(\"invalid-auth-event\"))};\nfunction dm(a,b){var c=a.b,d=a.c;b.Fa(d,c)(a.g,a.f,a.T(),a.i).then(function(e){b.na(d,e,null,c)}).o(function(e){b.na(d,null,e,c)})};function em(){this.ib=!1;Object.defineProperty(this,\"appVerificationDisabled\",{get:function(){return this.ib},set:function(a){this.ib=a},enumerable:!1})};function fm(a,b){this.a=b;M(this,\"verificationId\",a)}fm.prototype.confirm=function(a){a=ph(this.verificationId,a);return this.a(a)};function gm(a,b,c,d){return(new lh(a)).fb(b,c).then(function(e){return new fm(e,d)})};function hm(a){var b=ig(a);if(!(b&&b.exp&&b.auth_time&&b.iat))throw new t(\"internal-error\",\"An internal error occurred. The token obtained by Firebase appears to be malformed. Please retry the operation.\");N(this,{token:a,expirationTime:bf(1E3*b.exp),authTime:bf(1E3*b.auth_time),issuedAtTime:bf(1E3*b.iat),signInProvider:b.firebase&&b.firebase.sign_in_provider?b.firebase.sign_in_provider:null,signInSecondFactor:b.firebase&&b.firebase.sign_in_second_factor?b.firebase.sign_in_second_factor:null,claims:b})}\n;function im(a,b,c){var d=b&&b[jm];if(!d)throw new t(\"argument-error\",\"Internal assert: Invalid MultiFactorResolver\");this.a=a;this.f=nb(b);this.g=c;this.c=new yg(null,d);this.b=[];var e=this;w(b[km]||[],function(f){(f=tf(f))&&e.b.push(f)});M(this,\"auth\",this.a);M(this,\"session\",this.c);M(this,\"hints\",this.b)}var km=\"mfaInfo\",jm=\"mfaPendingCredential\";im.prototype.Rc=function(a){var b=this;return a.sb(this.a.a,this.c).then(function(c){var d=nb(b.f);delete d[km];delete d[jm];z(d,c);return b.g(d)})};function lm(a,b,c,d){t.call(this,\"multi-factor-auth-required\",d,b);this.b=new im(a,b,c);M(this,\"resolver\",this.b)}r(lm,t);function mm(a,b,c){if(a&&n(a.serverResponse)&&\"auth/multi-factor-auth-required\"===a.code)try{return new lm(b,a.serverResponse,c,a.message)}catch(d){}return null};function nm(){}nm.prototype.sb=function(a,b,c){return b.type==zg?om(this,a,b,c):pm(this,a,b)};function om(a,b,c,d){return c.Ha().then(function(e){e={idToken:e};\"undefined\"!==typeof d&&(e.displayName=d);z(e,{phoneVerificationInfo:hh(a.a)});return O(b,Gj,e)})}function pm(a,b,c){return c.Ha().then(function(d){d={mfaPendingCredential:d};z(d,{phoneVerificationInfo:hh(a.a)});return O(b,Hj,d)})}function qm(a){M(this,\"factorId\",a.fa);this.a=a}r(qm,nm);\nfunction rm(a){qm.call(this,a);if(this.a.fa!=lh.PROVIDER_ID)throw new t(\"argument-error\",\"firebase.auth.PhoneMultiFactorAssertion requires a valid firebase.auth.PhoneAuthCredential\");}r(rm,qm);function sm(a,b){G.call(this,a);for(var c in b)this[c]=b[c]}r(sm,G);function tm(a,b){this.a=a;this.b=[];this.c=q(this.yc,this);nd(this.a,\"userReloaded\",this.c);var c=[];b&&b.multiFactor&&b.multiFactor.enrolledFactors&&w(b.multiFactor.enrolledFactors,function(d){var e=null,f={};if(d){d.uid&&(f[qf]=d.uid);d.displayName&&(f[rf]=d.displayName);d.enrollmentTime&&(f[sf]=(new Date(d.enrollmentTime)).toISOString());d.phoneNumber&&(f[pf]=d.phoneNumber);try{e=new uf(f)}catch(g){}d=e}else d=null;d&&c.push(d)});um(this,c)}\nfunction vm(a){var b=[];w(a.mfaInfo||[],function(c){(c=tf(c))&&b.push(c)});return b}k=tm.prototype;k.yc=function(a){um(this,vm(a.hd))};function um(a,b){a.b=b;M(a,\"enrolledFactors\",b)}k.Rb=function(){return this.a.I().then(function(a){return new yg(a,null)})};k.fc=function(a,b){var c=this,d=this.a.a;return this.Rb().then(function(e){return a.sb(d,e,b)}).then(function(e){wm(c.a,e);return c.a.reload()})};\nk.bd=function(a){var b=this,c=\"string\"===typeof a?a:a.uid,d=this.a.a;return this.a.I().then(function(e){return O(d,Lj,{idToken:e,mfaEnrollmentId:c})}).then(function(e){var f=Qa(b.b,function(g){return g.uid!=c});um(b,f);wm(b.a,e);return b.a.reload().o(function(g){if(\"auth/user-token-expired\"!=g.code)throw g;})})};k.w=function(){return{multiFactor:{enrolledFactors:Ra(this.b,function(a){return a.w()})}}};function xm(a,b,c){this.h=a;this.i=b;this.g=c;this.c=3E4;this.f=96E4;this.b=null;this.a=this.c;if(this.f<this.c)throw Error(\"Proactive refresh lower bound greater than upper bound!\");}xm.prototype.start=function(){this.a=this.c;ym(this,!0)};function zm(a,b){if(b)return a.a=a.c,a.g();b=a.a;a.a*=2;a.a>a.f&&(a.a=a.f);return b}function ym(a,b){a.stop();a.b=Fd(zm(a,b)).then(function(){return af()}).then(function(){return a.h()}).then(function(){ym(a,!0)}).o(function(c){a.i(c)&&ym(a,!1)})}\nxm.prototype.stop=function(){this.b&&(this.b.cancel(),this.b=null)};function Am(a){this.f=a;this.b=this.a=null;this.c=Date.now()}Am.prototype.w=function(){return{apiKey:this.f.c,refreshToken:this.a,accessToken:this.b&&this.b.toString(),expirationTime:this.c}};function Bm(a,b){\"undefined\"===typeof b&&(a.b?(b=a.b,b=b.a-b.g):b=0);a.c=Date.now()+1E3*b}function Cm(a,b){a.b=jg(b[Dg]||\"\");a.a=b.refreshToken;b=b.expiresIn;Bm(a,\"undefined\"!==typeof b?Number(b):void 0)}function Dm(a,b){a.b=b.b;a.a=b.a;a.c=b.c}\nfunction Em(a,b){return Wi(a.f,b).then(function(c){a.b=jg(c.access_token);a.a=c.refresh_token;Bm(a,c.expires_in);return{accessToken:a.b.toString(),refreshToken:a.a}}).o(function(c){\"auth/user-token-expired\"==c.code&&(a.a=null);throw c;})}Am.prototype.getToken=function(a){a=!!a;return this.b&&!this.a?F(new t(\"user-token-expired\")):a||!this.b||Date.now()>this.c-3E4?this.a?Em(this,{grant_type:\"refresh_token\",refresh_token:this.a}):E(null):E({accessToken:this.b.toString(),refreshToken:this.a})};function Fm(a,b){this.a=a||null;this.b=b||null;N(this,{lastSignInTime:bf(b||null),creationTime:bf(a||null)})}function Gm(a){return new Fm(a.a,a.b)}Fm.prototype.w=function(){return{lastLoginAt:this.b,createdAt:this.a}};function Hm(a,b,c,d,e,f){N(this,{uid:a,displayName:d||null,photoURL:e||null,email:c||null,phoneNumber:f||null,providerId:b})}\nfunction Im(a,b,c){this.J=[];this.l=a.apiKey;this.m=a.appName;this.s=a.authDomain||null;var d=firebase.SDK_VERSION?Oe(firebase.SDK_VERSION):null;this.a=new Ii(this.l,Ca(Da),d);a.emulatorConfig&&Pi(this.a,a.emulatorConfig);this.b=new Am(this.a);Jm(this,b[Dg]);Cm(this.b,b);M(this,\"refreshToken\",this.b.a);Km(this,c||{});H.call(this);this.R=!1;this.s&&Re()&&(this.i=Xl(this.s,this.l,this.m));this.S=[];this.h=null;this.u=Lm(this);this.aa=q(this.hb,this);var e=this;this.ya=null;this.Oa=function(f){e.wa(f.h)};\nthis.ja=null;this.Aa=function(f){Pi(e.a,f.c)};this.X=null;this.$=[];this.Ba=function(f){Mm(e,f.f)};this.ba=null;this.O=new tm(this,c);M(this,\"multiFactor\",this.O)}r(Im,H);Im.prototype.wa=function(a){this.ya=a;Oi(this.a,a)};Im.prototype.la=function(){return this.ya};function Nm(a,b){a.ja&&xd(a.ja,\"languageCodeChanged\",a.Oa);(a.ja=b)&&nd(b,\"languageCodeChanged\",a.Oa)}function Om(a,b){a.X&&xd(a.X,\"emulatorConfigChanged\",a.Aa);(a.X=b)&&nd(b,\"emulatorConfigChanged\",a.Aa)}\nfunction Mm(a,b){a.$=b;Ri(a.a,firebase.SDK_VERSION?Oe(firebase.SDK_VERSION,a.$):null)}Im.prototype.Ga=function(){return Za(this.$)};function Pm(a,b){a.ba&&xd(a.ba,\"frameworkChanged\",a.Ba);(a.ba=b)&&nd(b,\"frameworkChanged\",a.Ba)}Im.prototype.hb=function(){this.u.b&&(this.u.stop(),this.u.start())};function Qm(a){try{return firebase.app(a.m).auth()}catch(b){throw new t(\"internal-error\",\"No firebase.auth.Auth instance is available for the Firebase App '\"+a.m+\"'!\");}}\nfunction Lm(a){return new xm(function(){return a.I(!0)},function(b){return b&&\"auth/network-request-failed\"==b.code?!0:!1},function(){var b=a.b.c-Date.now()-3E5;return 0<b?b:0})}function Rm(a){a.D||a.u.b||(a.u.start(),xd(a,\"tokenChanged\",a.aa),nd(a,\"tokenChanged\",a.aa))}function Sm(a){xd(a,\"tokenChanged\",a.aa);a.u.stop()}function Jm(a,b){a.za=b;M(a,\"_lat\",b)}function Tm(a,b){Xa(a.S,function(c){return c==b})}\nfunction Um(a){for(var b=[],c=0;c<a.S.length;c++)b.push(a.S[c](a));return Jc(b).then(function(){return a})}function Vm(a){a.i&&!a.R&&(a.R=!0,Pl(a.i,a))}function Km(a,b){N(a,{uid:b.uid,displayName:b.displayName||null,photoURL:b.photoURL||null,email:b.email||null,emailVerified:b.emailVerified||!1,phoneNumber:b.phoneNumber||null,isAnonymous:b.isAnonymous||!1,tenantId:b.tenantId||null,metadata:new Fm(b.createdAt,b.lastLoginAt),providerData:[]});a.a.b=a.tenantId}M(Im.prototype,\"providerId\",\"firebase\");\nfunction Wm(){}function Xm(a){return E().then(function(){if(a.D)throw new t(\"app-deleted\");})}function Ym(a){return Ra(a.providerData,function(b){return b.providerId})}function Zm(a,b){b&&($m(a,b.providerId),a.providerData.push(b))}function $m(a,b){Xa(a.providerData,function(c){return c.providerId==b})}function an(a,b,c){(\"uid\"!=b||c)&&a.hasOwnProperty(b)&&M(a,b,c)}\nfunction bn(a,b){a!=b&&(N(a,{uid:b.uid,displayName:b.displayName,photoURL:b.photoURL,email:b.email,emailVerified:b.emailVerified,phoneNumber:b.phoneNumber,isAnonymous:b.isAnonymous,tenantId:b.tenantId,providerData:[]}),b.metadata?M(a,\"metadata\",Gm(b.metadata)):M(a,\"metadata\",new Fm),w(b.providerData,function(c){Zm(a,c)}),Dm(a.b,b.b),M(a,\"refreshToken\",a.b.a),um(a.O,b.O.b))}k=Im.prototype;k.reload=function(){var a=this;return R(this,Xm(this).then(function(){return cn(a).then(function(){return Um(a)}).then(Wm)}))};\nfunction cn(a){return a.I().then(function(b){var c=a.isAnonymous;return dn(a,b).then(function(){c||an(a,\"isAnonymous\",!1);return b})})}k.oc=function(a){return this.I(a).then(function(b){return new hm(b)})};k.I=function(a){var b=this;return R(this,Xm(this).then(function(){return b.b.getToken(a)}).then(function(c){if(!c)throw new t(\"internal-error\");c.accessToken!=b.za&&(Jm(b,c.accessToken),b.dispatchEvent(new sm(\"tokenChanged\")));an(b,\"refreshToken\",c.refreshToken);return c.accessToken}))};\nfunction wm(a,b){b[Dg]&&a.za!=b[Dg]&&(Cm(a.b,b),a.dispatchEvent(new sm(\"tokenChanged\")),Jm(a,b[Dg]),an(a,\"refreshToken\",a.b.a))}function dn(a,b){return O(a.a,Ij,{idToken:b}).then(q(a.Kc,a))}\nk.Kc=function(a){a=a.users;if(!a||!a.length)throw new t(\"internal-error\");a=a[0];Km(this,{uid:a.localId,displayName:a.displayName,photoURL:a.photoUrl,email:a.email,emailVerified:!!a.emailVerified,phoneNumber:a.phoneNumber,lastLoginAt:a.lastLoginAt,createdAt:a.createdAt,tenantId:a.tenantId});for(var b=en(a),c=0;c<b.length;c++)Zm(this,b[c]);an(this,\"isAnonymous\",!(this.email&&a.passwordHash)&&!(this.providerData&&this.providerData.length));this.dispatchEvent(new sm(\"userReloaded\",{hd:a}))};\nfunction en(a){return(a=a.providerUserInfo)&&a.length?Ra(a,function(b){return new Hm(b.rawId,b.providerId,b.email,b.displayName,b.photoUrl,b.phoneNumber)}):[]}k.Lc=function(a){gf(\"firebase.User.prototype.reauthenticateAndRetrieveDataWithCredential is deprecated. Please use firebase.User.prototype.reauthenticateWithCredential instead.\");return this.tb(a)};\nk.tb=function(a){var b=this,c=null;return R(this,a.c(this.a,this.uid).then(function(d){wm(b,d);c=fn(b,d,\"reauthenticate\");b.h=null;return b.reload()}).then(function(){return c}),!0)};function gn(a,b){return cn(a).then(function(){if(Va(Ym(a),b))return Um(a).then(function(){throw new t(\"provider-already-linked\");})})}k.Cc=function(a){gf(\"firebase.User.prototype.linkAndRetrieveDataWithCredential is deprecated. Please use firebase.User.prototype.linkWithCredential instead.\");return this.qb(a)};\nk.qb=function(a){var b=this,c=null;return R(this,gn(this,a.providerId).then(function(){return b.I()}).then(function(d){return a.b(b.a,d)}).then(function(d){c=fn(b,d,\"link\");return hn(b,d)}).then(function(){return c}))};k.Dc=function(a,b){var c=this;return R(this,gn(this,\"phone\").then(function(){return gm(Qm(c),a,b,q(c.qb,c))}))};k.Mc=function(a,b){var c=this;return R(this,E().then(function(){return gm(Qm(c),a,b,q(c.tb,c))}),!0)};\nfunction fn(a,b,c){var d=qh(b);b=og(b);return kf({user:a,credential:d,additionalUserInfo:b,operationType:c})}function hn(a,b){wm(a,b);return a.reload().then(function(){return a})}k.Bb=function(a){var b=this;return R(this,this.I().then(function(c){return b.a.Bb(c,a)}).then(function(c){wm(b,c);return b.reload()}))};k.ed=function(a){var b=this;return R(this,this.I().then(function(c){return a.b(b.a,c)}).then(function(c){wm(b,c);return b.reload()}))};\nk.Cb=function(a){var b=this;return R(this,this.I().then(function(c){return b.a.Cb(c,a)}).then(function(c){wm(b,c);return b.reload()}))};\nk.Db=function(a){if(void 0===a.displayName&&void 0===a.photoURL)return Xm(this);var b=this;return R(this,this.I().then(function(c){return b.a.Db(c,{displayName:a.displayName,photoUrl:a.photoURL})}).then(function(c){wm(b,c);an(b,\"displayName\",c.displayName||null);an(b,\"photoURL\",c.photoUrl||null);w(b.providerData,function(d){\"password\"===d.providerId&&(M(d,\"displayName\",b.displayName),M(d,\"photoURL\",b.photoURL))});return Um(b)}).then(Wm))};\nk.cd=function(a){var b=this;return R(this,cn(this).then(function(c){return Va(Ym(b),a)?rj(b.a,c,[a]).then(function(d){var e={};w(d.providerUserInfo||[],function(f){e[f.providerId]=!0});w(Ym(b),function(f){e[f]||$m(b,f)});e[lh.PROVIDER_ID]||M(b,\"phoneNumber\",null);return Um(b)}):Um(b).then(function(){throw new t(\"no-such-provider\");})}))};\nk.delete=function(){var a=this;return R(this,this.I().then(function(b){return O(a.a,Fj,{idToken:b})}).then(function(){a.dispatchEvent(new sm(\"userDeleted\"))})).then(function(){for(var b=0;b<a.J.length;b++)a.J[b].cancel(\"app-deleted\");Nm(a,null);Om(a,null);Pm(a,null);a.J=[];a.D=!0;Sm(a);M(a,\"refreshToken\",null);a.i&&Ql(a.i,a)})};\nk.Fb=function(a,b){return\"linkViaPopup\"==a&&(this.g||null)==b&&this.f||\"reauthViaPopup\"==a&&(this.g||null)==b&&this.f||\"linkViaRedirect\"==a&&(this.ga||null)==b||\"reauthViaRedirect\"==a&&(this.ga||null)==b?!0:!1};k.na=function(a,b,c,d){\"linkViaPopup\"!=a&&\"reauthViaPopup\"!=a||d!=(this.g||null)||(c&&this.C?this.C(c):b&&!c&&this.f&&this.f(b),this.c&&(this.c.cancel(),this.c=null),delete this.f,delete this.C)};\nk.Fa=function(a,b){return\"linkViaPopup\"==a&&b==(this.g||null)?q(this.Kb,this):\"reauthViaPopup\"==a&&b==(this.g||null)?q(this.Lb,this):\"linkViaRedirect\"==a&&(this.ga||null)==b?q(this.Kb,this):\"reauthViaRedirect\"==a&&(this.ga||null)==b?q(this.Lb,this):null};k.Ec=function(a){var b=this;return jn(this,\"linkViaPopup\",a,function(){return gn(b,a.providerId).then(function(){return Um(b)})},!1)};k.Nc=function(a){return jn(this,\"reauthViaPopup\",a,function(){return E()},!0)};\nfunction jn(a,b,c,d,e){if(!Re())return F(new t(\"operation-not-supported-in-this-environment\"));if(a.h&&!e)return F(a.h);var f=ng(c.providerId),g=Qe(a.uid+\":::\"),h=null;(!Te()||Ie())&&a.s&&c.isOAuthProvider&&(h=ek(a.s,a.l,a.m,b,c,null,g,firebase.SDK_VERSION||null,null,null,a.tenantId));var m=ze(h,f&&f.ua,f&&f.ta);d=d().then(function(){kn(a);if(!e)return a.I().then(function(){})}).then(function(){return Tl(a.i,m,b,c,g,!!h,a.tenantId)}).then(function(){return new D(function(p,v){a.na(b,null,new t(\"cancelled-popup-request\"),\na.g||null);a.f=p;a.C=v;a.g=g;a.c=Vl(a.i,a,b,m,g)})}).then(function(p){m&&ye(m);return p?kf(p):null}).o(function(p){m&&ye(m);throw p;});return R(a,d,e)}k.Fc=function(a){var b=this;return ln(this,\"linkViaRedirect\",a,function(){return gn(b,a.providerId)},!1)};k.Oc=function(a){return ln(this,\"reauthViaRedirect\",a,function(){return E()},!0)};\nfunction ln(a,b,c,d,e){if(!Re())return F(new t(\"operation-not-supported-in-this-environment\"));if(a.h&&!e)return F(a.h);var f=null,g=Qe(a.uid+\":::\");d=d().then(function(){kn(a);if(!e)return a.I().then(function(){})}).then(function(){a.ga=g;return Um(a)}).then(function(h){a.ha&&(h=a.ha,h=h.b.set(mn,a.w(),h.a));return h}).then(function(){return Ul(a.i,b,c,g,a.tenantId)}).o(function(h){f=h;if(a.ha)return nn(a.ha);throw f;}).then(function(){if(f)throw f;});return R(a,d,e)}\nfunction kn(a){if(!a.i||!a.R){if(a.i&&!a.R)throw new t(\"internal-error\");throw new t(\"auth-domain-config-required\");}}k.Kb=function(a,b,c,d){var e=this;this.c&&(this.c.cancel(),this.c=null);var f=null;c=this.I().then(function(g){return Hg(e.a,{requestUri:a,postBody:d,sessionId:b,idToken:g})}).then(function(g){f=fn(e,g,\"link\");return hn(e,g)}).then(function(){return f});return R(this,c)};\nk.Lb=function(a,b,c,d){var e=this;this.c&&(this.c.cancel(),this.c=null);var f=null,g=E().then(function(){return Cg(Ig(e.a,{requestUri:a,sessionId:b,postBody:d,tenantId:c}),e.uid)}).then(function(h){f=fn(e,h,\"reauthenticate\");wm(e,h);e.h=null;return e.reload()}).then(function(){return f});return R(this,g,!0)};\nk.ub=function(a){var b=this,c=null;return R(this,this.I().then(function(d){c=d;return\"undefined\"===typeof a||mb(a)?{}:bg(new Sf(a))}).then(function(d){return b.a.ub(c,d)}).then(function(d){if(b.email!=d)return b.reload()}).then(function(){}))};k.Eb=function(a,b){var c=this,d=null;return R(this,this.I().then(function(e){d=e;return\"undefined\"===typeof b||mb(b)?{}:bg(new Sf(b))}).then(function(e){return c.a.Eb(d,a,e)}).then(function(e){if(c.email!=e)return c.reload()}).then(function(){}))};\nfunction R(a,b,c){var d=on(a,b,c);a.J.push(d);d.oa(function(){Wa(a.J,d)});return d.o(function(e){var f=null;e&&\"auth/multi-factor-auth-required\"===e.code&&(f=mm(e.w(),Qm(a),q(a.jc,a)));throw f||e;})}k.jc=function(a){var b=null,c=this;a=Cg(E(a),c.uid).then(function(d){b=fn(c,d,\"reauthenticate\");wm(c,d);c.h=null;return c.reload()}).then(function(){return b});return R(this,a,!0)};\nfunction on(a,b,c){return a.h&&!c?(b.cancel(),F(a.h)):b.o(function(d){!d||\"auth/user-disabled\"!=d.code&&\"auth/user-token-expired\"!=d.code||(a.h||a.dispatchEvent(new sm(\"userInvalidated\")),a.h=d);throw d;})}k.toJSON=function(){return this.w()};\nk.w=function(){var a={uid:this.uid,displayName:this.displayName,photoURL:this.photoURL,email:this.email,emailVerified:this.emailVerified,phoneNumber:this.phoneNumber,isAnonymous:this.isAnonymous,tenantId:this.tenantId,providerData:[],apiKey:this.l,appName:this.m,authDomain:this.s,stsTokenManager:this.b.w(),redirectEventId:this.ga||null};this.metadata&&z(a,this.metadata.w());w(this.providerData,function(b){a.providerData.push(lf(b))});z(a,this.O.w());return a};\nfunction pn(a){if(!a.apiKey)return null;var b={apiKey:a.apiKey,authDomain:a.authDomain,appName:a.appName,emulatorConfig:a.emulatorConfig},c={};if(a.stsTokenManager&&a.stsTokenManager.accessToken){c[Dg]=a.stsTokenManager.accessToken;c.refreshToken=a.stsTokenManager.refreshToken||null;var d=a.stsTokenManager.expirationTime;d&&(c.expiresIn=(d-Date.now())/1E3)}else return null;var e=new Im(b,c,a);a.providerData&&w(a.providerData,function(f){f&&Zm(e,kf(f))});a.redirectEventId&&(e.ga=a.redirectEventId);\nreturn e}function qn(a,b,c,d){var e=new Im(a,b);c&&(e.ha=c);d&&Mm(e,d);return e.reload().then(function(){return e})}function rn(a,b,c,d){var e=a.b,f={};f[Dg]=e.b&&e.b.toString();f.refreshToken=e.a;b=new Im(b||{apiKey:a.l,authDomain:a.s,appName:a.m},f);c&&(b.ha=c);d&&Mm(b,d);bn(b,a);return b};function sn(a){this.a=a;this.b=Vk()}var mn={name:\"redirectUser\",F:\"session\"};function nn(a){return Zk(a.b,mn,a.a)}function tn(a,b){return a.b.get(mn,a.a).then(function(c){c&&b&&(c.authDomain=b);return pn(c||{})})};function un(a){this.a=a;this.b=Vk();this.c=null;this.f=vn(this);this.b.addListener(wn(\"local\"),this.a,q(this.g,this))}un.prototype.g=function(){var a=this,b=wn(\"local\");xn(this,function(){return E().then(function(){return a.c&&\"local\"!=a.c.F?a.b.get(b,a.a):null}).then(function(c){if(c)return yn(a,\"local\").then(function(){a.c=b})})})};function yn(a,b){var c=[],d;for(d in Rk)Rk[d]!==b&&c.push(Zk(a.b,wn(Rk[d]),a.a));c.push(Zk(a.b,zn,a.a));return Ic(c)}\nfunction vn(a){var b=wn(\"local\"),c=wn(\"session\"),d=wn(\"none\");return Yk(a.b,b,a.a).then(function(){return a.b.get(c,a.a)}).then(function(e){return e?c:a.b.get(d,a.a).then(function(f){return f?d:a.b.get(b,a.a).then(function(g){return g?b:a.b.get(zn,a.a).then(function(h){return h?wn(h):b})})})}).then(function(e){a.c=e;return yn(a,e.F)}).o(function(){a.c||(a.c=b)})}var zn={name:\"persistence\",F:\"session\"};function wn(a){return{name:\"authUser\",F:a}}\nun.prototype.xb=function(a){var b=null,c=this;Sk(a);return xn(this,function(){return a!=c.c.F?c.b.get(c.c,c.a).then(function(d){b=d;return yn(c,a)}).then(function(){c.c=wn(a);if(b)return c.b.set(c.c,b,c.a)}):E()})};function An(a){return xn(a,function(){return a.b.set(zn,a.c.F,a.a)})}function Bn(a,b){return xn(a,function(){return a.b.set(a.c,b.w(),a.a)})}function Cn(a){return xn(a,function(){return Zk(a.b,a.c,a.a)})}\nfunction Dn(a,b,c){return xn(a,function(){return a.b.get(a.c,a.a).then(function(d){d&&b&&(d.authDomain=b);d&&c&&(d.emulatorConfig=c);return pn(d||{})})})}function xn(a,b){a.f=a.f.then(b,b);return a.f};function En(a){this.l=!1;M(this,\"settings\",new em);M(this,\"app\",a);if(S(this).options&&S(this).options.apiKey)a=firebase.SDK_VERSION?Oe(firebase.SDK_VERSION):null,this.a=new Ii(S(this).options&&S(this).options.apiKey,Ca(Da),a);else throw new t(\"invalid-api-key\");this.R=[];this.s=[];this.O=[];this.hb=firebase.INTERNAL.createSubscribe(q(this.zc,this));this.X=void 0;this.bc=firebase.INTERNAL.createSubscribe(q(this.Ac,this));Fn(this,null);this.i=new un(S(this).options.apiKey+\":\"+S(this).name);this.D=\nnew sn(S(this).options.apiKey+\":\"+S(this).name);this.$=T(this,Gn(this));this.h=T(this,Hn(this));this.ba=!1;this.ja=q(this.Zc,this);this.Ba=q(this.da,this);this.ya=q(this.mc,this);this.za=q(this.wc,this);this.Aa=q(this.xc,this);this.b=null;In(this);this.INTERNAL={};this.INTERNAL[\"delete\"]=q(this.delete,this);this.INTERNAL.logFramework=q(this.Gc,this);this.u=0;H.call(this);Jn(this);this.J=[];this.P=null}r(En,H);function Kn(a){G.call(this,\"languageCodeChanged\");this.h=a}r(Kn,G);\nfunction Ln(a){G.call(this,\"emulatorConfigChanged\");this.c=a}r(Ln,G);function Mn(a){G.call(this,\"frameworkChanged\");this.f=a}r(Mn,G);k=En.prototype;k.xb=function(a){a=this.i.xb(a);return T(this,a)};k.wa=function(a){this.aa===a||this.l||(this.aa=a,Oi(this.a,this.aa),this.dispatchEvent(new Kn(this.la())))};k.la=function(){return this.aa};k.fd=function(){var a=l.navigator;this.wa(a?a.languages&&a.languages[0]||a.language||a.userLanguage||null:null)};\nk.gd=function(a,b){if(!this.P){if(!/^https?:\\/\\//.test(a))throw new t(\"argument-error\",\"Emulator URL must start with a valid scheme (http:// or https://).\");b=b?!!b.disableWarnings:!1;Nn(b);this.P={url:a,ec:b};this.settings.ib=!0;Pi(this.a,this.P);this.dispatchEvent(new Ln(this.P))}};\nfunction Nn(a){\"undefined\"!==typeof console&&\"function\"===typeof console.info&&console.info(\"WARNING: You are using the Auth Emulator, which is intended for local testing only.  Do not use with production credentials.\");l.document&&!a&&Ee().then(function(){var b=l.document.createElement(\"div\");b.innerText=\"Running in emulator mode. Do not use with production credentials.\";b.style.position=\"fixed\";b.style.width=\"100%\";b.style.backgroundColor=\"#ffffff\";b.style.border=\".1em solid #000000\";b.style.color=\n\"#ff0000\";b.style.bottom=\"0px\";b.style.left=\"0px\";b.style.margin=\"0px\";b.style.zIndex=1E4;b.style.textAlign=\"center\";b.classList.add(\"firebase-emulator-warning\");l.document.body.appendChild(b)})}k.Gc=function(a){this.J.push(a);Ri(this.a,firebase.SDK_VERSION?Oe(firebase.SDK_VERSION,this.J):null);this.dispatchEvent(new Mn(this.J))};k.Ga=function(){return Za(this.J)};k.yb=function(a){this.S===a||this.l||(this.S=a,this.a.b=this.S)};k.T=function(){return this.S};\nfunction Jn(a){Object.defineProperty(a,\"lc\",{get:function(){return this.la()},set:function(b){this.wa(b)},enumerable:!1});a.aa=null;Object.defineProperty(a,\"ti\",{get:function(){return this.T()},set:function(b){this.yb(b)},enumerable:!1});a.S=null;Object.defineProperty(a,\"emulatorConfig\",{get:function(){if(this.P){var b=J(this.P.url);b=kf({protocol:b.c,host:b.a,port:b.g,options:kf({disableWarnings:this.P.ec})})}else b=null;return b},enumerable:!1})}\nk.toJSON=function(){return{apiKey:S(this).options.apiKey,authDomain:S(this).options.authDomain,appName:S(this).name,currentUser:U(this)&&U(this).w()}};function On(a){return a.Oa||F(new t(\"auth-domain-config-required\"))}\nfunction In(a){var b=S(a).options.authDomain,c=S(a).options.apiKey;b&&Re()&&(a.Oa=a.$.then(function(){if(!a.l){a.b=Xl(b,c,S(a).name,a.P);Pl(a.b,a);U(a)&&Vm(U(a));if(a.m){Vm(a.m);var d=a.m;d.wa(a.la());Nm(d,a);d=a.m;Mm(d,a.J);Pm(d,a);d=a.m;Pi(d.a,a.P);Om(d,a);a.m=null}return a.b}}))}k.Fb=function(a,b){switch(a){case \"unknown\":case \"signInViaRedirect\":return!0;case \"signInViaPopup\":return this.g==b&&!!this.f;default:return!1}};\nk.na=function(a,b,c,d){\"signInViaPopup\"==a&&this.g==d&&(c&&this.C?this.C(c):b&&!c&&this.f&&this.f(b),this.c&&(this.c.cancel(),this.c=null),delete this.f,delete this.C)};k.Fa=function(a,b){return\"signInViaRedirect\"==a||\"signInViaPopup\"==a&&this.g==b&&this.f?q(this.ic,this):null};k.ic=function(a,b,c,d){var e=this,f={requestUri:a,postBody:d,sessionId:b,tenantId:c};this.c&&(this.c.cancel(),this.c=null);return e.$.then(function(){return Pn(e,Fg(e.a,f))})};\nk.Xc=function(a){if(!Re())return F(new t(\"operation-not-supported-in-this-environment\"));var b=this,c=ng(a.providerId),d=Qe(),e=null;(!Te()||Ie())&&S(this).options.authDomain&&a.isOAuthProvider&&(e=ek(S(this).options.authDomain,S(this).options.apiKey,S(this).name,\"signInViaPopup\",a,null,d,firebase.SDK_VERSION||null,null,null,this.T(),this.P));var f=ze(e,c&&c.ua,c&&c.ta);c=On(this).then(function(g){return Tl(g,f,\"signInViaPopup\",a,d,!!e,b.T())}).then(function(){return new D(function(g,h){b.na(\"signInViaPopup\",\nnull,new t(\"cancelled-popup-request\"),b.g);b.f=g;b.C=h;b.g=d;b.c=Vl(b.b,b,\"signInViaPopup\",f,d)})}).then(function(g){f&&ye(f);return g?kf(g):null}).o(function(g){f&&ye(f);throw g;});return T(this,c)};k.Yc=function(a){if(!Re())return F(new t(\"operation-not-supported-in-this-environment\"));var b=this,c=On(this).then(function(){return An(b.i)}).then(function(){return Ul(b.b,\"signInViaRedirect\",a,void 0,b.T())});return T(this,c)};\nfunction Qn(a){if(!Re())return F(new t(\"operation-not-supported-in-this-environment\"));var b=On(a).then(function(){return a.b.qa()}).then(function(c){return c?kf(c):null});return T(a,b)}k.qa=function(){var a=this;return Qn(this).then(function(b){a.b&&$l(a.b.b);return b}).o(function(b){a.b&&$l(a.b.b);throw b;})};\nk.dd=function(a){if(!a)return F(new t(\"null-user\"));if(this.S!=a.tenantId)return F(new t(\"tenant-id-mismatch\"));var b=this,c={};c.apiKey=S(this).options.apiKey;c.authDomain=S(this).options.authDomain;c.appName=S(this).name;var d=rn(a,c,b.D,b.Ga());return T(this,this.h.then(function(){if(S(b).options.apiKey!=a.l)return d.reload()}).then(function(){if(U(b)&&a.uid==U(b).uid)return bn(U(b),a),b.da(a);Fn(b,d);Vm(d);return b.da(d)}).then(function(){Rn(b)}))};\nfunction Sn(a,b){var c={};c.apiKey=S(a).options.apiKey;c.authDomain=S(a).options.authDomain;c.appName=S(a).name;a.P&&(c.emulatorConfig=a.P);return a.$.then(function(){return qn(c,b,a.D,a.Ga())}).then(function(d){if(U(a)&&d.uid==U(a).uid)return bn(U(a),d),a.da(d);Fn(a,d);Vm(d);return a.da(d)}).then(function(){Rn(a)})}\nfunction Fn(a,b){U(a)&&(Tm(U(a),a.Ba),xd(U(a),\"tokenChanged\",a.ya),xd(U(a),\"userDeleted\",a.za),xd(U(a),\"userInvalidated\",a.Aa),Sm(U(a)));b&&(b.S.push(a.Ba),nd(b,\"tokenChanged\",a.ya),nd(b,\"userDeleted\",a.za),nd(b,\"userInvalidated\",a.Aa),0<a.u&&Rm(b));M(a,\"currentUser\",b);b&&(b.wa(a.la()),Nm(b,a),Mm(b,a.J),Pm(b,a),Pi(b.a,a.P),Om(b,a))}k.Ab=function(){var a=this,b=this.h.then(function(){a.b&&$l(a.b.b);if(!U(a))return E();Fn(a,null);return Cn(a.i).then(function(){Rn(a)})});return T(this,b)};\nfunction Tn(a){var b=tn(a.D,S(a).options.authDomain).then(function(c){if(a.m=c)c.ha=a.D;return nn(a.D)});return T(a,b)}function Gn(a){var b=S(a).options.authDomain,c=Tn(a).then(function(){return Dn(a.i,b,a.P)}).then(function(d){return d?(d.ha=a.D,a.m&&(a.m.ga||null)==(d.ga||null)?d:d.reload().then(function(){return Bn(a.i,d).then(function(){return d})}).o(function(e){return\"auth/network-request-failed\"==e.code?d:Cn(a.i)})):null}).then(function(d){Fn(a,d||null)});return T(a,c)}\nfunction Hn(a){return a.$.then(function(){return Qn(a)}).o(function(){}).then(function(){if(!a.l)return a.ja()}).o(function(){}).then(function(){if(!a.l){a.ba=!0;var b=a.i;b.b.addListener(wn(\"local\"),b.a,a.ja)}})}\nk.Zc=function(){var a=this;return Dn(this.i,S(this).options.authDomain).then(function(b){if(!a.l){var c;if(c=U(a)&&b){c=U(a).uid;var d=b.uid;c=void 0===c||null===c||\"\"===c||void 0===d||null===d||\"\"===d?!1:c==d}if(c)return bn(U(a),b),U(a).I();if(U(a)||b)Fn(a,b),b&&(Vm(b),b.ha=a.D),a.b&&Pl(a.b,a),Rn(a)}})};k.da=function(a){return Bn(this.i,a)};k.mc=function(){Rn(this);this.da(U(this))};k.wc=function(){this.Ab()};k.xc=function(){this.Ab()};\nfunction Pn(a,b){var c=null,d=null;return T(a,b.then(function(e){c=qh(e);d=og(e);return Sn(a,e)},function(e){var f=null;e&&\"auth/multi-factor-auth-required\"===e.code&&(f=mm(e.w(),a,q(a.kc,a)));throw f||e;}).then(function(){return kf({user:U(a),credential:c,additionalUserInfo:d,operationType:\"signIn\"})}))}k.kc=function(a){var b=this;return this.h.then(function(){return Pn(b,E(a))})};k.zc=function(a){var b=this;this.addAuthTokenListener(function(){a.next(U(b))})};\nk.Ac=function(a){var b=this;Un(this,function(){a.next(U(b))})};k.Ic=function(a,b,c){var d=this;this.ba&&Promise.resolve().then(function(){\"function\"===typeof a?a(U(d)):\"function\"===typeof a.next&&a.next(U(d))});return this.hb(a,b,c)};k.Hc=function(a,b,c){var d=this;this.ba&&Promise.resolve().then(function(){d.X=d.getUid();\"function\"===typeof a?a(U(d)):\"function\"===typeof a.next&&a.next(U(d))});return this.bc(a,b,c)};\nk.nc=function(a){var b=this,c=this.h.then(function(){return U(b)?U(b).I(a).then(function(d){return{accessToken:d}}):null});return T(this,c)};k.Tc=function(a){var b=this;return this.h.then(function(){return Pn(b,O(b.a,Kj,{token:a}))}).then(function(c){var d=c.user;an(d,\"isAnonymous\",!1);b.da(d);return c})};k.Uc=function(a,b){var c=this;return this.h.then(function(){return Pn(c,O(c.a,ah,{email:a,password:b}))})};\nk.dc=function(a,b){var c=this;return this.h.then(function(){return Pn(c,O(c.a,Ej,{email:a,password:b}))})};k.$a=function(a){var b=this;return this.h.then(function(){return Pn(b,a.ka(b.a))})};k.Sc=function(a){gf(\"firebase.auth.Auth.prototype.signInAndRetrieveDataWithCredential is deprecated. Please use firebase.auth.Auth.prototype.signInWithCredential instead.\");return this.$a(a)};\nk.zb=function(){var a=this;return this.h.then(function(){var b=U(a);if(b&&b.isAnonymous){var c=kf({providerId:null,isNewUser:!1});return kf({user:b,credential:null,additionalUserInfo:c,operationType:\"signIn\"})}return Pn(a,a.a.zb()).then(function(d){var e=d.user;an(e,\"isAnonymous\",!0);a.da(e);return d})})};function S(a){return a.app}function U(a){return a.currentUser}k.getUid=function(){return U(this)&&U(this).uid||null};function Vn(a){return U(a)&&U(a)._lat||null}\nfunction Rn(a){if(a.ba){for(var b=0;b<a.s.length;b++)if(a.s[b])a.s[b](Vn(a));if(a.X!==a.getUid()&&a.O.length)for(a.X=a.getUid(),b=0;b<a.O.length;b++)if(a.O[b])a.O[b](Vn(a))}}k.cc=function(a){this.addAuthTokenListener(a);this.u++;0<this.u&&U(this)&&Rm(U(this))};k.Pc=function(a){var b=this;w(this.s,function(c){c==a&&b.u--});0>this.u&&(this.u=0);0==this.u&&U(this)&&Sm(U(this));this.removeAuthTokenListener(a)};\nk.addAuthTokenListener=function(a){var b=this;this.s.push(a);T(this,this.h.then(function(){b.l||Va(b.s,a)&&a(Vn(b))}))};k.removeAuthTokenListener=function(a){Xa(this.s,function(b){return b==a})};function Un(a,b){a.O.push(b);T(a,a.h.then(function(){!a.l&&Va(a.O,b)&&a.X!==a.getUid()&&(a.X=a.getUid(),b(Vn(a)))}))}\nk.delete=function(){this.l=!0;for(var a=0;a<this.R.length;a++)this.R[a].cancel(\"app-deleted\");this.R=[];this.i&&(a=this.i,a.b.removeListener(wn(\"local\"),a.a,this.ja));this.b&&(Ql(this.b,this),$l(this.b.b));return Promise.resolve()};function T(a,b){a.R.push(b);b.oa(function(){Wa(a.R,b)});return b}k.hc=function(a){return T(this,aj(this.a,a))};k.Bc=function(a){return!!fh(a)};\nk.wb=function(a,b){var c=this;return T(this,E().then(function(){var d=new Sf(b);if(!d.c)throw new t(\"argument-error\",$f+\" must be true when sending sign in link to email\");return bg(d)}).then(function(d){return c.a.wb(a,d)}).then(function(){}))};k.jd=function(a){return this.Ra(a).then(function(b){return b.data.email})};k.nb=function(a,b){return T(this,this.a.nb(a,b).then(function(){}))};k.Ra=function(a){return T(this,this.a.Ra(a).then(function(b){return new vf(b)}))};\nk.jb=function(a){return T(this,this.a.jb(a).then(function(){}))};k.vb=function(a,b){var c=this;return T(this,E().then(function(){return\"undefined\"===typeof b||mb(b)?{}:bg(new Sf(b))}).then(function(d){return c.a.vb(a,d)}).then(function(){}))};k.Wc=function(a,b){return T(this,gm(this,a,b,q(this.$a,this)))};\nk.Vc=function(a,b){var c=this;return T(this,E().then(function(){var d=b||re(),e=eh(a,d);d=fh(d);if(!d)throw new t(\"argument-error\",\"Invalid email link!\");if(d.tenantId!==c.T())throw new t(\"tenant-id-mismatch\");return c.$a(e)}))};function Wn(){}Wn.prototype.render=function(){};Wn.prototype.reset=function(){};Wn.prototype.getResponse=function(){};Wn.prototype.execute=function(){};function Xn(){this.a={};this.b=1E12}var Yn=null;Xn.prototype.render=function(a,b){this.a[this.b.toString()]=new Zn(a,b);return this.b++};Xn.prototype.reset=function(a){var b=$n(this,a);a=ao(a);b&&a&&(b.delete(),delete this.a[a])};Xn.prototype.getResponse=function(a){return(a=$n(this,a))?a.getResponse():null};Xn.prototype.execute=function(a){(a=$n(this,a))&&a.execute()};function $n(a,b){return(b=ao(b))?a.a[b]||null:null}function ao(a){return(a=\"undefined\"===typeof a?1E12:a)?a.toString():null}\nfunction Zn(a,b){this.g=!1;this.c=b;this.a=this.b=null;this.h=\"invisible\"!==this.c.size;this.f=kc(a);var c=this;this.i=function(){c.execute()};this.h?this.execute():nd(this.f,\"click\",this.i)}Zn.prototype.getResponse=function(){bo(this);return this.b};\nZn.prototype.execute=function(){bo(this);var a=this;this.a||(this.a=setTimeout(function(){a.b=Me();var b=a.c.callback,c=a.c[\"expired-callback\"];if(b)try{b(a.b)}catch(d){}a.a=setTimeout(function(){a.a=null;a.b=null;if(c)try{c()}catch(d){}a.h&&a.execute()},6E4)},500))};Zn.prototype.delete=function(){bo(this);this.g=!0;clearTimeout(this.a);this.a=null;xd(this.f,\"click\",this.i)};function bo(a){if(a.g)throw Error(\"reCAPTCHA mock was already deleted!\");};function co(){}M(co,\"FACTOR_ID\",\"phone\");function eo(){}eo.prototype.g=function(){Yn||(Yn=new Xn);return E(Yn)};eo.prototype.c=function(){};var fo=null;function go(){this.b=l.grecaptcha?Infinity:0;this.f=null;this.a=\"__rcb\"+Math.floor(1E6*Math.random()).toString()}var ho=new qb(rb,\"https://www.google.com/recaptcha/api.js?onload=%{onload}&render=explicit&hl=%{hl}\"),io=new Ze(3E4,6E4);\ngo.prototype.g=function(a){var b=this;return new D(function(c,d){var e=setTimeout(function(){d(new t(\"network-request-failed\"))},io.get());if(!l.grecaptcha||a!==b.f&&!b.b){l[b.a]=function(){if(l.grecaptcha){b.f=a;var g=l.grecaptcha.render;l.grecaptcha.render=function(h,m){h=g(h,m);b.b++;return h};clearTimeout(e);c(l.grecaptcha)}else clearTimeout(e),d(new t(\"internal-error\"));delete l[b.a]};var f=zb(ho,{onload:b.a,hl:a||\"\"});E(Bi(f)).o(function(){clearTimeout(e);d(new t(\"internal-error\",\"Unable to load external reCAPTCHA dependencies!\"))})}else clearTimeout(e),\nc(l.grecaptcha)})};go.prototype.c=function(){this.b--};var jo=null;function ko(a,b,c,d,e,f,g){M(this,\"type\",\"recaptcha\");this.c=this.f=null;this.D=!1;this.v=b;this.g=null;g?(fo||(fo=new eo),g=fo):(jo||(jo=new go),g=jo);this.m=g;this.a=c||{theme:\"light\",type:\"image\"};this.h=[];if(this.a[lo])throw new t(\"argument-error\",\"sitekey should not be provided for reCAPTCHA as one is automatically provisioned for the current project.\");this.i=\"invisible\"===this.a[mo];if(!l.document)throw new t(\"operation-not-supported-in-this-environment\",\"RecaptchaVerifier is only supported in a browser HTTP/HTTPS environment with DOM support.\");\nif(!kc(b)||!this.i&&kc(b).hasChildNodes())throw new t(\"argument-error\",\"reCAPTCHA container is either not found or already contains inner elements!\");this.s=new Ii(a,f||null,e||null);this.u=d||function(){return null};var h=this;this.l=[];var m=this.a[no];this.a[no]=function(v){oo(h,v);if(\"function\"===typeof m)m(v);else if(\"string\"===typeof m){var B=L(m,l);\"function\"===typeof B&&B(v)}};var p=this.a[po];this.a[po]=function(){oo(h,null);if(\"function\"===typeof p)p();else if(\"string\"===typeof p){var v=\nL(p,l);\"function\"===typeof v&&v()}}}var no=\"callback\",po=\"expired-callback\",lo=\"sitekey\",mo=\"size\";function oo(a,b){for(var c=0;c<a.l.length;c++)try{a.l[c](b)}catch(d){}}function qo(a,b){Xa(a.l,function(c){return c==b})}function ro(a,b){a.h.push(b);b.oa(function(){Wa(a.h,b)});return b}k=ko.prototype;\nk.Ia=function(){var a=this;return this.f?this.f:this.f=ro(this,E().then(function(){if(Se()&&!Je())return Ee();throw new t(\"operation-not-supported-in-this-environment\",\"RecaptchaVerifier is only supported in a browser HTTP/HTTPS environment.\");}).then(function(){return a.m.g(a.u())}).then(function(b){a.g=b;return O(a.s,Jj,{})}).then(function(b){a.a[lo]=b.recaptchaSiteKey}).o(function(b){a.f=null;throw b;}))};\nk.render=function(){so(this);var a=this;return ro(this,this.Ia().then(function(){if(null===a.c){var b=a.v;if(!a.i){var c=kc(b);b=nc(\"DIV\");c.appendChild(b)}a.c=a.g.render(b,a.a)}return a.c}))};k.verify=function(){so(this);var a=this;return ro(this,this.render().then(function(b){return new D(function(c){var d=a.g.getResponse(b);if(d)c(d);else{var e=function(f){f&&(qo(a,e),c(f))};a.l.push(e);a.i&&a.g.execute(a.c)}})}))};k.reset=function(){so(this);null!==this.c&&this.g.reset(this.c)};\nfunction so(a){if(a.D)throw new t(\"internal-error\",\"RecaptchaVerifier instance has been destroyed.\");}k.clear=function(){so(this);this.D=!0;this.m.c();for(var a=0;a<this.h.length;a++)this.h[a].cancel(\"RecaptchaVerifier instance has been destroyed.\");if(!this.i){a=kc(this.v);for(var b;b=a.firstChild;)a.removeChild(b)}};\nfunction to(a,b,c){var d=!1;try{this.b=c||firebase.app()}catch(g){throw new t(\"argument-error\",\"No firebase.app.App instance is currently initialized.\");}if(this.b.options&&this.b.options.apiKey)c=this.b.options.apiKey;else throw new t(\"invalid-api-key\");var e=this,f=null;try{f=this.b.auth().Ga()}catch(g){}try{d=this.b.auth().settings.appVerificationDisabledForTesting}catch(g){}f=firebase.SDK_VERSION?Oe(firebase.SDK_VERSION,f):null;ko.call(this,c,a,b,function(){try{var g=e.b.auth().la()}catch(h){g=\nnull}return g},f,Ca(Da),d)}r(to,ko);function uo(a,b,c,d){a:{c=Array.prototype.slice.call(c);var e=0;for(var f=!1,g=0;g<b.length;g++)if(b[g].optional)f=!0;else{if(f)throw new t(\"internal-error\",\"Argument validator encountered a required argument after an optional argument.\");e++}f=b.length;if(c.length<e||f<c.length)d=\"Expected \"+(e==f?1==e?\"1 argument\":e+\" arguments\":e+\"-\"+f+\" arguments\")+\" but got \"+c.length+\".\";else{for(e=0;e<c.length;e++)if(f=b[e].optional&&void 0===c[e],!b[e].M(c[e])&&!f){b=b[e];if(0>e||e>=vo.length)throw new t(\"internal-error\",\n\"Argument validator received an unsupported number of arguments.\");c=vo[e];d=(d?\"\":c+\" argument \")+(b.name?'\"'+b.name+'\" ':\"\")+\"must be \"+b.K+\".\";break a}d=null}}if(d)throw new t(\"argument-error\",a+\" failed: \"+d);}var vo=\"First Second Third Fourth Fifth Sixth Seventh Eighth Ninth\".split(\" \");function V(a,b){return{name:a||\"\",K:\"a valid string\",optional:!!b,M:function(c){return\"string\"===typeof c}}}\nfunction wo(a,b){return{name:a||\"\",K:\"a boolean\",optional:!!b,M:function(c){return\"boolean\"===typeof c}}}function W(a,b){return{name:a||\"\",K:\"a valid object\",optional:!!b,M:n}}function xo(a,b){return{name:a||\"\",K:\"a function\",optional:!!b,M:function(c){return\"function\"===typeof c}}}function yo(a,b){return{name:a||\"\",K:\"null\",optional:!!b,M:function(c){return null===c}}}function zo(){return{name:\"\",K:\"an HTML element\",optional:!1,M:function(a){return!!(a&&a instanceof Element)}}}\nfunction Ao(){return{name:\"auth\",K:\"an instance of Firebase Auth\",optional:!0,M:function(a){return!!(a&&a instanceof En)}}}function Bo(){return{name:\"app\",K:\"an instance of Firebase App\",optional:!0,M:function(a){return!!(a&&a instanceof firebase.app.App)}}}function Co(a){return{name:a?a+\"Credential\":\"credential\",K:a?\"a valid \"+a+\" credential\":\"a valid credential\",optional:!1,M:function(b){if(!b)return!1;var c=!a||b.providerId===a;return!(!b.ka||!c)}}}\nfunction Do(){return{name:\"multiFactorAssertion\",K:\"a valid multiFactorAssertion\",optional:!1,M:function(a){return a?!!a.sb:!1}}}function Eo(){return{name:\"authProvider\",K:\"a valid Auth provider\",optional:!1,M:function(a){return!!(a&&a.providerId&&a.hasOwnProperty&&a.hasOwnProperty(\"isOAuthProvider\"))}}}function Fo(a,b){return n(a)&&\"string\"===typeof a.type&&a.type===b&&\"function\"===typeof a.Ha}function Go(a){return n(a)&&\"string\"===typeof a.uid}\nfunction Ho(){return{name:\"applicationVerifier\",K:\"an implementation of firebase.auth.ApplicationVerifier\",optional:!1,M:function(a){return!(!a||\"string\"!==typeof a.type||\"function\"!==typeof a.verify)}}}function X(a,b,c,d){return{name:c||\"\",K:a.K+\" or \"+b.K,optional:!!d,M:function(e){return a.M(e)||b.M(e)}}};function Y(a,b){for(var c in b){var d=b[c].name;a[d]=Io(d,a[c],b[c].j)}}function Jo(a,b){for(var c in b){var d=b[c].name;d!==c&&Object.defineProperty(a,d,{get:ua(function(e){return this[e]},c),set:ua(function(e,f,g,h){uo(e,[g],[h],!0);this[f]=h},d,c,b[c].kb),enumerable:!0})}}function Z(a,b,c,d){a[b]=Io(b,c,d)}\nfunction Io(a,b,c){function d(){var g=Array.prototype.slice.call(arguments);uo(e,c,g);return b.apply(this,g)}if(!c)return b;var e=Ko(a),f;for(f in b)d[f]=b[f];for(f in b.prototype)d.prototype[f]=b.prototype[f];return d}function Ko(a){a=a.split(\".\");return a[a.length-1]};Y(En.prototype,{jb:{name:\"applyActionCode\",j:[V(\"code\")]},Ra:{name:\"checkActionCode\",j:[V(\"code\")]},nb:{name:\"confirmPasswordReset\",j:[V(\"code\"),V(\"newPassword\")]},dc:{name:\"createUserWithEmailAndPassword\",j:[V(\"email\"),V(\"password\")]},hc:{name:\"fetchSignInMethodsForEmail\",j:[V(\"email\")]},qa:{name:\"getRedirectResult\",j:[]},Bc:{name:\"isSignInWithEmailLink\",j:[V(\"emailLink\")]},Hc:{name:\"onAuthStateChanged\",j:[X(W(),xo(),\"nextOrObserver\"),xo(\"opt_error\",!0),xo(\"opt_completed\",!0)]},Ic:{name:\"onIdTokenChanged\",\nj:[X(W(),xo(),\"nextOrObserver\"),xo(\"opt_error\",!0),xo(\"opt_completed\",!0)]},vb:{name:\"sendPasswordResetEmail\",j:[V(\"email\"),X(W(\"opt_actionCodeSettings\",!0),yo(null,!0),\"opt_actionCodeSettings\",!0)]},wb:{name:\"sendSignInLinkToEmail\",j:[V(\"email\"),W(\"actionCodeSettings\")]},xb:{name:\"setPersistence\",j:[V(\"persistence\")]},Sc:{name:\"signInAndRetrieveDataWithCredential\",j:[Co()]},zb:{name:\"signInAnonymously\",j:[]},$a:{name:\"signInWithCredential\",j:[Co()]},Tc:{name:\"signInWithCustomToken\",j:[V(\"token\")]},\nUc:{name:\"signInWithEmailAndPassword\",j:[V(\"email\"),V(\"password\")]},Vc:{name:\"signInWithEmailLink\",j:[V(\"email\"),V(\"emailLink\",!0)]},Wc:{name:\"signInWithPhoneNumber\",j:[V(\"phoneNumber\"),Ho()]},Xc:{name:\"signInWithPopup\",j:[Eo()]},Yc:{name:\"signInWithRedirect\",j:[Eo()]},dd:{name:\"updateCurrentUser\",j:[X(function(a){return{name:\"user\",K:\"an instance of Firebase User\",optional:!!a,M:function(b){return!!(b&&b instanceof Im)}}}(),yo(),\"user\")]},Ab:{name:\"signOut\",j:[]},toJSON:{name:\"toJSON\",j:[V(null,\n!0)]},fd:{name:\"useDeviceLanguage\",j:[]},gd:{name:\"useEmulator\",j:[V(\"url\"),W(\"options\",!0)]},jd:{name:\"verifyPasswordResetCode\",j:[V(\"code\")]}});Jo(En.prototype,{lc:{name:\"languageCode\",kb:X(V(),yo(),\"languageCode\")},ti:{name:\"tenantId\",kb:X(V(),yo(),\"tenantId\")}});En.Persistence=Rk;En.Persistence.LOCAL=\"local\";En.Persistence.SESSION=\"session\";En.Persistence.NONE=\"none\";\nY(Im.prototype,{\"delete\":{name:\"delete\",j:[]},oc:{name:\"getIdTokenResult\",j:[wo(\"opt_forceRefresh\",!0)]},I:{name:\"getIdToken\",j:[wo(\"opt_forceRefresh\",!0)]},Cc:{name:\"linkAndRetrieveDataWithCredential\",j:[Co()]},qb:{name:\"linkWithCredential\",j:[Co()]},Dc:{name:\"linkWithPhoneNumber\",j:[V(\"phoneNumber\"),Ho()]},Ec:{name:\"linkWithPopup\",j:[Eo()]},Fc:{name:\"linkWithRedirect\",j:[Eo()]},Lc:{name:\"reauthenticateAndRetrieveDataWithCredential\",j:[Co()]},tb:{name:\"reauthenticateWithCredential\",j:[Co()]},Mc:{name:\"reauthenticateWithPhoneNumber\",\nj:[V(\"phoneNumber\"),Ho()]},Nc:{name:\"reauthenticateWithPopup\",j:[Eo()]},Oc:{name:\"reauthenticateWithRedirect\",j:[Eo()]},reload:{name:\"reload\",j:[]},ub:{name:\"sendEmailVerification\",j:[X(W(\"opt_actionCodeSettings\",!0),yo(null,!0),\"opt_actionCodeSettings\",!0)]},toJSON:{name:\"toJSON\",j:[V(null,!0)]},cd:{name:\"unlink\",j:[V(\"provider\")]},Bb:{name:\"updateEmail\",j:[V(\"email\")]},Cb:{name:\"updatePassword\",j:[V(\"password\")]},ed:{name:\"updatePhoneNumber\",j:[Co(\"phone\")]},Db:{name:\"updateProfile\",j:[W(\"profile\")]},\nEb:{name:\"verifyBeforeUpdateEmail\",j:[V(\"email\"),X(W(\"opt_actionCodeSettings\",!0),yo(null,!0),\"opt_actionCodeSettings\",!0)]}});Y(Xn.prototype,{execute:{name:\"execute\"},render:{name:\"render\"},reset:{name:\"reset\"},getResponse:{name:\"getResponse\"}});Y(Wn.prototype,{execute:{name:\"execute\"},render:{name:\"render\"},reset:{name:\"reset\"},getResponse:{name:\"getResponse\"}});Y(D.prototype,{oa:{name:\"finally\"},o:{name:\"catch\"},then:{name:\"then\"}});\nJo(em.prototype,{appVerificationDisabled:{name:\"appVerificationDisabledForTesting\",kb:wo(\"appVerificationDisabledForTesting\")}});Y(fm.prototype,{confirm:{name:\"confirm\",j:[V(\"verificationCode\")]}});Z(Bg,\"fromJSON\",function(a){a=\"string\"===typeof a?JSON.parse(a):a;for(var b,c=[Mg,dh,kh,Jg],d=0;d<c.length;d++)if(b=c[d](a))return b;return null},[X(V(),W(),\"json\")]);Z(Zg,\"credential\",function(a,b){return new Yg(a,b)},[V(\"email\"),V(\"password\")]);Y(Yg.prototype,{w:{name:\"toJSON\",j:[V(null,!0)]}});\nY(Qg.prototype,{Ca:{name:\"addScope\",j:[V(\"scope\")]},Ka:{name:\"setCustomParameters\",j:[W(\"customOAuthParameters\")]}});Z(Qg,\"credential\",Rg,[X(V(),W(),\"token\")]);Z(Zg,\"credentialWithLink\",eh,[V(\"email\"),V(\"emailLink\")]);Y(Sg.prototype,{Ca:{name:\"addScope\",j:[V(\"scope\")]},Ka:{name:\"setCustomParameters\",j:[W(\"customOAuthParameters\")]}});Z(Sg,\"credential\",Tg,[X(V(),W(),\"token\")]);Y(Ug.prototype,{Ca:{name:\"addScope\",j:[V(\"scope\")]},Ka:{name:\"setCustomParameters\",j:[W(\"customOAuthParameters\")]}});\nZ(Ug,\"credential\",Vg,[X(V(),X(W(),yo()),\"idToken\"),X(V(),yo(),\"accessToken\",!0)]);Y(Wg.prototype,{Ka:{name:\"setCustomParameters\",j:[W(\"customOAuthParameters\")]}});Z(Wg,\"credential\",Xg,[X(V(),W(),\"token\"),V(\"secret\",!0)]);Y(Pg.prototype,{Ca:{name:\"addScope\",j:[V(\"scope\")]},credential:{name:\"credential\",j:[X(V(),X(W(),yo()),\"optionsOrIdToken\"),X(V(),yo(),\"accessToken\",!0)]},Ka:{name:\"setCustomParameters\",j:[W(\"customOAuthParameters\")]}});Y(Kg.prototype,{w:{name:\"toJSON\",j:[V(null,!0)]}});\nY(Eg.prototype,{w:{name:\"toJSON\",j:[V(null,!0)]}});Z(lh,\"credential\",ph,[V(\"verificationId\"),V(\"verificationCode\")]);\nY(lh.prototype,{fb:{name:\"verifyPhoneNumber\",j:[X(V(),function(a,b){return{name:a||\"phoneInfoOptions\",K:\"valid phone info options\",optional:!!b,M:function(c){return c?c.session&&c.phoneNumber?Fo(c.session,zg)&&\"string\"===typeof c.phoneNumber:c.session&&c.multiFactorHint?Fo(c.session,Ag)&&Go(c.multiFactorHint):c.session&&c.multiFactorUid?Fo(c.session,Ag)&&\"string\"===typeof c.multiFactorUid:c.phoneNumber?\"string\"===typeof c.phoneNumber:!1:!1}}}(),\"phoneInfoOptions\"),Ho()]}});\nY(gh.prototype,{w:{name:\"toJSON\",j:[V(null,!0)]}});Y(t.prototype,{toJSON:{name:\"toJSON\",j:[V(null,!0)]}});Y(yh.prototype,{toJSON:{name:\"toJSON\",j:[V(null,!0)]}});Y(xh.prototype,{toJSON:{name:\"toJSON\",j:[V(null,!0)]}});Y(lm.prototype,{toJSON:{name:\"toJSON\",j:[V(null,!0)]}});Y(im.prototype,{Rc:{name:\"resolveSignIn\",j:[Do()]}});\nY(tm.prototype,{Rb:{name:\"getSession\",j:[]},fc:{name:\"enroll\",j:[Do(),V(\"displayName\",!0)]},bd:{name:\"unenroll\",j:[X({name:\"multiFactorInfo\",K:\"a valid multiFactorInfo\",optional:!1,M:Go},V(),\"multiFactorInfoIdentifier\")]}});Y(to.prototype,{clear:{name:\"clear\",j:[]},render:{name:\"render\",j:[]},verify:{name:\"verify\",j:[]}});Z(Jf,\"parseLink\",Rf,[V(\"link\")]);Z(co,\"assertion\",function(a){return new rm(a)},[Co(\"phone\")]);\n(function(){if(\"undefined\"!==typeof firebase&&firebase.INTERNAL&&firebase.INTERNAL.registerComponent){var a={ActionCodeInfo:{Operation:{EMAIL_SIGNIN:Af,PASSWORD_RESET:\"PASSWORD_RESET\",RECOVER_EMAIL:\"RECOVER_EMAIL\",REVERT_SECOND_FACTOR_ADDITION:Cf,VERIFY_AND_CHANGE_EMAIL:Bf,VERIFY_EMAIL:\"VERIFY_EMAIL\"}},Auth:En,AuthCredential:Bg,Error:t};Z(a,\"EmailAuthProvider\",Zg,[]);Z(a,\"FacebookAuthProvider\",Qg,[]);Z(a,\"GithubAuthProvider\",Sg,[]);Z(a,\"GoogleAuthProvider\",Ug,[]);Z(a,\"TwitterAuthProvider\",Wg,[]);\nZ(a,\"OAuthProvider\",Pg,[V(\"providerId\")]);Z(a,\"SAMLAuthProvider\",Og,[V(\"providerId\")]);Z(a,\"PhoneAuthProvider\",lh,[Ao()]);Z(a,\"RecaptchaVerifier\",to,[X(V(),zo(),\"recaptchaContainer\"),W(\"recaptchaParameters\",!0),Bo()]);Z(a,\"ActionCodeURL\",Jf,[]);Z(a,\"PhoneMultiFactorGenerator\",co,[]);firebase.INTERNAL.registerComponent({name:\"auth\",instanceFactory:function(b){b=b.getProvider(\"app\").getImmediate();return new En(b)},multipleInstances:!1,serviceProps:a,instantiationMode:\"LAZY\",type:\"PUBLIC\"});firebase.INTERNAL.registerComponent({name:\"auth-internal\",\ninstanceFactory:function(b){b=b.getProvider(\"auth\").getImmediate();return{getUid:q(b.getUid,b),getToken:q(b.nc,b),addAuthTokenListener:q(b.cc,b),removeAuthTokenListener:q(b.Pc,b)}},multipleInstances:!1,instantiationMode:\"LAZY\",type:\"PRIVATE\"});firebase.registerVersion(\"@firebase/auth\",\"0.16.4\");firebase.INTERNAL.extendNamespace({User:Im})}else throw Error(\"Cannot find the firebase namespace; be sure to include firebase-app.js before this library.\");})();}).apply(typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : typeof window !== 'undefined' ? window : {});\n\n//# sourceMappingURL=auth.esm.js.map\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { jsonEval, stringify } from '@firebase/util';\n\n/**\n * Wraps a DOM Storage object and:\n * - automatically encode objects as JSON strings before storing them to allow us to store arbitrary types.\n * - prefixes names with \"firebase:\" to avoid collisions with app data.\n *\n * We automatically (see storage.js) create two such wrappers, one for sessionStorage,\n * and one for localStorage.\n *\n */\nexport class DOMStorageWrapper {\n  // Use a prefix to avoid collisions with other stuff saved by the app.\n  private prefix_ = 'firebase:';\n\n  /**\n   * @param domStorage_ The underlying storage object (e.g. localStorage or sessionStorage)\n   */\n  constructor(private domStorage_: Storage) {}\n\n  /**\n   * @param key The key to save the value under\n   * @param value The value being stored, or null to remove the key.\n   */\n  set(key: string, value: unknown | null) {\n    if (value == null) {\n      this.domStorage_.removeItem(this.prefixedName_(key));\n    } else {\n      this.domStorage_.setItem(this.prefixedName_(key), stringify(value));\n    }\n  }\n\n  /**\n   * @return The value that was stored under this key, or null\n   */\n  get(key: string): unknown {\n    const storedVal = this.domStorage_.getItem(this.prefixedName_(key));\n    if (storedVal == null) {\n      return null;\n    } else {\n      return jsonEval(storedVal);\n    }\n  }\n\n  remove(key: string) {\n    this.domStorage_.removeItem(this.prefixedName_(key));\n  }\n\n  isInMemoryStorage: boolean;\n\n  prefixedName_(name: string): string {\n    return this.prefix_ + name;\n  }\n\n  toString(): string {\n    return this.domStorage_.toString();\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { contains } from '@firebase/util';\n\n/**\n * An in-memory storage implementation that matches the API of DOMStorageWrapper\n * (TODO: create interface for both to implement).\n */\nexport class MemoryStorage {\n  private cache_: { [k: string]: unknown } = {};\n\n  set(key: string, value: unknown | null) {\n    if (value == null) {\n      delete this.cache_[key];\n    } else {\n      this.cache_[key] = value;\n    }\n  }\n\n  get(key: string): unknown {\n    if (contains(this.cache_, key)) {\n      return this.cache_[key];\n    }\n    return null;\n  }\n\n  remove(key: string) {\n    delete this.cache_[key];\n  }\n\n  isInMemoryStorage = true;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { DOMStorageWrapper } from './DOMStorageWrapper';\nimport { MemoryStorage } from './MemoryStorage';\n\ndeclare const window: Window;\n\n/**\n * Helper to create a DOMStorageWrapper or else fall back to MemoryStorage.\n * TODO: Once MemoryStorage and DOMStorageWrapper have a shared interface this method annotation should change\n * to reflect this type\n *\n * @param domStorageName Name of the underlying storage object\n *   (e.g. 'localStorage' or 'sessionStorage').\n * @return Turning off type information until a common interface is defined.\n */\nconst createStoragefor = function (\n  domStorageName: string\n): DOMStorageWrapper | MemoryStorage {\n  try {\n    // NOTE: just accessing \"localStorage\" or \"window['localStorage']\" may throw a security exception,\n    // so it must be inside the try/catch.\n    if (\n      typeof window !== 'undefined' &&\n      typeof window[domStorageName] !== 'undefined'\n    ) {\n      // Need to test cache. Just because it's here doesn't mean it works\n      const domStorage = window[domStorageName];\n      domStorage.setItem('firebase:sentinel', 'cache');\n      domStorage.removeItem('firebase:sentinel');\n      return new DOMStorageWrapper(domStorage);\n    }\n  } catch (e) {}\n\n  // Failed to create wrapper.  Just return in-memory storage.\n  // TODO: log?\n  return new MemoryStorage();\n};\n\n/** A storage object that lasts across sessions */\nexport const PersistentStorage = createStoragefor('localStorage');\n\n/** A storage object that only lasts one session */\nexport const SessionStorage = createStoragefor('sessionStorage');\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Query } from '../../api/Query';\nimport {\n  assert,\n  base64,\n  Sha1,\n  stringToByteArray,\n  stringify,\n  isNodeSdk\n} from '@firebase/util';\nimport { SessionStorage } from '../storage/storage';\nimport { Logger, LogLevel } from '@firebase/logger';\n\ndeclare const window: Window;\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ndeclare const Windows: any;\n\nconst logClient = new Logger('@firebase/database');\n\n/**\n * Returns a locally-unique ID (generated by just incrementing up from 0 each time its called).\n */\nexport const LUIDGenerator: () => number = (function () {\n  let id = 1;\n  return function () {\n    return id++;\n  };\n})();\n\n/**\n * Sha1 hash of the input string\n * @param str The string to hash\n * @return {!string} The resulting hash\n */\nexport const sha1 = function (str: string): string {\n  const utf8Bytes = stringToByteArray(str);\n  const sha1 = new Sha1();\n  sha1.update(utf8Bytes);\n  const sha1Bytes = sha1.digest();\n  return base64.encodeByteArray(sha1Bytes);\n};\n\nconst buildLogMessage_ = function (...varArgs: unknown[]): string {\n  let message = '';\n  for (let i = 0; i < varArgs.length; i++) {\n    const arg = varArgs[i];\n    if (\n      Array.isArray(arg) ||\n      (arg &&\n        typeof arg === 'object' &&\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        typeof (arg as any).length === 'number')\n    ) {\n      message += buildLogMessage_.apply(null, arg);\n    } else if (typeof arg === 'object') {\n      message += stringify(arg);\n    } else {\n      message += arg;\n    }\n    message += ' ';\n  }\n\n  return message;\n};\n\n/**\n * Use this for all debug messages in Firebase.\n */\nexport let logger: ((a: string) => void) | null = null;\n\n/**\n * Flag to check for log availability on first log message\n */\nlet firstLog_ = true;\n\n/**\n * The implementation of Firebase.enableLogging (defined here to break dependencies)\n * @param logger_ A flag to turn on logging, or a custom logger\n * @param persistent Whether or not to persist logging settings across refreshes\n */\nexport const enableLogging = function (\n  logger_?: boolean | ((a: string) => void) | null,\n  persistent?: boolean\n) {\n  assert(\n    !persistent || logger_ === true || logger_ === false,\n    \"Can't turn on custom loggers persistently.\"\n  );\n  if (logger_ === true) {\n    logClient.logLevel = LogLevel.VERBOSE;\n    logger = logClient.log.bind(logClient);\n    if (persistent) {\n      SessionStorage.set('logging_enabled', true);\n    }\n  } else if (typeof logger_ === 'function') {\n    logger = logger_;\n  } else {\n    logger = null;\n    SessionStorage.remove('logging_enabled');\n  }\n};\n\nexport const log = function (...varArgs: unknown[]) {\n  if (firstLog_ === true) {\n    firstLog_ = false;\n    if (logger === null && SessionStorage.get('logging_enabled') === true) {\n      enableLogging(true);\n    }\n  }\n\n  if (logger) {\n    const message = buildLogMessage_.apply(null, varArgs);\n    logger(message);\n  }\n};\n\nexport const logWrapper = function (\n  prefix: string\n): (...varArgs: unknown[]) => void {\n  return function (...varArgs: unknown[]) {\n    log(prefix, ...varArgs);\n  };\n};\n\nexport const error = function (...varArgs: string[]) {\n  const message = 'FIREBASE INTERNAL ERROR: ' + buildLogMessage_(...varArgs);\n  logClient.error(message);\n};\n\nexport const fatal = function (...varArgs: string[]) {\n  const message = `FIREBASE FATAL ERROR: ${buildLogMessage_(...varArgs)}`;\n  logClient.error(message);\n  throw new Error(message);\n};\n\nexport const warn = function (...varArgs: unknown[]) {\n  const message = 'FIREBASE WARNING: ' + buildLogMessage_(...varArgs);\n  logClient.warn(message);\n};\n\n/**\n * Logs a warning if the containing page uses https. Called when a call to new Firebase\n * does not use https.\n */\nexport const warnIfPageIsSecure = function () {\n  // Be very careful accessing browser globals. Who knows what may or may not exist.\n  if (\n    typeof window !== 'undefined' &&\n    window.location &&\n    window.location.protocol &&\n    window.location.protocol.indexOf('https:') !== -1\n  ) {\n    warn(\n      'Insecure Firebase access from a secure page. ' +\n        'Please use https in calls to new Firebase().'\n    );\n  }\n};\n\nexport const warnAboutUnsupportedMethod = function (methodName: string) {\n  warn(\n    methodName +\n      ' is unsupported and will likely change soon.  ' +\n      'Please do not use.'\n  );\n};\n\n/**\n * Returns true if data is NaN, or +/- Infinity.\n */\nexport const isInvalidJSONNumber = function (data: unknown): boolean {\n  return (\n    typeof data === 'number' &&\n    (data !== data || // NaN\n      data === Number.POSITIVE_INFINITY ||\n      data === Number.NEGATIVE_INFINITY)\n  );\n};\n\nexport const executeWhenDOMReady = function (fn: () => void) {\n  if (isNodeSdk() || document.readyState === 'complete') {\n    fn();\n  } else {\n    // Modeled after jQuery. Try DOMContentLoaded and onreadystatechange (which\n    // fire before onload), but fall back to onload.\n\n    let called = false;\n    const wrappedFn = function () {\n      if (!document.body) {\n        setTimeout(wrappedFn, Math.floor(10));\n        return;\n      }\n\n      if (!called) {\n        called = true;\n        fn();\n      }\n    };\n\n    if (document.addEventListener) {\n      document.addEventListener('DOMContentLoaded', wrappedFn, false);\n      // fallback to onload.\n      window.addEventListener('load', wrappedFn, false);\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    } else if ((document as any).attachEvent) {\n      // IE.\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      (document as any).attachEvent('onreadystatechange', () => {\n        if (document.readyState === 'complete') {\n          wrappedFn();\n        }\n      });\n      // fallback to onload.\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      (window as any).attachEvent('onload', wrappedFn);\n\n      // jQuery has an extra hack for IE that we could employ (based on\n      // http://javascript.nwbox.com/IEContentLoaded/) But it looks really old.\n      // I'm hoping we don't need it.\n    }\n  }\n};\n\n/**\n * Minimum key name. Invalid for actual data, used as a marker to sort before any valid names\n */\nexport const MIN_NAME = '[MIN_NAME]';\n\n/**\n * Maximum key name. Invalid for actual data, used as a marker to sort above any valid names\n */\nexport const MAX_NAME = '[MAX_NAME]';\n\n/**\n * Compares valid Firebase key names, plus min and max name\n */\nexport const nameCompare = function (a: string, b: string): number {\n  if (a === b) {\n    return 0;\n  } else if (a === MIN_NAME || b === MAX_NAME) {\n    return -1;\n  } else if (b === MIN_NAME || a === MAX_NAME) {\n    return 1;\n  } else {\n    const aAsInt = tryParseInt(a),\n      bAsInt = tryParseInt(b);\n\n    if (aAsInt !== null) {\n      if (bAsInt !== null) {\n        return aAsInt - bAsInt === 0 ? a.length - b.length : aAsInt - bAsInt;\n      } else {\n        return -1;\n      }\n    } else if (bAsInt !== null) {\n      return 1;\n    } else {\n      return a < b ? -1 : 1;\n    }\n  }\n};\n\n/**\n * @return {!number} comparison result.\n */\nexport const stringCompare = function (a: string, b: string): number {\n  if (a === b) {\n    return 0;\n  } else if (a < b) {\n    return -1;\n  } else {\n    return 1;\n  }\n};\n\nexport const requireKey = function (\n  key: string,\n  obj: { [k: string]: unknown }\n): unknown {\n  if (obj && key in obj) {\n    return obj[key];\n  } else {\n    throw new Error(\n      'Missing required key (' + key + ') in object: ' + stringify(obj)\n    );\n  }\n};\n\nexport const ObjectToUniqueKey = function (obj: unknown): string {\n  if (typeof obj !== 'object' || obj === null) {\n    return stringify(obj);\n  }\n\n  const keys = [];\n  // eslint-disable-next-line guard-for-in\n  for (const k in obj) {\n    keys.push(k);\n  }\n\n  // Export as json, but with the keys sorted.\n  keys.sort();\n  let key = '{';\n  for (let i = 0; i < keys.length; i++) {\n    if (i !== 0) {\n      key += ',';\n    }\n    key += stringify(keys[i]);\n    key += ':';\n    key += ObjectToUniqueKey(obj[keys[i]]);\n  }\n\n  key += '}';\n  return key;\n};\n\n/**\n * Splits a string into a number of smaller segments of maximum size\n * @param str The string\n * @param segsize The maximum number of chars in the string.\n * @return The string, split into appropriately-sized chunks\n */\nexport const splitStringBySize = function (\n  str: string,\n  segsize: number\n): string[] {\n  const len = str.length;\n\n  if (len <= segsize) {\n    return [str];\n  }\n\n  const dataSegs = [];\n  for (let c = 0; c < len; c += segsize) {\n    if (c + segsize > len) {\n      dataSegs.push(str.substring(c, len));\n    } else {\n      dataSegs.push(str.substring(c, c + segsize));\n    }\n  }\n  return dataSegs;\n};\n\n/**\n * Apply a function to each (key, value) pair in an object or\n * apply a function to each (index, value) pair in an array\n * @param obj The object or array to iterate over\n * @param fn The function to apply\n */\nexport function each(obj: object, fn: (k: string, v: unknown) => void) {\n  for (const key in obj) {\n    if (obj.hasOwnProperty(key)) {\n      fn(key, obj[key]);\n    }\n  }\n}\n\n/**\n * Like goog.bind, but doesn't bother to create a closure if opt_context is null/undefined.\n * @param callback Callback function.\n * @param context Optional context to bind to.\n *\n */\nexport const bindCallback = function (\n  callback: (a: unknown) => void,\n  context?: object | null\n): (a: unknown) => void {\n  return context ? callback.bind(context) : callback;\n};\n\n/**\n * Borrowed from http://hg.secondlife.com/llsd/src/tip/js/typedarray.js (MIT License)\n * I made one modification at the end and removed the NaN / Infinity\n * handling (since it seemed broken [caused an overflow] and we don't need it).  See MJL comments.\n * @param v A double\n *\n */\nexport const doubleToIEEE754String = function (v: number): string {\n  assert(!isInvalidJSONNumber(v), 'Invalid JSON number'); // MJL\n\n  const ebits = 11,\n    fbits = 52;\n  const bias = (1 << (ebits - 1)) - 1;\n  let s, e, f, ln, i;\n\n  // Compute sign, exponent, fraction\n  // Skip NaN / Infinity handling --MJL.\n  if (v === 0) {\n    e = 0;\n    f = 0;\n    s = 1 / v === -Infinity ? 1 : 0;\n  } else {\n    s = v < 0;\n    v = Math.abs(v);\n\n    if (v >= Math.pow(2, 1 - bias)) {\n      // Normalized\n      ln = Math.min(Math.floor(Math.log(v) / Math.LN2), bias);\n      e = ln + bias;\n      f = Math.round(v * Math.pow(2, fbits - ln) - Math.pow(2, fbits));\n    } else {\n      // Denormalized\n      e = 0;\n      f = Math.round(v / Math.pow(2, 1 - bias - fbits));\n    }\n  }\n\n  // Pack sign, exponent, fraction\n  const bits = [];\n  for (i = fbits; i; i -= 1) {\n    bits.push(f % 2 ? 1 : 0);\n    f = Math.floor(f / 2);\n  }\n  for (i = ebits; i; i -= 1) {\n    bits.push(e % 2 ? 1 : 0);\n    e = Math.floor(e / 2);\n  }\n  bits.push(s ? 1 : 0);\n  bits.reverse();\n  const str = bits.join('');\n\n  // Return the data as a hex string. --MJL\n  let hexByteString = '';\n  for (i = 0; i < 64; i += 8) {\n    let hexByte = parseInt(str.substr(i, 8), 2).toString(16);\n    if (hexByte.length === 1) {\n      hexByte = '0' + hexByte;\n    }\n    hexByteString = hexByteString + hexByte;\n  }\n  return hexByteString.toLowerCase();\n};\n\n/**\n * Used to detect if we're in a Chrome content script (which executes in an\n * isolated environment where long-polling doesn't work).\n */\nexport const isChromeExtensionContentScript = function (): boolean {\n  return !!(\n    typeof window === 'object' &&\n    window['chrome'] &&\n    window['chrome']['extension'] &&\n    !/^chrome/.test(window.location.href)\n  );\n};\n\n/**\n * Used to detect if we're in a Windows 8 Store app.\n */\nexport const isWindowsStoreApp = function (): boolean {\n  // Check for the presence of a couple WinRT globals\n  return typeof Windows === 'object' && typeof Windows.UI === 'object';\n};\n\n/**\n * Converts a server error code to a Javascript Error\n */\nexport const errorForServerCode = function (code: string, query: Query): Error {\n  let reason = 'Unknown Error';\n  if (code === 'too_big') {\n    reason =\n      'The data requested exceeds the maximum size ' +\n      'that can be accessed with a single request.';\n  } else if (code === 'permission_denied') {\n    reason = \"Client doesn't have permission to access the desired data.\";\n  } else if (code === 'unavailable') {\n    reason = 'The service is unavailable';\n  }\n\n  const error = new Error(\n    code + ' at ' + query.path.toString() + ': ' + reason\n  );\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  (error as any).code = code.toUpperCase();\n  return error;\n};\n\n/**\n * Used to test for integer-looking strings\n */\nexport const INTEGER_REGEXP_ = new RegExp('^-?(0*)\\\\d{1,10}$');\n\n/**\n * For use in keys, the minimum possible 32-bit integer.\n */\nexport const INTEGER_32_MIN = -2147483648;\n\n/**\n * For use in kyes, the maximum possible 32-bit integer.\n */\nexport const INTEGER_32_MAX = 2147483647;\n\n/**\n * If the string contains a 32-bit integer, return it.  Else return null.\n */\nexport const tryParseInt = function (str: string): number | null {\n  if (INTEGER_REGEXP_.test(str)) {\n    const intVal = Number(str);\n    if (intVal >= INTEGER_32_MIN && intVal <= INTEGER_32_MAX) {\n      return intVal;\n    }\n  }\n  return null;\n};\n\n/**\n * Helper to run some code but catch any exceptions and re-throw them later.\n * Useful for preventing user callbacks from breaking internal code.\n *\n * Re-throwing the exception from a setTimeout is a little evil, but it's very\n * convenient (we don't have to try to figure out when is a safe point to\n * re-throw it), and the behavior seems reasonable:\n *\n * * If you aren't pausing on exceptions, you get an error in the console with\n *   the correct stack trace.\n * * If you're pausing on all exceptions, the debugger will pause on your\n *   exception and then again when we rethrow it.\n * * If you're only pausing on uncaught exceptions, the debugger will only pause\n *   on us re-throwing it.\n *\n * @param fn The code to guard.\n */\nexport const exceptionGuard = function (fn: () => void) {\n  try {\n    fn();\n  } catch (e) {\n    // Re-throw exception when it's safe.\n    setTimeout(() => {\n      // It used to be that \"throw e\" would result in a good console error with\n      // relevant context, but as of Chrome 39, you just get the firebase.js\n      // file/line number where we re-throw it, which is useless. So we log\n      // e.stack explicitly.\n      const stack = e.stack || '';\n      warn('Exception was thrown by user callback.', stack);\n      throw e;\n    }, Math.floor(0));\n  }\n};\n\n/**\n * Helper function to safely call opt_callback with the specified arguments.  It:\n * 1. Turns into a no-op if opt_callback is null or undefined.\n * 2. Wraps the call inside exceptionGuard to prevent exceptions from breaking our state.\n *\n * @param callback Optional onComplete callback.\n * @param varArgs Arbitrary args to be passed to opt_onComplete\n */\nexport const callUserCallback = function (\n  // eslint-disable-next-line @typescript-eslint/ban-types\n  callback?: Function | null,\n  ...varArgs: unknown[]\n) {\n  if (typeof callback === 'function') {\n    exceptionGuard(() => {\n      callback(...varArgs);\n    });\n  }\n};\n\n/**\n * @return {boolean} true if we think we're currently being crawled.\n */\nexport const beingCrawled = function (): boolean {\n  const userAgent =\n    (typeof window === 'object' &&\n      window['navigator'] &&\n      window['navigator']['userAgent']) ||\n    '';\n\n  // For now we whitelist the most popular crawlers.  We should refine this to be the set of crawlers we\n  // believe to support JavaScript/AJAX rendering.\n  // NOTE: Google Webmaster Tools doesn't really belong, but their \"This is how a visitor to your website\n  // would have seen the page\" is flaky if we don't treat it as a crawler.\n  return (\n    userAgent.search(\n      /googlebot|google webmaster tools|bingbot|yahoo! slurp|baiduspider|yandexbot|duckduckbot/i\n    ) >= 0\n  );\n};\n\n/**\n * Export a property of an object using a getter function.\n */\nexport const exportPropGetter = function (\n  object: object,\n  name: string,\n  fnGet: () => unknown\n) {\n  Object.defineProperty(object, name, { get: fnGet });\n};\n\n/**\n * Same as setTimeout() except on Node.JS it will /not/ prevent the process from exiting.\n *\n * It is removed with clearTimeout() as normal.\n *\n * @param fn Function to run.\n * @param time Milliseconds to wait before running.\n * @return The setTimeout() return value.\n */\nexport const setTimeoutNonBlocking = function (\n  fn: () => void,\n  time: number\n): number | object {\n  const timeout: number | object = setTimeout(fn, time);\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  if (typeof timeout === 'object' && (timeout as any)['unref']) {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    (timeout as any)['unref']();\n  }\n  return timeout;\n};\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { nameCompare } from './util';\nimport { stringLength } from '@firebase/util';\n\n/** Maximum key depth. */\nconst MAX_PATH_DEPTH = 32;\n\n/** Maximum number of (UTF8) bytes in a Firebase path. */\nconst MAX_PATH_LENGTH_BYTES = 768;\n\n/**\n * An immutable object representing a parsed path.  It's immutable so that you\n * can pass them around to other functions without worrying about them changing\n * it.\n */\n\nexport class Path {\n  pieces_: string[];\n  pieceNum_: number;\n\n  /**\n   * @param pathOrString Path string to parse, or another path, or the raw\n   * tokens array\n   */\n  constructor(pathOrString: string | string[], pieceNum?: number) {\n    if (pieceNum === void 0) {\n      this.pieces_ = (pathOrString as string).split('/');\n\n      // Remove empty pieces.\n      let copyTo = 0;\n      for (let i = 0; i < this.pieces_.length; i++) {\n        if (this.pieces_[i].length > 0) {\n          this.pieces_[copyTo] = this.pieces_[i];\n          copyTo++;\n        }\n      }\n      this.pieces_.length = copyTo;\n\n      this.pieceNum_ = 0;\n    } else {\n      this.pieces_ = pathOrString as string[];\n      this.pieceNum_ = pieceNum;\n    }\n  }\n\n  toString(): string {\n    let pathString = '';\n    for (let i = this.pieceNum_; i < this.pieces_.length; i++) {\n      if (this.pieces_[i] !== '') {\n        pathString += '/' + this.pieces_[i];\n      }\n    }\n\n    return pathString || '/';\n  }\n}\n\nexport function newEmptyPath(): Path {\n  return new Path('');\n}\n\nexport function pathGetFront(path: Path): string | null {\n  if (path.pieceNum_ >= path.pieces_.length) {\n    return null;\n  }\n\n  return path.pieces_[path.pieceNum_];\n}\n\n/**\n * @return The number of segments in this path\n */\nexport function pathGetLength(path: Path): number {\n  return path.pieces_.length - path.pieceNum_;\n}\n\nexport function pathPopFront(path: Path): Path {\n  let pieceNum = path.pieceNum_;\n  if (pieceNum < path.pieces_.length) {\n    pieceNum++;\n  }\n  return new Path(path.pieces_, pieceNum);\n}\n\nexport function pathGetBack(path: Path): string | null {\n  if (path.pieceNum_ < path.pieces_.length) {\n    return path.pieces_[path.pieces_.length - 1];\n  }\n\n  return null;\n}\n\nexport function pathToUrlEncodedString(path: Path): string {\n  let pathString = '';\n  for (let i = path.pieceNum_; i < path.pieces_.length; i++) {\n    if (path.pieces_[i] !== '') {\n      pathString += '/' + encodeURIComponent(String(path.pieces_[i]));\n    }\n  }\n\n  return pathString || '/';\n}\n\n/**\n * Shallow copy of the parts of the path.\n *\n */\nexport function pathSlice(path: Path, begin: number = 0): string[] {\n  return path.pieces_.slice(path.pieceNum_ + begin);\n}\n\nexport function pathParent(path: Path): Path | null {\n  if (path.pieceNum_ >= path.pieces_.length) {\n    return null;\n  }\n\n  const pieces = [];\n  for (let i = path.pieceNum_; i < path.pieces_.length - 1; i++) {\n    pieces.push(path.pieces_[i]);\n  }\n\n  return new Path(pieces, 0);\n}\n\nexport function pathChild(path: Path, childPathObj: string | Path): Path {\n  const pieces = [];\n  for (let i = path.pieceNum_; i < path.pieces_.length; i++) {\n    pieces.push(path.pieces_[i]);\n  }\n\n  if (childPathObj instanceof Path) {\n    for (let i = childPathObj.pieceNum_; i < childPathObj.pieces_.length; i++) {\n      pieces.push(childPathObj.pieces_[i]);\n    }\n  } else {\n    const childPieces = childPathObj.split('/');\n    for (let i = 0; i < childPieces.length; i++) {\n      if (childPieces[i].length > 0) {\n        pieces.push(childPieces[i]);\n      }\n    }\n  }\n\n  return new Path(pieces, 0);\n}\n\n/**\n * @return True if there are no segments in this path\n */\nexport function pathIsEmpty(path: Path): boolean {\n  return path.pieceNum_ >= path.pieces_.length;\n}\n\n/**\n * @return The path from outerPath to innerPath\n */\nexport function newRelativePath(outerPath: Path, innerPath: Path): Path {\n  const outer = pathGetFront(outerPath),\n    inner = pathGetFront(innerPath);\n  if (outer === null) {\n    return innerPath;\n  } else if (outer === inner) {\n    return newRelativePath(pathPopFront(outerPath), pathPopFront(innerPath));\n  } else {\n    throw new Error(\n      'INTERNAL ERROR: innerPath (' +\n        innerPath +\n        ') is not within ' +\n        'outerPath (' +\n        outerPath +\n        ')'\n    );\n  }\n}\n\n/**\n * @return -1, 0, 1 if left is less, equal, or greater than the right.\n */\nexport function pathCompare(left: Path, right: Path): number {\n  const leftKeys = pathSlice(left, 0);\n  const rightKeys = pathSlice(right, 0);\n  for (let i = 0; i < leftKeys.length && i < rightKeys.length; i++) {\n    const cmp = nameCompare(leftKeys[i], rightKeys[i]);\n    if (cmp !== 0) {\n      return cmp;\n    }\n  }\n  if (leftKeys.length === rightKeys.length) {\n    return 0;\n  }\n  return leftKeys.length < rightKeys.length ? -1 : 1;\n}\n\n/**\n * @return true if paths are the same.\n */\nexport function pathEquals(path: Path, other: Path): boolean {\n  if (pathGetLength(path) !== pathGetLength(other)) {\n    return false;\n  }\n\n  for (\n    let i = path.pieceNum_, j = other.pieceNum_;\n    i <= path.pieces_.length;\n    i++, j++\n  ) {\n    if (path.pieces_[i] !== other.pieces_[j]) {\n      return false;\n    }\n  }\n\n  return true;\n}\n\n/**\n * @return True if this path is a parent (or the same as) other\n */\nexport function pathContains(path: Path, other: Path): boolean {\n  let i = path.pieceNum_;\n  let j = other.pieceNum_;\n  if (pathGetLength(path) > pathGetLength(other)) {\n    return false;\n  }\n  while (i < path.pieces_.length) {\n    if (path.pieces_[i] !== other.pieces_[j]) {\n      return false;\n    }\n    ++i;\n    ++j;\n  }\n  return true;\n}\n\n/**\n * Dynamic (mutable) path used to count path lengths.\n *\n * This class is used to efficiently check paths for valid\n * length (in UTF8 bytes) and depth (used in path validation).\n *\n * Throws Error exception if path is ever invalid.\n *\n * The definition of a path always begins with '/'.\n */\nexport class ValidationPath {\n  parts_: string[];\n  /** Initialize to number of '/' chars needed in path. */\n  byteLength_: number;\n\n  /**\n   * @param path Initial Path.\n   * @param errorPrefix_ Prefix for any error messages.\n   */\n  constructor(path: Path, public errorPrefix_: string) {\n    this.parts_ = pathSlice(path, 0);\n    /** Initialize to number of '/' chars needed in path. */\n    this.byteLength_ = Math.max(1, this.parts_.length);\n\n    for (let i = 0; i < this.parts_.length; i++) {\n      this.byteLength_ += stringLength(this.parts_[i]);\n    }\n    validationPathCheckValid(this);\n  }\n}\n\nexport function validationPathPush(\n  validationPath: ValidationPath,\n  child: string\n): void {\n  // Count the needed '/'\n  if (validationPath.parts_.length > 0) {\n    validationPath.byteLength_ += 1;\n  }\n  validationPath.parts_.push(child);\n  validationPath.byteLength_ += stringLength(child);\n  validationPathCheckValid(validationPath);\n}\n\nexport function validationPathPop(validationPath: ValidationPath): void {\n  const last = validationPath.parts_.pop();\n  validationPath.byteLength_ -= stringLength(last);\n  // Un-count the previous '/'\n  if (validationPath.parts_.length > 0) {\n    validationPath.byteLength_ -= 1;\n  }\n}\n\nfunction validationPathCheckValid(validationPath: ValidationPath): void {\n  if (validationPath.byteLength_ > MAX_PATH_LENGTH_BYTES) {\n    throw new Error(\n      validationPath.errorPrefix_ +\n        'has a key path longer than ' +\n        MAX_PATH_LENGTH_BYTES +\n        ' bytes (' +\n        validationPath.byteLength_ +\n        ').'\n    );\n  }\n  if (validationPath.parts_.length > MAX_PATH_DEPTH) {\n    throw new Error(\n      validationPath.errorPrefix_ +\n        'path specified exceeds the maximum depth that can be written (' +\n        MAX_PATH_DEPTH +\n        ') or object contains a cycle ' +\n        validationPathToErrorString(validationPath)\n    );\n  }\n}\n\n/**\n * String for use in error messages - uses '.' notation for path.\n */\nexport function validationPathToErrorString(\n  validationPath: ValidationPath\n): string {\n  if (validationPath.parts_.length === 0) {\n    return '';\n  }\n  return \"in property '\" + validationPath.parts_.join('.') + \"'\";\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nexport const PROTOCOL_VERSION = '5';\n\nexport const VERSION_PARAM = 'v';\n\nexport const TRANSPORT_SESSION_PARAM = 's';\n\nexport const REFERER_PARAM = 'r';\n\nexport const FORGE_REF = 'f';\n\n// Matches console.firebase.google.com, firebase-console-*.corp.google.com and\n// firebase.corp.google.com\nexport const FORGE_DOMAIN_RE = /(console\\.firebase|firebase-console-\\w+\\.corp|firebase\\.corp)\\.google\\.com/;\n\nexport const LAST_SESSION_PARAM = 'ls';\n\nexport const APPLICATION_ID_PARAM = 'p';\n\nexport const WEBSOCKET = 'websocket';\n\nexport const LONG_POLLING = 'long_polling';\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert } from '@firebase/util';\nimport { PersistentStorage } from './storage/storage';\nimport { LONG_POLLING, WEBSOCKET } from '../realtime/Constants';\nimport { each } from './util/util';\n\n/**\n * A class that holds metadata about a Repo object\n */\nexport class RepoInfo {\n  private _host: string;\n  private _domain: string;\n  internalHost: string;\n\n  /**\n   * @param host Hostname portion of the url for the repo\n   * @param secure Whether or not this repo is accessed over ssl\n   * @param namespace The namespace represented by the repo\n   * @param webSocketOnly Whether to prefer websockets over all other transports (used by Nest).\n   * @param nodeAdmin Whether this instance uses Admin SDK credentials\n   * @param persistenceKey Override the default session persistence storage key\n   */\n  constructor(\n    host: string,\n    public readonly secure: boolean,\n    public readonly namespace: string,\n    public readonly webSocketOnly: boolean,\n    public readonly nodeAdmin: boolean = false,\n    public readonly persistenceKey: string = '',\n    public readonly includeNamespaceInQueryParams: boolean = false\n  ) {\n    this._host = host.toLowerCase();\n    this._domain = this._host.substr(this._host.indexOf('.') + 1);\n    this.internalHost =\n      (PersistentStorage.get('host:' + host) as string) || this._host;\n  }\n\n  isCacheableHost(): boolean {\n    return this.internalHost.substr(0, 2) === 's-';\n  }\n\n  isCustomHost() {\n    return (\n      this._domain !== 'firebaseio.com' &&\n      this._domain !== 'firebaseio-demo.com'\n    );\n  }\n\n  get host() {\n    return this._host;\n  }\n\n  set host(newHost: string) {\n    if (newHost !== this.internalHost) {\n      this.internalHost = newHost;\n      if (this.isCacheableHost()) {\n        PersistentStorage.set('host:' + this._host, this.internalHost);\n      }\n    }\n  }\n\n  toString(): string {\n    let str = this.toURLString();\n    if (this.persistenceKey) {\n      str += '<' + this.persistenceKey + '>';\n    }\n    return str;\n  }\n\n  toURLString(): string {\n    const protocol = this.secure ? 'https://' : 'http://';\n    const query = this.includeNamespaceInQueryParams\n      ? `?ns=${this.namespace}`\n      : '';\n    return `${protocol}${this.host}/${query}`;\n  }\n}\n\nfunction repoInfoNeedsQueryParam(repoInfo: RepoInfo): boolean {\n  return (\n    repoInfo.host !== repoInfo.internalHost ||\n    repoInfo.isCustomHost() ||\n    repoInfo.includeNamespaceInQueryParams\n  );\n}\n\n/**\n * Returns the websocket URL for this repo\n * @param repoInfo - RepoInfo object\n * @param type - of connection\n * @param params - list\n * @returns The URL for this repo\n */\nexport function repoInfoConnectionURL(\n  repoInfo: RepoInfo,\n  type: string,\n  params: { [k: string]: string }\n): string {\n  assert(typeof type === 'string', 'typeof type must == string');\n  assert(typeof params === 'object', 'typeof params must == object');\n\n  let connURL: string;\n  if (type === WEBSOCKET) {\n    connURL =\n      (repoInfo.secure ? 'wss://' : 'ws://') + repoInfo.internalHost + '/.ws?';\n  } else if (type === LONG_POLLING) {\n    connURL =\n      (repoInfo.secure ? 'https://' : 'http://') +\n      repoInfo.internalHost +\n      '/.lp?';\n  } else {\n    throw new Error('Unknown connection type: ' + type);\n  }\n  if (repoInfoNeedsQueryParam(repoInfo)) {\n    params['ns'] = repoInfo.namespace;\n  }\n\n  const pairs: string[] = [];\n\n  each(params, (key: string, value: string) => {\n    pairs.push(key + '=' + value);\n  });\n\n  return connURL + pairs.join('&');\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Path } from '../Path';\nimport { RepoInfo } from '../../RepoInfo';\nimport { warnIfPageIsSecure, warn, fatal } from '../util';\n\nfunction decodePath(pathString: string): string {\n  let pathStringDecoded = '';\n  const pieces = pathString.split('/');\n  for (let i = 0; i < pieces.length; i++) {\n    if (pieces[i].length > 0) {\n      let piece = pieces[i];\n      try {\n        piece = decodeURIComponent(piece.replace(/\\+/g, ' '));\n      } catch (e) {}\n      pathStringDecoded += '/' + piece;\n    }\n  }\n  return pathStringDecoded;\n}\n\n/**\n * @return key value hash\n */\nfunction decodeQuery(queryString: string): { [key: string]: string } {\n  const results = {};\n  if (queryString.charAt(0) === '?') {\n    queryString = queryString.substring(1);\n  }\n  for (const segment of queryString.split('&')) {\n    if (segment.length === 0) {\n      continue;\n    }\n    const kv = segment.split('=');\n    if (kv.length === 2) {\n      results[decodeURIComponent(kv[0])] = decodeURIComponent(kv[1]);\n    } else {\n      warn(`Invalid query segment '${segment}' in query '${queryString}'`);\n    }\n  }\n  return results;\n}\n\nexport const parseRepoInfo = function (\n  dataURL: string,\n  nodeAdmin: boolean\n): { repoInfo: RepoInfo; path: Path } {\n  const parsedUrl = parseDatabaseURL(dataURL),\n    namespace = parsedUrl.namespace;\n\n  if (parsedUrl.domain === 'firebase.com') {\n    fatal(\n      parsedUrl.host +\n        ' is no longer supported. ' +\n        'Please use <YOUR FIREBASE>.firebaseio.com instead'\n    );\n  }\n\n  // Catch common error of uninitialized namespace value.\n  if (\n    (!namespace || namespace === 'undefined') &&\n    parsedUrl.domain !== 'localhost'\n  ) {\n    fatal(\n      'Cannot parse Firebase url. Please use https://<YOUR FIREBASE>.firebaseio.com'\n    );\n  }\n\n  if (!parsedUrl.secure) {\n    warnIfPageIsSecure();\n  }\n\n  const webSocketOnly = parsedUrl.scheme === 'ws' || parsedUrl.scheme === 'wss';\n\n  return {\n    repoInfo: new RepoInfo(\n      parsedUrl.host,\n      parsedUrl.secure,\n      namespace,\n      nodeAdmin,\n      webSocketOnly,\n      /*persistenceKey=*/ '',\n      /*includeNamespaceInQueryParams=*/ namespace !== parsedUrl.subdomain\n    ),\n    path: new Path(parsedUrl.pathString)\n  };\n};\n\nexport const parseDatabaseURL = function (\n  dataURL: string\n): {\n  host: string;\n  port: number;\n  domain: string;\n  subdomain: string;\n  secure: boolean;\n  scheme: string;\n  pathString: string;\n  namespace: string;\n} {\n  // Default to empty strings in the event of a malformed string.\n  let host = '',\n    domain = '',\n    subdomain = '',\n    pathString = '',\n    namespace = '';\n\n  // Always default to SSL, unless otherwise specified.\n  let secure = true,\n    scheme = 'https',\n    port = 443;\n\n  // Don't do any validation here. The caller is responsible for validating the result of parsing.\n  if (typeof dataURL === 'string') {\n    // Parse scheme.\n    let colonInd = dataURL.indexOf('//');\n    if (colonInd >= 0) {\n      scheme = dataURL.substring(0, colonInd - 1);\n      dataURL = dataURL.substring(colonInd + 2);\n    }\n\n    // Parse host, path, and query string.\n    let slashInd = dataURL.indexOf('/');\n    if (slashInd === -1) {\n      slashInd = dataURL.length;\n    }\n    let questionMarkInd = dataURL.indexOf('?');\n    if (questionMarkInd === -1) {\n      questionMarkInd = dataURL.length;\n    }\n    host = dataURL.substring(0, Math.min(slashInd, questionMarkInd));\n    if (slashInd < questionMarkInd) {\n      // For pathString, questionMarkInd will always come after slashInd\n      pathString = decodePath(dataURL.substring(slashInd, questionMarkInd));\n    }\n    const queryParams = decodeQuery(\n      dataURL.substring(Math.min(dataURL.length, questionMarkInd))\n    );\n\n    // If we have a port, use scheme for determining if it's secure.\n    colonInd = host.indexOf(':');\n    if (colonInd >= 0) {\n      secure = scheme === 'https' || scheme === 'wss';\n      port = parseInt(host.substring(colonInd + 1), 10);\n    } else {\n      colonInd = host.length;\n    }\n\n    const hostWithoutPort = host.slice(0, colonInd);\n    if (hostWithoutPort.toLowerCase() === 'localhost') {\n      domain = 'localhost';\n    } else if (hostWithoutPort.split('.').length <= 2) {\n      domain = hostWithoutPort;\n    } else {\n      // Interpret the subdomain of a 3 or more component URL as the namespace name.\n      const dotInd = host.indexOf('.');\n      subdomain = host.substring(0, dotInd).toLowerCase();\n      domain = host.substring(dotInd + 1);\n      // Normalize namespaces to lowercase to share storage / connection.\n      namespace = subdomain;\n    }\n    // Always treat the value of the `ns` as the namespace name if it is present.\n    if ('ns' in queryParams) {\n      namespace = queryParams['ns'];\n    }\n  }\n\n  return {\n    host,\n    port,\n    domain,\n    subdomain,\n    secure,\n    scheme,\n    pathString,\n    namespace\n  };\n};\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert, contains } from '@firebase/util';\nimport { doubleToIEEE754String } from '../util/util';\n\nimport { Node } from './Node';\nimport { Indexable } from '../util/misc';\n\nlet MAX_NODE: Node;\n\nexport function setMaxNode(val: Node) {\n  MAX_NODE = val;\n}\n\nexport const priorityHashText = function (priority: string | number): string {\n  if (typeof priority === 'number') {\n    return 'number:' + doubleToIEEE754String(priority);\n  } else {\n    return 'string:' + priority;\n  }\n};\n\n/**\n * Validates that a priority snapshot Node is valid.\n */\nexport const validatePriorityNode = function (priorityNode: Node) {\n  if (priorityNode.isLeafNode()) {\n    const val = priorityNode.val();\n    assert(\n      typeof val === 'string' ||\n        typeof val === 'number' ||\n        (typeof val === 'object' && contains(val as Indexable, '.sv')),\n      'Priority must be a string or number.'\n    );\n  } else {\n    assert(\n      priorityNode === MAX_NODE || priorityNode.isEmpty(),\n      'priority of unexpected type.'\n    );\n  }\n  // Don't call getPriority() on MAX_NODE to avoid hitting assertion.\n  assert(\n    priorityNode === MAX_NODE || priorityNode.getPriority().isEmpty(),\n    \"Priority nodes can't have a priority of their own.\"\n  );\n};\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  Path,\n  pathChild,\n  pathCompare,\n  pathContains,\n  pathGetBack,\n  pathGetFront,\n  pathSlice,\n  ValidationPath,\n  validationPathPop,\n  validationPathPush,\n  validationPathToErrorString\n} from './Path';\nimport {\n  contains,\n  errorPrefix as errorPrefixFxn,\n  safeGet,\n  stringLength\n} from '@firebase/util';\nimport { each, isInvalidJSONNumber } from './util';\n\nimport { RepoInfo } from '../RepoInfo';\n\n/**\n * True for invalid Firebase keys\n */\nexport const INVALID_KEY_REGEX_ = /[\\[\\].#$\\/\\u0000-\\u001F\\u007F]/;\n\n/**\n * True for invalid Firebase paths.\n * Allows '/' in paths.\n */\nexport const INVALID_PATH_REGEX_ = /[\\[\\].#$\\u0000-\\u001F\\u007F]/;\n\n/**\n * Maximum number of characters to allow in leaf value\n */\nexport const MAX_LEAF_SIZE_ = 10 * 1024 * 1024;\n\nexport const isValidKey = function (key: unknown): boolean {\n  return (\n    typeof key === 'string' && key.length !== 0 && !INVALID_KEY_REGEX_.test(key)\n  );\n};\n\nexport const isValidPathString = function (pathString: string): boolean {\n  return (\n    typeof pathString === 'string' &&\n    pathString.length !== 0 &&\n    !INVALID_PATH_REGEX_.test(pathString)\n  );\n};\n\nexport const isValidRootPathString = function (pathString: string): boolean {\n  if (pathString) {\n    // Allow '/.info/' at the beginning.\n    pathString = pathString.replace(/^\\/*\\.info(\\/|$)/, '/');\n  }\n\n  return isValidPathString(pathString);\n};\n\nexport const isValidPriority = function (priority: unknown): boolean {\n  return (\n    priority === null ||\n    typeof priority === 'string' ||\n    (typeof priority === 'number' && !isInvalidJSONNumber(priority)) ||\n    (priority &&\n      typeof priority === 'object' &&\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      contains(priority as any, '.sv'))\n  );\n};\n\n/**\n * Pre-validate a datum passed as an argument to Firebase function.\n */\nexport const validateFirebaseDataArg = function (\n  fnName: string,\n  argumentNumber: number,\n  data: unknown,\n  path: Path,\n  optional: boolean\n) {\n  if (optional && data === undefined) {\n    return;\n  }\n\n  validateFirebaseData(\n    errorPrefixFxn(fnName, argumentNumber, optional),\n    data,\n    path\n  );\n};\n\n/**\n * Validate a data object client-side before sending to server.\n */\nexport const validateFirebaseData = function (\n  errorPrefix: string,\n  data: unknown,\n  path_: Path | ValidationPath\n) {\n  const path =\n    path_ instanceof Path ? new ValidationPath(path_, errorPrefix) : path_;\n\n  if (data === undefined) {\n    throw new Error(\n      errorPrefix + 'contains undefined ' + validationPathToErrorString(path)\n    );\n  }\n  if (typeof data === 'function') {\n    throw new Error(\n      errorPrefix +\n        'contains a function ' +\n        validationPathToErrorString(path) +\n        ' with contents = ' +\n        data.toString()\n    );\n  }\n  if (isInvalidJSONNumber(data)) {\n    throw new Error(\n      errorPrefix +\n        'contains ' +\n        data.toString() +\n        ' ' +\n        validationPathToErrorString(path)\n    );\n  }\n\n  // Check max leaf size, but try to avoid the utf8 conversion if we can.\n  if (\n    typeof data === 'string' &&\n    data.length > MAX_LEAF_SIZE_ / 3 &&\n    stringLength(data) > MAX_LEAF_SIZE_\n  ) {\n    throw new Error(\n      errorPrefix +\n        'contains a string greater than ' +\n        MAX_LEAF_SIZE_ +\n        ' utf8 bytes ' +\n        validationPathToErrorString(path) +\n        \" ('\" +\n        data.substring(0, 50) +\n        \"...')\"\n    );\n  }\n\n  // TODO = Perf = Consider combining the recursive validation of keys into NodeFromJSON\n  // to save extra walking of large objects.\n  if (data && typeof data === 'object') {\n    let hasDotValue = false;\n    let hasActualChild = false;\n    each(data, (key: string, value: unknown) => {\n      if (key === '.value') {\n        hasDotValue = true;\n      } else if (key !== '.priority' && key !== '.sv') {\n        hasActualChild = true;\n        if (!isValidKey(key)) {\n          throw new Error(\n            errorPrefix +\n              ' contains an invalid key (' +\n              key +\n              ') ' +\n              validationPathToErrorString(path) +\n              '.  Keys must be non-empty strings ' +\n              'and can\\'t contain \".\", \"#\", \"$\", \"/\", \"[\", or \"]\"'\n          );\n        }\n      }\n\n      validationPathPush(path, key);\n      validateFirebaseData(errorPrefix, value, path);\n      validationPathPop(path);\n    });\n\n    if (hasDotValue && hasActualChild) {\n      throw new Error(\n        errorPrefix +\n          ' contains \".value\" child ' +\n          validationPathToErrorString(path) +\n          ' in addition to actual children.'\n      );\n    }\n  }\n};\n\n/**\n * Pre-validate paths passed in the firebase function.\n */\nexport const validateFirebaseMergePaths = function (\n  errorPrefix: string,\n  mergePaths: Path[]\n) {\n  let i, curPath: Path;\n  for (i = 0; i < mergePaths.length; i++) {\n    curPath = mergePaths[i];\n    const keys = pathSlice(curPath);\n    for (let j = 0; j < keys.length; j++) {\n      if (keys[j] === '.priority' && j === keys.length - 1) {\n        // .priority is OK\n      } else if (!isValidKey(keys[j])) {\n        throw new Error(\n          errorPrefix +\n            'contains an invalid key (' +\n            keys[j] +\n            ') in path ' +\n            curPath.toString() +\n            '. Keys must be non-empty strings ' +\n            'and can\\'t contain \".\", \"#\", \"$\", \"/\", \"[\", or \"]\"'\n        );\n      }\n    }\n  }\n\n  // Check that update keys are not descendants of each other.\n  // We rely on the property that sorting guarantees that ancestors come\n  // right before descendants.\n  mergePaths.sort(pathCompare);\n  let prevPath: Path | null = null;\n  for (i = 0; i < mergePaths.length; i++) {\n    curPath = mergePaths[i];\n    if (prevPath !== null && pathContains(prevPath, curPath)) {\n      throw new Error(\n        errorPrefix +\n          'contains a path ' +\n          prevPath.toString() +\n          ' that is ancestor of another path ' +\n          curPath.toString()\n      );\n    }\n    prevPath = curPath;\n  }\n};\n\n/**\n * pre-validate an object passed as an argument to firebase function (\n * must be an object - e.g. for firebase.update()).\n */\nexport const validateFirebaseMergeDataArg = function (\n  fnName: string,\n  argumentNumber: number,\n  data: unknown,\n  path: Path,\n  optional: boolean\n) {\n  if (optional && data === undefined) {\n    return;\n  }\n\n  const errorPrefix = errorPrefixFxn(fnName, argumentNumber, optional);\n\n  if (!(data && typeof data === 'object') || Array.isArray(data)) {\n    throw new Error(\n      errorPrefix + ' must be an object containing the children to replace.'\n    );\n  }\n\n  const mergePaths: Path[] = [];\n  each(data, (key: string, value: unknown) => {\n    const curPath = new Path(key);\n    validateFirebaseData(errorPrefix, value, pathChild(path, curPath));\n    if (pathGetBack(curPath) === '.priority') {\n      if (!isValidPriority(value)) {\n        throw new Error(\n          errorPrefix +\n            \"contains an invalid value for '\" +\n            curPath.toString() +\n            \"', which must be a valid \" +\n            'Firebase priority (a string, finite number, server value, or null).'\n        );\n      }\n    }\n    mergePaths.push(curPath);\n  });\n  validateFirebaseMergePaths(errorPrefix, mergePaths);\n};\n\nexport const validatePriority = function (\n  fnName: string,\n  argumentNumber: number,\n  priority: unknown,\n  optional: boolean\n) {\n  if (optional && priority === undefined) {\n    return;\n  }\n  if (isInvalidJSONNumber(priority)) {\n    throw new Error(\n      errorPrefixFxn(fnName, argumentNumber, optional) +\n        'is ' +\n        priority.toString() +\n        ', but must be a valid Firebase priority (a string, finite number, ' +\n        'server value, or null).'\n    );\n  }\n  // Special case to allow importing data with a .sv.\n  if (!isValidPriority(priority)) {\n    throw new Error(\n      errorPrefixFxn(fnName, argumentNumber, optional) +\n        'must be a valid Firebase priority ' +\n        '(a string, finite number, server value, or null).'\n    );\n  }\n};\n\nexport const validateEventType = function (\n  fnName: string,\n  argumentNumber: number,\n  eventType: string,\n  optional: boolean\n) {\n  if (optional && eventType === undefined) {\n    return;\n  }\n\n  switch (eventType) {\n    case 'value':\n    case 'child_added':\n    case 'child_removed':\n    case 'child_changed':\n    case 'child_moved':\n      break;\n    default:\n      throw new Error(\n        errorPrefixFxn(fnName, argumentNumber, optional) +\n          'must be a valid event type = \"value\", \"child_added\", \"child_removed\", ' +\n          '\"child_changed\", or \"child_moved\".'\n      );\n  }\n};\n\nexport const validateKey = function (\n  fnName: string,\n  argumentNumber: number,\n  key: string,\n  optional: boolean\n) {\n  if (optional && key === undefined) {\n    return;\n  }\n  if (!isValidKey(key)) {\n    throw new Error(\n      errorPrefixFxn(fnName, argumentNumber, optional) +\n        'was an invalid key = \"' +\n        key +\n        '\".  Firebase keys must be non-empty strings and ' +\n        'can\\'t contain \".\", \"#\", \"$\", \"/\", \"[\", or \"]\").'\n    );\n  }\n};\n\nexport const validatePathString = function (\n  fnName: string,\n  argumentNumber: number,\n  pathString: string,\n  optional: boolean\n) {\n  if (optional && pathString === undefined) {\n    return;\n  }\n\n  if (!isValidPathString(pathString)) {\n    throw new Error(\n      errorPrefixFxn(fnName, argumentNumber, optional) +\n        'was an invalid path = \"' +\n        pathString +\n        '\". Paths must be non-empty strings and ' +\n        'can\\'t contain \".\", \"#\", \"$\", \"[\", or \"]\"'\n    );\n  }\n};\n\nexport const validateRootPathString = function (\n  fnName: string,\n  argumentNumber: number,\n  pathString: string,\n  optional: boolean\n) {\n  if (pathString) {\n    // Allow '/.info/' at the beginning.\n    pathString = pathString.replace(/^\\/*\\.info(\\/|$)/, '/');\n  }\n\n  validatePathString(fnName, argumentNumber, pathString, optional);\n};\n\nexport const validateWritablePath = function (fnName: string, path: Path) {\n  if (pathGetFront(path) === '.info') {\n    throw new Error(fnName + \" failed = Can't modify data under /.info/\");\n  }\n};\n\nexport const validateUrl = function (\n  fnName: string,\n  argumentNumber: number,\n  parsedUrl: { repoInfo: RepoInfo; path: Path }\n) {\n  // TODO = Validate server better.\n  const pathString = parsedUrl.path.toString();\n  if (\n    !(typeof parsedUrl.repoInfo.host === 'string') ||\n    parsedUrl.repoInfo.host.length === 0 ||\n    (!isValidKey(parsedUrl.repoInfo.namespace) &&\n      parsedUrl.repoInfo.host.split(':')[0] !== 'localhost') ||\n    (pathString.length !== 0 && !isValidRootPathString(pathString))\n  ) {\n    throw new Error(\n      errorPrefixFxn(fnName, argumentNumber, false) +\n        'must be a valid firebase URL and ' +\n        'the path can\\'t contain \".\", \"#\", \"$\", \"[\", or \"]\".'\n    );\n  }\n};\n\nexport const validateCredential = function (\n  fnName: string,\n  argumentNumber: number,\n  cred: unknown,\n  optional: boolean\n) {\n  if (optional && cred === undefined) {\n    return;\n  }\n  if (!(typeof cred === 'string')) {\n    throw new Error(\n      errorPrefixFxn(fnName, argumentNumber, optional) +\n        'must be a valid credential (a string).'\n    );\n  }\n};\n\nexport const validateBoolean = function (\n  fnName: string,\n  argumentNumber: number,\n  bool: unknown,\n  optional: boolean\n) {\n  if (optional && bool === undefined) {\n    return;\n  }\n  if (typeof bool !== 'boolean') {\n    throw new Error(\n      errorPrefixFxn(fnName, argumentNumber, optional) + 'must be a boolean.'\n    );\n  }\n};\n\nexport const validateString = function (\n  fnName: string,\n  argumentNumber: number,\n  string: unknown,\n  optional: boolean\n) {\n  if (optional && string === undefined) {\n    return;\n  }\n  if (!(typeof string === 'string')) {\n    throw new Error(\n      errorPrefixFxn(fnName, argumentNumber, optional) +\n        'must be a valid string.'\n    );\n  }\n};\n\nexport const validateObject = function (\n  fnName: string,\n  argumentNumber: number,\n  obj: unknown,\n  optional: boolean\n) {\n  if (optional && obj === undefined) {\n    return;\n  }\n  if (!(obj && typeof obj === 'object') || obj === null) {\n    throw new Error(\n      errorPrefixFxn(fnName, argumentNumber, optional) +\n        'must be a valid object.'\n    );\n  }\n};\n\nexport const validateObjectContainsKey = function (\n  fnName: string,\n  argumentNumber: number,\n  obj: unknown,\n  key: string,\n  optional: boolean,\n  optType?: string\n) {\n  const objectContainsKey =\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    obj && typeof obj === 'object' && contains(obj as any, key);\n\n  if (!objectContainsKey) {\n    if (optional) {\n      return;\n    } else {\n      throw new Error(\n        errorPrefixFxn(fnName, argumentNumber, optional) +\n          'must contain the key \"' +\n          key +\n          '\"'\n      );\n    }\n  }\n\n  if (optType) {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const val = safeGet(obj as any, key);\n    if (\n      (optType === 'number' && !(typeof val === 'number')) ||\n      (optType === 'string' && !(typeof val === 'string')) ||\n      (optType === 'boolean' && !(typeof val === 'boolean')) ||\n      (optType === 'function' && !(typeof val === 'function')) ||\n      (optType === 'object' && !(typeof val === 'object') && val)\n    ) {\n      if (optional) {\n        throw new Error(\n          errorPrefixFxn(fnName, argumentNumber, optional) +\n            'contains invalid value for key \"' +\n            key +\n            '\" (must be of type \"' +\n            optType +\n            '\")'\n        );\n      } else {\n        throw new Error(\n          errorPrefixFxn(fnName, argumentNumber, optional) +\n            'must contain the key \"' +\n            key +\n            '\" with type \"' +\n            optType +\n            '\"'\n        );\n      }\n    }\n  }\n};\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert } from '@firebase/util';\nimport { doubleToIEEE754String, sha1 } from '../util/util';\nimport { priorityHashText, validatePriorityNode } from './snap';\nimport { Node } from './Node';\nimport {\n  Path,\n  pathGetFront,\n  pathGetLength,\n  pathIsEmpty,\n  pathPopFront\n} from '../util/Path';\nimport { Index } from './indexes/Index';\nimport { ChildrenNodeConstructor } from './ChildrenNode';\nimport { Indexable } from '../util/misc';\n\nlet __childrenNodeConstructor: ChildrenNodeConstructor;\n\n/**\n * LeafNode is a class for storing leaf nodes in a DataSnapshot.  It\n * implements Node and stores the value of the node (a string,\n * number, or boolean) accessible via getValue().\n */\nexport class LeafNode implements Node {\n  static set __childrenNodeConstructor(val: ChildrenNodeConstructor) {\n    __childrenNodeConstructor = val;\n  }\n\n  static get __childrenNodeConstructor() {\n    return __childrenNodeConstructor;\n  }\n\n  /**\n   * The sort order for comparing leaf nodes of different types. If two leaf nodes have\n   * the same type, the comparison falls back to their value\n   */\n  static VALUE_TYPE_ORDER = ['object', 'boolean', 'number', 'string'];\n\n  private lazyHash_: string | null = null;\n\n  /**\n   * @param value_ The value to store in this leaf node. The object type is\n   * possible in the event of a deferred value\n   * @param priorityNode_ The priority of this node.\n   */\n  constructor(\n    private readonly value_: string | number | boolean | Indexable,\n    private priorityNode_: Node = LeafNode.__childrenNodeConstructor.EMPTY_NODE\n  ) {\n    assert(\n      this.value_ !== undefined && this.value_ !== null,\n      \"LeafNode shouldn't be created with null/undefined value.\"\n    );\n\n    validatePriorityNode(this.priorityNode_);\n  }\n\n  /** @inheritDoc */\n  isLeafNode(): boolean {\n    return true;\n  }\n\n  /** @inheritDoc */\n  getPriority(): Node {\n    return this.priorityNode_;\n  }\n\n  /** @inheritDoc */\n  updatePriority(newPriorityNode: Node): Node {\n    return new LeafNode(this.value_, newPriorityNode);\n  }\n\n  /** @inheritDoc */\n  getImmediateChild(childName: string): Node {\n    // Hack to treat priority as a regular child\n    if (childName === '.priority') {\n      return this.priorityNode_;\n    } else {\n      return LeafNode.__childrenNodeConstructor.EMPTY_NODE;\n    }\n  }\n\n  /** @inheritDoc */\n  getChild(path: Path): Node {\n    if (pathIsEmpty(path)) {\n      return this;\n    } else if (pathGetFront(path) === '.priority') {\n      return this.priorityNode_;\n    } else {\n      return LeafNode.__childrenNodeConstructor.EMPTY_NODE;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  hasChild(): boolean {\n    return false;\n  }\n\n  /** @inheritDoc */\n  getPredecessorChildName(childName: string, childNode: Node): null {\n    return null;\n  }\n\n  /** @inheritDoc */\n  updateImmediateChild(childName: string, newChildNode: Node): Node {\n    if (childName === '.priority') {\n      return this.updatePriority(newChildNode);\n    } else if (newChildNode.isEmpty() && childName !== '.priority') {\n      return this;\n    } else {\n      return LeafNode.__childrenNodeConstructor.EMPTY_NODE.updateImmediateChild(\n        childName,\n        newChildNode\n      ).updatePriority(this.priorityNode_);\n    }\n  }\n\n  /** @inheritDoc */\n  updateChild(path: Path, newChildNode: Node): Node {\n    const front = pathGetFront(path);\n    if (front === null) {\n      return newChildNode;\n    } else if (newChildNode.isEmpty() && front !== '.priority') {\n      return this;\n    } else {\n      assert(\n        front !== '.priority' || pathGetLength(path) === 1,\n        '.priority must be the last token in a path'\n      );\n\n      return this.updateImmediateChild(\n        front,\n        LeafNode.__childrenNodeConstructor.EMPTY_NODE.updateChild(\n          pathPopFront(path),\n          newChildNode\n        )\n      );\n    }\n  }\n\n  /** @inheritDoc */\n  isEmpty(): boolean {\n    return false;\n  }\n\n  /** @inheritDoc */\n  numChildren(): number {\n    return 0;\n  }\n\n  /** @inheritDoc */\n  forEachChild(index: Index, action: (s: string, n: Node) => void): boolean {\n    return false;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  val(exportFormat?: boolean): {} {\n    if (exportFormat && !this.getPriority().isEmpty()) {\n      return {\n        '.value': this.getValue(),\n        '.priority': this.getPriority().val()\n      };\n    } else {\n      return this.getValue();\n    }\n  }\n\n  /** @inheritDoc */\n  hash(): string {\n    if (this.lazyHash_ === null) {\n      let toHash = '';\n      if (!this.priorityNode_.isEmpty()) {\n        toHash +=\n          'priority:' +\n          priorityHashText(this.priorityNode_.val() as number | string) +\n          ':';\n      }\n\n      const type = typeof this.value_;\n      toHash += type + ':';\n      if (type === 'number') {\n        toHash += doubleToIEEE754String(this.value_ as number);\n      } else {\n        toHash += this.value_;\n      }\n      this.lazyHash_ = sha1(toHash);\n    }\n    return this.lazyHash_;\n  }\n\n  /**\n   * Returns the value of the leaf node.\n   * @return The value of the node.\n   */\n  getValue(): Indexable | string | number | boolean {\n    return this.value_;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  compareTo(other: Node): number {\n    if (other === LeafNode.__childrenNodeConstructor.EMPTY_NODE) {\n      return 1;\n    } else if (other instanceof LeafNode.__childrenNodeConstructor) {\n      return -1;\n    } else {\n      assert(other.isLeafNode(), 'Unknown node type');\n      return this.compareToLeafNode_(other as LeafNode);\n    }\n  }\n\n  /**\n   * Comparison specifically for two leaf nodes\n   */\n  private compareToLeafNode_(otherLeaf: LeafNode): number {\n    const otherLeafType = typeof otherLeaf.value_;\n    const thisLeafType = typeof this.value_;\n    const otherIndex = LeafNode.VALUE_TYPE_ORDER.indexOf(otherLeafType);\n    const thisIndex = LeafNode.VALUE_TYPE_ORDER.indexOf(thisLeafType);\n    assert(otherIndex >= 0, 'Unknown leaf type: ' + otherLeafType);\n    assert(thisIndex >= 0, 'Unknown leaf type: ' + thisLeafType);\n    if (otherIndex === thisIndex) {\n      // Same type, compare values\n      if (thisLeafType === 'object') {\n        // Deferred value nodes are all equal, but we should also never get to this point...\n        return 0;\n      } else {\n        // Note that this works because true > false, all others are number or string comparisons\n        if (this.value_ < otherLeaf.value_) {\n          return -1;\n        } else if (this.value_ === otherLeaf.value_) {\n          return 0;\n        } else {\n          return 1;\n        }\n      }\n    } else {\n      return thisIndex - otherIndex;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  withIndex(): Node {\n    return this;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  isIndexed(): boolean {\n    return true;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  equals(other: Node): boolean {\n    /**\n     * @inheritDoc\n     */\n    if (other === this) {\n      return true;\n    } else if (other.isLeafNode()) {\n      const otherLeaf = other as LeafNode;\n      return (\n        this.value_ === otherLeaf.value_ &&\n        this.priorityNode_.equals(otherLeaf.priorityNode_)\n      );\n    } else {\n      return false;\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Index } from './Index';\nimport { nameCompare, MAX_NAME } from '../../util/util';\nimport { NamedNode, Node } from '../Node';\nimport { LeafNode } from '../LeafNode';\n\nlet nodeFromJSON: (a: unknown) => Node;\nlet MAX_NODE: Node;\n\nexport function setNodeFromJSON(val: (a: unknown) => Node) {\n  nodeFromJSON = val;\n}\n\nexport function setMaxNode(val: Node) {\n  MAX_NODE = val;\n}\n\nexport class PriorityIndex extends Index {\n  /**\n   * @inheritDoc\n   */\n  compare(a: NamedNode, b: NamedNode): number {\n    const aPriority = a.node.getPriority();\n    const bPriority = b.node.getPriority();\n    const indexCmp = aPriority.compareTo(bPriority);\n    if (indexCmp === 0) {\n      return nameCompare(a.name, b.name);\n    } else {\n      return indexCmp;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  isDefinedOn(node: Node): boolean {\n    return !node.getPriority().isEmpty();\n  }\n\n  /**\n   * @inheritDoc\n   */\n  indexedValueChanged(oldNode: Node, newNode: Node): boolean {\n    return !oldNode.getPriority().equals(newNode.getPriority());\n  }\n\n  /**\n   * @inheritDoc\n   */\n  minPost(): NamedNode {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return (NamedNode as any).MIN;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  maxPost(): NamedNode {\n    return new NamedNode(MAX_NAME, new LeafNode('[PRIORITY-POST]', MAX_NODE));\n  }\n\n  makePost(indexValue: unknown, name: string): NamedNode {\n    const priorityNode = nodeFromJSON(indexValue);\n    return new NamedNode(name, new LeafNode('[PRIORITY-POST]', priorityNode));\n  }\n\n  /**\n   * @return String representation for inclusion in a query spec\n   */\n  toString(): string {\n    return '.priority';\n  }\n}\n\nexport const PRIORITY_INDEX = new PriorityIndex();\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/**\n * @fileoverview Implementation of an immutable SortedMap using a Left-leaning\n * Red-Black Tree, adapted from the implementation in Mugs\n * (http://mads379.github.com/mugs/) by Mads Hartmann Jensen\n * (mads379@gmail.com).\n *\n * Original paper on Left-leaning Red-Black Trees:\n *   http://www.cs.princeton.edu/~rs/talks/LLRB/LLRB.pdf\n *\n * Invariant 1: No red node has a red child\n * Invariant 2: Every leaf path has the same number of black nodes\n * Invariant 3: Only the left child can be red (left leaning)\n */\n\n// TODO: There are some improvements I'd like to make to improve memory / perf:\n//  * Create two prototypes, LLRedNode and LLBlackNode, instead of storing a\n//    color property in every node.\n// TODO: It would also be good (and possibly necessary) to create a base\n// interface for LLRBNode and LLRBEmptyNode.\n\nexport type Comparator<K> = (key1: K, key2: K) => number;\n\n/**\n * An iterator over an LLRBNode.\n */\nexport class SortedMapIterator<K, V, T> {\n  private nodeStack_: Array<LLRBNode<K, V> | LLRBEmptyNode<K, V>> = [];\n\n  /**\n   * @param node Node to iterate.\n   * @param isReverse_ Whether or not to iterate in reverse\n   * @param resultGenerator_\n   */\n  constructor(\n    node: LLRBNode<K, V> | LLRBEmptyNode<K, V>,\n    startKey: K | null,\n    comparator: Comparator<K>,\n    private isReverse_: boolean,\n    private resultGenerator_: ((k: K, v: V) => T) | null = null\n  ) {\n    let cmp = 1;\n    while (!node.isEmpty()) {\n      node = node as LLRBNode<K, V>;\n      cmp = startKey ? comparator(node.key, startKey) : 1;\n      // flip the comparison if we're going in reverse\n      if (isReverse_) {\n        cmp *= -1;\n      }\n\n      if (cmp < 0) {\n        // This node is less than our start key. ignore it\n        if (this.isReverse_) {\n          node = node.left;\n        } else {\n          node = node.right;\n        }\n      } else if (cmp === 0) {\n        // This node is exactly equal to our start key. Push it on the stack, but stop iterating;\n        this.nodeStack_.push(node);\n        break;\n      } else {\n        // This node is greater than our start key, add it to the stack and move to the next one\n        this.nodeStack_.push(node);\n        if (this.isReverse_) {\n          node = node.right;\n        } else {\n          node = node.left;\n        }\n      }\n    }\n  }\n\n  getNext(): T {\n    if (this.nodeStack_.length === 0) {\n      return null;\n    }\n\n    let node = this.nodeStack_.pop();\n    let result: T;\n    if (this.resultGenerator_) {\n      result = this.resultGenerator_(node.key, node.value);\n    } else {\n      result = ({ key: node.key, value: node.value } as unknown) as T;\n    }\n\n    if (this.isReverse_) {\n      node = node.left;\n      while (!node.isEmpty()) {\n        this.nodeStack_.push(node);\n        node = node.right;\n      }\n    } else {\n      node = node.right;\n      while (!node.isEmpty()) {\n        this.nodeStack_.push(node);\n        node = node.left;\n      }\n    }\n\n    return result;\n  }\n\n  hasNext(): boolean {\n    return this.nodeStack_.length > 0;\n  }\n\n  peek(): T {\n    if (this.nodeStack_.length === 0) {\n      return null;\n    }\n\n    const node = this.nodeStack_[this.nodeStack_.length - 1];\n    if (this.resultGenerator_) {\n      return this.resultGenerator_(node.key, node.value);\n    } else {\n      return ({ key: node.key, value: node.value } as unknown) as T;\n    }\n  }\n}\n\n/**\n * Represents a node in a Left-leaning Red-Black tree.\n */\nexport class LLRBNode<K, V> {\n  color: boolean;\n  left: LLRBNode<K, V> | LLRBEmptyNode<K, V>;\n  right: LLRBNode<K, V> | LLRBEmptyNode<K, V>;\n\n  /**\n   * @param key Key associated with this node.\n   * @param value Value associated with this node.\n   * @param color Whether this node is red.\n   * @param left Left child.\n   * @param right Right child.\n   */\n  constructor(\n    public key: K,\n    public value: V,\n    color: boolean | null,\n    left?: LLRBNode<K, V> | LLRBEmptyNode<K, V> | null,\n    right?: LLRBNode<K, V> | LLRBEmptyNode<K, V> | null\n  ) {\n    this.color = color != null ? color : LLRBNode.RED;\n    this.left =\n      left != null ? left : (SortedMap.EMPTY_NODE as LLRBEmptyNode<K, V>);\n    this.right =\n      right != null ? right : (SortedMap.EMPTY_NODE as LLRBEmptyNode<K, V>);\n  }\n\n  static RED = true;\n  static BLACK = false;\n\n  /**\n   * Returns a copy of the current node, optionally replacing pieces of it.\n   *\n   * @param key New key for the node, or null.\n   * @param value New value for the node, or null.\n   * @param color New color for the node, or null.\n   * @param left New left child for the node, or null.\n   * @param right New right child for the node, or null.\n   * @return The node copy.\n   */\n  copy(\n    key: K | null,\n    value: V | null,\n    color: boolean | null,\n    left: LLRBNode<K, V> | LLRBEmptyNode<K, V> | null,\n    right: LLRBNode<K, V> | LLRBEmptyNode<K, V> | null\n  ): LLRBNode<K, V> {\n    return new LLRBNode(\n      key != null ? key : this.key,\n      value != null ? value : this.value,\n      color != null ? color : this.color,\n      left != null ? left : this.left,\n      right != null ? right : this.right\n    );\n  }\n\n  /**\n   * @return The total number of nodes in the tree.\n   */\n  count(): number {\n    return this.left.count() + 1 + this.right.count();\n  }\n\n  /**\n   * @return True if the tree is empty.\n   */\n  isEmpty(): boolean {\n    return false;\n  }\n\n  /**\n   * Traverses the tree in key order and calls the specified action function\n   * for each node.\n   *\n   * @param action Callback function to be called for each\n   *   node.  If it returns true, traversal is aborted.\n   * @return The first truthy value returned by action, or the last falsey\n   *   value returned by action\n   */\n  inorderTraversal(action: (k: K, v: V) => unknown): boolean {\n    return (\n      this.left.inorderTraversal(action) ||\n      !!action(this.key, this.value) ||\n      this.right.inorderTraversal(action)\n    );\n  }\n\n  /**\n   * Traverses the tree in reverse key order and calls the specified action function\n   * for each node.\n   *\n   * @param action Callback function to be called for each\n   * node.  If it returns true, traversal is aborted.\n   * @return True if traversal was aborted.\n   */\n  reverseTraversal(action: (k: K, v: V) => void): boolean {\n    return (\n      this.right.reverseTraversal(action) ||\n      action(this.key, this.value) ||\n      this.left.reverseTraversal(action)\n    );\n  }\n\n  /**\n   * @return The minimum node in the tree.\n   */\n  private min_(): LLRBNode<K, V> {\n    if (this.left.isEmpty()) {\n      return this;\n    } else {\n      return (this.left as LLRBNode<K, V>).min_();\n    }\n  }\n\n  /**\n   * @return The maximum key in the tree.\n   */\n  minKey(): K {\n    return this.min_().key;\n  }\n\n  /**\n   * @return The maximum key in the tree.\n   */\n  maxKey(): K {\n    if (this.right.isEmpty()) {\n      return this.key;\n    } else {\n      return this.right.maxKey();\n    }\n  }\n\n  /**\n   * @param key Key to insert.\n   * @param value Value to insert.\n   * @param comparator Comparator.\n   * @return New tree, with the key/value added.\n   */\n  insert(key: K, value: V, comparator: Comparator<K>): LLRBNode<K, V> {\n    let n: LLRBNode<K, V> = this;\n    const cmp = comparator(key, n.key);\n    if (cmp < 0) {\n      n = n.copy(null, null, null, n.left.insert(key, value, comparator), null);\n    } else if (cmp === 0) {\n      n = n.copy(null, value, null, null, null);\n    } else {\n      n = n.copy(\n        null,\n        null,\n        null,\n        null,\n        n.right.insert(key, value, comparator)\n      );\n    }\n    return n.fixUp_();\n  }\n\n  /**\n   * @return New tree, with the minimum key removed.\n   */\n  private removeMin_(): LLRBNode<K, V> | LLRBEmptyNode<K, V> {\n    if (this.left.isEmpty()) {\n      return SortedMap.EMPTY_NODE as LLRBEmptyNode<K, V>;\n    }\n    let n: LLRBNode<K, V> = this;\n    if (!n.left.isRed_() && !n.left.left.isRed_()) {\n      n = n.moveRedLeft_();\n    }\n    n = n.copy(null, null, null, (n.left as LLRBNode<K, V>).removeMin_(), null);\n    return n.fixUp_();\n  }\n\n  /**\n   * @param key The key of the item to remove.\n   * @param comparator Comparator.\n   * @return New tree, with the specified item removed.\n   */\n  remove(\n    key: K,\n    comparator: Comparator<K>\n  ): LLRBNode<K, V> | LLRBEmptyNode<K, V> {\n    let n, smallest;\n    n = this;\n    if (comparator(key, n.key) < 0) {\n      if (!n.left.isEmpty() && !n.left.isRed_() && !n.left.left.isRed_()) {\n        n = n.moveRedLeft_();\n      }\n      n = n.copy(null, null, null, n.left.remove(key, comparator), null);\n    } else {\n      if (n.left.isRed_()) {\n        n = n.rotateRight_();\n      }\n      if (!n.right.isEmpty() && !n.right.isRed_() && !n.right.left.isRed_()) {\n        n = n.moveRedRight_();\n      }\n      if (comparator(key, n.key) === 0) {\n        if (n.right.isEmpty()) {\n          return SortedMap.EMPTY_NODE as LLRBEmptyNode<K, V>;\n        } else {\n          smallest = (n.right as LLRBNode<K, V>).min_();\n          n = n.copy(\n            smallest.key,\n            smallest.value,\n            null,\n            null,\n            (n.right as LLRBNode<K, V>).removeMin_()\n          );\n        }\n      }\n      n = n.copy(null, null, null, null, n.right.remove(key, comparator));\n    }\n    return n.fixUp_();\n  }\n\n  /**\n   * @return Whether this is a RED node.\n   */\n  isRed_(): boolean {\n    return this.color;\n  }\n\n  /**\n   * @return New tree after performing any needed rotations.\n   */\n  private fixUp_(): LLRBNode<K, V> {\n    let n: LLRBNode<K, V> = this;\n    if (n.right.isRed_() && !n.left.isRed_()) {\n      n = n.rotateLeft_();\n    }\n    if (n.left.isRed_() && n.left.left.isRed_()) {\n      n = n.rotateRight_();\n    }\n    if (n.left.isRed_() && n.right.isRed_()) {\n      n = n.colorFlip_();\n    }\n    return n;\n  }\n\n  /**\n   * @return New tree, after moveRedLeft.\n   */\n  private moveRedLeft_(): LLRBNode<K, V> {\n    let n = this.colorFlip_();\n    if (n.right.left.isRed_()) {\n      n = n.copy(\n        null,\n        null,\n        null,\n        null,\n        (n.right as LLRBNode<K, V>).rotateRight_()\n      );\n      n = n.rotateLeft_();\n      n = n.colorFlip_();\n    }\n    return n;\n  }\n\n  /**\n   * @return New tree, after moveRedRight.\n   */\n  private moveRedRight_(): LLRBNode<K, V> {\n    let n = this.colorFlip_();\n    if (n.left.left.isRed_()) {\n      n = n.rotateRight_();\n      n = n.colorFlip_();\n    }\n    return n;\n  }\n\n  /**\n   * @return New tree, after rotateLeft.\n   */\n  private rotateLeft_(): LLRBNode<K, V> {\n    const nl = this.copy(null, null, LLRBNode.RED, null, this.right.left);\n    return this.right.copy(null, null, this.color, nl, null) as LLRBNode<K, V>;\n  }\n\n  /**\n   * @return New tree, after rotateRight.\n   */\n  private rotateRight_(): LLRBNode<K, V> {\n    const nr = this.copy(null, null, LLRBNode.RED, this.left.right, null);\n    return this.left.copy(null, null, this.color, null, nr) as LLRBNode<K, V>;\n  }\n\n  /**\n   * @return Newt ree, after colorFlip.\n   */\n  private colorFlip_(): LLRBNode<K, V> {\n    const left = this.left.copy(null, null, !this.left.color, null, null);\n    const right = this.right.copy(null, null, !this.right.color, null, null);\n    return this.copy(null, null, !this.color, left, right);\n  }\n\n  /**\n   * For testing.\n   *\n   * @return True if all is well.\n   */\n  private checkMaxDepth_(): boolean {\n    const blackDepth = this.check_();\n    return Math.pow(2.0, blackDepth) <= this.count() + 1;\n  }\n\n  check_(): number {\n    if (this.isRed_() && this.left.isRed_()) {\n      throw new Error(\n        'Red node has red child(' + this.key + ',' + this.value + ')'\n      );\n    }\n    if (this.right.isRed_()) {\n      throw new Error(\n        'Right child of (' + this.key + ',' + this.value + ') is red'\n      );\n    }\n    const blackDepth = this.left.check_();\n    if (blackDepth !== this.right.check_()) {\n      throw new Error('Black depths differ');\n    } else {\n      return blackDepth + (this.isRed_() ? 0 : 1);\n    }\n  }\n}\n\n/**\n * Represents an empty node (a leaf node in the Red-Black Tree).\n */\nexport class LLRBEmptyNode<K, V> {\n  key: K;\n  value: V;\n  left: LLRBNode<K, V> | LLRBEmptyNode<K, V>;\n  right: LLRBNode<K, V> | LLRBEmptyNode<K, V>;\n  color: boolean;\n\n  /**\n   * Returns a copy of the current node.\n   *\n   * @return The node copy.\n   */\n  copy(\n    key: K | null,\n    value: V | null,\n    color: boolean | null,\n    left: LLRBNode<K, V> | LLRBEmptyNode<K, V> | null,\n    right: LLRBNode<K, V> | LLRBEmptyNode<K, V> | null\n  ): LLRBEmptyNode<K, V> {\n    return this;\n  }\n\n  /**\n   * Returns a copy of the tree, with the specified key/value added.\n   *\n   * @param key Key to be added.\n   * @param value Value to be added.\n   * @param comparator Comparator.\n   * @return New tree, with item added.\n   */\n  insert(key: K, value: V, comparator: Comparator<K>): LLRBNode<K, V> {\n    return new LLRBNode(key, value, null);\n  }\n\n  /**\n   * Returns a copy of the tree, with the specified key removed.\n   *\n   * @param key The key to remove.\n   * @param comparator Comparator.\n   * @return New tree, with item removed.\n   */\n  remove(key: K, comparator: Comparator<K>): LLRBEmptyNode<K, V> {\n    return this;\n  }\n\n  /**\n   * @return The total number of nodes in the tree.\n   */\n  count(): number {\n    return 0;\n  }\n\n  /**\n   * @return True if the tree is empty.\n   */\n  isEmpty(): boolean {\n    return true;\n  }\n\n  /**\n   * Traverses the tree in key order and calls the specified action function\n   * for each node.\n   *\n   * @param action Callback function to be called for each\n   * node.  If it returns true, traversal is aborted.\n   * @return True if traversal was aborted.\n   */\n  inorderTraversal(action: (k: K, v: V) => unknown): boolean {\n    return false;\n  }\n\n  /**\n   * Traverses the tree in reverse key order and calls the specified action function\n   * for each node.\n   *\n   * @param action Callback function to be called for each\n   * node.  If it returns true, traversal is aborted.\n   * @return True if traversal was aborted.\n   */\n  reverseTraversal(action: (k: K, v: V) => void): boolean {\n    return false;\n  }\n\n  minKey(): null {\n    return null;\n  }\n\n  maxKey(): null {\n    return null;\n  }\n\n  check_(): number {\n    return 0;\n  }\n\n  /**\n   * @return Whether this node is red.\n   */\n  isRed_() {\n    return false;\n  }\n}\n\n/**\n * An immutable sorted map implementation, based on a Left-leaning Red-Black\n * tree.\n */\nexport class SortedMap<K, V> {\n  /**\n   * Always use the same empty node, to reduce memory.\n   */\n  static EMPTY_NODE = new LLRBEmptyNode();\n\n  /**\n   * @param comparator_ Key comparator.\n   * @param root_ (Optional) Root node for the map.\n   */\n  constructor(\n    private comparator_: Comparator<K>,\n    private root_:\n      | LLRBNode<K, V>\n      | LLRBEmptyNode<K, V> = SortedMap.EMPTY_NODE as LLRBEmptyNode<K, V>\n  ) {}\n\n  /**\n   * Returns a copy of the map, with the specified key/value added or replaced.\n   * (TODO: We should perhaps rename this method to 'put')\n   *\n   * @param key Key to be added.\n   * @param value Value to be added.\n   * @return New map, with item added.\n   */\n  insert(key: K, value: V): SortedMap<K, V> {\n    return new SortedMap(\n      this.comparator_,\n      this.root_\n        .insert(key, value, this.comparator_)\n        .copy(null, null, LLRBNode.BLACK, null, null)\n    );\n  }\n\n  /**\n   * Returns a copy of the map, with the specified key removed.\n   *\n   * @param key The key to remove.\n   * @return New map, with item removed.\n   */\n  remove(key: K): SortedMap<K, V> {\n    return new SortedMap(\n      this.comparator_,\n      this.root_\n        .remove(key, this.comparator_)\n        .copy(null, null, LLRBNode.BLACK, null, null)\n    );\n  }\n\n  /**\n   * Returns the value of the node with the given key, or null.\n   *\n   * @param key The key to look up.\n   * @return The value of the node with the given key, or null if the\n   * key doesn't exist.\n   */\n  get(key: K): V | null {\n    let cmp;\n    let node = this.root_;\n    while (!node.isEmpty()) {\n      cmp = this.comparator_(key, node.key);\n      if (cmp === 0) {\n        return node.value;\n      } else if (cmp < 0) {\n        node = node.left;\n      } else if (cmp > 0) {\n        node = node.right;\n      }\n    }\n    return null;\n  }\n\n  /**\n   * Returns the key of the item *before* the specified key, or null if key is the first item.\n   * @param key The key to find the predecessor of\n   * @return The predecessor key.\n   */\n  getPredecessorKey(key: K): K | null {\n    let cmp,\n      node = this.root_,\n      rightParent = null;\n    while (!node.isEmpty()) {\n      cmp = this.comparator_(key, node.key);\n      if (cmp === 0) {\n        if (!node.left.isEmpty()) {\n          node = node.left;\n          while (!node.right.isEmpty()) {\n            node = node.right;\n          }\n          return node.key;\n        } else if (rightParent) {\n          return rightParent.key;\n        } else {\n          return null; // first item.\n        }\n      } else if (cmp < 0) {\n        node = node.left;\n      } else if (cmp > 0) {\n        rightParent = node;\n        node = node.right;\n      }\n    }\n\n    throw new Error(\n      'Attempted to find predecessor key for a nonexistent key.  What gives?'\n    );\n  }\n\n  /**\n   * @return True if the map is empty.\n   */\n  isEmpty(): boolean {\n    return this.root_.isEmpty();\n  }\n\n  /**\n   * @return The total number of nodes in the map.\n   */\n  count(): number {\n    return this.root_.count();\n  }\n\n  /**\n   * @return The minimum key in the map.\n   */\n  minKey(): K | null {\n    return this.root_.minKey();\n  }\n\n  /**\n   * @return The maximum key in the map.\n   */\n  maxKey(): K | null {\n    return this.root_.maxKey();\n  }\n\n  /**\n   * Traverses the map in key order and calls the specified action function\n   * for each key/value pair.\n   *\n   * @param action Callback function to be called\n   * for each key/value pair.  If action returns true, traversal is aborted.\n   * @return The first truthy value returned by action, or the last falsey\n   *   value returned by action\n   */\n  inorderTraversal(action: (k: K, v: V) => unknown): boolean {\n    return this.root_.inorderTraversal(action);\n  }\n\n  /**\n   * Traverses the map in reverse key order and calls the specified action function\n   * for each key/value pair.\n   *\n   * @param action Callback function to be called\n   * for each key/value pair.  If action returns true, traversal is aborted.\n   * @return True if the traversal was aborted.\n   */\n  reverseTraversal(action: (k: K, v: V) => void): boolean {\n    return this.root_.reverseTraversal(action);\n  }\n\n  /**\n   * Returns an iterator over the SortedMap.\n   * @return The iterator.\n   */\n  getIterator<T>(\n    resultGenerator?: (k: K, v: V) => T\n  ): SortedMapIterator<K, V, T> {\n    return new SortedMapIterator(\n      this.root_,\n      null,\n      this.comparator_,\n      false,\n      resultGenerator\n    );\n  }\n\n  getIteratorFrom<T>(\n    key: K,\n    resultGenerator?: (k: K, v: V) => T\n  ): SortedMapIterator<K, V, T> {\n    return new SortedMapIterator(\n      this.root_,\n      key,\n      this.comparator_,\n      false,\n      resultGenerator\n    );\n  }\n\n  getReverseIteratorFrom<T>(\n    key: K,\n    resultGenerator?: (k: K, v: V) => T\n  ): SortedMapIterator<K, V, T> {\n    return new SortedMapIterator(\n      this.root_,\n      key,\n      this.comparator_,\n      true,\n      resultGenerator\n    );\n  }\n\n  getReverseIterator<T>(\n    resultGenerator?: (k: K, v: V) => T\n  ): SortedMapIterator<K, V, T> {\n    return new SortedMapIterator(\n      this.root_,\n      null,\n      this.comparator_,\n      true,\n      resultGenerator\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Path } from '../util/Path';\nimport { Index } from './indexes/Index';\n\n/**\n * Node is an interface defining the common functionality for nodes in\n * a DataSnapshot.\n *\n * @interface\n */\nexport interface Node {\n  /**\n   * Whether this node is a leaf node.\n   * @return Whether this is a leaf node.\n   */\n  isLeafNode(): boolean;\n\n  /**\n   * Gets the priority of the node.\n   * @return The priority of the node.\n   */\n  getPriority(): Node;\n\n  /**\n   * Returns a duplicate node with the new priority.\n   * @param newPriorityNode New priority to set for the node.\n   * @return Node with new priority.\n   */\n  updatePriority(newPriorityNode: Node): Node;\n\n  /**\n   * Returns the specified immediate child, or null if it doesn't exist.\n   * @param childName The name of the child to retrieve.\n   * @return The retrieved child, or an empty node.\n   */\n  getImmediateChild(childName: string): Node;\n\n  /**\n   * Returns a child by path, or null if it doesn't exist.\n   * @param path The path of the child to retrieve.\n   * @return The retrieved child or an empty node.\n   */\n  getChild(path: Path): Node;\n\n  /**\n   * Returns the name of the child immediately prior to the specified childNode, or null.\n   * @param childName The name of the child to find the predecessor of.\n   * @param childNode The node to find the predecessor of.\n   * @param index The index to use to determine the predecessor\n   * @return The name of the predecessor child, or null if childNode is the first child.\n   */\n  getPredecessorChildName(\n    childName: string,\n    childNode: Node,\n    index: Index\n  ): string | null;\n\n  /**\n   * Returns a duplicate node, with the specified immediate child updated.\n   * Any value in the node will be removed.\n   * @param childName The name of the child to update.\n   * @param newChildNode The new child node\n   * @return The updated node.\n   */\n  updateImmediateChild(childName: string, newChildNode: Node): Node;\n\n  /**\n   * Returns a duplicate node, with the specified child updated.  Any value will\n   * be removed.\n   * @param path The path of the child to update.\n   * @param newChildNode The new child node, which may be an empty node\n   * @return The updated node.\n   */\n  updateChild(path: Path, newChildNode: Node): Node;\n\n  /**\n   * True if the immediate child specified exists\n   */\n  hasChild(childName: string): boolean;\n\n  /**\n   * @return True if this node has no value or children.\n   */\n  isEmpty(): boolean;\n\n  /**\n   * @return The number of children of this node.\n   */\n  numChildren(): number;\n\n  /**\n   * Calls action for each child.\n   * @param action Action to be called for\n   * each child.  It's passed the child name and the child node.\n   * @return The first truthy value return by action, or the last falsey one\n   */\n  forEachChild(index: Index, action: (a: string, b: Node) => void): unknown;\n\n  /**\n   * @param exportFormat True for export format (also wire protocol format).\n   * @return Value of this node as JSON.\n   */\n  val(exportFormat?: boolean): unknown;\n\n  /**\n   * @return hash representing the node contents.\n   */\n  hash(): string;\n\n  /**\n   * @param other Another node\n   * @return -1 for less than, 0 for equal, 1 for greater than other\n   */\n  compareTo(other: Node): number;\n\n  /**\n   * @return Whether or not this snapshot equals other\n   */\n  equals(other: Node): boolean;\n\n  /**\n   * @return This node, with the specified index now available\n   */\n  withIndex(indexDefinition: Index): Node;\n\n  isIndexed(indexDefinition: Index): boolean;\n}\n\nexport class NamedNode {\n  constructor(public name: string, public node: Node) {}\n\n  static Wrap(name: string, node: Node) {\n    return new NamedNode(name, node);\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Node, NamedNode } from '../Node';\nimport { MIN_NAME } from '../../util/util';\nimport { Comparator } from '../../util/SortedMap';\n\nexport abstract class Index {\n  abstract compare(a: NamedNode, b: NamedNode): number;\n\n  abstract isDefinedOn(node: Node): boolean;\n\n  /**\n   * @return A standalone comparison function for\n   * this index\n   */\n  getCompare(): Comparator<NamedNode> {\n    return this.compare.bind(this);\n  }\n\n  /**\n   * Given a before and after value for a node, determine if the indexed value has changed. Even if they are different,\n   * it's possible that the changes are isolated to parts of the snapshot that are not indexed.\n   *\n   *\n   * @return True if the portion of the snapshot being indexed changed between oldNode and newNode\n   */\n  indexedValueChanged(oldNode: Node, newNode: Node): boolean {\n    const oldWrapped = new NamedNode(MIN_NAME, oldNode);\n    const newWrapped = new NamedNode(MIN_NAME, newNode);\n    return this.compare(oldWrapped, newWrapped) !== 0;\n  }\n\n  /**\n   * @return a node wrapper that will sort equal to or less than\n   * any other node wrapper, using this index\n   */\n  minPost(): NamedNode {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return (NamedNode as any).MIN;\n  }\n\n  /**\n   * @return a node wrapper that will sort greater than or equal to\n   * any other node wrapper, using this index\n   */\n  abstract maxPost(): NamedNode;\n\n  abstract makePost(indexValue: unknown, name: string): NamedNode;\n\n  /**\n   * @return String representation for inclusion in a query spec\n   */\n  abstract toString(): string;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Index } from './Index';\nimport { Node, NamedNode } from '../Node';\nimport { nameCompare, MAX_NAME } from '../../util/util';\nimport { assert, assertionError } from '@firebase/util';\nimport { ChildrenNode } from '../ChildrenNode';\n\nlet __EMPTY_NODE: ChildrenNode;\n\nexport class KeyIndex extends Index {\n  static get __EMPTY_NODE() {\n    return __EMPTY_NODE;\n  }\n\n  static set __EMPTY_NODE(val) {\n    __EMPTY_NODE = val;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  compare(a: NamedNode, b: NamedNode): number {\n    return nameCompare(a.name, b.name);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  isDefinedOn(node: Node): boolean {\n    // We could probably return true here (since every node has a key), but it's never called\n    // so just leaving unimplemented for now.\n    throw assertionError('KeyIndex.isDefinedOn not expected to be called.');\n  }\n\n  /**\n   * @inheritDoc\n   */\n  indexedValueChanged(oldNode: Node, newNode: Node): boolean {\n    return false; // The key for a node never changes.\n  }\n\n  /**\n   * @inheritDoc\n   */\n  minPost() {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return (NamedNode as any).MIN;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  maxPost(): NamedNode {\n    // TODO: This should really be created once and cached in a static property, but\n    // NamedNode isn't defined yet, so I can't use it in a static.  Bleh.\n    return new NamedNode(MAX_NAME, __EMPTY_NODE);\n  }\n\n  makePost(indexValue: string, name: string): NamedNode {\n    assert(\n      typeof indexValue === 'string',\n      'KeyIndex indexValue must always be a string.'\n    );\n    // We just use empty node, but it'll never be compared, since our comparator only looks at name.\n    return new NamedNode(indexValue, __EMPTY_NODE);\n  }\n\n  /**\n   * @return String representation for inclusion in a query spec\n   */\n  toString(): string {\n    return '.key';\n  }\n}\n\nexport const KEY_INDEX = new KeyIndex();\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert, contains, map, safeGet } from '@firebase/util';\nimport { buildChildSet } from './childSet';\n\nimport { NamedNode, Node } from './Node';\nimport { PRIORITY_INDEX } from './indexes/PriorityIndex';\nimport { KEY_INDEX } from './indexes/KeyIndex';\nimport { SortedMap } from '../util/SortedMap';\nimport { Index } from './indexes/Index';\n\nlet _defaultIndexMap: IndexMap;\n\nconst fallbackObject = {};\n\nexport class IndexMap {\n  /**\n   * The default IndexMap for nodes without a priority\n   */\n  static get Default(): IndexMap {\n    assert(\n      fallbackObject && PRIORITY_INDEX,\n      'ChildrenNode.ts has not been loaded'\n    );\n    _defaultIndexMap =\n      _defaultIndexMap ||\n      new IndexMap(\n        { '.priority': fallbackObject },\n        { '.priority': PRIORITY_INDEX }\n      );\n    return _defaultIndexMap;\n  }\n\n  constructor(\n    private indexes_: {\n      [k: string]: SortedMap<NamedNode, Node> | /*FallbackType*/ object;\n    },\n    private indexSet_: { [k: string]: Index }\n  ) {}\n\n  get(indexKey: string): SortedMap<NamedNode, Node> | null {\n    const sortedMap = safeGet(this.indexes_, indexKey);\n    if (!sortedMap) {\n      throw new Error('No index defined for ' + indexKey);\n    }\n\n    if (sortedMap instanceof SortedMap) {\n      return sortedMap;\n    } else {\n      // The index exists, but it falls back to just name comparison. Return null so that the calling code uses the\n      // regular child map\n      return null;\n    }\n  }\n\n  hasIndex(indexDefinition: Index): boolean {\n    return contains(this.indexSet_, indexDefinition.toString());\n  }\n\n  addIndex(\n    indexDefinition: Index,\n    existingChildren: SortedMap<string, Node>\n  ): IndexMap {\n    assert(\n      indexDefinition !== KEY_INDEX,\n      \"KeyIndex always exists and isn't meant to be added to the IndexMap.\"\n    );\n    const childList = [];\n    let sawIndexedValue = false;\n    const iter = existingChildren.getIterator(NamedNode.Wrap);\n    let next = iter.getNext();\n    while (next) {\n      sawIndexedValue =\n        sawIndexedValue || indexDefinition.isDefinedOn(next.node);\n      childList.push(next);\n      next = iter.getNext();\n    }\n    let newIndex;\n    if (sawIndexedValue) {\n      newIndex = buildChildSet(childList, indexDefinition.getCompare());\n    } else {\n      newIndex = fallbackObject;\n    }\n    const indexName = indexDefinition.toString();\n    const newIndexSet = { ...this.indexSet_ };\n    newIndexSet[indexName] = indexDefinition;\n    const newIndexes = { ...this.indexes_ };\n    newIndexes[indexName] = newIndex;\n    return new IndexMap(newIndexes, newIndexSet);\n  }\n\n  /**\n   * Ensure that this node is properly tracked in any indexes that we're maintaining\n   */\n  addToIndexes(\n    namedNode: NamedNode,\n    existingChildren: SortedMap<string, Node>\n  ): IndexMap {\n    const newIndexes = map(\n      this.indexes_,\n      (indexedChildren: SortedMap<NamedNode, Node>, indexName: string) => {\n        const index = safeGet(this.indexSet_, indexName);\n        assert(index, 'Missing index implementation for ' + indexName);\n        if (indexedChildren === fallbackObject) {\n          // Check to see if we need to index everything\n          if (index.isDefinedOn(namedNode.node)) {\n            // We need to build this index\n            const childList = [];\n            const iter = existingChildren.getIterator(NamedNode.Wrap);\n            let next = iter.getNext();\n            while (next) {\n              if (next.name !== namedNode.name) {\n                childList.push(next);\n              }\n              next = iter.getNext();\n            }\n            childList.push(namedNode);\n            return buildChildSet(childList, index.getCompare());\n          } else {\n            // No change, this remains a fallback\n            return fallbackObject;\n          }\n        } else {\n          const existingSnap = existingChildren.get(namedNode.name);\n          let newChildren = indexedChildren;\n          if (existingSnap) {\n            newChildren = newChildren.remove(\n              new NamedNode(namedNode.name, existingSnap)\n            );\n          }\n          return newChildren.insert(namedNode, namedNode.node);\n        }\n      }\n    );\n    return new IndexMap(newIndexes, this.indexSet_);\n  }\n\n  /**\n   * Create a new IndexMap instance with the given value removed\n   */\n  removeFromIndexes(\n    namedNode: NamedNode,\n    existingChildren: SortedMap<string, Node>\n  ): IndexMap {\n    const newIndexes = map(\n      this.indexes_,\n      (indexedChildren: SortedMap<NamedNode, Node>) => {\n        if (indexedChildren === fallbackObject) {\n          // This is the fallback. Just return it, nothing to do in this case\n          return indexedChildren;\n        } else {\n          const existingSnap = existingChildren.get(namedNode.name);\n          if (existingSnap) {\n            return indexedChildren.remove(\n              new NamedNode(namedNode.name, existingSnap)\n            );\n          } else {\n            // No record of this child\n            return indexedChildren;\n          }\n        }\n      }\n    );\n    return new IndexMap(newIndexes, this.indexSet_);\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert } from '@firebase/util';\nimport { MAX_NAME, MIN_NAME, sha1 } from '../util/util';\nimport { SortedMap, SortedMapIterator } from '../util/SortedMap';\nimport { NamedNode, Node } from './Node';\nimport { priorityHashText, setMaxNode, validatePriorityNode } from './snap';\nimport {\n  PRIORITY_INDEX,\n  setMaxNode as setPriorityMaxNode\n} from './indexes/PriorityIndex';\nimport { KEY_INDEX, KeyIndex } from './indexes/KeyIndex';\nimport { IndexMap } from './IndexMap';\nimport { LeafNode } from './LeafNode';\nimport { NAME_COMPARATOR } from './comparators';\nimport { Index } from './indexes/Index';\nimport { Path, pathGetFront, pathGetLength, pathPopFront } from '../util/Path';\n\nexport interface ChildrenNodeConstructor {\n  new (\n    children_: SortedMap<string, Node>,\n    priorityNode_: Node | null,\n    indexMap_: IndexMap\n  ): ChildrenNode;\n  EMPTY_NODE: ChildrenNode;\n}\n\n// TODO: For memory savings, don't store priorityNode_ if it's empty.\n\nlet EMPTY_NODE: ChildrenNode;\n\n/**\n * ChildrenNode is a class for storing internal nodes in a DataSnapshot\n * (i.e. nodes with children).  It implements Node and stores the\n * list of children in the children property, sorted by child name.\n */\nexport class ChildrenNode implements Node {\n  private lazyHash_: string | null = null;\n\n  static get EMPTY_NODE(): ChildrenNode {\n    return (\n      EMPTY_NODE ||\n      (EMPTY_NODE = new ChildrenNode(\n        new SortedMap<string, Node>(NAME_COMPARATOR),\n        null,\n        IndexMap.Default\n      ))\n    );\n  }\n\n  /**\n   * @param children_ List of children of this node..\n   * @param priorityNode_ The priority of this node (as a snapshot node).\n   */\n  constructor(\n    private readonly children_: SortedMap<string, Node>,\n    private readonly priorityNode_: Node | null,\n    private indexMap_: IndexMap\n  ) {\n    /**\n     * Note: The only reason we allow null priority is for EMPTY_NODE, since we can't use\n     * EMPTY_NODE as the priority of EMPTY_NODE.  We might want to consider making EMPTY_NODE its own\n     * class instead of an empty ChildrenNode.\n     */\n    if (this.priorityNode_) {\n      validatePriorityNode(this.priorityNode_);\n    }\n\n    if (this.children_.isEmpty()) {\n      assert(\n        !this.priorityNode_ || this.priorityNode_.isEmpty(),\n        'An empty node cannot have a priority'\n      );\n    }\n  }\n\n  /** @inheritDoc */\n  isLeafNode(): boolean {\n    return false;\n  }\n\n  /** @inheritDoc */\n  getPriority(): Node {\n    return this.priorityNode_ || EMPTY_NODE;\n  }\n\n  /** @inheritDoc */\n  updatePriority(newPriorityNode: Node): Node {\n    if (this.children_.isEmpty()) {\n      // Don't allow priorities on empty nodes\n      return this;\n    } else {\n      return new ChildrenNode(this.children_, newPriorityNode, this.indexMap_);\n    }\n  }\n\n  /** @inheritDoc */\n  getImmediateChild(childName: string): Node {\n    // Hack to treat priority as a regular child\n    if (childName === '.priority') {\n      return this.getPriority();\n    } else {\n      const child = this.children_.get(childName);\n      return child === null ? EMPTY_NODE : child;\n    }\n  }\n\n  /** @inheritDoc */\n  getChild(path: Path): Node {\n    const front = pathGetFront(path);\n    if (front === null) {\n      return this;\n    }\n\n    return this.getImmediateChild(front).getChild(pathPopFront(path));\n  }\n\n  /** @inheritDoc */\n  hasChild(childName: string): boolean {\n    return this.children_.get(childName) !== null;\n  }\n\n  /** @inheritDoc */\n  updateImmediateChild(childName: string, newChildNode: Node): Node {\n    assert(newChildNode, 'We should always be passing snapshot nodes');\n    if (childName === '.priority') {\n      return this.updatePriority(newChildNode);\n    } else {\n      const namedNode = new NamedNode(childName, newChildNode);\n      let newChildren, newIndexMap;\n      if (newChildNode.isEmpty()) {\n        newChildren = this.children_.remove(childName);\n        newIndexMap = this.indexMap_.removeFromIndexes(\n          namedNode,\n          this.children_\n        );\n      } else {\n        newChildren = this.children_.insert(childName, newChildNode);\n        newIndexMap = this.indexMap_.addToIndexes(namedNode, this.children_);\n      }\n\n      const newPriority = newChildren.isEmpty()\n        ? EMPTY_NODE\n        : this.priorityNode_;\n      return new ChildrenNode(newChildren, newPriority, newIndexMap);\n    }\n  }\n\n  /** @inheritDoc */\n  updateChild(path: Path, newChildNode: Node): Node {\n    const front = pathGetFront(path);\n    if (front === null) {\n      return newChildNode;\n    } else {\n      assert(\n        pathGetFront(path) !== '.priority' || pathGetLength(path) === 1,\n        '.priority must be the last token in a path'\n      );\n      const newImmediateChild = this.getImmediateChild(front).updateChild(\n        pathPopFront(path),\n        newChildNode\n      );\n      return this.updateImmediateChild(front, newImmediateChild);\n    }\n  }\n\n  /** @inheritDoc */\n  isEmpty(): boolean {\n    return this.children_.isEmpty();\n  }\n\n  /** @inheritDoc */\n  numChildren(): number {\n    return this.children_.count();\n  }\n\n  private static INTEGER_REGEXP_ = /^(0|[1-9]\\d*)$/;\n\n  /** @inheritDoc */\n  val(exportFormat?: boolean): object {\n    if (this.isEmpty()) {\n      return null;\n    }\n\n    const obj: { [k: string]: unknown } = {};\n    let numKeys = 0,\n      maxKey = 0,\n      allIntegerKeys = true;\n    this.forEachChild(PRIORITY_INDEX, (key: string, childNode: Node) => {\n      obj[key] = childNode.val(exportFormat);\n\n      numKeys++;\n      if (allIntegerKeys && ChildrenNode.INTEGER_REGEXP_.test(key)) {\n        maxKey = Math.max(maxKey, Number(key));\n      } else {\n        allIntegerKeys = false;\n      }\n    });\n\n    if (!exportFormat && allIntegerKeys && maxKey < 2 * numKeys) {\n      // convert to array.\n      const array: unknown[] = [];\n      // eslint-disable-next-line guard-for-in\n      for (const key in obj) {\n        array[(key as unknown) as number] = obj[key];\n      }\n\n      return array;\n    } else {\n      if (exportFormat && !this.getPriority().isEmpty()) {\n        obj['.priority'] = this.getPriority().val();\n      }\n      return obj;\n    }\n  }\n\n  /** @inheritDoc */\n  hash(): string {\n    if (this.lazyHash_ === null) {\n      let toHash = '';\n      if (!this.getPriority().isEmpty()) {\n        toHash +=\n          'priority:' +\n          priorityHashText(this.getPriority().val() as string | number) +\n          ':';\n      }\n\n      this.forEachChild(PRIORITY_INDEX, (key, childNode) => {\n        const childHash = childNode.hash();\n        if (childHash !== '') {\n          toHash += ':' + key + ':' + childHash;\n        }\n      });\n\n      this.lazyHash_ = toHash === '' ? '' : sha1(toHash);\n    }\n    return this.lazyHash_;\n  }\n\n  /** @inheritDoc */\n  getPredecessorChildName(\n    childName: string,\n    childNode: Node,\n    index: Index\n  ): string {\n    const idx = this.resolveIndex_(index);\n    if (idx) {\n      const predecessor = idx.getPredecessorKey(\n        new NamedNode(childName, childNode)\n      );\n      return predecessor ? predecessor.name : null;\n    } else {\n      return this.children_.getPredecessorKey(childName);\n    }\n  }\n\n  getFirstChildName(indexDefinition: Index): string | null {\n    const idx = this.resolveIndex_(indexDefinition);\n    if (idx) {\n      const minKey = idx.minKey();\n      return minKey && minKey.name;\n    } else {\n      return this.children_.minKey();\n    }\n  }\n\n  getFirstChild(indexDefinition: Index): NamedNode | null {\n    const minKey = this.getFirstChildName(indexDefinition);\n    if (minKey) {\n      return new NamedNode(minKey, this.children_.get(minKey));\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * Given an index, return the key name of the largest value we have, according to that index\n   */\n  getLastChildName(indexDefinition: Index): string | null {\n    const idx = this.resolveIndex_(indexDefinition);\n    if (idx) {\n      const maxKey = idx.maxKey();\n      return maxKey && maxKey.name;\n    } else {\n      return this.children_.maxKey();\n    }\n  }\n\n  getLastChild(indexDefinition: Index): NamedNode | null {\n    const maxKey = this.getLastChildName(indexDefinition);\n    if (maxKey) {\n      return new NamedNode(maxKey, this.children_.get(maxKey));\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  forEachChild(\n    index: Index,\n    action: (key: string, node: Node) => boolean | void\n  ): boolean {\n    const idx = this.resolveIndex_(index);\n    if (idx) {\n      return idx.inorderTraversal(wrappedNode => {\n        return action(wrappedNode.name, wrappedNode.node);\n      });\n    } else {\n      return this.children_.inorderTraversal(action);\n    }\n  }\n\n  getIterator(\n    indexDefinition: Index\n  ): SortedMapIterator<string | NamedNode, Node, NamedNode> {\n    return this.getIteratorFrom(indexDefinition.minPost(), indexDefinition);\n  }\n\n  getIteratorFrom(\n    startPost: NamedNode,\n    indexDefinition: Index\n  ): SortedMapIterator<string | NamedNode, Node, NamedNode> {\n    const idx = this.resolveIndex_(indexDefinition);\n    if (idx) {\n      return idx.getIteratorFrom(startPost, key => key);\n    } else {\n      const iterator = this.children_.getIteratorFrom(\n        startPost.name,\n        NamedNode.Wrap\n      );\n      let next = iterator.peek();\n      while (next != null && indexDefinition.compare(next, startPost) < 0) {\n        iterator.getNext();\n        next = iterator.peek();\n      }\n      return iterator;\n    }\n  }\n\n  getReverseIterator(\n    indexDefinition: Index\n  ): SortedMapIterator<string | NamedNode, Node, NamedNode> {\n    return this.getReverseIteratorFrom(\n      indexDefinition.maxPost(),\n      indexDefinition\n    );\n  }\n\n  getReverseIteratorFrom(\n    endPost: NamedNode,\n    indexDefinition: Index\n  ): SortedMapIterator<string | NamedNode, Node, NamedNode> {\n    const idx = this.resolveIndex_(indexDefinition);\n    if (idx) {\n      return idx.getReverseIteratorFrom(endPost, key => {\n        return key;\n      });\n    } else {\n      const iterator = this.children_.getReverseIteratorFrom(\n        endPost.name,\n        NamedNode.Wrap\n      );\n      let next = iterator.peek();\n      while (next != null && indexDefinition.compare(next, endPost) > 0) {\n        iterator.getNext();\n        next = iterator.peek();\n      }\n      return iterator;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  compareTo(other: ChildrenNode): number {\n    if (this.isEmpty()) {\n      if (other.isEmpty()) {\n        return 0;\n      } else {\n        return -1;\n      }\n    } else if (other.isLeafNode() || other.isEmpty()) {\n      return 1;\n    } else if (other === MAX_NODE) {\n      return -1;\n    } else {\n      // Must be another node with children.\n      return 0;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  withIndex(indexDefinition: Index): Node {\n    if (\n      indexDefinition === KEY_INDEX ||\n      this.indexMap_.hasIndex(indexDefinition)\n    ) {\n      return this;\n    } else {\n      const newIndexMap = this.indexMap_.addIndex(\n        indexDefinition,\n        this.children_\n      );\n      return new ChildrenNode(this.children_, this.priorityNode_, newIndexMap);\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  isIndexed(index: Index): boolean {\n    return index === KEY_INDEX || this.indexMap_.hasIndex(index);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  equals(other: Node): boolean {\n    if (other === this) {\n      return true;\n    } else if (other.isLeafNode()) {\n      return false;\n    } else {\n      const otherChildrenNode = other as ChildrenNode;\n      if (!this.getPriority().equals(otherChildrenNode.getPriority())) {\n        return false;\n      } else if (\n        this.children_.count() === otherChildrenNode.children_.count()\n      ) {\n        const thisIter = this.getIterator(PRIORITY_INDEX);\n        const otherIter = otherChildrenNode.getIterator(PRIORITY_INDEX);\n        let thisCurrent = thisIter.getNext();\n        let otherCurrent = otherIter.getNext();\n        while (thisCurrent && otherCurrent) {\n          if (\n            thisCurrent.name !== otherCurrent.name ||\n            !thisCurrent.node.equals(otherCurrent.node)\n          ) {\n            return false;\n          }\n          thisCurrent = thisIter.getNext();\n          otherCurrent = otherIter.getNext();\n        }\n        return thisCurrent === null && otherCurrent === null;\n      } else {\n        return false;\n      }\n    }\n  }\n\n  /**\n   * Returns a SortedMap ordered by index, or null if the default (by-key) ordering can be used\n   * instead.\n   *\n   */\n  private resolveIndex_(\n    indexDefinition: Index\n  ): SortedMap<NamedNode, Node> | null {\n    if (indexDefinition === KEY_INDEX) {\n      return null;\n    } else {\n      return this.indexMap_.get(indexDefinition.toString());\n    }\n  }\n}\n\nexport class MaxNode extends ChildrenNode {\n  constructor() {\n    super(\n      new SortedMap<string, Node>(NAME_COMPARATOR),\n      ChildrenNode.EMPTY_NODE,\n      IndexMap.Default\n    );\n  }\n\n  compareTo(other: Node): number {\n    if (other === this) {\n      return 0;\n    } else {\n      return 1;\n    }\n  }\n\n  equals(other: Node): boolean {\n    // Not that we every compare it, but MAX_NODE is only ever equal to itself\n    return other === this;\n  }\n\n  getPriority(): MaxNode {\n    return this;\n  }\n\n  getImmediateChild(childName: string): ChildrenNode {\n    return ChildrenNode.EMPTY_NODE;\n  }\n\n  isEmpty(): boolean {\n    return false;\n  }\n}\n\n/**\n * Marker that will sort higher than any other snapshot.\n */\nexport const MAX_NODE = new MaxNode();\n\n/**\n * Document NamedNode extensions\n */\ndeclare module './Node' {\n  interface NamedNode {\n    MIN: NamedNode;\n    MAX: NamedNode;\n  }\n}\n\nObject.defineProperties(NamedNode, {\n  MIN: {\n    value: new NamedNode(MIN_NAME, ChildrenNode.EMPTY_NODE)\n  },\n  MAX: {\n    value: new NamedNode(MAX_NAME, MAX_NODE)\n  }\n});\n\n/**\n * Reference Extensions\n */\nKeyIndex.__EMPTY_NODE = ChildrenNode.EMPTY_NODE;\nLeafNode.__childrenNodeConstructor = ChildrenNode;\nsetMaxNode(MAX_NODE);\nsetPriorityMaxNode(MAX_NODE);\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { LLRBNode, SortedMap } from '../util/SortedMap';\n\nimport { NamedNode } from './Node';\n\nconst LOG_2 = Math.log(2);\n\nclass Base12Num {\n  count: number;\n  private current_: number;\n  private bits_: number;\n\n  constructor(length: number) {\n    const logBase2 = (num: number) =>\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      parseInt((Math.log(num) / LOG_2) as any, 10);\n    const bitMask = (bits: number) => parseInt(Array(bits + 1).join('1'), 2);\n    this.count = logBase2(length + 1);\n    this.current_ = this.count - 1;\n    const mask = bitMask(this.count);\n    this.bits_ = (length + 1) & mask;\n  }\n\n  nextBitIsOne(): boolean {\n    //noinspection JSBitwiseOperatorUsage\n    const result = !(this.bits_ & (0x1 << this.current_));\n    this.current_--;\n    return result;\n  }\n}\n\n/**\n * Takes a list of child nodes and constructs a SortedSet using the given comparison\n * function\n *\n * Uses the algorithm described in the paper linked here:\n * http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.46.1458\n *\n * @param childList Unsorted list of children\n * @param cmp The comparison method to be used\n * @param keyFn An optional function to extract K from a node wrapper, if K's\n * type is not NamedNode\n * @param mapSortFn An optional override for comparator used by the generated sorted map\n */\nexport const buildChildSet = function <K, V>(\n  childList: NamedNode[],\n  cmp: (a: NamedNode, b: NamedNode) => number,\n  keyFn?: (a: NamedNode) => K,\n  mapSortFn?: (a: K, b: K) => number\n): SortedMap<K, V> {\n  childList.sort(cmp);\n\n  const buildBalancedTree = function (\n    low: number,\n    high: number\n  ): LLRBNode<K, V> | null {\n    const length = high - low;\n    let namedNode: NamedNode;\n    let key: K;\n    if (length === 0) {\n      return null;\n    } else if (length === 1) {\n      namedNode = childList[low];\n      key = keyFn ? keyFn(namedNode) : ((namedNode as unknown) as K);\n      return new LLRBNode(\n        key,\n        (namedNode.node as unknown) as V,\n        LLRBNode.BLACK,\n        null,\n        null\n      );\n    } else {\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      const middle = parseInt((length / 2) as any, 10) + low;\n      const left = buildBalancedTree(low, middle);\n      const right = buildBalancedTree(middle + 1, high);\n      namedNode = childList[middle];\n      key = keyFn ? keyFn(namedNode) : ((namedNode as unknown) as K);\n      return new LLRBNode(\n        key,\n        (namedNode.node as unknown) as V,\n        LLRBNode.BLACK,\n        left,\n        right\n      );\n    }\n  };\n\n  const buildFrom12Array = function (base12: Base12Num): LLRBNode<K, V> {\n    let node: LLRBNode<K, V> = null;\n    let root = null;\n    let index = childList.length;\n\n    const buildPennant = function (chunkSize: number, color: boolean) {\n      const low = index - chunkSize;\n      const high = index;\n      index -= chunkSize;\n      const childTree = buildBalancedTree(low + 1, high);\n      const namedNode = childList[low];\n      const key: K = keyFn ? keyFn(namedNode) : ((namedNode as unknown) as K);\n      attachPennant(\n        new LLRBNode(\n          key,\n          (namedNode.node as unknown) as V,\n          color,\n          null,\n          childTree\n        )\n      );\n    };\n\n    const attachPennant = function (pennant: LLRBNode<K, V>) {\n      if (node) {\n        node.left = pennant;\n        node = pennant;\n      } else {\n        root = pennant;\n        node = pennant;\n      }\n    };\n\n    for (let i = 0; i < base12.count; ++i) {\n      const isOne = base12.nextBitIsOne();\n      // The number of nodes taken in each slice is 2^(arr.length - (i + 1))\n      const chunkSize = Math.pow(2, base12.count - (i + 1));\n      if (isOne) {\n        buildPennant(chunkSize, LLRBNode.BLACK);\n      } else {\n        // current == 2\n        buildPennant(chunkSize, LLRBNode.BLACK);\n        buildPennant(chunkSize, LLRBNode.RED);\n      }\n    }\n    return root;\n  };\n\n  const base12 = new Base12Num(childList.length);\n  const root = buildFrom12Array(base12);\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  return new SortedMap<K, V>(mapSortFn || (cmp as any), root);\n};\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { nameCompare } from '../util/util';\nimport { NamedNode } from './Node';\n\nexport function NAME_ONLY_COMPARATOR(left: NamedNode, right: NamedNode) {\n  return nameCompare(left.name, right.name);\n}\n\nexport function NAME_COMPARATOR(left: string, right: string) {\n  return nameCompare(left, right);\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ChildrenNode } from './ChildrenNode';\nimport { LeafNode } from './LeafNode';\nimport { NamedNode, Node } from './Node';\nimport { contains, assert } from '@firebase/util';\n\nimport { buildChildSet } from './childSet';\nimport { NAME_COMPARATOR, NAME_ONLY_COMPARATOR } from './comparators';\nimport { IndexMap } from './IndexMap';\nimport { PRIORITY_INDEX, setNodeFromJSON } from './indexes/PriorityIndex';\nimport { SortedMap } from '../util/SortedMap';\nimport { each } from '../util/util';\nimport { Indexable } from '../util/misc';\n\nconst USE_HINZE = true;\n\n/**\n * Constructs a snapshot node representing the passed JSON and returns it.\n * @param json JSON to create a node for.\n * @param priority Optional priority to use.  This will be ignored if the\n * passed JSON contains a .priority property.\n */\nexport function nodeFromJSON(\n  json: unknown | null,\n  priority: unknown = null\n): Node {\n  if (json === null) {\n    return ChildrenNode.EMPTY_NODE;\n  }\n\n  if (typeof json === 'object' && '.priority' in json) {\n    priority = json['.priority'];\n  }\n\n  assert(\n    priority === null ||\n      typeof priority === 'string' ||\n      typeof priority === 'number' ||\n      (typeof priority === 'object' && '.sv' in (priority as object)),\n    'Invalid priority type found: ' + typeof priority\n  );\n\n  if (typeof json === 'object' && '.value' in json && json['.value'] !== null) {\n    json = json['.value'];\n  }\n\n  // Valid leaf nodes include non-objects or server-value wrapper objects\n  if (typeof json !== 'object' || '.sv' in json) {\n    const jsonLeaf = json as string | number | boolean | Indexable;\n    return new LeafNode(jsonLeaf, nodeFromJSON(priority));\n  }\n\n  if (!(json instanceof Array) && USE_HINZE) {\n    const children: NamedNode[] = [];\n    let childrenHavePriority = false;\n    const hinzeJsonObj = json;\n    each(hinzeJsonObj, (key, child) => {\n      if (key.substring(0, 1) !== '.') {\n        // Ignore metadata nodes\n        const childNode = nodeFromJSON(child);\n        if (!childNode.isEmpty()) {\n          childrenHavePriority =\n            childrenHavePriority || !childNode.getPriority().isEmpty();\n          children.push(new NamedNode(key, childNode));\n        }\n      }\n    });\n\n    if (children.length === 0) {\n      return ChildrenNode.EMPTY_NODE;\n    }\n\n    const childSet = buildChildSet(\n      children,\n      NAME_ONLY_COMPARATOR,\n      namedNode => namedNode.name,\n      NAME_COMPARATOR\n    ) as SortedMap<string, Node>;\n    if (childrenHavePriority) {\n      const sortedChildSet = buildChildSet(\n        children,\n        PRIORITY_INDEX.getCompare()\n      );\n      return new ChildrenNode(\n        childSet,\n        nodeFromJSON(priority),\n        new IndexMap(\n          { '.priority': sortedChildSet },\n          { '.priority': PRIORITY_INDEX }\n        )\n      );\n    } else {\n      return new ChildrenNode(\n        childSet,\n        nodeFromJSON(priority),\n        IndexMap.Default\n      );\n    }\n  } else {\n    let node: Node = ChildrenNode.EMPTY_NODE;\n    each(json, (key: string, childData: unknown) => {\n      if (contains(json as object, key)) {\n        if (key.substring(0, 1) !== '.') {\n          // ignore metadata nodes.\n          const childNode = nodeFromJSON(childData);\n          if (childNode.isLeafNode() || !childNode.isEmpty()) {\n            node = node.updateImmediateChild(key, childNode);\n          }\n        }\n      }\n    });\n\n    return node.updatePriority(nodeFromJSON(priority));\n  }\n}\n\nsetNodeFromJSON(nodeFromJSON);\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Path } from '../util/Path';\n\n/**\n *\n * @enum\n */\nexport enum OperationType {\n  OVERWRITE,\n  MERGE,\n  ACK_USER_WRITE,\n  LISTEN_COMPLETE\n}\n\n/**\n * @interface\n */\nexport interface Operation {\n  source: OperationSource;\n\n  type: OperationType;\n\n  path: Path;\n\n  operationForChild(childName: string): Operation | null;\n}\n\nexport interface OperationSource {\n  fromUser: boolean;\n  fromServer: boolean;\n  queryId: string | null;\n  tagged: boolean;\n}\n\nexport function newOperationSourceUser(): OperationSource {\n  return {\n    fromUser: true,\n    fromServer: false,\n    queryId: null,\n    tagged: false\n  };\n}\n\nexport function newOperationSourceServer(): OperationSource {\n  return {\n    fromUser: false,\n    fromServer: true,\n    queryId: null,\n    tagged: false\n  };\n}\n\nexport function newOperationSourceServerTaggedQuery(\n  queryId: string\n): OperationSource {\n  return {\n    fromUser: false,\n    fromServer: true,\n    queryId,\n    tagged: true\n  };\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert } from '@firebase/util';\nimport {\n  newEmptyPath,\n  Path,\n  pathGetFront,\n  pathIsEmpty,\n  pathPopFront\n} from '../util/Path';\nimport { newOperationSourceUser, Operation, OperationType } from './Operation';\nimport { ImmutableTree } from '../util/ImmutableTree';\n\nexport class AckUserWrite implements Operation {\n  /** @inheritDoc */\n  type = OperationType.ACK_USER_WRITE;\n\n  /** @inheritDoc */\n  source = newOperationSourceUser();\n\n  /**\n   * @param affectedTree A tree containing true for each affected path. Affected paths can't overlap.\n   */\n  constructor(\n    /** @inheritDoc */ public path: Path,\n    /** @inheritDoc */ public affectedTree: ImmutableTree<boolean>,\n    /** @inheritDoc */ public revert: boolean\n  ) {}\n\n  /**\n   * @inheritDoc\n   */\n  operationForChild(childName: string): AckUserWrite {\n    if (!pathIsEmpty(this.path)) {\n      assert(\n        pathGetFront(this.path) === childName,\n        'operationForChild called for unrelated child.'\n      );\n      return new AckUserWrite(\n        pathPopFront(this.path),\n        this.affectedTree,\n        this.revert\n      );\n    } else if (this.affectedTree.value != null) {\n      assert(\n        this.affectedTree.children.isEmpty(),\n        'affectedTree should not have overlapping affected paths.'\n      );\n      // All child locations are affected as well; just return same operation.\n      return this;\n    } else {\n      const childTree = this.affectedTree.subtree(new Path(childName));\n      return new AckUserWrite(newEmptyPath(), childTree, this.revert);\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { SortedMap } from './SortedMap';\nimport {\n  newEmptyPath,\n  Path,\n  pathChild,\n  pathGetFront,\n  pathIsEmpty,\n  pathPopFront\n} from './Path';\nimport { each, stringCompare } from './util';\n\nlet emptyChildrenSingleton: SortedMap<string, ImmutableTree<null>>;\n\n/**\n * Singleton empty children collection.\n *\n */\nconst EmptyChildren = (): SortedMap<string, ImmutableTree<null>> => {\n  if (!emptyChildrenSingleton) {\n    emptyChildrenSingleton = new SortedMap<string, ImmutableTree<null>>(\n      stringCompare\n    );\n  }\n  return emptyChildrenSingleton;\n};\n\n/**\n * A tree with immutable elements.\n */\nexport class ImmutableTree<T> {\n  static fromObject<T>(obj: { [k: string]: T }): ImmutableTree<T> {\n    let tree: ImmutableTree<T> = new ImmutableTree<T>(null);\n    each(obj, (childPath: string, childSnap: T) => {\n      tree = tree.set(new Path(childPath), childSnap);\n    });\n    return tree;\n  }\n\n  constructor(\n    public readonly value: T | null,\n    public readonly children: SortedMap<\n      string,\n      ImmutableTree<T>\n    > = EmptyChildren()\n  ) {}\n\n  /**\n   * True if the value is empty and there are no children\n   */\n  isEmpty(): boolean {\n    return this.value === null && this.children.isEmpty();\n  }\n\n  /**\n   * Given a path and predicate, return the first node and the path to that node\n   * where the predicate returns true.\n   *\n   * TODO Do a perf test -- If we're creating a bunch of {path: value:} objects\n   * on the way back out, it may be better to pass down a pathSoFar obj.\n   *\n   * @param relativePath The remainder of the path\n   * @param predicate The predicate to satisfy to return a node\n   */\n  findRootMostMatchingPathAndValue(\n    relativePath: Path,\n    predicate: (a: T) => boolean\n  ): { path: Path; value: T } | null {\n    if (this.value != null && predicate(this.value)) {\n      return { path: newEmptyPath(), value: this.value };\n    } else {\n      if (pathIsEmpty(relativePath)) {\n        return null;\n      } else {\n        const front = pathGetFront(relativePath);\n        const child = this.children.get(front);\n        if (child !== null) {\n          const childExistingPathAndValue = child.findRootMostMatchingPathAndValue(\n            pathPopFront(relativePath),\n            predicate\n          );\n          if (childExistingPathAndValue != null) {\n            const fullPath = pathChild(\n              new Path(front),\n              childExistingPathAndValue.path\n            );\n            return { path: fullPath, value: childExistingPathAndValue.value };\n          } else {\n            return null;\n          }\n        } else {\n          return null;\n        }\n      }\n    }\n  }\n\n  /**\n   * Find, if it exists, the shortest subpath of the given path that points a defined\n   * value in the tree\n   */\n  findRootMostValueAndPath(\n    relativePath: Path\n  ): { path: Path; value: T } | null {\n    return this.findRootMostMatchingPathAndValue(relativePath, () => true);\n  }\n\n  /**\n   * @return The subtree at the given path\n   */\n  subtree(relativePath: Path): ImmutableTree<T> {\n    if (pathIsEmpty(relativePath)) {\n      return this;\n    } else {\n      const front = pathGetFront(relativePath);\n      const childTree = this.children.get(front);\n      if (childTree !== null) {\n        return childTree.subtree(pathPopFront(relativePath));\n      } else {\n        return new ImmutableTree<T>(null);\n      }\n    }\n  }\n\n  /**\n   * Sets a value at the specified path.\n   *\n   * @param relativePath Path to set value at.\n   * @param toSet Value to set.\n   * @return Resulting tree.\n   */\n  set(relativePath: Path, toSet: T | null): ImmutableTree<T> {\n    if (pathIsEmpty(relativePath)) {\n      return new ImmutableTree(toSet, this.children);\n    } else {\n      const front = pathGetFront(relativePath);\n      const child = this.children.get(front) || new ImmutableTree<T>(null);\n      const newChild = child.set(pathPopFront(relativePath), toSet);\n      const newChildren = this.children.insert(front, newChild);\n      return new ImmutableTree(this.value, newChildren);\n    }\n  }\n\n  /**\n   * Removes the value at the specified path.\n   *\n   * @param relativePath Path to value to remove.\n   * @return Resulting tree.\n   */\n  remove(relativePath: Path): ImmutableTree<T> {\n    if (pathIsEmpty(relativePath)) {\n      if (this.children.isEmpty()) {\n        return new ImmutableTree<T>(null);\n      } else {\n        return new ImmutableTree(null, this.children);\n      }\n    } else {\n      const front = pathGetFront(relativePath);\n      const child = this.children.get(front);\n      if (child) {\n        const newChild = child.remove(pathPopFront(relativePath));\n        let newChildren;\n        if (newChild.isEmpty()) {\n          newChildren = this.children.remove(front);\n        } else {\n          newChildren = this.children.insert(front, newChild);\n        }\n        if (this.value === null && newChildren.isEmpty()) {\n          return new ImmutableTree<T>(null);\n        } else {\n          return new ImmutableTree(this.value, newChildren);\n        }\n      } else {\n        return this;\n      }\n    }\n  }\n\n  /**\n   * Gets a value from the tree.\n   *\n   * @param relativePath Path to get value for.\n   * @return Value at path, or null.\n   */\n  get(relativePath: Path): T | null {\n    if (pathIsEmpty(relativePath)) {\n      return this.value;\n    } else {\n      const front = pathGetFront(relativePath);\n      const child = this.children.get(front);\n      if (child) {\n        return child.get(pathPopFront(relativePath));\n      } else {\n        return null;\n      }\n    }\n  }\n\n  /**\n   * Replace the subtree at the specified path with the given new tree.\n   *\n   * @param relativePath Path to replace subtree for.\n   * @param newTree New tree.\n   * @return Resulting tree.\n   */\n  setTree(relativePath: Path, newTree: ImmutableTree<T>): ImmutableTree<T> {\n    if (pathIsEmpty(relativePath)) {\n      return newTree;\n    } else {\n      const front = pathGetFront(relativePath);\n      const child = this.children.get(front) || new ImmutableTree<T>(null);\n      const newChild = child.setTree(pathPopFront(relativePath), newTree);\n      let newChildren;\n      if (newChild.isEmpty()) {\n        newChildren = this.children.remove(front);\n      } else {\n        newChildren = this.children.insert(front, newChild);\n      }\n      return new ImmutableTree(this.value, newChildren);\n    }\n  }\n\n  /**\n   * Performs a depth first fold on this tree. Transforms a tree into a single\n   * value, given a function that operates on the path to a node, an optional\n   * current value, and a map of child names to folded subtrees\n   */\n  fold<V>(fn: (path: Path, value: T, children: { [k: string]: V }) => V): V {\n    return this.fold_(newEmptyPath(), fn);\n  }\n\n  /**\n   * Recursive helper for public-facing fold() method\n   */\n  private fold_<V>(\n    pathSoFar: Path,\n    fn: (path: Path, value: T | null, children: { [k: string]: V }) => V\n  ): V {\n    const accum: { [k: string]: V } = {};\n    this.children.inorderTraversal(\n      (childKey: string, childTree: ImmutableTree<T>) => {\n        accum[childKey] = childTree.fold_(pathChild(pathSoFar, childKey), fn);\n      }\n    );\n    return fn(pathSoFar, this.value, accum);\n  }\n\n  /**\n   * Find the first matching value on the given path. Return the result of applying f to it.\n   */\n  findOnPath<V>(path: Path, f: (path: Path, value: T) => V | null): V | null {\n    return this.findOnPath_(path, newEmptyPath(), f);\n  }\n\n  private findOnPath_<V>(\n    pathToFollow: Path,\n    pathSoFar: Path,\n    f: (path: Path, value: T) => V | null\n  ): V | null {\n    const result = this.value ? f(pathSoFar, this.value) : false;\n    if (result) {\n      return result;\n    } else {\n      if (pathIsEmpty(pathToFollow)) {\n        return null;\n      } else {\n        const front = pathGetFront(pathToFollow)!;\n        const nextChild = this.children.get(front);\n        if (nextChild) {\n          return nextChild.findOnPath_(\n            pathPopFront(pathToFollow),\n            pathChild(pathSoFar, front),\n            f\n          );\n        } else {\n          return null;\n        }\n      }\n    }\n  }\n\n  foreachOnPath(\n    path: Path,\n    f: (path: Path, value: T) => void\n  ): ImmutableTree<T> {\n    return this.foreachOnPath_(path, newEmptyPath(), f);\n  }\n\n  private foreachOnPath_(\n    pathToFollow: Path,\n    currentRelativePath: Path,\n    f: (path: Path, value: T) => void\n  ): ImmutableTree<T> {\n    if (pathIsEmpty(pathToFollow)) {\n      return this;\n    } else {\n      if (this.value) {\n        f(currentRelativePath, this.value);\n      }\n      const front = pathGetFront(pathToFollow);\n      const nextChild = this.children.get(front);\n      if (nextChild) {\n        return nextChild.foreachOnPath_(\n          pathPopFront(pathToFollow),\n          pathChild(currentRelativePath, front),\n          f\n        );\n      } else {\n        return new ImmutableTree<T>(null);\n      }\n    }\n  }\n\n  /**\n   * Calls the given function for each node in the tree that has a value.\n   *\n   * @param f A function to be called with the path from the root of the tree to\n   * a node, and the value at that node. Called in depth-first order.\n   */\n  foreach(f: (path: Path, value: T) => void) {\n    this.foreach_(newEmptyPath(), f);\n  }\n\n  private foreach_(\n    currentRelativePath: Path,\n    f: (path: Path, value: T) => void\n  ) {\n    this.children.inorderTraversal((childName, childTree) => {\n      childTree.foreach_(pathChild(currentRelativePath, childName), f);\n    });\n    if (this.value) {\n      f(currentRelativePath, this.value);\n    }\n  }\n\n  foreachChild(f: (name: string, value: T) => void) {\n    this.children.inorderTraversal(\n      (childName: string, childTree: ImmutableTree<T>) => {\n        if (childTree.value) {\n          f(childName, childTree.value);\n        }\n      }\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { newEmptyPath, Path, pathIsEmpty, pathPopFront } from '../util/Path';\nimport { Operation, OperationSource, OperationType } from './Operation';\n\nexport class ListenComplete implements Operation {\n  /** @inheritDoc */\n  type = OperationType.LISTEN_COMPLETE;\n\n  constructor(public source: OperationSource, public path: Path) {}\n\n  operationForChild(childName: string): ListenComplete {\n    if (pathIsEmpty(this.path)) {\n      return new ListenComplete(this.source, newEmptyPath());\n    } else {\n      return new ListenComplete(this.source, pathPopFront(this.path));\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Operation, OperationSource, OperationType } from './Operation';\nimport { newEmptyPath, Path, pathIsEmpty, pathPopFront } from '../util/Path';\nimport { Node } from '../snap/Node';\n\nexport class Overwrite implements Operation {\n  /** @inheritDoc */\n  type = OperationType.OVERWRITE;\n\n  constructor(\n    public source: OperationSource,\n    public path: Path,\n    public snap: Node\n  ) {}\n\n  operationForChild(childName: string): Overwrite {\n    if (pathIsEmpty(this.path)) {\n      return new Overwrite(\n        this.source,\n        newEmptyPath(),\n        this.snap.getImmediateChild(childName)\n      );\n    } else {\n      return new Overwrite(this.source, pathPopFront(this.path), this.snap);\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Operation, OperationSource, OperationType } from './Operation';\nimport { Overwrite } from './Overwrite';\nimport {\n  newEmptyPath,\n  Path,\n  pathGetFront,\n  pathIsEmpty,\n  pathPopFront\n} from '../util/Path';\nimport { assert } from '@firebase/util';\nimport { ImmutableTree } from '../util/ImmutableTree';\nimport { Node } from '../snap/Node';\n\nexport class Merge implements Operation {\n  /** @inheritDoc */\n  type = OperationType.MERGE;\n\n  constructor(\n    /** @inheritDoc */ public source: OperationSource,\n    /** @inheritDoc */ public path: Path,\n    /** @inheritDoc */ public children: ImmutableTree<Node>\n  ) {}\n\n  /**\n   * @inheritDoc\n   */\n  operationForChild(childName: string): Operation {\n    if (pathIsEmpty(this.path)) {\n      const childTree = this.children.subtree(new Path(childName));\n      if (childTree.isEmpty()) {\n        // This child is unaffected\n        return null;\n      } else if (childTree.value) {\n        // We have a snapshot for the child in question.  This becomes an overwrite of the child.\n        return new Overwrite(this.source, newEmptyPath(), childTree.value);\n      } else {\n        // This is a merge at a deeper level\n        return new Merge(this.source, newEmptyPath(), childTree);\n      }\n    } else {\n      assert(\n        pathGetFront(this.path) === childName,\n        \"Can't get a merge for a child not on the path of the operation\"\n      );\n      return new Merge(this.source, pathPopFront(this.path), this.children);\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  toString(): string {\n    return (\n      'Operation(' +\n      this.path +\n      ': ' +\n      this.source.toString() +\n      ' merge: ' +\n      this.children.toString() +\n      ')'\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Node } from '../snap/Node';\nimport { Path, pathGetFront, pathIsEmpty } from '../util/Path';\n\n/**\n * A cache node only stores complete children. Additionally it holds a flag whether the node can be considered fully\n * initialized in the sense that we know at one point in time this represented a valid state of the world, e.g.\n * initialized with data from the server, or a complete overwrite by the client. The filtered flag also tracks\n * whether a node potentially had children removed due to a filter.\n */\nexport class CacheNode {\n  constructor(\n    private node_: Node,\n    private fullyInitialized_: boolean,\n    private filtered_: boolean\n  ) {}\n\n  /**\n   * Returns whether this node was fully initialized with either server data or a complete overwrite by the client\n   */\n  isFullyInitialized(): boolean {\n    return this.fullyInitialized_;\n  }\n\n  /**\n   * Returns whether this node is potentially missing children due to a filter applied to the node\n   */\n  isFiltered(): boolean {\n    return this.filtered_;\n  }\n\n  isCompleteForPath(path: Path): boolean {\n    if (pathIsEmpty(path)) {\n      return this.isFullyInitialized() && !this.filtered_;\n    }\n\n    const childKey = pathGetFront(path);\n    return this.isCompleteForChild(childKey);\n  }\n\n  isCompleteForChild(key: string): boolean {\n    return (\n      (this.isFullyInitialized() && !this.filtered_) || this.node_.hasChild(key)\n    );\n  }\n\n  getNode(): Node {\n    return this.node_;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { CacheNode } from './CacheNode';\nimport { Node } from '../snap/Node';\n\n/**\n * Stores the data we have cached for a view.\n *\n * serverSnap is the cached server data, eventSnap is the cached event data (server data plus any local writes).\n */\nexport class ViewCache {\n  constructor(\n    private readonly eventCache_: CacheNode,\n    private readonly serverCache_: CacheNode\n  ) {}\n\n  updateEventSnap(\n    eventSnap: Node,\n    complete: boolean,\n    filtered: boolean\n  ): ViewCache {\n    return new ViewCache(\n      new CacheNode(eventSnap, complete, filtered),\n      this.serverCache_\n    );\n  }\n\n  updateServerSnap(\n    serverSnap: Node,\n    complete: boolean,\n    filtered: boolean\n  ): ViewCache {\n    return new ViewCache(\n      this.eventCache_,\n      new CacheNode(serverSnap, complete, filtered)\n    );\n  }\n\n  getEventCache(): CacheNode {\n    return this.eventCache_;\n  }\n\n  getCompleteEventSnap(): Node | null {\n    return this.eventCache_.isFullyInitialized()\n      ? this.eventCache_.getNode()\n      : null;\n  }\n\n  getServerCache(): CacheNode {\n    return this.serverCache_;\n  }\n\n  getCompleteServerSnap(): Node | null {\n    return this.serverCache_.isFullyInitialized()\n      ? this.serverCache_.getNode()\n      : null;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Node } from '../snap/Node';\n\nexport const enum ChangeType {\n  /** Event type for a child added */\n  CHILD_ADDED = 'child_added',\n  /** Event type for a child removed */\n  CHILD_REMOVED = 'child_removed',\n  /** Event type for a child changed */\n  CHILD_CHANGED = 'child_changed',\n  /** Event type for a child moved */\n  CHILD_MOVED = 'child_moved',\n  /** Event type for a value change */\n  VALUE = 'value'\n}\n\nexport interface Change {\n  /** @param type The event type */\n  type: ChangeType;\n  /** @param snapshotNode The data */\n  snapshotNode: Node;\n  /** @param childName The name for this child, if it's a child even */\n  childName?: string;\n  /** @param oldSnap Used for intermediate processing of child changed events */\n  oldSnap?: Node;\n  /**  * @param prevName The name for the previous child, if applicable */\n  prevName?: string | null;\n}\n\nexport function changeValue(snapshotNode: Node): Change {\n  return { type: ChangeType.VALUE, snapshotNode };\n}\n\nexport function changeChildAdded(\n  childName: string,\n  snapshotNode: Node\n): Change {\n  return { type: ChangeType.CHILD_ADDED, snapshotNode, childName };\n}\n\nexport function changeChildRemoved(\n  childName: string,\n  snapshotNode: Node\n): Change {\n  return { type: ChangeType.CHILD_REMOVED, snapshotNode, childName };\n}\n\nexport function changeChildChanged(\n  childName: string,\n  snapshotNode: Node,\n  oldSnap: Node\n): Change {\n  return {\n    type: ChangeType.CHILD_CHANGED,\n    snapshotNode,\n    childName,\n    oldSnap\n  };\n}\n\nexport function changeChildMoved(\n  childName: string,\n  snapshotNode: Node\n): Change {\n  return { type: ChangeType.CHILD_MOVED, snapshotNode, childName };\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert } from '@firebase/util';\nimport {\n  changeChildAdded,\n  changeChildChanged,\n  changeChildRemoved\n} from '../Change';\nimport { ChildrenNode } from '../../snap/ChildrenNode';\nimport { PRIORITY_INDEX } from '../../snap/indexes/PriorityIndex';\nimport { NodeFilter } from './NodeFilter';\nimport { Index } from '../../snap/indexes/Index';\nimport { Path } from '../../util/Path';\nimport { CompleteChildSource } from '../CompleteChildSource';\nimport { ChildChangeAccumulator } from '../ChildChangeAccumulator';\nimport { Node } from '../../snap/Node';\n\n/**\n * Doesn't really filter nodes but applies an index to the node and keeps track of any changes\n */\nexport class IndexedFilter implements NodeFilter {\n  constructor(private readonly index_: Index) {}\n\n  updateChild(\n    snap: Node,\n    key: string,\n    newChild: Node,\n    affectedPath: Path,\n    source: CompleteChildSource,\n    optChangeAccumulator: ChildChangeAccumulator | null\n  ): Node {\n    assert(\n      snap.isIndexed(this.index_),\n      'A node must be indexed if only a child is updated'\n    );\n    const oldChild = snap.getImmediateChild(key);\n    // Check if anything actually changed.\n    if (\n      oldChild.getChild(affectedPath).equals(newChild.getChild(affectedPath))\n    ) {\n      // There's an edge case where a child can enter or leave the view because affectedPath was set to null.\n      // In this case, affectedPath will appear null in both the old and new snapshots.  So we need\n      // to avoid treating these cases as \"nothing changed.\"\n      if (oldChild.isEmpty() === newChild.isEmpty()) {\n        // Nothing changed.\n\n        // This assert should be valid, but it's expensive (can dominate perf testing) so don't actually do it.\n        //assert(oldChild.equals(newChild), 'Old and new snapshots should be equal.');\n        return snap;\n      }\n    }\n\n    if (optChangeAccumulator != null) {\n      if (newChild.isEmpty()) {\n        if (snap.hasChild(key)) {\n          optChangeAccumulator.trackChildChange(\n            changeChildRemoved(key, oldChild)\n          );\n        } else {\n          assert(\n            snap.isLeafNode(),\n            'A child remove without an old child only makes sense on a leaf node'\n          );\n        }\n      } else if (oldChild.isEmpty()) {\n        optChangeAccumulator.trackChildChange(changeChildAdded(key, newChild));\n      } else {\n        optChangeAccumulator.trackChildChange(\n          changeChildChanged(key, newChild, oldChild)\n        );\n      }\n    }\n    if (snap.isLeafNode() && newChild.isEmpty()) {\n      return snap;\n    } else {\n      // Make sure the node is indexed\n      return snap.updateImmediateChild(key, newChild).withIndex(this.index_);\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  updateFullNode(\n    oldSnap: Node,\n    newSnap: Node,\n    optChangeAccumulator: ChildChangeAccumulator | null\n  ): Node {\n    if (optChangeAccumulator != null) {\n      if (!oldSnap.isLeafNode()) {\n        oldSnap.forEachChild(PRIORITY_INDEX, (key, childNode) => {\n          if (!newSnap.hasChild(key)) {\n            optChangeAccumulator.trackChildChange(\n              changeChildRemoved(key, childNode)\n            );\n          }\n        });\n      }\n      if (!newSnap.isLeafNode()) {\n        newSnap.forEachChild(PRIORITY_INDEX, (key, childNode) => {\n          if (oldSnap.hasChild(key)) {\n            const oldChild = oldSnap.getImmediateChild(key);\n            if (!oldChild.equals(childNode)) {\n              optChangeAccumulator.trackChildChange(\n                changeChildChanged(key, childNode, oldChild)\n              );\n            }\n          } else {\n            optChangeAccumulator.trackChildChange(\n              changeChildAdded(key, childNode)\n            );\n          }\n        });\n      }\n    }\n    return newSnap.withIndex(this.index_);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  updatePriority(oldSnap: Node, newPriority: Node): Node {\n    if (oldSnap.isEmpty()) {\n      return ChildrenNode.EMPTY_NODE;\n    } else {\n      return oldSnap.updatePriority(newPriority);\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  filtersNodes(): boolean {\n    return false;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getIndexedFilter(): IndexedFilter {\n    return this;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getIndex(): Index {\n    return this.index_;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  Change,\n  ChangeType,\n  changeChildAdded,\n  changeChildChanged,\n  changeChildRemoved\n} from './Change';\nimport { assert, assertionError } from '@firebase/util';\n\nexport class ChildChangeAccumulator {\n  private readonly changeMap: Map<string, Change> = new Map();\n\n  trackChildChange(change: Change) {\n    const type = change.type;\n    const childKey = change.childName!;\n    assert(\n      type === ChangeType.CHILD_ADDED ||\n        type === ChangeType.CHILD_CHANGED ||\n        type === ChangeType.CHILD_REMOVED,\n      'Only child changes supported for tracking'\n    );\n    assert(\n      childKey !== '.priority',\n      'Only non-priority child changes can be tracked.'\n    );\n    const oldChange = this.changeMap.get(childKey);\n    if (oldChange) {\n      const oldType = oldChange.type;\n      if (\n        type === ChangeType.CHILD_ADDED &&\n        oldType === ChangeType.CHILD_REMOVED\n      ) {\n        this.changeMap.set(\n          childKey,\n          changeChildChanged(\n            childKey,\n            change.snapshotNode,\n            oldChange.snapshotNode\n          )\n        );\n      } else if (\n        type === ChangeType.CHILD_REMOVED &&\n        oldType === ChangeType.CHILD_ADDED\n      ) {\n        this.changeMap.delete(childKey);\n      } else if (\n        type === ChangeType.CHILD_REMOVED &&\n        oldType === ChangeType.CHILD_CHANGED\n      ) {\n        this.changeMap.set(\n          childKey,\n          changeChildRemoved(childKey, oldChange.oldSnap)\n        );\n      } else if (\n        type === ChangeType.CHILD_CHANGED &&\n        oldType === ChangeType.CHILD_ADDED\n      ) {\n        this.changeMap.set(\n          childKey,\n          changeChildAdded(childKey, change.snapshotNode)\n        );\n      } else if (\n        type === ChangeType.CHILD_CHANGED &&\n        oldType === ChangeType.CHILD_CHANGED\n      ) {\n        this.changeMap.set(\n          childKey,\n          changeChildChanged(childKey, change.snapshotNode, oldChange.oldSnap)\n        );\n      } else {\n        throw assertionError(\n          'Illegal combination of changes: ' +\n            change +\n            ' occurred after ' +\n            oldChange\n        );\n      }\n    } else {\n      this.changeMap.set(childKey, change);\n    }\n  }\n\n  getChanges(): Change[] {\n    return Array.from(this.changeMap.values());\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { CacheNode } from './CacheNode';\nimport { NamedNode, Node } from '../snap/Node';\nimport { Index } from '../snap/indexes/Index';\nimport { WriteTreeRef } from '../WriteTree';\nimport { ViewCache } from './ViewCache';\n\n/**\n * Since updates to filtered nodes might require nodes to be pulled in from \"outside\" the node, this interface\n * can help to get complete children that can be pulled in.\n * A class implementing this interface takes potentially multiple sources (e.g. user writes, server data from\n * other views etc.) to try it's best to get a complete child that might be useful in pulling into the view.\n *\n * @interface\n */\nexport interface CompleteChildSource {\n  getCompleteChild(childKey: string): Node | null;\n\n  getChildAfterChild(\n    index: Index,\n    child: NamedNode,\n    reverse: boolean\n  ): NamedNode | null;\n}\n\n/**\n * An implementation of CompleteChildSource that never returns any additional children\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport class NoCompleteChildSource_ implements CompleteChildSource {\n  /**\n   * @inheritDoc\n   */\n  getCompleteChild(childKey?: string): Node | null {\n    return null;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getChildAfterChild(\n    index?: Index,\n    child?: NamedNode,\n    reverse?: boolean\n  ): NamedNode | null {\n    return null;\n  }\n}\n\n/**\n * Singleton instance.\n */\nexport const NO_COMPLETE_CHILD_SOURCE = new NoCompleteChildSource_();\n\n/**\n * An implementation of CompleteChildSource that uses a WriteTree in addition to any other server data or\n * old event caches available to calculate complete children.\n */\nexport class WriteTreeCompleteChildSource implements CompleteChildSource {\n  constructor(\n    private writes_: WriteTreeRef,\n    private viewCache_: ViewCache,\n    private optCompleteServerCache_: Node | null = null\n  ) {}\n\n  /**\n   * @inheritDoc\n   */\n  getCompleteChild(childKey: string): Node | null {\n    const node = this.viewCache_.getEventCache();\n    if (node.isCompleteForChild(childKey)) {\n      return node.getNode().getImmediateChild(childKey);\n    } else {\n      const serverNode =\n        this.optCompleteServerCache_ != null\n          ? new CacheNode(this.optCompleteServerCache_, true, false)\n          : this.viewCache_.getServerCache();\n      return this.writes_.calcCompleteChild(childKey, serverNode);\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getChildAfterChild(\n    index: Index,\n    child: NamedNode,\n    reverse: boolean\n  ): NamedNode | null {\n    const completeServerData =\n      this.optCompleteServerCache_ != null\n        ? this.optCompleteServerCache_\n        : this.viewCache_.getCompleteServerSnap();\n    const nodes = this.writes_.calcIndexedSlice(\n      completeServerData,\n      child,\n      1,\n      reverse,\n      index\n    );\n    if (nodes.length === 0) {\n      return null;\n    } else {\n      return nodes[0];\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Operation, OperationType } from '../operation/Operation';\nimport { assert, assertionError } from '@firebase/util';\nimport { ChildChangeAccumulator } from './ChildChangeAccumulator';\nimport { Change, changeValue } from './Change';\nimport { ChildrenNode } from '../snap/ChildrenNode';\nimport { KEY_INDEX } from '../snap/indexes/KeyIndex';\nimport { ImmutableTree } from '../util/ImmutableTree';\nimport {\n  newEmptyPath,\n  Path,\n  pathChild,\n  pathGetBack,\n  pathGetFront,\n  pathGetLength,\n  pathIsEmpty,\n  pathParent,\n  pathPopFront\n} from '../util/Path';\nimport {\n  CompleteChildSource,\n  NO_COMPLETE_CHILD_SOURCE,\n  WriteTreeCompleteChildSource\n} from './CompleteChildSource';\nimport { ViewCache } from './ViewCache';\nimport { NodeFilter } from './filter/NodeFilter';\nimport { WriteTreeRef } from '../WriteTree';\nimport { Overwrite } from '../operation/Overwrite';\nimport { Merge } from '../operation/Merge';\nimport { AckUserWrite } from '../operation/AckUserWrite';\nimport { Node } from '../snap/Node';\n\nexport class ProcessorResult {\n  constructor(\n    public readonly viewCache: ViewCache,\n    public readonly changes: Change[]\n  ) {}\n}\n\n/**\n */\nexport class ViewProcessor {\n  constructor(private readonly filter_: NodeFilter) {}\n\n  assertIndexed(viewCache: ViewCache) {\n    assert(\n      viewCache.getEventCache().getNode().isIndexed(this.filter_.getIndex()),\n      'Event snap not indexed'\n    );\n    assert(\n      viewCache.getServerCache().getNode().isIndexed(this.filter_.getIndex()),\n      'Server snap not indexed'\n    );\n  }\n\n  applyOperation(\n    oldViewCache: ViewCache,\n    operation: Operation,\n    writesCache: WriteTreeRef,\n    completeCache: Node | null\n  ): ProcessorResult {\n    const accumulator = new ChildChangeAccumulator();\n    let newViewCache, filterServerNode;\n    if (operation.type === OperationType.OVERWRITE) {\n      const overwrite = operation as Overwrite;\n      if (overwrite.source.fromUser) {\n        newViewCache = this.applyUserOverwrite_(\n          oldViewCache,\n          overwrite.path,\n          overwrite.snap,\n          writesCache,\n          completeCache,\n          accumulator\n        );\n      } else {\n        assert(overwrite.source.fromServer, 'Unknown source.');\n        // We filter the node if it's a tagged update or the node has been previously filtered  and the\n        // update is not at the root in which case it is ok (and necessary) to mark the node unfiltered\n        // again\n        filterServerNode =\n          overwrite.source.tagged ||\n          (oldViewCache.getServerCache().isFiltered() &&\n            !pathIsEmpty(overwrite.path));\n        newViewCache = this.applyServerOverwrite_(\n          oldViewCache,\n          overwrite.path,\n          overwrite.snap,\n          writesCache,\n          completeCache,\n          filterServerNode,\n          accumulator\n        );\n      }\n    } else if (operation.type === OperationType.MERGE) {\n      const merge = operation as Merge;\n      if (merge.source.fromUser) {\n        newViewCache = this.applyUserMerge_(\n          oldViewCache,\n          merge.path,\n          merge.children,\n          writesCache,\n          completeCache,\n          accumulator\n        );\n      } else {\n        assert(merge.source.fromServer, 'Unknown source.');\n        // We filter the node if it's a tagged update or the node has been previously filtered\n        filterServerNode =\n          merge.source.tagged || oldViewCache.getServerCache().isFiltered();\n        newViewCache = this.applyServerMerge_(\n          oldViewCache,\n          merge.path,\n          merge.children,\n          writesCache,\n          completeCache,\n          filterServerNode,\n          accumulator\n        );\n      }\n    } else if (operation.type === OperationType.ACK_USER_WRITE) {\n      const ackUserWrite = operation as AckUserWrite;\n      if (!ackUserWrite.revert) {\n        newViewCache = this.ackUserWrite_(\n          oldViewCache,\n          ackUserWrite.path,\n          ackUserWrite.affectedTree,\n          writesCache,\n          completeCache,\n          accumulator\n        );\n      } else {\n        newViewCache = this.revertUserWrite_(\n          oldViewCache,\n          ackUserWrite.path,\n          writesCache,\n          completeCache,\n          accumulator\n        );\n      }\n    } else if (operation.type === OperationType.LISTEN_COMPLETE) {\n      newViewCache = this.listenComplete_(\n        oldViewCache,\n        operation.path,\n        writesCache,\n        accumulator\n      );\n    } else {\n      throw assertionError('Unknown operation type: ' + operation.type);\n    }\n    const changes = accumulator.getChanges();\n    ViewProcessor.maybeAddValueEvent_(oldViewCache, newViewCache, changes);\n    return new ProcessorResult(newViewCache, changes);\n  }\n\n  private static maybeAddValueEvent_(\n    oldViewCache: ViewCache,\n    newViewCache: ViewCache,\n    accumulator: Change[]\n  ) {\n    const eventSnap = newViewCache.getEventCache();\n    if (eventSnap.isFullyInitialized()) {\n      const isLeafOrEmpty =\n        eventSnap.getNode().isLeafNode() || eventSnap.getNode().isEmpty();\n      const oldCompleteSnap = oldViewCache.getCompleteEventSnap();\n      if (\n        accumulator.length > 0 ||\n        !oldViewCache.getEventCache().isFullyInitialized() ||\n        (isLeafOrEmpty && !eventSnap.getNode().equals(oldCompleteSnap)) ||\n        !eventSnap.getNode().getPriority().equals(oldCompleteSnap.getPriority())\n      ) {\n        accumulator.push(changeValue(newViewCache.getCompleteEventSnap()));\n      }\n    }\n  }\n\n  private generateEventCacheAfterServerEvent_(\n    viewCache: ViewCache,\n    changePath: Path,\n    writesCache: WriteTreeRef,\n    source: CompleteChildSource,\n    accumulator: ChildChangeAccumulator\n  ): ViewCache {\n    const oldEventSnap = viewCache.getEventCache();\n    if (writesCache.shadowingWrite(changePath) != null) {\n      // we have a shadowing write, ignore changes\n      return viewCache;\n    } else {\n      let newEventCache, serverNode;\n      if (pathIsEmpty(changePath)) {\n        // TODO: figure out how this plays with \"sliding ack windows\"\n        assert(\n          viewCache.getServerCache().isFullyInitialized(),\n          'If change path is empty, we must have complete server data'\n        );\n        if (viewCache.getServerCache().isFiltered()) {\n          // We need to special case this, because we need to only apply writes to complete children, or\n          // we might end up raising events for incomplete children. If the server data is filtered deep\n          // writes cannot be guaranteed to be complete\n          const serverCache = viewCache.getCompleteServerSnap();\n          const completeChildren =\n            serverCache instanceof ChildrenNode\n              ? serverCache\n              : ChildrenNode.EMPTY_NODE;\n          const completeEventChildren = writesCache.calcCompleteEventChildren(\n            completeChildren\n          );\n          newEventCache = this.filter_.updateFullNode(\n            viewCache.getEventCache().getNode(),\n            completeEventChildren,\n            accumulator\n          );\n        } else {\n          const completeNode = writesCache.calcCompleteEventCache(\n            viewCache.getCompleteServerSnap()\n          );\n          newEventCache = this.filter_.updateFullNode(\n            viewCache.getEventCache().getNode(),\n            completeNode,\n            accumulator\n          );\n        }\n      } else {\n        const childKey = pathGetFront(changePath);\n        if (childKey === '.priority') {\n          assert(\n            pathGetLength(changePath) === 1,\n            \"Can't have a priority with additional path components\"\n          );\n          const oldEventNode = oldEventSnap.getNode();\n          serverNode = viewCache.getServerCache().getNode();\n          // we might have overwrites for this priority\n          const updatedPriority = writesCache.calcEventCacheAfterServerOverwrite(\n            changePath,\n            oldEventNode,\n            serverNode\n          );\n          if (updatedPriority != null) {\n            newEventCache = this.filter_.updatePriority(\n              oldEventNode,\n              updatedPriority\n            );\n          } else {\n            // priority didn't change, keep old node\n            newEventCache = oldEventSnap.getNode();\n          }\n        } else {\n          const childChangePath = pathPopFront(changePath);\n          // update child\n          let newEventChild;\n          if (oldEventSnap.isCompleteForChild(childKey)) {\n            serverNode = viewCache.getServerCache().getNode();\n            const eventChildUpdate = writesCache.calcEventCacheAfterServerOverwrite(\n              changePath,\n              oldEventSnap.getNode(),\n              serverNode\n            );\n            if (eventChildUpdate != null) {\n              newEventChild = oldEventSnap\n                .getNode()\n                .getImmediateChild(childKey)\n                .updateChild(childChangePath, eventChildUpdate);\n            } else {\n              // Nothing changed, just keep the old child\n              newEventChild = oldEventSnap\n                .getNode()\n                .getImmediateChild(childKey);\n            }\n          } else {\n            newEventChild = writesCache.calcCompleteChild(\n              childKey,\n              viewCache.getServerCache()\n            );\n          }\n          if (newEventChild != null) {\n            newEventCache = this.filter_.updateChild(\n              oldEventSnap.getNode(),\n              childKey,\n              newEventChild,\n              childChangePath,\n              source,\n              accumulator\n            );\n          } else {\n            // no complete child available or no change\n            newEventCache = oldEventSnap.getNode();\n          }\n        }\n      }\n      return viewCache.updateEventSnap(\n        newEventCache,\n        oldEventSnap.isFullyInitialized() || pathIsEmpty(changePath),\n        this.filter_.filtersNodes()\n      );\n    }\n  }\n\n  applyServerOverwrite_(\n    oldViewCache: ViewCache,\n    changePath: Path,\n    changedSnap: Node,\n    writesCache: WriteTreeRef,\n    completeCache: Node | null,\n    filterServerNode: boolean,\n    accumulator: ChildChangeAccumulator\n  ): ViewCache {\n    const oldServerSnap = oldViewCache.getServerCache();\n    let newServerCache;\n    const serverFilter = filterServerNode\n      ? this.filter_\n      : this.filter_.getIndexedFilter();\n    if (pathIsEmpty(changePath)) {\n      newServerCache = serverFilter.updateFullNode(\n        oldServerSnap.getNode(),\n        changedSnap,\n        null\n      );\n    } else if (serverFilter.filtersNodes() && !oldServerSnap.isFiltered()) {\n      // we want to filter the server node, but we didn't filter the server node yet, so simulate a full update\n      const newServerNode = oldServerSnap\n        .getNode()\n        .updateChild(changePath, changedSnap);\n      newServerCache = serverFilter.updateFullNode(\n        oldServerSnap.getNode(),\n        newServerNode,\n        null\n      );\n    } else {\n      const childKey = pathGetFront(changePath);\n      if (\n        !oldServerSnap.isCompleteForPath(changePath) &&\n        pathGetLength(changePath) > 1\n      ) {\n        // We don't update incomplete nodes with updates intended for other listeners\n        return oldViewCache;\n      }\n      const childChangePath = pathPopFront(changePath);\n      const childNode = oldServerSnap.getNode().getImmediateChild(childKey);\n      const newChildNode = childNode.updateChild(childChangePath, changedSnap);\n      if (childKey === '.priority') {\n        newServerCache = serverFilter.updatePriority(\n          oldServerSnap.getNode(),\n          newChildNode\n        );\n      } else {\n        newServerCache = serverFilter.updateChild(\n          oldServerSnap.getNode(),\n          childKey,\n          newChildNode,\n          childChangePath,\n          NO_COMPLETE_CHILD_SOURCE,\n          null\n        );\n      }\n    }\n    const newViewCache = oldViewCache.updateServerSnap(\n      newServerCache,\n      oldServerSnap.isFullyInitialized() || pathIsEmpty(changePath),\n      serverFilter.filtersNodes()\n    );\n    const source = new WriteTreeCompleteChildSource(\n      writesCache,\n      newViewCache,\n      completeCache\n    );\n    return this.generateEventCacheAfterServerEvent_(\n      newViewCache,\n      changePath,\n      writesCache,\n      source,\n      accumulator\n    );\n  }\n\n  applyUserOverwrite_(\n    oldViewCache: ViewCache,\n    changePath: Path,\n    changedSnap: Node,\n    writesCache: WriteTreeRef,\n    completeCache: Node | null,\n    accumulator: ChildChangeAccumulator\n  ): ViewCache {\n    const oldEventSnap = oldViewCache.getEventCache();\n    let newViewCache, newEventCache;\n    const source = new WriteTreeCompleteChildSource(\n      writesCache,\n      oldViewCache,\n      completeCache\n    );\n    if (pathIsEmpty(changePath)) {\n      newEventCache = this.filter_.updateFullNode(\n        oldViewCache.getEventCache().getNode(),\n        changedSnap,\n        accumulator\n      );\n      newViewCache = oldViewCache.updateEventSnap(\n        newEventCache,\n        true,\n        this.filter_.filtersNodes()\n      );\n    } else {\n      const childKey = pathGetFront(changePath);\n      if (childKey === '.priority') {\n        newEventCache = this.filter_.updatePriority(\n          oldViewCache.getEventCache().getNode(),\n          changedSnap\n        );\n        newViewCache = oldViewCache.updateEventSnap(\n          newEventCache,\n          oldEventSnap.isFullyInitialized(),\n          oldEventSnap.isFiltered()\n        );\n      } else {\n        const childChangePath = pathPopFront(changePath);\n        const oldChild = oldEventSnap.getNode().getImmediateChild(childKey);\n        let newChild;\n        if (pathIsEmpty(childChangePath)) {\n          // Child overwrite, we can replace the child\n          newChild = changedSnap;\n        } else {\n          const childNode = source.getCompleteChild(childKey);\n          if (childNode != null) {\n            if (\n              pathGetBack(childChangePath) === '.priority' &&\n              childNode.getChild(pathParent(childChangePath)).isEmpty()\n            ) {\n              // This is a priority update on an empty node. If this node exists on the server, the\n              // server will send down the priority in the update, so ignore for now\n              newChild = childNode;\n            } else {\n              newChild = childNode.updateChild(childChangePath, changedSnap);\n            }\n          } else {\n            // There is no complete child node available\n            newChild = ChildrenNode.EMPTY_NODE;\n          }\n        }\n        if (!oldChild.equals(newChild)) {\n          const newEventSnap = this.filter_.updateChild(\n            oldEventSnap.getNode(),\n            childKey,\n            newChild,\n            childChangePath,\n            source,\n            accumulator\n          );\n          newViewCache = oldViewCache.updateEventSnap(\n            newEventSnap,\n            oldEventSnap.isFullyInitialized(),\n            this.filter_.filtersNodes()\n          );\n        } else {\n          newViewCache = oldViewCache;\n        }\n      }\n    }\n    return newViewCache;\n  }\n\n  private static cacheHasChild_(\n    viewCache: ViewCache,\n    childKey: string\n  ): boolean {\n    return viewCache.getEventCache().isCompleteForChild(childKey);\n  }\n\n  private applyUserMerge_(\n    viewCache: ViewCache,\n    path: Path,\n    changedChildren: ImmutableTree<Node>,\n    writesCache: WriteTreeRef,\n    serverCache: Node | null,\n    accumulator: ChildChangeAccumulator\n  ): ViewCache {\n    // HACK: In the case of a limit query, there may be some changes that bump things out of the\n    // window leaving room for new items.  It's important we process these changes first, so we\n    // iterate the changes twice, first processing any that affect items currently in view.\n    // TODO: I consider an item \"in view\" if cacheHasChild is true, which checks both the server\n    // and event snap.  I'm not sure if this will result in edge cases when a child is in one but\n    // not the other.\n    let curViewCache = viewCache;\n    changedChildren.foreach((relativePath, childNode) => {\n      const writePath = pathChild(path, relativePath);\n      if (ViewProcessor.cacheHasChild_(viewCache, pathGetFront(writePath))) {\n        curViewCache = this.applyUserOverwrite_(\n          curViewCache,\n          writePath,\n          childNode,\n          writesCache,\n          serverCache,\n          accumulator\n        );\n      }\n    });\n\n    changedChildren.foreach((relativePath, childNode) => {\n      const writePath = pathChild(path, relativePath);\n      if (!ViewProcessor.cacheHasChild_(viewCache, pathGetFront(writePath))) {\n        curViewCache = this.applyUserOverwrite_(\n          curViewCache,\n          writePath,\n          childNode,\n          writesCache,\n          serverCache,\n          accumulator\n        );\n      }\n    });\n\n    return curViewCache;\n  }\n\n  private applyMerge_(node: Node, merge: ImmutableTree<Node>): Node {\n    merge.foreach((relativePath, childNode) => {\n      node = node.updateChild(relativePath, childNode);\n    });\n    return node;\n  }\n\n  private applyServerMerge_(\n    viewCache: ViewCache,\n    path: Path,\n    changedChildren: ImmutableTree<Node>,\n    writesCache: WriteTreeRef,\n    serverCache: Node | null,\n    filterServerNode: boolean,\n    accumulator: ChildChangeAccumulator\n  ): ViewCache {\n    // If we don't have a cache yet, this merge was intended for a previously listen in the same location. Ignore it and\n    // wait for the complete data update coming soon.\n    if (\n      viewCache.getServerCache().getNode().isEmpty() &&\n      !viewCache.getServerCache().isFullyInitialized()\n    ) {\n      return viewCache;\n    }\n\n    // HACK: In the case of a limit query, there may be some changes that bump things out of the\n    // window leaving room for new items.  It's important we process these changes first, so we\n    // iterate the changes twice, first processing any that affect items currently in view.\n    // TODO: I consider an item \"in view\" if cacheHasChild is true, which checks both the server\n    // and event snap.  I'm not sure if this will result in edge cases when a child is in one but\n    // not the other.\n    let curViewCache = viewCache;\n    let viewMergeTree;\n    if (pathIsEmpty(path)) {\n      viewMergeTree = changedChildren;\n    } else {\n      viewMergeTree = new ImmutableTree<Node>(null).setTree(\n        path,\n        changedChildren\n      );\n    }\n    const serverNode = viewCache.getServerCache().getNode();\n    viewMergeTree.children.inorderTraversal((childKey, childTree) => {\n      if (serverNode.hasChild(childKey)) {\n        const serverChild = viewCache\n          .getServerCache()\n          .getNode()\n          .getImmediateChild(childKey);\n        const newChild = this.applyMerge_(serverChild, childTree);\n        curViewCache = this.applyServerOverwrite_(\n          curViewCache,\n          new Path(childKey),\n          newChild,\n          writesCache,\n          serverCache,\n          filterServerNode,\n          accumulator\n        );\n      }\n    });\n    viewMergeTree.children.inorderTraversal((childKey, childMergeTree) => {\n      const isUnknownDeepMerge =\n        !viewCache.getServerCache().isCompleteForChild(childKey) &&\n        childMergeTree.value === undefined;\n      if (!serverNode.hasChild(childKey) && !isUnknownDeepMerge) {\n        const serverChild = viewCache\n          .getServerCache()\n          .getNode()\n          .getImmediateChild(childKey);\n        const newChild = this.applyMerge_(serverChild, childMergeTree);\n        curViewCache = this.applyServerOverwrite_(\n          curViewCache,\n          new Path(childKey),\n          newChild,\n          writesCache,\n          serverCache,\n          filterServerNode,\n          accumulator\n        );\n      }\n    });\n\n    return curViewCache;\n  }\n\n  private ackUserWrite_(\n    viewCache: ViewCache,\n    ackPath: Path,\n    affectedTree: ImmutableTree<boolean>,\n    writesCache: WriteTreeRef,\n    completeCache: Node | null,\n    accumulator: ChildChangeAccumulator\n  ): ViewCache {\n    if (writesCache.shadowingWrite(ackPath) != null) {\n      return viewCache;\n    }\n\n    // Only filter server node if it is currently filtered\n    const filterServerNode = viewCache.getServerCache().isFiltered();\n\n    // Essentially we'll just get our existing server cache for the affected paths and re-apply it as a server update\n    // now that it won't be shadowed.\n    const serverCache = viewCache.getServerCache();\n    if (affectedTree.value != null) {\n      // This is an overwrite.\n      if (\n        (pathIsEmpty(ackPath) && serverCache.isFullyInitialized()) ||\n        serverCache.isCompleteForPath(ackPath)\n      ) {\n        return this.applyServerOverwrite_(\n          viewCache,\n          ackPath,\n          serverCache.getNode().getChild(ackPath),\n          writesCache,\n          completeCache,\n          filterServerNode,\n          accumulator\n        );\n      } else if (pathIsEmpty(ackPath)) {\n        // This is a goofy edge case where we are acking data at this location but don't have full data.  We\n        // should just re-apply whatever we have in our cache as a merge.\n        let changedChildren = new ImmutableTree<Node>(null);\n        serverCache.getNode().forEachChild(KEY_INDEX, (name, node) => {\n          changedChildren = changedChildren.set(new Path(name), node);\n        });\n        return this.applyServerMerge_(\n          viewCache,\n          ackPath,\n          changedChildren,\n          writesCache,\n          completeCache,\n          filterServerNode,\n          accumulator\n        );\n      } else {\n        return viewCache;\n      }\n    } else {\n      // This is a merge.\n      let changedChildren = new ImmutableTree<Node>(null);\n      affectedTree.foreach((mergePath, value) => {\n        const serverCachePath = pathChild(ackPath, mergePath);\n        if (serverCache.isCompleteForPath(serverCachePath)) {\n          changedChildren = changedChildren.set(\n            mergePath,\n            serverCache.getNode().getChild(serverCachePath)\n          );\n        }\n      });\n      return this.applyServerMerge_(\n        viewCache,\n        ackPath,\n        changedChildren,\n        writesCache,\n        completeCache,\n        filterServerNode,\n        accumulator\n      );\n    }\n  }\n\n  private listenComplete_(\n    viewCache: ViewCache,\n    path: Path,\n    writesCache: WriteTreeRef,\n    accumulator: ChildChangeAccumulator\n  ): ViewCache {\n    const oldServerNode = viewCache.getServerCache();\n    const newViewCache = viewCache.updateServerSnap(\n      oldServerNode.getNode(),\n      oldServerNode.isFullyInitialized() || pathIsEmpty(path),\n      oldServerNode.isFiltered()\n    );\n    return this.generateEventCacheAfterServerEvent_(\n      newViewCache,\n      path,\n      writesCache,\n      NO_COMPLETE_CHILD_SOURCE,\n      accumulator\n    );\n  }\n\n  private revertUserWrite_(\n    viewCache: ViewCache,\n    path: Path,\n    writesCache: WriteTreeRef,\n    completeServerCache: Node | null,\n    accumulator: ChildChangeAccumulator\n  ): ViewCache {\n    let complete;\n    if (writesCache.shadowingWrite(path) != null) {\n      return viewCache;\n    } else {\n      const source = new WriteTreeCompleteChildSource(\n        writesCache,\n        viewCache,\n        completeServerCache\n      );\n      const oldEventCache = viewCache.getEventCache().getNode();\n      let newEventCache;\n      if (pathIsEmpty(path) || pathGetFront(path) === '.priority') {\n        let newNode;\n        if (viewCache.getServerCache().isFullyInitialized()) {\n          newNode = writesCache.calcCompleteEventCache(\n            viewCache.getCompleteServerSnap()\n          );\n        } else {\n          const serverChildren = viewCache.getServerCache().getNode();\n          assert(\n            serverChildren instanceof ChildrenNode,\n            'serverChildren would be complete if leaf node'\n          );\n          newNode = writesCache.calcCompleteEventChildren(\n            serverChildren as ChildrenNode\n          );\n        }\n        newNode = newNode as Node;\n        newEventCache = this.filter_.updateFullNode(\n          oldEventCache,\n          newNode,\n          accumulator\n        );\n      } else {\n        const childKey = pathGetFront(path);\n        let newChild = writesCache.calcCompleteChild(\n          childKey,\n          viewCache.getServerCache()\n        );\n        if (\n          newChild == null &&\n          viewCache.getServerCache().isCompleteForChild(childKey)\n        ) {\n          newChild = oldEventCache.getImmediateChild(childKey);\n        }\n        if (newChild != null) {\n          newEventCache = this.filter_.updateChild(\n            oldEventCache,\n            childKey,\n            newChild,\n            pathPopFront(path),\n            source,\n            accumulator\n          );\n        } else if (viewCache.getEventCache().getNode().hasChild(childKey)) {\n          // No complete child available, delete the existing one, if any\n          newEventCache = this.filter_.updateChild(\n            oldEventCache,\n            childKey,\n            ChildrenNode.EMPTY_NODE,\n            pathPopFront(path),\n            source,\n            accumulator\n          );\n        } else {\n          newEventCache = oldEventCache;\n        }\n        if (\n          newEventCache.isEmpty() &&\n          viewCache.getServerCache().isFullyInitialized()\n        ) {\n          // We might have reverted all child writes. Maybe the old event was a leaf node\n          complete = writesCache.calcCompleteEventCache(\n            viewCache.getCompleteServerSnap()\n          );\n          if (complete.isLeafNode()) {\n            newEventCache = this.filter_.updateFullNode(\n              newEventCache,\n              complete,\n              accumulator\n            );\n          }\n        }\n      }\n      complete =\n        viewCache.getServerCache().isFullyInitialized() ||\n        writesCache.shadowingWrite(newEmptyPath()) != null;\n      return viewCache.updateEventSnap(\n        newEventCache,\n        complete,\n        this.filter_.filtersNodes()\n      );\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { NamedNode, Node } from '../snap/Node';\nimport { Change, ChangeType, changeChildMoved } from './Change';\nimport { assertionError } from '@firebase/util';\nimport { Query } from '../../api/Query';\nimport { Index } from '../snap/indexes/Index';\nimport { EventRegistration } from './EventRegistration';\nimport { Event } from './Event';\n\n/**\n * An EventGenerator is used to convert \"raw\" changes (Change) as computed by the\n * CacheDiffer into actual events (Event) that can be raised.  See generateEventsForChanges()\n * for details.\n *\n */\nexport class EventGenerator {\n  index_: Index;\n\n  constructor(public query_: Query) {\n    this.index_ = this.query_.getQueryParams().getIndex();\n  }\n}\n\n/**\n * Given a set of raw changes (no moved events and prevName not specified yet), and a set of\n * EventRegistrations that should be notified of these changes, generate the actual events to be raised.\n *\n * Notes:\n *  - child_moved events will be synthesized at this time for any child_changed events that affect\n *    our index.\n *  - prevName will be calculated based on the index ordering.\n */\nexport function eventGeneratorGenerateEventsForChanges(\n  eventGenerator: EventGenerator,\n  changes: Change[],\n  eventCache: Node,\n  eventRegistrations: EventRegistration[]\n): Event[] {\n  const events: Event[] = [];\n  const moves: Change[] = [];\n\n  changes.forEach(change => {\n    if (\n      change.type === ChangeType.CHILD_CHANGED &&\n      eventGenerator.index_.indexedValueChanged(\n        change.oldSnap as Node,\n        change.snapshotNode\n      )\n    ) {\n      moves.push(changeChildMoved(change.childName, change.snapshotNode));\n    }\n  });\n\n  eventGeneratorGenerateEventsForType(\n    eventGenerator,\n    events,\n    ChangeType.CHILD_REMOVED,\n    changes,\n    eventRegistrations,\n    eventCache\n  );\n  eventGeneratorGenerateEventsForType(\n    eventGenerator,\n    events,\n    ChangeType.CHILD_ADDED,\n    changes,\n    eventRegistrations,\n    eventCache\n  );\n  eventGeneratorGenerateEventsForType(\n    eventGenerator,\n    events,\n    ChangeType.CHILD_MOVED,\n    moves,\n    eventRegistrations,\n    eventCache\n  );\n  eventGeneratorGenerateEventsForType(\n    eventGenerator,\n    events,\n    ChangeType.CHILD_CHANGED,\n    changes,\n    eventRegistrations,\n    eventCache\n  );\n  eventGeneratorGenerateEventsForType(\n    eventGenerator,\n    events,\n    ChangeType.VALUE,\n    changes,\n    eventRegistrations,\n    eventCache\n  );\n\n  return events;\n}\n\n/**\n * Given changes of a single change type, generate the corresponding events.\n */\nfunction eventGeneratorGenerateEventsForType(\n  eventGenerator: EventGenerator,\n  events: Event[],\n  eventType: string,\n  changes: Change[],\n  registrations: EventRegistration[],\n  eventCache: Node\n) {\n  const filteredChanges = changes.filter(change => change.type === eventType);\n\n  filteredChanges.sort((a, b) =>\n    eventGeneratorCompareChanges(eventGenerator, a, b)\n  );\n  filteredChanges.forEach(change => {\n    const materializedChange = eventGeneratorMaterializeSingleChange(\n      eventGenerator,\n      change,\n      eventCache\n    );\n    registrations.forEach(registration => {\n      if (registration.respondsTo(change.type)) {\n        events.push(\n          registration.createEvent(materializedChange, eventGenerator.query_)\n        );\n      }\n    });\n  });\n}\n\nfunction eventGeneratorMaterializeSingleChange(\n  eventGenerator: EventGenerator,\n  change: Change,\n  eventCache: Node\n): Change {\n  if (change.type === 'value' || change.type === 'child_removed') {\n    return change;\n  } else {\n    change.prevName = eventCache.getPredecessorChildName(\n      change.childName,\n      change.snapshotNode,\n      eventGenerator.index_\n    );\n    return change;\n  }\n}\n\nfunction eventGeneratorCompareChanges(\n  eventGenerator: EventGenerator,\n  a: Change,\n  b: Change\n) {\n  if (a.childName == null || b.childName == null) {\n    throw assertionError('Should only compare child_ events.');\n  }\n  const aWrapped = new NamedNode(a.childName, a.snapshotNode);\n  const bWrapped = new NamedNode(b.childName, b.snapshotNode);\n  return eventGenerator.index_.compare(aWrapped, bWrapped);\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert } from '@firebase/util';\nimport {\n  tryParseInt,\n  MAX_NAME,\n  MIN_NAME,\n  INTEGER_32_MIN,\n  INTEGER_32_MAX\n} from '../util/util';\n\n// Modeled after base64 web-safe chars, but ordered by ASCII.\nconst PUSH_CHARS =\n  '-0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ_abcdefghijklmnopqrstuvwxyz';\n\nconst MIN_PUSH_CHAR = '-';\n\nconst MAX_PUSH_CHAR = 'z';\n\nconst MAX_KEY_LEN = 786;\n\n/**\n * Fancy ID generator that creates 20-character string identifiers with the\n * following properties:\n *\n * 1. They're based on timestamp so that they sort *after* any existing ids.\n * 2. They contain 72-bits of random data after the timestamp so that IDs won't\n *    collide with other clients' IDs.\n * 3. They sort *lexicographically* (so the timestamp is converted to characters\n *    that will sort properly).\n * 4. They're monotonically increasing. Even if you generate more than one in\n *    the same timestamp, the latter ones will sort after the former ones. We do\n *    this by using the previous random bits but \"incrementing\" them by 1 (only\n *    in the case of a timestamp collision).\n */\nexport const nextPushId = (function () {\n  // Timestamp of last push, used to prevent local collisions if you push twice\n  // in one ms.\n  let lastPushTime = 0;\n\n  // We generate 72-bits of randomness which get turned into 12 characters and\n  // appended to the timestamp to prevent collisions with other clients. We\n  // store the last characters we generated because in the event of a collision,\n  // we'll use those same characters except \"incremented\" by one.\n  const lastRandChars: number[] = [];\n\n  return function (now: number) {\n    const duplicateTime = now === lastPushTime;\n    lastPushTime = now;\n\n    let i;\n    const timeStampChars = new Array(8);\n    for (i = 7; i >= 0; i--) {\n      timeStampChars[i] = PUSH_CHARS.charAt(now % 64);\n      // NOTE: Can't use << here because javascript will convert to int and lose\n      // the upper bits.\n      now = Math.floor(now / 64);\n    }\n    assert(now === 0, 'Cannot push at time == 0');\n\n    let id = timeStampChars.join('');\n\n    if (!duplicateTime) {\n      for (i = 0; i < 12; i++) {\n        lastRandChars[i] = Math.floor(Math.random() * 64);\n      }\n    } else {\n      // If the timestamp hasn't changed since last push, use the same random\n      // number, except incremented by 1.\n      for (i = 11; i >= 0 && lastRandChars[i] === 63; i--) {\n        lastRandChars[i] = 0;\n      }\n      lastRandChars[i]++;\n    }\n    for (i = 0; i < 12; i++) {\n      id += PUSH_CHARS.charAt(lastRandChars[i]);\n    }\n    assert(id.length === 20, 'nextPushId: Length should be 20.');\n\n    return id;\n  };\n})();\n\nexport const successor = function (key: string) {\n  if (key === '' + INTEGER_32_MAX) {\n    // See https://firebase.google.com/docs/database/web/lists-of-data#data-order\n    return MIN_PUSH_CHAR;\n  }\n  const keyAsInt: number = tryParseInt(key);\n  if (keyAsInt != null) {\n    return '' + (keyAsInt + 1);\n  }\n  const next = new Array(key.length);\n\n  for (let i = 0; i < next.length; i++) {\n    next[i] = key.charAt(i);\n  }\n\n  if (next.length < MAX_KEY_LEN) {\n    next.push(MIN_PUSH_CHAR);\n    return next.join('');\n  }\n\n  let i = next.length - 1;\n\n  while (i >= 0 && next[i] === MAX_PUSH_CHAR) {\n    i--;\n  }\n\n  // `successor` was called on the largest possible key, so return the\n  // MAX_NAME, which sorts larger than all keys.\n  if (i === -1) {\n    return MAX_NAME;\n  }\n\n  const source = next[i];\n  const sourcePlusOne = PUSH_CHARS.charAt(PUSH_CHARS.indexOf(source) + 1);\n  next[i] = sourcePlusOne;\n\n  return next.slice(0, i + 1).join('');\n};\n\n// `key` is assumed to be non-empty.\nexport const predecessor = function (key: string) {\n  if (key === '' + INTEGER_32_MIN) {\n    return MIN_NAME;\n  }\n  const keyAsInt: number = tryParseInt(key);\n  if (keyAsInt != null) {\n    return '' + (keyAsInt - 1);\n  }\n  const next = new Array(key.length);\n  for (let i = 0; i < next.length; i++) {\n    next[i] = key.charAt(i);\n  }\n  // If `key` ends in `MIN_PUSH_CHAR`, the largest key lexicographically\n  // smaller than `key`, is `key[0:key.length - 1]`. The next key smaller\n  // than that, `predecessor(predecessor(key))`, is\n  //\n  // `key[0:key.length - 2] + (key[key.length - 1] - 1) + \\\n  //   { MAX_PUSH_CHAR repeated MAX_KEY_LEN - (key.length - 1) times }\n  //\n  // analogous to increment/decrement for base-10 integers.\n  //\n  // This works because lexigographic comparison works character-by-character,\n  // using length as a tie-breaker if one key is a prefix of the other.\n  if (next[next.length - 1] === MIN_PUSH_CHAR) {\n    if (next.length === 1) {\n      // See https://firebase.google.com/docs/database/web/lists-of-data#orderbykey\n      return '' + INTEGER_32_MAX;\n    }\n    delete next[next.length - 1];\n    return next.join('');\n  }\n  // Replace the last character with it's immediate predecessor, and\n  // fill the suffix of the key with MAX_PUSH_CHAR. This is the\n  // lexicographically largest possible key smaller than `key`.\n  next[next.length - 1] = PUSH_CHARS.charAt(\n    PUSH_CHARS.indexOf(next[next.length - 1]) - 1\n  );\n  return next.join('') + MAX_PUSH_CHAR.repeat(MAX_KEY_LEN - next.length);\n};\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Index } from './Index';\nimport { NamedNode, Node } from '../Node';\nimport { nameCompare } from '../../util/util';\nimport { nodeFromJSON } from '../nodeFromJSON';\n\nexport class ValueIndex extends Index {\n  /**\n   * @inheritDoc\n   */\n  compare(a: NamedNode, b: NamedNode): number {\n    const indexCmp = a.node.compareTo(b.node);\n    if (indexCmp === 0) {\n      return nameCompare(a.name, b.name);\n    } else {\n      return indexCmp;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  isDefinedOn(node: Node): boolean {\n    return true;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  indexedValueChanged(oldNode: Node, newNode: Node): boolean {\n    return !oldNode.equals(newNode);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  minPost(): NamedNode {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return (NamedNode as any).MIN;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  maxPost(): NamedNode {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return (NamedNode as any).MAX;\n  }\n\n  makePost(indexValue: object, name: string): NamedNode {\n    const valueNode = nodeFromJSON(indexValue);\n    return new NamedNode(name, valueNode);\n  }\n\n  /**\n   * @return String representation for inclusion in a query spec\n   */\n  toString(): string {\n    return '.value';\n  }\n}\n\nexport const VALUE_INDEX = new ValueIndex();\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert } from '@firebase/util';\nimport { MAX_NAME, nameCompare } from '../../util/util';\nimport { Index } from './Index';\nimport { ChildrenNode, MAX_NODE } from '../ChildrenNode';\nimport { NamedNode, Node } from '../Node';\nimport { nodeFromJSON } from '../nodeFromJSON';\nimport { Path, pathGetFront, pathIsEmpty, pathSlice } from '../../util/Path';\n\nexport class PathIndex extends Index {\n  constructor(private indexPath_: Path) {\n    super();\n\n    assert(\n      !pathIsEmpty(indexPath_) && pathGetFront(indexPath_) !== '.priority',\n      \"Can't create PathIndex with empty path or .priority key\"\n    );\n  }\n\n  protected extractChild(snap: Node): Node {\n    return snap.getChild(this.indexPath_);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  isDefinedOn(node: Node): boolean {\n    return !node.getChild(this.indexPath_).isEmpty();\n  }\n\n  /**\n   * @inheritDoc\n   */\n  compare(a: NamedNode, b: NamedNode): number {\n    const aChild = this.extractChild(a.node);\n    const bChild = this.extractChild(b.node);\n    const indexCmp = aChild.compareTo(bChild);\n    if (indexCmp === 0) {\n      return nameCompare(a.name, b.name);\n    } else {\n      return indexCmp;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  makePost(indexValue: object, name: string): NamedNode {\n    const valueNode = nodeFromJSON(indexValue);\n    const node = ChildrenNode.EMPTY_NODE.updateChild(\n      this.indexPath_,\n      valueNode\n    );\n    return new NamedNode(name, node);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  maxPost(): NamedNode {\n    const node = ChildrenNode.EMPTY_NODE.updateChild(this.indexPath_, MAX_NODE);\n    return new NamedNode(MAX_NAME, node);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  toString(): string {\n    return pathSlice(this.indexPath_, 0).join('/');\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { IndexedFilter } from './IndexedFilter';\nimport { PRIORITY_INDEX } from '../../snap/indexes/PriorityIndex';\nimport { NamedNode, Node } from '../../../core/snap/Node';\nimport { ChildrenNode } from '../../snap/ChildrenNode';\nimport { NodeFilter } from './NodeFilter';\nimport { QueryParams } from '../QueryParams';\nimport { Index } from '../../snap/indexes/Index';\nimport { Path } from '../../util/Path';\nimport { CompleteChildSource } from '../CompleteChildSource';\nimport { ChildChangeAccumulator } from '../ChildChangeAccumulator';\n\n/**\n * Filters nodes by range and uses an IndexFilter to track any changes after filtering the node\n */\nexport class RangedFilter implements NodeFilter {\n  private indexedFilter_: IndexedFilter;\n\n  private index_: Index;\n\n  private startPost_: NamedNode;\n\n  private endPost_: NamedNode;\n\n  constructor(params: QueryParams) {\n    this.indexedFilter_ = new IndexedFilter(params.getIndex());\n    this.index_ = params.getIndex();\n    this.startPost_ = RangedFilter.getStartPost_(params);\n    this.endPost_ = RangedFilter.getEndPost_(params);\n  }\n\n  getStartPost(): NamedNode {\n    return this.startPost_;\n  }\n\n  getEndPost(): NamedNode {\n    return this.endPost_;\n  }\n\n  matches(node: NamedNode): boolean {\n    return (\n      this.index_.compare(this.getStartPost(), node) <= 0 &&\n      this.index_.compare(node, this.getEndPost()) <= 0\n    );\n  }\n\n  /**\n   * @inheritDoc\n   */\n  updateChild(\n    snap: Node,\n    key: string,\n    newChild: Node,\n    affectedPath: Path,\n    source: CompleteChildSource,\n    optChangeAccumulator: ChildChangeAccumulator | null\n  ): Node {\n    if (!this.matches(new NamedNode(key, newChild))) {\n      newChild = ChildrenNode.EMPTY_NODE;\n    }\n    return this.indexedFilter_.updateChild(\n      snap,\n      key,\n      newChild,\n      affectedPath,\n      source,\n      optChangeAccumulator\n    );\n  }\n\n  /**\n   * @inheritDoc\n   */\n  updateFullNode(\n    oldSnap: Node,\n    newSnap: Node,\n    optChangeAccumulator: ChildChangeAccumulator | null\n  ): Node {\n    if (newSnap.isLeafNode()) {\n      // Make sure we have a children node with the correct index, not a leaf node;\n      newSnap = ChildrenNode.EMPTY_NODE;\n    }\n    let filtered = newSnap.withIndex(this.index_);\n    // Don't support priorities on queries\n    filtered = filtered.updatePriority(ChildrenNode.EMPTY_NODE);\n    const self = this;\n    newSnap.forEachChild(PRIORITY_INDEX, (key, childNode) => {\n      if (!self.matches(new NamedNode(key, childNode))) {\n        filtered = filtered.updateImmediateChild(key, ChildrenNode.EMPTY_NODE);\n      }\n    });\n    return this.indexedFilter_.updateFullNode(\n      oldSnap,\n      filtered,\n      optChangeAccumulator\n    );\n  }\n\n  /**\n   * @inheritDoc\n   */\n  updatePriority(oldSnap: Node, newPriority: Node): Node {\n    // Don't support priorities on queries\n    return oldSnap;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  filtersNodes(): boolean {\n    return true;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getIndexedFilter(): IndexedFilter {\n    return this.indexedFilter_;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getIndex(): Index {\n    return this.index_;\n  }\n\n  private static getStartPost_(params: QueryParams): NamedNode {\n    if (params.hasStart()) {\n      const startName = params.getIndexStartName();\n      return params.getIndex().makePost(params.getIndexStartValue(), startName);\n    } else {\n      return params.getIndex().minPost();\n    }\n  }\n\n  private static getEndPost_(params: QueryParams): NamedNode {\n    if (params.hasEnd()) {\n      const endName = params.getIndexEndName();\n      return params.getIndex().makePost(params.getIndexEndValue(), endName);\n    } else {\n      return params.getIndex().maxPost();\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { RangedFilter } from './RangedFilter';\nimport { ChildrenNode } from '../../snap/ChildrenNode';\nimport { NamedNode, Node } from '../../snap/Node';\nimport { assert } from '@firebase/util';\nimport {\n  changeChildAdded,\n  changeChildChanged,\n  changeChildRemoved\n} from '../Change';\nimport { NodeFilter } from './NodeFilter';\nimport { Index } from '../../snap/indexes/Index';\nimport { IndexedFilter } from './IndexedFilter';\nimport { QueryParams } from '../QueryParams';\nimport { Path } from '../../util/Path';\nimport { CompleteChildSource } from '../CompleteChildSource';\nimport { ChildChangeAccumulator } from '../ChildChangeAccumulator';\n\n/**\n * Applies a limit and a range to a node and uses RangedFilter to do the heavy lifting where possible\n */\nexport class LimitedFilter implements NodeFilter {\n  private readonly rangedFilter_: RangedFilter;\n\n  private readonly index_: Index;\n\n  private readonly limit_: number;\n\n  private readonly reverse_: boolean;\n\n  constructor(params: QueryParams) {\n    this.rangedFilter_ = new RangedFilter(params);\n    this.index_ = params.getIndex();\n    this.limit_ = params.getLimit();\n    this.reverse_ = !params.isViewFromLeft();\n  }\n\n  /**\n   * @inheritDoc\n   */\n  updateChild(\n    snap: Node,\n    key: string,\n    newChild: Node,\n    affectedPath: Path,\n    source: CompleteChildSource,\n    optChangeAccumulator: ChildChangeAccumulator | null\n  ): Node {\n    if (!this.rangedFilter_.matches(new NamedNode(key, newChild))) {\n      newChild = ChildrenNode.EMPTY_NODE;\n    }\n    if (snap.getImmediateChild(key).equals(newChild)) {\n      // No change\n      return snap;\n    } else if (snap.numChildren() < this.limit_) {\n      return this.rangedFilter_\n        .getIndexedFilter()\n        .updateChild(\n          snap,\n          key,\n          newChild,\n          affectedPath,\n          source,\n          optChangeAccumulator\n        );\n    } else {\n      return this.fullLimitUpdateChild_(\n        snap,\n        key,\n        newChild,\n        source,\n        optChangeAccumulator\n      );\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  updateFullNode(\n    oldSnap: Node,\n    newSnap: Node,\n    optChangeAccumulator: ChildChangeAccumulator | null\n  ): Node {\n    let filtered;\n    if (newSnap.isLeafNode() || newSnap.isEmpty()) {\n      // Make sure we have a children node with the correct index, not a leaf node;\n      filtered = ChildrenNode.EMPTY_NODE.withIndex(this.index_);\n    } else {\n      if (\n        this.limit_ * 2 < newSnap.numChildren() &&\n        newSnap.isIndexed(this.index_)\n      ) {\n        // Easier to build up a snapshot, since what we're given has more than twice the elements we want\n        filtered = ChildrenNode.EMPTY_NODE.withIndex(this.index_);\n        // anchor to the startPost, endPost, or last element as appropriate\n        let iterator;\n        if (this.reverse_) {\n          iterator = (newSnap as ChildrenNode).getReverseIteratorFrom(\n            this.rangedFilter_.getEndPost(),\n            this.index_\n          );\n        } else {\n          iterator = (newSnap as ChildrenNode).getIteratorFrom(\n            this.rangedFilter_.getStartPost(),\n            this.index_\n          );\n        }\n        let count = 0;\n        while (iterator.hasNext() && count < this.limit_) {\n          const next = iterator.getNext();\n          let inRange;\n          if (this.reverse_) {\n            inRange =\n              this.index_.compare(this.rangedFilter_.getStartPost(), next) <= 0;\n          } else {\n            inRange =\n              this.index_.compare(next, this.rangedFilter_.getEndPost()) <= 0;\n          }\n          if (inRange) {\n            filtered = filtered.updateImmediateChild(next.name, next.node);\n            count++;\n          } else {\n            // if we have reached the end post, we cannot keep adding elemments\n            break;\n          }\n        }\n      } else {\n        // The snap contains less than twice the limit. Faster to delete from the snap than build up a new one\n        filtered = newSnap.withIndex(this.index_);\n        // Don't support priorities on queries\n        filtered = filtered.updatePriority(\n          ChildrenNode.EMPTY_NODE\n        ) as ChildrenNode;\n        let startPost;\n        let endPost;\n        let cmp;\n        let iterator;\n        if (this.reverse_) {\n          iterator = filtered.getReverseIterator(this.index_);\n          startPost = this.rangedFilter_.getEndPost();\n          endPost = this.rangedFilter_.getStartPost();\n          const indexCompare = this.index_.getCompare();\n          cmp = (a: NamedNode, b: NamedNode) => indexCompare(b, a);\n        } else {\n          iterator = filtered.getIterator(this.index_);\n          startPost = this.rangedFilter_.getStartPost();\n          endPost = this.rangedFilter_.getEndPost();\n          cmp = this.index_.getCompare();\n        }\n\n        let count = 0;\n        let foundStartPost = false;\n        while (iterator.hasNext()) {\n          const next = iterator.getNext();\n          if (!foundStartPost && cmp(startPost, next) <= 0) {\n            // start adding\n            foundStartPost = true;\n          }\n          const inRange =\n            foundStartPost && count < this.limit_ && cmp(next, endPost) <= 0;\n          if (inRange) {\n            count++;\n          } else {\n            filtered = filtered.updateImmediateChild(\n              next.name,\n              ChildrenNode.EMPTY_NODE\n            );\n          }\n        }\n      }\n    }\n    return this.rangedFilter_\n      .getIndexedFilter()\n      .updateFullNode(oldSnap, filtered, optChangeAccumulator);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  updatePriority(oldSnap: Node, newPriority: Node): Node {\n    // Don't support priorities on queries\n    return oldSnap;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  filtersNodes(): boolean {\n    return true;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getIndexedFilter(): IndexedFilter {\n    return this.rangedFilter_.getIndexedFilter();\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getIndex(): Index {\n    return this.index_;\n  }\n\n  private fullLimitUpdateChild_(\n    snap: Node,\n    childKey: string,\n    childSnap: Node,\n    source: CompleteChildSource,\n    changeAccumulator: ChildChangeAccumulator | null\n  ): Node {\n    // TODO: rename all cache stuff etc to general snap terminology\n    let cmp;\n    if (this.reverse_) {\n      const indexCmp = this.index_.getCompare();\n      cmp = (a: NamedNode, b: NamedNode) => indexCmp(b, a);\n    } else {\n      cmp = this.index_.getCompare();\n    }\n    const oldEventCache = snap as ChildrenNode;\n    assert(oldEventCache.numChildren() === this.limit_, '');\n    const newChildNamedNode = new NamedNode(childKey, childSnap);\n    const windowBoundary = this.reverse_\n      ? oldEventCache.getFirstChild(this.index_)\n      : (oldEventCache.getLastChild(this.index_) as NamedNode);\n    const inRange = this.rangedFilter_.matches(newChildNamedNode);\n    if (oldEventCache.hasChild(childKey)) {\n      const oldChildSnap = oldEventCache.getImmediateChild(childKey);\n      let nextChild = source.getChildAfterChild(\n        this.index_,\n        windowBoundary,\n        this.reverse_\n      );\n      while (\n        nextChild != null &&\n        (nextChild.name === childKey || oldEventCache.hasChild(nextChild.name))\n      ) {\n        // There is a weird edge case where a node is updated as part of a merge in the write tree, but hasn't\n        // been applied to the limited filter yet. Ignore this next child which will be updated later in\n        // the limited filter...\n        nextChild = source.getChildAfterChild(\n          this.index_,\n          nextChild,\n          this.reverse_\n        );\n      }\n      const compareNext =\n        nextChild == null ? 1 : cmp(nextChild, newChildNamedNode);\n      const remainsInWindow =\n        inRange && !childSnap.isEmpty() && compareNext >= 0;\n      if (remainsInWindow) {\n        if (changeAccumulator != null) {\n          changeAccumulator.trackChildChange(\n            changeChildChanged(childKey, childSnap, oldChildSnap)\n          );\n        }\n        return oldEventCache.updateImmediateChild(childKey, childSnap);\n      } else {\n        if (changeAccumulator != null) {\n          changeAccumulator.trackChildChange(\n            changeChildRemoved(childKey, oldChildSnap)\n          );\n        }\n        const newEventCache = oldEventCache.updateImmediateChild(\n          childKey,\n          ChildrenNode.EMPTY_NODE\n        );\n        const nextChildInRange =\n          nextChild != null && this.rangedFilter_.matches(nextChild);\n        if (nextChildInRange) {\n          if (changeAccumulator != null) {\n            changeAccumulator.trackChildChange(\n              changeChildAdded(nextChild.name, nextChild.node)\n            );\n          }\n          return newEventCache.updateImmediateChild(\n            nextChild.name,\n            nextChild.node\n          );\n        } else {\n          return newEventCache;\n        }\n      }\n    } else if (childSnap.isEmpty()) {\n      // we're deleting a node, but it was not in the window, so ignore it\n      return snap;\n    } else if (inRange) {\n      if (cmp(windowBoundary, newChildNamedNode) >= 0) {\n        if (changeAccumulator != null) {\n          changeAccumulator.trackChildChange(\n            changeChildRemoved(windowBoundary.name, windowBoundary.node)\n          );\n          changeAccumulator.trackChildChange(\n            changeChildAdded(childKey, childSnap)\n          );\n        }\n        return oldEventCache\n          .updateImmediateChild(childKey, childSnap)\n          .updateImmediateChild(windowBoundary.name, ChildrenNode.EMPTY_NODE);\n      } else {\n        return snap;\n      }\n    } else {\n      return snap;\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert, stringify } from '@firebase/util';\nimport { MIN_NAME, MAX_NAME } from '../util/util';\nimport { predecessor, successor } from '../util/NextPushId';\nimport { KEY_INDEX } from '../snap/indexes/KeyIndex';\nimport { PRIORITY_INDEX } from '../snap/indexes/PriorityIndex';\nimport { VALUE_INDEX } from '../snap/indexes/ValueIndex';\nimport { PathIndex } from '../snap/indexes/PathIndex';\nimport { IndexedFilter } from './filter/IndexedFilter';\nimport { LimitedFilter } from './filter/LimitedFilter';\nimport { RangedFilter } from './filter/RangedFilter';\nimport { NodeFilter } from './filter/NodeFilter';\nimport { Index } from '../snap/indexes/Index';\n\n/**\n * Wire Protocol Constants\n */\nconst enum WIRE_PROTOCOL_CONSTANTS {\n  INDEX_START_VALUE = 'sp',\n  INDEX_START_NAME = 'sn',\n  INDEX_END_VALUE = 'ep',\n  INDEX_END_NAME = 'en',\n  LIMIT = 'l',\n  VIEW_FROM = 'vf',\n  VIEW_FROM_LEFT = 'l',\n  VIEW_FROM_RIGHT = 'r',\n  INDEX = 'i'\n}\n\n/**\n * REST Query Constants\n */\nconst enum REST_QUERY_CONSTANTS {\n  ORDER_BY = 'orderBy',\n  PRIORITY_INDEX = '$priority',\n  VALUE_INDEX = '$value',\n  KEY_INDEX = '$key',\n  START_AT = 'startAt',\n  END_AT = 'endAt',\n  LIMIT_TO_FIRST = 'limitToFirst',\n  LIMIT_TO_LAST = 'limitToLast'\n}\n\n/**\n * This class is an immutable-from-the-public-api struct containing a set of query parameters defining a\n * range to be returned for a particular location. It is assumed that validation of parameters is done at the\n * user-facing API level, so it is not done here.\n */\nexport class QueryParams {\n  limitSet_ = false;\n  startSet_ = false;\n  startNameSet_ = false;\n  startAfterSet_ = false;\n  endSet_ = false;\n  endNameSet_ = false;\n  endBeforeSet_ = false;\n  limit_ = 0;\n  viewFrom_ = '';\n  indexStartValue_: unknown | null = null;\n  indexStartName_ = '';\n  indexEndValue_: unknown | null = null;\n  indexEndName_ = '';\n  index_ = PRIORITY_INDEX;\n\n  hasStart(): boolean {\n    return this.startSet_;\n  }\n\n  hasStartAfter(): boolean {\n    return this.startAfterSet_;\n  }\n\n  hasEndBefore(): boolean {\n    return this.endBeforeSet_;\n  }\n\n  /**\n   * @return True if it would return from left.\n   */\n  isViewFromLeft(): boolean {\n    if (this.viewFrom_ === '') {\n      // limit(), rather than limitToFirst or limitToLast was called.\n      // This means that only one of startSet_ and endSet_ is true. Use them\n      // to calculate which side of the view to anchor to. If neither is set,\n      // anchor to the end.\n      return this.startSet_;\n    } else {\n      return this.viewFrom_ === WIRE_PROTOCOL_CONSTANTS.VIEW_FROM_LEFT;\n    }\n  }\n\n  /**\n   * Only valid to call if hasStart() returns true\n   */\n  getIndexStartValue(): unknown {\n    assert(this.startSet_, 'Only valid if start has been set');\n    return this.indexStartValue_;\n  }\n\n  /**\n   * Only valid to call if hasStart() returns true.\n   * Returns the starting key name for the range defined by these query parameters\n   */\n  getIndexStartName(): string {\n    assert(this.startSet_, 'Only valid if start has been set');\n    if (this.startNameSet_) {\n      return this.indexStartName_;\n    } else {\n      return MIN_NAME;\n    }\n  }\n\n  hasEnd(): boolean {\n    return this.endSet_;\n  }\n\n  /**\n   * Only valid to call if hasEnd() returns true.\n   */\n  getIndexEndValue(): unknown {\n    assert(this.endSet_, 'Only valid if end has been set');\n    return this.indexEndValue_;\n  }\n\n  /**\n   * Only valid to call if hasEnd() returns true.\n   * Returns the end key name for the range defined by these query parameters\n   */\n  getIndexEndName(): string {\n    assert(this.endSet_, 'Only valid if end has been set');\n    if (this.endNameSet_) {\n      return this.indexEndName_;\n    } else {\n      return MAX_NAME;\n    }\n  }\n\n  hasLimit(): boolean {\n    return this.limitSet_;\n  }\n\n  /**\n   * @return True if a limit has been set and it has been explicitly anchored\n   */\n  hasAnchoredLimit(): boolean {\n    return this.limitSet_ && this.viewFrom_ !== '';\n  }\n\n  /**\n   * Only valid to call if hasLimit() returns true\n   */\n  getLimit(): number {\n    assert(this.limitSet_, 'Only valid if limit has been set');\n    return this.limit_;\n  }\n\n  getIndex(): Index {\n    return this.index_;\n  }\n\n  loadsAllData(): boolean {\n    return !(this.startSet_ || this.endSet_ || this.limitSet_);\n  }\n\n  isDefault(): boolean {\n    return this.loadsAllData() && this.index_ === PRIORITY_INDEX;\n  }\n\n  copy(): QueryParams {\n    const copy = new QueryParams();\n    copy.limitSet_ = this.limitSet_;\n    copy.limit_ = this.limit_;\n    copy.startSet_ = this.startSet_;\n    copy.indexStartValue_ = this.indexStartValue_;\n    copy.startNameSet_ = this.startNameSet_;\n    copy.indexStartName_ = this.indexStartName_;\n    copy.endSet_ = this.endSet_;\n    copy.indexEndValue_ = this.indexEndValue_;\n    copy.endNameSet_ = this.endNameSet_;\n    copy.indexEndName_ = this.indexEndName_;\n    copy.index_ = this.index_;\n    copy.viewFrom_ = this.viewFrom_;\n    return copy;\n  }\n}\n\nexport function queryParamsGetNodeFilter(queryParams: QueryParams): NodeFilter {\n  if (queryParams.loadsAllData()) {\n    return new IndexedFilter(queryParams.getIndex());\n  } else if (queryParams.hasLimit()) {\n    return new LimitedFilter(queryParams);\n  } else {\n    return new RangedFilter(queryParams);\n  }\n}\n\nexport function queryParamsLimit(\n  queryParams: QueryParams,\n  newLimit: number\n): QueryParams {\n  const newParams = queryParams.copy();\n  newParams.limitSet_ = true;\n  newParams.limit_ = newLimit;\n  newParams.viewFrom_ = '';\n  return newParams;\n}\n\nexport function queryParamsLimitToFirst(\n  queryParams: QueryParams,\n  newLimit: number\n): QueryParams {\n  const newParams = queryParams.copy();\n  newParams.limitSet_ = true;\n  newParams.limit_ = newLimit;\n  newParams.viewFrom_ = WIRE_PROTOCOL_CONSTANTS.VIEW_FROM_LEFT;\n  return newParams;\n}\n\nexport function queryParamsLimitToLast(\n  queryParams: QueryParams,\n  newLimit: number\n): QueryParams {\n  const newParams = queryParams.copy();\n  newParams.limitSet_ = true;\n  newParams.limit_ = newLimit;\n  newParams.viewFrom_ = WIRE_PROTOCOL_CONSTANTS.VIEW_FROM_RIGHT;\n  return newParams;\n}\n\nexport function queryParamsStartAt(\n  queryParams: QueryParams,\n  indexValue: unknown,\n  key?: string | null\n): QueryParams {\n  const newParams = queryParams.copy();\n  newParams.startSet_ = true;\n  if (indexValue === undefined) {\n    indexValue = null;\n  }\n  newParams.indexStartValue_ = indexValue;\n  if (key != null) {\n    newParams.startNameSet_ = true;\n    newParams.indexStartName_ = key;\n  } else {\n    newParams.startNameSet_ = false;\n    newParams.indexStartName_ = '';\n  }\n  return newParams;\n}\n\nexport function queryParamsStartAfter(\n  queryParams: QueryParams,\n  indexValue: unknown,\n  key?: string | null\n): QueryParams {\n  let params: QueryParams;\n  if (queryParams.index_ === KEY_INDEX) {\n    if (typeof indexValue === 'string') {\n      indexValue = successor(indexValue as string);\n    }\n    params = queryParamsStartAt(queryParams, indexValue, key);\n  } else {\n    let childKey: string;\n    if (key == null) {\n      childKey = MAX_NAME;\n    } else {\n      childKey = successor(key);\n    }\n    params = queryParamsStartAt(queryParams, indexValue, childKey);\n  }\n  params.startAfterSet_ = true;\n  return params;\n}\n\nexport function queryParamsEndAt(\n  queryParams: QueryParams,\n  indexValue: unknown,\n  key?: string | null\n): QueryParams {\n  const newParams = queryParams.copy();\n  newParams.endSet_ = true;\n  if (indexValue === undefined) {\n    indexValue = null;\n  }\n  newParams.indexEndValue_ = indexValue;\n  if (key !== undefined) {\n    newParams.endNameSet_ = true;\n    newParams.indexEndName_ = key;\n  } else {\n    newParams.endNameSet_ = false;\n    newParams.indexEndName_ = '';\n  }\n  return newParams;\n}\n\nexport function queryParamsEndBefore(\n  queryParams: QueryParams,\n  indexValue: unknown,\n  key?: string | null\n): QueryParams {\n  let childKey: string;\n  let params: QueryParams;\n  if (queryParams.index_ === KEY_INDEX) {\n    if (typeof indexValue === 'string') {\n      indexValue = predecessor(indexValue as string);\n    }\n    params = queryParamsEndAt(queryParams, indexValue, key);\n  } else {\n    if (key == null) {\n      childKey = MIN_NAME;\n    } else {\n      childKey = predecessor(key);\n    }\n    params = queryParamsEndAt(queryParams, indexValue, childKey);\n  }\n  params.endBeforeSet_ = true;\n  return params;\n}\n\nexport function queryParamsOrderBy(\n  queryParams: QueryParams,\n  index: Index\n): QueryParams {\n  const newParams = queryParams.copy();\n  newParams.index_ = index;\n  return newParams;\n}\n\n/**\n * Returns a set of REST query string parameters representing this query.\n *\n * @return query string parameters\n */\nexport function queryParamsToRestQueryStringParameters(\n  queryParams: QueryParams\n): Record<string, string | number> {\n  const qs: Record<string, string | number> = {};\n\n  if (queryParams.isDefault()) {\n    return qs;\n  }\n\n  let orderBy;\n  if (queryParams.index_ === PRIORITY_INDEX) {\n    orderBy = REST_QUERY_CONSTANTS.PRIORITY_INDEX;\n  } else if (queryParams.index_ === VALUE_INDEX) {\n    orderBy = REST_QUERY_CONSTANTS.VALUE_INDEX;\n  } else if (queryParams.index_ === KEY_INDEX) {\n    orderBy = REST_QUERY_CONSTANTS.KEY_INDEX;\n  } else {\n    assert(queryParams.index_ instanceof PathIndex, 'Unrecognized index type!');\n    orderBy = queryParams.index_.toString();\n  }\n  qs[REST_QUERY_CONSTANTS.ORDER_BY] = stringify(orderBy);\n\n  if (queryParams.startSet_) {\n    qs[REST_QUERY_CONSTANTS.START_AT] = stringify(queryParams.indexStartValue_);\n    if (queryParams.startNameSet_) {\n      qs[REST_QUERY_CONSTANTS.START_AT] +=\n        ',' + stringify(queryParams.indexStartName_);\n    }\n  }\n\n  if (queryParams.endSet_) {\n    qs[REST_QUERY_CONSTANTS.END_AT] = stringify(queryParams.indexEndValue_);\n    if (queryParams.endNameSet_) {\n      qs[REST_QUERY_CONSTANTS.END_AT] +=\n        ',' + stringify(queryParams.indexEndName_);\n    }\n  }\n\n  if (queryParams.limitSet_) {\n    if (queryParams.isViewFromLeft()) {\n      qs[REST_QUERY_CONSTANTS.LIMIT_TO_FIRST] = queryParams.limit_;\n    } else {\n      qs[REST_QUERY_CONSTANTS.LIMIT_TO_LAST] = queryParams.limit_;\n    }\n  }\n\n  return qs;\n}\n\nexport function queryParamsGetQueryObject(\n  queryParams: QueryParams\n): Record<string, unknown> {\n  const obj: Record<string, unknown> = {};\n  if (queryParams.startSet_) {\n    obj[WIRE_PROTOCOL_CONSTANTS.INDEX_START_VALUE] =\n      queryParams.indexStartValue_;\n    if (queryParams.startNameSet_) {\n      obj[WIRE_PROTOCOL_CONSTANTS.INDEX_START_NAME] =\n        queryParams.indexStartName_;\n    }\n  }\n  if (queryParams.endSet_) {\n    obj[WIRE_PROTOCOL_CONSTANTS.INDEX_END_VALUE] = queryParams.indexEndValue_;\n    if (queryParams.endNameSet_) {\n      obj[WIRE_PROTOCOL_CONSTANTS.INDEX_END_NAME] = queryParams.indexEndName_;\n    }\n  }\n  if (queryParams.limitSet_) {\n    obj[WIRE_PROTOCOL_CONSTANTS.LIMIT] = queryParams.limit_;\n    let viewFrom = queryParams.viewFrom_;\n    if (viewFrom === '') {\n      if (queryParams.isViewFromLeft()) {\n        viewFrom = WIRE_PROTOCOL_CONSTANTS.VIEW_FROM_LEFT;\n      } else {\n        viewFrom = WIRE_PROTOCOL_CONSTANTS.VIEW_FROM_RIGHT;\n      }\n    }\n    obj[WIRE_PROTOCOL_CONSTANTS.VIEW_FROM] = viewFrom;\n  }\n  // For now, priority index is the default, so we only specify if it's some other index\n  if (queryParams.index_ !== PRIORITY_INDEX) {\n    obj[WIRE_PROTOCOL_CONSTANTS.INDEX] = queryParams.index_.toString();\n  }\n  return obj;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { IndexedFilter } from './filter/IndexedFilter';\nimport { ViewProcessor } from './ViewProcessor';\nimport { ChildrenNode } from '../snap/ChildrenNode';\nimport { CacheNode } from './CacheNode';\nimport { ViewCache } from './ViewCache';\nimport {\n  EventGenerator,\n  eventGeneratorGenerateEventsForChanges\n} from './EventGenerator';\nimport { assert } from '@firebase/util';\nimport { Operation, OperationType } from '../operation/Operation';\nimport { Change, changeChildAdded, changeValue } from './Change';\nimport { PRIORITY_INDEX } from '../snap/indexes/PriorityIndex';\nimport { Query } from '../../api/Query';\nimport { EventRegistration } from './EventRegistration';\nimport { Node } from '../snap/Node';\nimport { Path, pathGetFront, pathIsEmpty } from '../util/Path';\nimport { WriteTreeRef } from '../WriteTree';\nimport { CancelEvent, Event } from './Event';\nimport { queryParamsGetNodeFilter } from './QueryParams';\n\n/**\n * A view represents a specific location and query that has 1 or more event registrations.\n *\n * It does several things:\n *  - Maintains the list of event registrations for this location/query.\n *  - Maintains a cache of the data visible for this location/query.\n *  - Applies new operations (via applyOperation), updates the cache, and based on the event\n *    registrations returns the set of events to be raised.\n */\nexport class View {\n  private processor_: ViewProcessor;\n  private viewCache_: ViewCache;\n  private eventRegistrations_: EventRegistration[] = [];\n  private eventGenerator_: EventGenerator;\n\n  constructor(private query_: Query, initialViewCache: ViewCache) {\n    const params = this.query_.getQueryParams();\n\n    const indexFilter = new IndexedFilter(params.getIndex());\n    const filter = queryParamsGetNodeFilter(params);\n\n    this.processor_ = new ViewProcessor(filter);\n\n    const initialServerCache = initialViewCache.getServerCache();\n    const initialEventCache = initialViewCache.getEventCache();\n\n    // Don't filter server node with other filter than index, wait for tagged listen\n    const serverSnap = indexFilter.updateFullNode(\n      ChildrenNode.EMPTY_NODE,\n      initialServerCache.getNode(),\n      null\n    );\n    const eventSnap = filter.updateFullNode(\n      ChildrenNode.EMPTY_NODE,\n      initialEventCache.getNode(),\n      null\n    );\n    const newServerCache = new CacheNode(\n      serverSnap,\n      initialServerCache.isFullyInitialized(),\n      indexFilter.filtersNodes()\n    );\n    const newEventCache = new CacheNode(\n      eventSnap,\n      initialEventCache.isFullyInitialized(),\n      filter.filtersNodes()\n    );\n\n    this.viewCache_ = new ViewCache(newEventCache, newServerCache);\n    this.eventGenerator_ = new EventGenerator(this.query_);\n  }\n\n  getQuery(): Query {\n    return this.query_;\n  }\n\n  getServerCache(): Node | null {\n    return this.viewCache_.getServerCache().getNode();\n  }\n\n  getCompleteNode(): Node | null {\n    return this.viewCache_.getCompleteEventSnap();\n  }\n\n  getCompleteServerCache(path: Path): Node | null {\n    const cache = this.viewCache_.getCompleteServerSnap();\n    if (cache) {\n      // If this isn't a \"loadsAllData\" view, then cache isn't actually a complete cache and\n      // we need to see if it contains the child we're interested in.\n      if (\n        this.query_.getQueryParams().loadsAllData() ||\n        (!pathIsEmpty(path) &&\n          !cache.getImmediateChild(pathGetFront(path)).isEmpty())\n      ) {\n        return cache.getChild(path);\n      }\n    }\n    return null;\n  }\n\n  isEmpty(): boolean {\n    return this.eventRegistrations_.length === 0;\n  }\n\n  addEventRegistration(eventRegistration: EventRegistration) {\n    this.eventRegistrations_.push(eventRegistration);\n  }\n\n  /**\n   * @param eventRegistration If null, remove all callbacks.\n   * @param cancelError If a cancelError is provided, appropriate cancel events will be returned.\n   * @return Cancel events, if cancelError was provided.\n   */\n  removeEventRegistration(\n    eventRegistration: EventRegistration | null,\n    cancelError?: Error\n  ): Event[] {\n    const cancelEvents: CancelEvent[] = [];\n    if (cancelError) {\n      assert(\n        eventRegistration == null,\n        'A cancel should cancel all event registrations.'\n      );\n      const path = this.query_.path;\n      this.eventRegistrations_.forEach(registration => {\n        const maybeEvent = registration.createCancelEvent(cancelError, path);\n        if (maybeEvent) {\n          cancelEvents.push(maybeEvent);\n        }\n      });\n    }\n\n    if (eventRegistration) {\n      let remaining = [];\n      for (let i = 0; i < this.eventRegistrations_.length; ++i) {\n        const existing = this.eventRegistrations_[i];\n        if (!existing.matches(eventRegistration)) {\n          remaining.push(existing);\n        } else if (eventRegistration.hasAnyCallback()) {\n          // We're removing just this one\n          remaining = remaining.concat(this.eventRegistrations_.slice(i + 1));\n          break;\n        }\n      }\n      this.eventRegistrations_ = remaining;\n    } else {\n      this.eventRegistrations_ = [];\n    }\n    return cancelEvents;\n  }\n\n  /**\n   * Applies the given Operation, updates our cache, and returns the appropriate events.\n   */\n  applyOperation(\n    operation: Operation,\n    writesCache: WriteTreeRef,\n    completeServerCache: Node | null\n  ): Event[] {\n    if (\n      operation.type === OperationType.MERGE &&\n      operation.source.queryId !== null\n    ) {\n      assert(\n        this.viewCache_.getCompleteServerSnap(),\n        'We should always have a full cache before handling merges'\n      );\n      assert(\n        this.viewCache_.getCompleteEventSnap(),\n        'Missing event cache, even though we have a server cache'\n      );\n    }\n\n    const oldViewCache = this.viewCache_;\n    const result = this.processor_.applyOperation(\n      oldViewCache,\n      operation,\n      writesCache,\n      completeServerCache\n    );\n    this.processor_.assertIndexed(result.viewCache);\n\n    assert(\n      result.viewCache.getServerCache().isFullyInitialized() ||\n        !oldViewCache.getServerCache().isFullyInitialized(),\n      'Once a server snap is complete, it should never go back'\n    );\n\n    this.viewCache_ = result.viewCache;\n\n    return this.generateEventsForChanges_(\n      result.changes,\n      result.viewCache.getEventCache().getNode(),\n      null\n    );\n  }\n\n  getInitialEvents(registration: EventRegistration): Event[] {\n    const eventSnap = this.viewCache_.getEventCache();\n    const initialChanges: Change[] = [];\n    if (!eventSnap.getNode().isLeafNode()) {\n      const eventNode = eventSnap.getNode() as ChildrenNode;\n      eventNode.forEachChild(PRIORITY_INDEX, (key, childNode) => {\n        initialChanges.push(changeChildAdded(key, childNode));\n      });\n    }\n    if (eventSnap.isFullyInitialized()) {\n      initialChanges.push(changeValue(eventSnap.getNode()));\n    }\n    return this.generateEventsForChanges_(\n      initialChanges,\n      eventSnap.getNode(),\n      registration\n    );\n  }\n\n  generateEventsForChanges_(\n    changes: Change[],\n    eventCache: Node,\n    eventRegistration?: EventRegistration\n  ): Event[] {\n    const registrations = eventRegistration\n      ? [eventRegistration]\n      : this.eventRegistrations_;\n    return eventGeneratorGenerateEventsForChanges(\n      this.eventGenerator_,\n      changes,\n      eventCache,\n      registrations\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { CacheNode } from './view/CacheNode';\nimport { ChildrenNode } from './snap/ChildrenNode';\nimport { assert } from '@firebase/util';\nimport { ViewCache } from './view/ViewCache';\nimport { View } from './view/View';\nimport { Operation } from './operation/Operation';\nimport { WriteTreeRef } from './WriteTree';\nimport { Query } from '../api/Query';\nimport { EventRegistration } from './view/EventRegistration';\nimport { Node } from './snap/Node';\nimport { Path } from './util/Path';\nimport { Event } from './view/Event';\nimport { ReferenceConstructor } from '../api/Reference';\n\nlet referenceConstructor: ReferenceConstructor;\n\n/**\n * SyncPoint represents a single location in a SyncTree with 1 or more event registrations, meaning we need to\n * maintain 1 or more Views at this location to cache server data and raise appropriate events for server changes\n * and user writes (set, transaction, update).\n *\n * It's responsible for:\n *  - Maintaining the set of 1 or more views necessary at this location (a SyncPoint with 0 views should be removed).\n *  - Proxying user / server operations to the views as appropriate (i.e. applyServerOverwrite,\n *    applyUserOverwrite, etc.)\n */\nexport class SyncPoint {\n  /**\n   * The Views being tracked at this location in the tree, stored as a map where the key is a\n   * queryId and the value is the View for that query.\n   *\n   * NOTE: This list will be quite small (usually 1, but perhaps 2 or 3; any more is an odd use case).\n   */\n  readonly views: Map<string, View> = new Map();\n}\n\nexport function syncPointSetReferenceConstructor(\n  val: ReferenceConstructor\n): void {\n  assert(\n    !referenceConstructor,\n    '__referenceConstructor has already been defined'\n  );\n  referenceConstructor = val;\n}\n\nfunction syncPointGetReferenceConstructor(): ReferenceConstructor {\n  assert(referenceConstructor, 'Reference.ts has not been loaded');\n  return referenceConstructor;\n}\n\nexport function syncPointIsEmpty(syncPoint: SyncPoint): boolean {\n  return syncPoint.views.size === 0;\n}\n\nexport function syncPointApplyOperation(\n  syncPoint: SyncPoint,\n  operation: Operation,\n  writesCache: WriteTreeRef,\n  optCompleteServerCache: Node | null\n): Event[] {\n  const queryId = operation.source.queryId;\n  if (queryId !== null) {\n    const view = syncPoint.views.get(queryId);\n    assert(view != null, 'SyncTree gave us an op for an invalid query.');\n    return view.applyOperation(operation, writesCache, optCompleteServerCache);\n  } else {\n    let events: Event[] = [];\n\n    for (const view of syncPoint.views.values()) {\n      events = events.concat(\n        view.applyOperation(operation, writesCache, optCompleteServerCache)\n      );\n    }\n\n    return events;\n  }\n}\n\n/**\n * Get a view for the specified query.\n *\n * @param query The query to return a view for\n * @param writesCache\n * @param serverCache\n * @param serverCacheComplete\n * @return Events to raise.\n */\nexport function syncPointGetView(\n  syncPoint: SyncPoint,\n  query: Query,\n  writesCache: WriteTreeRef,\n  serverCache: Node | null,\n  serverCacheComplete: boolean\n): View {\n  const queryId = query.queryIdentifier();\n  const view = syncPoint.views.get(queryId);\n  if (!view) {\n    // TODO: make writesCache take flag for complete server node\n    let eventCache = writesCache.calcCompleteEventCache(\n      serverCacheComplete ? serverCache : null\n    );\n    let eventCacheComplete = false;\n    if (eventCache) {\n      eventCacheComplete = true;\n    } else if (serverCache instanceof ChildrenNode) {\n      eventCache = writesCache.calcCompleteEventChildren(serverCache);\n      eventCacheComplete = false;\n    } else {\n      eventCache = ChildrenNode.EMPTY_NODE;\n      eventCacheComplete = false;\n    }\n    const viewCache = new ViewCache(\n      new CacheNode(eventCache, eventCacheComplete, false),\n      new CacheNode(serverCache, serverCacheComplete, false)\n    );\n    return new View(query, viewCache);\n  }\n  return view;\n}\n\n/**\n * Add an event callback for the specified query.\n *\n * @param query\n * @param eventRegistration\n * @param writesCache\n * @param serverCache Complete server cache, if we have it.\n * @param serverCacheComplete\n * @return Events to raise.\n */\nexport function syncPointAddEventRegistration(\n  syncPoint: SyncPoint,\n  query: Query,\n  eventRegistration: EventRegistration,\n  writesCache: WriteTreeRef,\n  serverCache: Node | null,\n  serverCacheComplete: boolean\n): Event[] {\n  const view = syncPointGetView(\n    syncPoint,\n    query,\n    writesCache,\n    serverCache,\n    serverCacheComplete\n  );\n  if (!syncPoint.views.has(query.queryIdentifier())) {\n    syncPoint.views.set(query.queryIdentifier(), view);\n  }\n  // This is guaranteed to exist now, we just created anything that was missing\n  view.addEventRegistration(eventRegistration);\n  return view.getInitialEvents(eventRegistration);\n}\n\n/**\n * Remove event callback(s).  Return cancelEvents if a cancelError is specified.\n *\n * If query is the default query, we'll check all views for the specified eventRegistration.\n * If eventRegistration is null, we'll remove all callbacks for the specified view(s).\n *\n * @param eventRegistration If null, remove all callbacks.\n * @param cancelError If a cancelError is provided, appropriate cancel events will be returned.\n * @return removed queries and any cancel events\n */\nexport function syncPointRemoveEventRegistration(\n  syncPoint: SyncPoint,\n  query: Query,\n  eventRegistration: EventRegistration | null,\n  cancelError?: Error\n): { removed: Query[]; events: Event[] } {\n  const queryId = query.queryIdentifier();\n  const removed: Query[] = [];\n  let cancelEvents: Event[] = [];\n  const hadCompleteView = syncPointHasCompleteView(syncPoint);\n  if (queryId === 'default') {\n    // When you do ref.off(...), we search all views for the registration to remove.\n    for (const [viewQueryId, view] of syncPoint.views.entries()) {\n      cancelEvents = cancelEvents.concat(\n        view.removeEventRegistration(eventRegistration, cancelError)\n      );\n      if (view.isEmpty()) {\n        syncPoint.views.delete(viewQueryId);\n\n        // We'll deal with complete views later.\n        if (!view.getQuery().getQueryParams().loadsAllData()) {\n          removed.push(view.getQuery());\n        }\n      }\n    }\n  } else {\n    // remove the callback from the specific view.\n    const view = syncPoint.views.get(queryId);\n    if (view) {\n      cancelEvents = cancelEvents.concat(\n        view.removeEventRegistration(eventRegistration, cancelError)\n      );\n      if (view.isEmpty()) {\n        syncPoint.views.delete(queryId);\n\n        // We'll deal with complete views later.\n        if (!view.getQuery().getQueryParams().loadsAllData()) {\n          removed.push(view.getQuery());\n        }\n      }\n    }\n  }\n\n  if (hadCompleteView && !syncPointHasCompleteView(syncPoint)) {\n    // We removed our last complete view.\n    removed.push(\n      new (syncPointGetReferenceConstructor())(query.repo, query.path)\n    );\n  }\n\n  return { removed, events: cancelEvents };\n}\n\nexport function syncPointGetQueryViews(syncPoint: SyncPoint): View[] {\n  const result = [];\n  for (const view of syncPoint.views.values()) {\n    if (!view.getQuery().getQueryParams().loadsAllData()) {\n      result.push(view);\n    }\n  }\n  return result;\n}\n\n/**\n * @param path The path to the desired complete snapshot\n * @return A complete cache, if it exists\n */\nexport function syncPointGetCompleteServerCache(\n  syncPoint: SyncPoint,\n  path: Path\n): Node | null {\n  let serverCache: Node | null = null;\n  for (const view of syncPoint.views.values()) {\n    serverCache = serverCache || view.getCompleteServerCache(path);\n  }\n  return serverCache;\n}\n\nexport function syncPointViewForQuery(\n  syncPoint: SyncPoint,\n  query: Query\n): View | null {\n  const params = query.getQueryParams();\n  if (params.loadsAllData()) {\n    return syncPointGetCompleteView(syncPoint);\n  } else {\n    const queryId = query.queryIdentifier();\n    return syncPoint.views.get(queryId);\n  }\n}\n\nexport function syncPointViewExistsForQuery(\n  syncPoint: SyncPoint,\n  query: Query\n): boolean {\n  return syncPointViewForQuery(syncPoint, query) != null;\n}\n\nexport function syncPointHasCompleteView(syncPoint: SyncPoint): boolean {\n  return syncPointGetCompleteView(syncPoint) != null;\n}\n\nexport function syncPointGetCompleteView(syncPoint: SyncPoint): View | null {\n  for (const view of syncPoint.views.values()) {\n    if (view.getQuery().getQueryParams().loadsAllData()) {\n      return view;\n    }\n  }\n  return null;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ImmutableTree } from './util/ImmutableTree';\nimport {\n  newEmptyPath,\n  newRelativePath,\n  Path,\n  pathChild,\n  pathIsEmpty\n} from './util/Path';\nimport { NamedNode, Node } from './snap/Node';\nimport { PRIORITY_INDEX } from './snap/indexes/PriorityIndex';\nimport { assert } from '@firebase/util';\nimport { ChildrenNode } from './snap/ChildrenNode';\nimport { each } from './util/util';\n\n/**\n * This class holds a collection of writes that can be applied to nodes in unison. It abstracts away the logic with\n * dealing with priority writes and multiple nested writes. At any given path there is only allowed to be one write\n * modifying that path. Any write to an existing path or shadowing an existing path will modify that existing write\n * to reflect the write added.\n */\nexport class CompoundWrite {\n  constructor(public writeTree_: ImmutableTree<Node>) {}\n\n  static empty(): CompoundWrite {\n    return new CompoundWrite(new ImmutableTree(null));\n  }\n}\n\nexport function compoundWriteAddWrite(\n  compoundWrite: CompoundWrite,\n  path: Path,\n  node: Node\n): CompoundWrite {\n  if (pathIsEmpty(path)) {\n    return new CompoundWrite(new ImmutableTree(node));\n  } else {\n    const rootmost = compoundWrite.writeTree_.findRootMostValueAndPath(path);\n    if (rootmost != null) {\n      const rootMostPath = rootmost.path;\n      let value = rootmost.value;\n      const relativePath = newRelativePath(rootMostPath, path);\n      value = value.updateChild(relativePath, node);\n      return new CompoundWrite(\n        compoundWrite.writeTree_.set(rootMostPath, value)\n      );\n    } else {\n      const subtree = new ImmutableTree(node);\n      const newWriteTree = compoundWrite.writeTree_.setTree(path, subtree);\n      return new CompoundWrite(newWriteTree);\n    }\n  }\n}\n\nexport function compoundWriteAddWrites(\n  compoundWrite: CompoundWrite,\n  path: Path,\n  updates: { [name: string]: Node }\n): CompoundWrite {\n  let newWrite = compoundWrite;\n  each(updates, (childKey: string, node: Node) => {\n    newWrite = compoundWriteAddWrite(newWrite, pathChild(path, childKey), node);\n  });\n  return newWrite;\n}\n\n/**\n * Will remove a write at the given path and deeper paths. This will <em>not</em> modify a write at a higher\n * location, which must be removed by calling this method with that path.\n *\n * @param compoundWrite The CompoundWrite to remove.\n * @param path The path at which a write and all deeper writes should be removed\n * @return The new CompoundWrite with the removed path\n */\nexport function compoundWriteRemoveWrite(\n  compoundWrite: CompoundWrite,\n  path: Path\n): CompoundWrite {\n  if (pathIsEmpty(path)) {\n    return CompoundWrite.empty();\n  } else {\n    const newWriteTree = compoundWrite.writeTree_.setTree(\n      path,\n      new ImmutableTree<Node>(null)\n    );\n    return new CompoundWrite(newWriteTree);\n  }\n}\n\n/**\n * Returns whether this CompoundWrite will fully overwrite a node at a given location and can therefore be\n * considered \"complete\".\n *\n * @param compoundWrite The CompoundWrite to check.\n * @param path The path to check for\n * @return Whether there is a complete write at that path\n */\nexport function compoundWriteHasCompleteWrite(\n  compoundWrite: CompoundWrite,\n  path: Path\n): boolean {\n  return compoundWriteGetCompleteNode(compoundWrite, path) != null;\n}\n\n/**\n * Returns a node for a path if and only if the node is a \"complete\" overwrite at that path. This will not aggregate\n * writes from deeper paths, but will return child nodes from a more shallow path.\n *\n * @param compoundWrite The CompoundWrite to get the node from.\n * @param path The path to get a complete write\n * @return The node if complete at that path, or null otherwise.\n */\nexport function compoundWriteGetCompleteNode(\n  compoundWrite: CompoundWrite,\n  path: Path\n): Node | null {\n  const rootmost = compoundWrite.writeTree_.findRootMostValueAndPath(path);\n  if (rootmost != null) {\n    return compoundWrite.writeTree_\n      .get(rootmost.path)\n      .getChild(newRelativePath(rootmost.path, path));\n  } else {\n    return null;\n  }\n}\n\n/**\n * Returns all children that are guaranteed to be a complete overwrite.\n *\n * @param compoundWrite The CompoundWrite to get children from.\n * @return A list of all complete children.\n */\nexport function compoundWriteGetCompleteChildren(\n  compoundWrite: CompoundWrite\n): NamedNode[] {\n  const children: NamedNode[] = [];\n  const node = compoundWrite.writeTree_.value;\n  if (node != null) {\n    // If it's a leaf node, it has no children; so nothing to do.\n    if (!node.isLeafNode()) {\n      (node as ChildrenNode).forEachChild(\n        PRIORITY_INDEX,\n        (childName, childNode) => {\n          children.push(new NamedNode(childName, childNode));\n        }\n      );\n    }\n  } else {\n    compoundWrite.writeTree_.children.inorderTraversal(\n      (childName, childTree) => {\n        if (childTree.value != null) {\n          children.push(new NamedNode(childName, childTree.value));\n        }\n      }\n    );\n  }\n  return children;\n}\n\nexport function compoundWriteChildCompoundWrite(\n  compoundWrite: CompoundWrite,\n  path: Path\n): CompoundWrite {\n  if (pathIsEmpty(path)) {\n    return compoundWrite;\n  } else {\n    const shadowingNode = compoundWriteGetCompleteNode(compoundWrite, path);\n    if (shadowingNode != null) {\n      return new CompoundWrite(new ImmutableTree(shadowingNode));\n    } else {\n      return new CompoundWrite(compoundWrite.writeTree_.subtree(path));\n    }\n  }\n}\n\n/**\n * Returns true if this CompoundWrite is empty and therefore does not modify any nodes.\n * @return Whether this CompoundWrite is empty\n */\nexport function compoundWriteIsEmpty(compoundWrite: CompoundWrite): boolean {\n  return compoundWrite.writeTree_.isEmpty();\n}\n\n/**\n * Applies this CompoundWrite to a node. The node is returned with all writes from this CompoundWrite applied to the\n * node\n * @param node The node to apply this CompoundWrite to\n * @return The node with all writes applied\n */\nexport function compoundWriteApply(\n  compoundWrite: CompoundWrite,\n  node: Node\n): Node {\n  return applySubtreeWrite(newEmptyPath(), compoundWrite.writeTree_, node);\n}\n\nfunction applySubtreeWrite(\n  relativePath: Path,\n  writeTree: ImmutableTree<Node>,\n  node: Node\n): Node {\n  if (writeTree.value != null) {\n    // Since there a write is always a leaf, we're done here\n    return node.updateChild(relativePath, writeTree.value);\n  } else {\n    let priorityWrite = null;\n    writeTree.children.inorderTraversal((childKey, childTree) => {\n      if (childKey === '.priority') {\n        // Apply priorities at the end so we don't update priorities for either empty nodes or forget\n        // to apply priorities to empty nodes that are later filled\n        assert(\n          childTree.value !== null,\n          'Priority writes must always be leaf nodes'\n        );\n        priorityWrite = childTree.value;\n      } else {\n        node = applySubtreeWrite(\n          pathChild(relativePath, childKey),\n          childTree,\n          node\n        );\n      }\n    });\n    // If there was a priority write, we only apply it if the node is not empty\n    if (!node.getChild(relativePath).isEmpty() && priorityWrite !== null) {\n      node = node.updateChild(\n        pathChild(relativePath, '.priority'),\n        priorityWrite\n      );\n    }\n    return node;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert, assertionError, safeGet } from '@firebase/util';\n\nimport {\n  newEmptyPath,\n  newRelativePath,\n  Path,\n  pathChild,\n  pathContains,\n  pathGetFront,\n  pathIsEmpty,\n  pathPopFront\n} from './util/Path';\nimport {\n  CompoundWrite,\n  compoundWriteAddWrite,\n  compoundWriteAddWrites,\n  compoundWriteApply,\n  compoundWriteChildCompoundWrite,\n  compoundWriteGetCompleteChildren,\n  compoundWriteGetCompleteNode,\n  compoundWriteHasCompleteWrite,\n  compoundWriteIsEmpty,\n  compoundWriteRemoveWrite\n} from './CompoundWrite';\nimport { PRIORITY_INDEX } from './snap/indexes/PriorityIndex';\nimport { ChildrenNode } from './snap/ChildrenNode';\nimport { NamedNode, Node } from './snap/Node';\nimport { CacheNode } from './view/CacheNode';\nimport { Index } from './snap/indexes/Index';\nimport { each } from './util/util';\n\n/**\n * Defines a single user-initiated write operation. May be the result of a set(), transaction(), or update() call. In\n * the case of a set() or transaction, snap wil be non-null.  In the case of an update(), children will be non-null.\n */\nexport interface WriteRecord {\n  writeId: number;\n  path: Path;\n  snap?: Node | null;\n  children?: { [k: string]: Node } | null;\n  visible: boolean;\n}\n\n/**\n * WriteTree tracks all pending user-initiated writes and has methods to calculate the result of merging them\n * with underlying server data (to create \"event cache\" data).  Pending writes are added with addOverwrite()\n * and addMerge(), and removed with removeWrite().\n */\nexport class WriteTree {\n  /**\n   * A tree tracking the result of applying all visible writes.  This does not include transactions with\n   * applyLocally=false or writes that are completely shadowed by other writes.\n   */\n  private visibleWrites_: CompoundWrite = CompoundWrite.empty();\n\n  /**\n   * A list of all pending writes, regardless of visibility and shadowed-ness.  Used to calculate arbitrary\n   * sets of the changed data, such as hidden writes (from transactions) or changes with certain writes excluded (also\n   * used by transactions).\n   */\n  private allWrites_: WriteRecord[] = [];\n\n  private lastWriteId_ = -1;\n\n  /**\n   * Create a new WriteTreeRef for the given path. For use with a new sync point at the given path.\n   *\n   */\n  childWrites(path: Path): WriteTreeRef {\n    return new WriteTreeRef(path, this);\n  }\n\n  /**\n   * Record a new overwrite from user code.\n   *\n   * @param visible This is set to false by some transactions. It should be excluded from event caches\n   */\n  addOverwrite(path: Path, snap: Node, writeId: number, visible?: boolean) {\n    assert(\n      writeId > this.lastWriteId_,\n      'Stacking an older write on top of newer ones'\n    );\n    if (visible === undefined) {\n      visible = true;\n    }\n    this.allWrites_.push({\n      path,\n      snap,\n      writeId,\n      visible\n    });\n\n    if (visible) {\n      this.visibleWrites_ = compoundWriteAddWrite(\n        this.visibleWrites_,\n        path,\n        snap\n      );\n    }\n    this.lastWriteId_ = writeId;\n  }\n\n  /**\n   * Record a new merge from user code.\n   */\n  addMerge(\n    path: Path,\n    changedChildren: { [k: string]: Node },\n    writeId: number\n  ) {\n    assert(\n      writeId > this.lastWriteId_,\n      'Stacking an older merge on top of newer ones'\n    );\n    this.allWrites_.push({\n      path,\n      children: changedChildren,\n      writeId,\n      visible: true\n    });\n\n    this.visibleWrites_ = compoundWriteAddWrites(\n      this.visibleWrites_,\n      path,\n      changedChildren\n    );\n    this.lastWriteId_ = writeId;\n  }\n\n  getWrite(writeId: number): WriteRecord | null {\n    for (let i = 0; i < this.allWrites_.length; i++) {\n      const record = this.allWrites_[i];\n      if (record.writeId === writeId) {\n        return record;\n      }\n    }\n    return null;\n  }\n\n  /**\n   * Remove a write (either an overwrite or merge) that has been successfully acknowledge by the server. Recalculates\n   * the tree if necessary.  We return true if it may have been visible, meaning views need to reevaluate.\n   *\n   * @return true if the write may have been visible (meaning we'll need to reevaluate / raise\n   * events as a result).\n   */\n  removeWrite(writeId: number): boolean {\n    // Note: disabling this check. It could be a transaction that preempted another transaction, and thus was applied\n    // out of order.\n    //const validClear = revert || this.allWrites_.length === 0 || writeId <= this.allWrites_[0].writeId;\n    //assert(validClear, \"Either we don't have this write, or it's the first one in the queue\");\n\n    const idx = this.allWrites_.findIndex(s => {\n      return s.writeId === writeId;\n    });\n    assert(idx >= 0, 'removeWrite called with nonexistent writeId.');\n    const writeToRemove = this.allWrites_[idx];\n    this.allWrites_.splice(idx, 1);\n\n    let removedWriteWasVisible = writeToRemove.visible;\n    let removedWriteOverlapsWithOtherWrites = false;\n\n    let i = this.allWrites_.length - 1;\n\n    while (removedWriteWasVisible && i >= 0) {\n      const currentWrite = this.allWrites_[i];\n      if (currentWrite.visible) {\n        if (\n          i >= idx &&\n          this.recordContainsPath_(currentWrite, writeToRemove.path)\n        ) {\n          // The removed write was completely shadowed by a subsequent write.\n          removedWriteWasVisible = false;\n        } else if (pathContains(writeToRemove.path, currentWrite.path)) {\n          // Either we're covering some writes or they're covering part of us (depending on which came first).\n          removedWriteOverlapsWithOtherWrites = true;\n        }\n      }\n      i--;\n    }\n\n    if (!removedWriteWasVisible) {\n      return false;\n    } else if (removedWriteOverlapsWithOtherWrites) {\n      // There's some shadowing going on. Just rebuild the visible writes from scratch.\n      this.resetTree_();\n      return true;\n    } else {\n      // There's no shadowing.  We can safely just remove the write(s) from visibleWrites.\n      if (writeToRemove.snap) {\n        this.visibleWrites_ = compoundWriteRemoveWrite(\n          this.visibleWrites_,\n          writeToRemove.path\n        );\n      } else {\n        const children = writeToRemove.children;\n        each(children, (childName: string) => {\n          this.visibleWrites_ = compoundWriteRemoveWrite(\n            this.visibleWrites_,\n            pathChild(writeToRemove.path, childName)\n          );\n        });\n      }\n      return true;\n    }\n  }\n\n  /**\n   * Return a complete snapshot for the given path if there's visible write data at that path, else null.\n   * No server data is considered.\n   *\n   */\n  getCompleteWriteData(path: Path): Node | null {\n    return compoundWriteGetCompleteNode(this.visibleWrites_, path);\n  }\n\n  /**\n   * Given optional, underlying server data, and an optional set of constraints (exclude some sets, include hidden\n   * writes), attempt to calculate a complete snapshot for the given path\n   *\n   * @param writeIdsToExclude An optional set to be excluded\n   * @param includeHiddenWrites Defaults to false, whether or not to layer on writes with visible set to false\n   */\n  calcCompleteEventCache(\n    treePath: Path,\n    completeServerCache: Node | null,\n    writeIdsToExclude?: number[],\n    includeHiddenWrites?: boolean\n  ): Node | null {\n    if (!writeIdsToExclude && !includeHiddenWrites) {\n      const shadowingNode = compoundWriteGetCompleteNode(\n        this.visibleWrites_,\n        treePath\n      );\n      if (shadowingNode != null) {\n        return shadowingNode;\n      } else {\n        const subMerge = compoundWriteChildCompoundWrite(\n          this.visibleWrites_,\n          treePath\n        );\n        if (compoundWriteIsEmpty(subMerge)) {\n          return completeServerCache;\n        } else if (\n          completeServerCache == null &&\n          !compoundWriteHasCompleteWrite(subMerge, newEmptyPath())\n        ) {\n          // We wouldn't have a complete snapshot, since there's no underlying data and no complete shadow\n          return null;\n        } else {\n          const layeredCache = completeServerCache || ChildrenNode.EMPTY_NODE;\n          return compoundWriteApply(subMerge, layeredCache);\n        }\n      }\n    } else {\n      const merge = compoundWriteChildCompoundWrite(\n        this.visibleWrites_,\n        treePath\n      );\n      if (!includeHiddenWrites && compoundWriteIsEmpty(merge)) {\n        return completeServerCache;\n      } else {\n        // If the server cache is null, and we don't have a complete cache, we need to return null\n        if (\n          !includeHiddenWrites &&\n          completeServerCache == null &&\n          !compoundWriteHasCompleteWrite(merge, newEmptyPath())\n        ) {\n          return null;\n        } else {\n          const filter = function (write: WriteRecord) {\n            return (\n              (write.visible || includeHiddenWrites) &&\n              (!writeIdsToExclude ||\n                !~writeIdsToExclude.indexOf(write.writeId)) &&\n              (pathContains(write.path, treePath) ||\n                pathContains(treePath, write.path))\n            );\n          };\n          const mergeAtPath = WriteTree.layerTree_(\n            this.allWrites_,\n            filter,\n            treePath\n          );\n          const layeredCache = completeServerCache || ChildrenNode.EMPTY_NODE;\n          return compoundWriteApply(mergeAtPath, layeredCache);\n        }\n      }\n    }\n  }\n\n  /**\n   * With optional, underlying server data, attempt to return a children node of children that we have complete data for.\n   * Used when creating new views, to pre-fill their complete event children snapshot.\n   */\n  calcCompleteEventChildren(\n    treePath: Path,\n    completeServerChildren: ChildrenNode | null\n  ) {\n    let completeChildren = ChildrenNode.EMPTY_NODE as Node;\n    const topLevelSet = compoundWriteGetCompleteNode(\n      this.visibleWrites_,\n      treePath\n    );\n    if (topLevelSet) {\n      if (!topLevelSet.isLeafNode()) {\n        // we're shadowing everything. Return the children.\n        topLevelSet.forEachChild(PRIORITY_INDEX, (childName, childSnap) => {\n          completeChildren = completeChildren.updateImmediateChild(\n            childName,\n            childSnap\n          );\n        });\n      }\n      return completeChildren;\n    } else if (completeServerChildren) {\n      // Layer any children we have on top of this\n      // We know we don't have a top-level set, so just enumerate existing children\n      const merge = compoundWriteChildCompoundWrite(\n        this.visibleWrites_,\n        treePath\n      );\n      completeServerChildren.forEachChild(\n        PRIORITY_INDEX,\n        (childName, childNode) => {\n          const node = compoundWriteApply(\n            compoundWriteChildCompoundWrite(merge, new Path(childName)),\n            childNode\n          );\n          completeChildren = completeChildren.updateImmediateChild(\n            childName,\n            node\n          );\n        }\n      );\n      // Add any complete children we have from the set\n      compoundWriteGetCompleteChildren(merge).forEach(namedNode => {\n        completeChildren = completeChildren.updateImmediateChild(\n          namedNode.name,\n          namedNode.node\n        );\n      });\n      return completeChildren;\n    } else {\n      // We don't have anything to layer on top of. Layer on any children we have\n      // Note that we can return an empty snap if we have a defined delete\n      const merge = compoundWriteChildCompoundWrite(\n        this.visibleWrites_,\n        treePath\n      );\n      compoundWriteGetCompleteChildren(merge).forEach(namedNode => {\n        completeChildren = completeChildren.updateImmediateChild(\n          namedNode.name,\n          namedNode.node\n        );\n      });\n      return completeChildren;\n    }\n  }\n\n  /**\n   * Given that the underlying server data has updated, determine what, if anything, needs to be\n   * applied to the event cache.\n   *\n   * Possibilities:\n   *\n   * 1. No writes are shadowing. Events should be raised, the snap to be applied comes from the server data\n   *\n   * 2. Some write is completely shadowing. No events to be raised\n   *\n   * 3. Is partially shadowed. Events\n   *\n   * Either existingEventSnap or existingServerSnap must exist\n   */\n  calcEventCacheAfterServerOverwrite(\n    treePath: Path,\n    childPath: Path,\n    existingEventSnap: Node | null,\n    existingServerSnap: Node | null\n  ): Node | null {\n    assert(\n      existingEventSnap || existingServerSnap,\n      'Either existingEventSnap or existingServerSnap must exist'\n    );\n    const path = pathChild(treePath, childPath);\n    if (compoundWriteHasCompleteWrite(this.visibleWrites_, path)) {\n      // At this point we can probably guarantee that we're in case 2, meaning no events\n      // May need to check visibility while doing the findRootMostValueAndPath call\n      return null;\n    } else {\n      // No complete shadowing. We're either partially shadowing or not shadowing at all.\n      const childMerge = compoundWriteChildCompoundWrite(\n        this.visibleWrites_,\n        path\n      );\n      if (compoundWriteIsEmpty(childMerge)) {\n        // We're not shadowing at all. Case 1\n        return existingServerSnap.getChild(childPath);\n      } else {\n        // This could be more efficient if the serverNode + updates doesn't change the eventSnap\n        // However this is tricky to find out, since user updates don't necessary change the server\n        // snap, e.g. priority updates on empty nodes, or deep deletes. Another special case is if the server\n        // adds nodes, but doesn't change any existing writes. It is therefore not enough to\n        // only check if the updates change the serverNode.\n        // Maybe check if the merge tree contains these special cases and only do a full overwrite in that case?\n        return compoundWriteApply(\n          childMerge,\n          existingServerSnap.getChild(childPath)\n        );\n      }\n    }\n  }\n\n  /**\n   * Returns a complete child for a given server snap after applying all user writes or null if there is no\n   * complete child for this ChildKey.\n   */\n  calcCompleteChild(\n    treePath: Path,\n    childKey: string,\n    existingServerSnap: CacheNode\n  ): Node | null {\n    const path = pathChild(treePath, childKey);\n    const shadowingNode = compoundWriteGetCompleteNode(\n      this.visibleWrites_,\n      path\n    );\n    if (shadowingNode != null) {\n      return shadowingNode;\n    } else {\n      if (existingServerSnap.isCompleteForChild(childKey)) {\n        const childMerge = compoundWriteChildCompoundWrite(\n          this.visibleWrites_,\n          path\n        );\n        return compoundWriteApply(\n          childMerge,\n          existingServerSnap.getNode().getImmediateChild(childKey)\n        );\n      } else {\n        return null;\n      }\n    }\n  }\n\n  /**\n   * Returns a node if there is a complete overwrite for this path. More specifically, if there is a write at\n   * a higher path, this will return the child of that write relative to the write and this path.\n   * Returns null if there is no write at this path.\n   */\n  shadowingWrite(path: Path): Node | null {\n    return compoundWriteGetCompleteNode(this.visibleWrites_, path);\n  }\n\n  /**\n   * This method is used when processing child remove events on a query. If we can, we pull in children that were outside\n   * the window, but may now be in the window.\n   */\n  calcIndexedSlice(\n    treePath: Path,\n    completeServerData: Node | null,\n    startPost: NamedNode,\n    count: number,\n    reverse: boolean,\n    index: Index\n  ): NamedNode[] {\n    let toIterate: Node;\n    const merge = compoundWriteChildCompoundWrite(\n      this.visibleWrites_,\n      treePath\n    );\n    const shadowingNode = compoundWriteGetCompleteNode(merge, newEmptyPath());\n    if (shadowingNode != null) {\n      toIterate = shadowingNode;\n    } else if (completeServerData != null) {\n      toIterate = compoundWriteApply(merge, completeServerData);\n    } else {\n      // no children to iterate on\n      return [];\n    }\n    toIterate = toIterate.withIndex(index);\n    if (!toIterate.isEmpty() && !toIterate.isLeafNode()) {\n      const nodes = [];\n      const cmp = index.getCompare();\n      const iter = reverse\n        ? (toIterate as ChildrenNode).getReverseIteratorFrom(startPost, index)\n        : (toIterate as ChildrenNode).getIteratorFrom(startPost, index);\n      let next = iter.getNext();\n      while (next && nodes.length < count) {\n        if (cmp(next, startPost) !== 0) {\n          nodes.push(next);\n        }\n        next = iter.getNext();\n      }\n      return nodes;\n    } else {\n      return [];\n    }\n  }\n\n  private recordContainsPath_(writeRecord: WriteRecord, path: Path): boolean {\n    if (writeRecord.snap) {\n      return pathContains(writeRecord.path, path);\n    } else {\n      for (const childName in writeRecord.children) {\n        if (\n          writeRecord.children.hasOwnProperty(childName) &&\n          pathContains(pathChild(writeRecord.path, childName), path)\n        ) {\n          return true;\n        }\n      }\n      return false;\n    }\n  }\n\n  /**\n   * Re-layer the writes and merges into a tree so we can efficiently calculate event snapshots\n   */\n  private resetTree_() {\n    this.visibleWrites_ = WriteTree.layerTree_(\n      this.allWrites_,\n      WriteTree.DefaultFilter_,\n      newEmptyPath()\n    );\n    if (this.allWrites_.length > 0) {\n      this.lastWriteId_ = this.allWrites_[this.allWrites_.length - 1].writeId;\n    } else {\n      this.lastWriteId_ = -1;\n    }\n  }\n\n  /**\n   * The default filter used when constructing the tree. Keep everything that's visible.\n   */\n  private static DefaultFilter_(write: WriteRecord) {\n    return write.visible;\n  }\n\n  /**\n   * Static method. Given an array of WriteRecords, a filter for which ones to include, and a path, construct the tree of\n   * event data at that path.\n   */\n  private static layerTree_(\n    writes: WriteRecord[],\n    filter: (w: WriteRecord) => boolean,\n    treeRoot: Path\n  ): CompoundWrite {\n    let compoundWrite = CompoundWrite.empty();\n    for (let i = 0; i < writes.length; ++i) {\n      const write = writes[i];\n      // Theory, a later set will either:\n      // a) abort a relevant transaction, so no need to worry about excluding it from calculating that transaction\n      // b) not be relevant to a transaction (separate branch), so again will not affect the data for that transaction\n      if (filter(write)) {\n        const writePath = write.path;\n        let relativePath: Path;\n        if (write.snap) {\n          if (pathContains(treeRoot, writePath)) {\n            relativePath = newRelativePath(treeRoot, writePath);\n            compoundWrite = compoundWriteAddWrite(\n              compoundWrite,\n              relativePath,\n              write.snap\n            );\n          } else if (pathContains(writePath, treeRoot)) {\n            relativePath = newRelativePath(writePath, treeRoot);\n            compoundWrite = compoundWriteAddWrite(\n              compoundWrite,\n              newEmptyPath(),\n              write.snap.getChild(relativePath)\n            );\n          } else {\n            // There is no overlap between root path and write path, ignore write\n          }\n        } else if (write.children) {\n          if (pathContains(treeRoot, writePath)) {\n            relativePath = newRelativePath(treeRoot, writePath);\n            compoundWrite = compoundWriteAddWrites(\n              compoundWrite,\n              relativePath,\n              write.children\n            );\n          } else if (pathContains(writePath, treeRoot)) {\n            relativePath = newRelativePath(writePath, treeRoot);\n            if (pathIsEmpty(relativePath)) {\n              compoundWrite = compoundWriteAddWrites(\n                compoundWrite,\n                newEmptyPath(),\n                write.children\n              );\n            } else {\n              const child = safeGet(write.children, pathGetFront(relativePath));\n              if (child) {\n                // There exists a child in this node that matches the root path\n                const deepNode = child.getChild(pathPopFront(relativePath));\n                compoundWrite = compoundWriteAddWrite(\n                  compoundWrite,\n                  newEmptyPath(),\n                  deepNode\n                );\n              }\n            }\n          } else {\n            // There is no overlap between root path and write path, ignore write\n          }\n        } else {\n          throw assertionError('WriteRecord should have .snap or .children');\n        }\n      }\n    }\n    return compoundWrite;\n  }\n}\n\n/**\n * A WriteTreeRef wraps a WriteTree and a path, for convenient access to a particular subtree.  All of the methods\n * just proxy to the underlying WriteTree.\n *\n */\nexport class WriteTreeRef {\n  /**\n   * The path to this particular write tree ref. Used for calling methods on writeTree_ while exposing a simpler\n   * interface to callers.\n   */\n  private readonly treePath_: Path;\n\n  /**\n   * * A reference to the actual tree of write data. All methods are pass-through to the tree, but with the appropriate\n   * path prefixed.\n   *\n   * This lets us make cheap references to points in the tree for sync points without having to copy and maintain all of\n   * the data.\n   */\n  private readonly writeTree_: WriteTree;\n\n  constructor(path: Path, writeTree: WriteTree) {\n    this.treePath_ = path;\n    this.writeTree_ = writeTree;\n  }\n\n  /**\n   * If possible, returns a complete event cache, using the underlying server data if possible. In addition, can be used\n   * to get a cache that includes hidden writes, and excludes arbitrary writes. Note that customizing the returned node\n   * can lead to a more expensive calculation.\n   *\n   * @param writeIdsToExclude Optional writes to exclude.\n   * @param includeHiddenWrites Defaults to false, whether or not to layer on writes with visible set to false\n   */\n  calcCompleteEventCache(\n    completeServerCache: Node | null,\n    writeIdsToExclude?: number[],\n    includeHiddenWrites?: boolean\n  ): Node | null {\n    return this.writeTree_.calcCompleteEventCache(\n      this.treePath_,\n      completeServerCache,\n      writeIdsToExclude,\n      includeHiddenWrites\n    );\n  }\n\n  /**\n   * If possible, returns a children node containing all of the complete children we have data for. The returned data is a\n   * mix of the given server data and write data.\n   *\n   */\n  calcCompleteEventChildren(\n    completeServerChildren: ChildrenNode | null\n  ): ChildrenNode {\n    return this.writeTree_.calcCompleteEventChildren(\n      this.treePath_,\n      completeServerChildren\n    ) as ChildrenNode;\n  }\n\n  /**\n   * Given that either the underlying server data has updated or the outstanding writes have updated, determine what,\n   * if anything, needs to be applied to the event cache.\n   *\n   * Possibilities:\n   *\n   * 1. No writes are shadowing. Events should be raised, the snap to be applied comes from the server data\n   *\n   * 2. Some write is completely shadowing. No events to be raised\n   *\n   * 3. Is partially shadowed. Events should be raised\n   *\n   * Either existingEventSnap or existingServerSnap must exist, this is validated via an assert\n   *\n   *\n   */\n  calcEventCacheAfterServerOverwrite(\n    path: Path,\n    existingEventSnap: Node | null,\n    existingServerSnap: Node | null\n  ): Node | null {\n    return this.writeTree_.calcEventCacheAfterServerOverwrite(\n      this.treePath_,\n      path,\n      existingEventSnap,\n      existingServerSnap\n    );\n  }\n\n  /**\n   * Returns a node if there is a complete overwrite for this path. More specifically, if there is a write at\n   * a higher path, this will return the child of that write relative to the write and this path.\n   * Returns null if there is no write at this path.\n   *\n   */\n  shadowingWrite(path: Path): Node | null {\n    return this.writeTree_.shadowingWrite(pathChild(this.treePath_, path));\n  }\n\n  /**\n   * This method is used when processing child remove events on a query. If we can, we pull in children that were outside\n   * the window, but may now be in the window\n   */\n  calcIndexedSlice(\n    completeServerData: Node | null,\n    startPost: NamedNode,\n    count: number,\n    reverse: boolean,\n    index: Index\n  ): NamedNode[] {\n    return this.writeTree_.calcIndexedSlice(\n      this.treePath_,\n      completeServerData,\n      startPost,\n      count,\n      reverse,\n      index\n    );\n  }\n\n  /**\n   * Returns a complete child for a given server snap after applying all user writes or null if there is no\n   * complete child for this ChildKey.\n   */\n  calcCompleteChild(\n    childKey: string,\n    existingServerCache: CacheNode\n  ): Node | null {\n    return this.writeTree_.calcCompleteChild(\n      this.treePath_,\n      childKey,\n      existingServerCache\n    );\n  }\n\n  /**\n   * Return a WriteTreeRef for a child.\n   */\n  child(childName: string): WriteTreeRef {\n    return new WriteTreeRef(\n      pathChild(this.treePath_, childName),\n      this.writeTree_\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert } from '@firebase/util';\nimport { each, errorForServerCode } from './util/util';\nimport { AckUserWrite } from './operation/AckUserWrite';\nimport { ChildrenNode } from './snap/ChildrenNode';\nimport { ImmutableTree } from './util/ImmutableTree';\nimport { ListenComplete } from './operation/ListenComplete';\nimport { Merge } from './operation/Merge';\nimport {\n  newOperationSourceServer,\n  newOperationSourceServerTaggedQuery,\n  newOperationSourceUser,\n  Operation\n} from './operation/Operation';\nimport { Overwrite } from './operation/Overwrite';\nimport {\n  newEmptyPath,\n  newRelativePath,\n  Path,\n  pathGetFront,\n  pathIsEmpty\n} from './util/Path';\nimport {\n  SyncPoint,\n  syncPointAddEventRegistration,\n  syncPointApplyOperation,\n  syncPointGetCompleteServerCache,\n  syncPointGetCompleteView,\n  syncPointGetQueryViews,\n  syncPointGetView,\n  syncPointHasCompleteView,\n  syncPointIsEmpty,\n  syncPointRemoveEventRegistration,\n  syncPointViewExistsForQuery,\n  syncPointViewForQuery\n} from './SyncPoint';\nimport { WriteTree, WriteTreeRef } from './WriteTree';\nimport { Query } from '../api/Query';\nimport { Node } from './snap/Node';\nimport { Event } from './view/Event';\nimport { EventRegistration } from './view/EventRegistration';\nimport { View } from './view/View';\nimport { CacheNode } from './view/CacheNode';\n\n/**\n * @typedef {{\n *   startListening: function(\n *     !Query,\n *     ?number,\n *     function():string,\n *     function(!string, *):!Array.<!Event>\n *   ):!Array.<!Event>,\n *\n *   stopListening: function(!Query, ?number)\n * }}\n */\nexport interface ListenProvider {\n  startListening(\n    query: Query,\n    tag: number | null,\n    hashFn: () => string,\n    onComplete: (a: string, b?: unknown) => Event[]\n  ): Event[];\n\n  stopListening(a: Query, b: number | null): void;\n}\n\n/**\n * Static tracker for next query tag.\n */\nlet syncTreeNextQueryTag_ = 1;\n\n/**\n * SyncTree is the central class for managing event callback registration, data caching, views\n * (query processing), and event generation.  There are typically two SyncTree instances for\n * each Repo, one for the normal Firebase data, and one for the .info data.\n *\n * It has a number of responsibilities, including:\n *  - Tracking all user event callbacks (registered via addEventRegistration() and removeEventRegistration()).\n *  - Applying and caching data changes for user set(), transaction(), and update() calls\n *    (applyUserOverwrite(), applyUserMerge()).\n *  - Applying and caching data changes for server data changes (applyServerOverwrite(),\n *    applyServerMerge()).\n *  - Generating user-facing events for server and user changes (all of the apply* methods\n *    return the set of events that need to be raised as a result).\n *  - Maintaining the appropriate set of server listens to ensure we are always subscribed\n *    to the correct set of paths and queries to satisfy the current set of user event\n *    callbacks (listens are started/stopped using the provided listenProvider).\n *\n * NOTE: Although SyncTree tracks event callbacks and calculates events to raise, the actual\n * events are returned to the caller rather than raised synchronously.\n *\n */\nexport class SyncTree {\n  /**\n   * Tree of SyncPoints.  There's a SyncPoint at any location that has 1 or more views.\n   */\n  syncPointTree_: ImmutableTree<SyncPoint> = new ImmutableTree<SyncPoint>(null);\n\n  /**\n   * A tree of all pending user writes (user-initiated set()'s, transaction()'s, update()'s, etc.).\n   */\n  pendingWriteTree_ = new WriteTree();\n\n  readonly tagToQueryMap: Map<number, string> = new Map();\n  readonly queryToTagMap: Map<string, number> = new Map();\n\n  /**\n   * @param listenProvider_ Used by SyncTree to start / stop listening\n   *   to server data.\n   */\n  constructor(public listenProvider_: ListenProvider) {}\n}\n\n/**\n * Apply the data changes for a user-generated set() or transaction() call.\n *\n * @return Events to raise.\n */\nexport function syncTreeApplyUserOverwrite(\n  syncTree: SyncTree,\n  path: Path,\n  newData: Node,\n  writeId: number,\n  visible?: boolean\n): Event[] {\n  // Record pending write.\n  syncTree.pendingWriteTree_.addOverwrite(path, newData, writeId, visible);\n\n  if (!visible) {\n    return [];\n  } else {\n    return syncTreeApplyOperationToSyncPoints_(\n      syncTree,\n      new Overwrite(newOperationSourceUser(), path, newData)\n    );\n  }\n}\n\n/**\n * Apply the data from a user-generated update() call\n *\n * @return Events to raise.\n */\nexport function syncTreeApplyUserMerge(\n  syncTree: SyncTree,\n  path: Path,\n  changedChildren: { [k: string]: Node },\n  writeId: number\n): Event[] {\n  // Record pending merge.\n  syncTree.pendingWriteTree_.addMerge(path, changedChildren, writeId);\n\n  const changeTree = ImmutableTree.fromObject(changedChildren);\n\n  return syncTreeApplyOperationToSyncPoints_(\n    syncTree,\n    new Merge(newOperationSourceUser(), path, changeTree)\n  );\n}\n\n/**\n * Acknowledge a pending user write that was previously registered with applyUserOverwrite() or applyUserMerge().\n *\n * @param revert True if the given write failed and needs to be reverted\n * @return Events to raise.\n */\nexport function syncTreeAckUserWrite(\n  syncTree: SyncTree,\n  writeId: number,\n  revert: boolean = false\n) {\n  const write = syncTree.pendingWriteTree_.getWrite(writeId);\n  const needToReevaluate = syncTree.pendingWriteTree_.removeWrite(writeId);\n  if (!needToReevaluate) {\n    return [];\n  } else {\n    let affectedTree = new ImmutableTree<boolean>(null);\n    if (write.snap != null) {\n      // overwrite\n      affectedTree = affectedTree.set(newEmptyPath(), true);\n    } else {\n      each(write.children, (pathString: string) => {\n        affectedTree = affectedTree.set(new Path(pathString), true);\n      });\n    }\n    return syncTreeApplyOperationToSyncPoints_(\n      syncTree,\n      new AckUserWrite(write.path, affectedTree, revert)\n    );\n  }\n}\n\n/**\n * Apply new server data for the specified path..\n *\n * @return Events to raise.\n */\nexport function syncTreeApplyServerOverwrite(\n  syncTree: SyncTree,\n  path: Path,\n  newData: Node\n): Event[] {\n  return syncTreeApplyOperationToSyncPoints_(\n    syncTree,\n    new Overwrite(newOperationSourceServer(), path, newData)\n  );\n}\n\n/**\n * Apply new server data to be merged in at the specified path.\n *\n * @return Events to raise.\n */\nexport function syncTreeApplyServerMerge(\n  syncTree: SyncTree,\n  path: Path,\n  changedChildren: { [k: string]: Node }\n): Event[] {\n  const changeTree = ImmutableTree.fromObject(changedChildren);\n\n  return syncTreeApplyOperationToSyncPoints_(\n    syncTree,\n    new Merge(newOperationSourceServer(), path, changeTree)\n  );\n}\n\n/**\n * Apply a listen complete for a query\n *\n * @return Events to raise.\n */\nexport function syncTreeApplyListenComplete(\n  syncTree: SyncTree,\n  path: Path\n): Event[] {\n  return syncTreeApplyOperationToSyncPoints_(\n    syncTree,\n    new ListenComplete(newOperationSourceServer(), path)\n  );\n}\n\n/**\n * Apply a listen complete for a tagged query\n *\n * @return Events to raise.\n */\nexport function syncTreeApplyTaggedListenComplete(\n  syncTree: SyncTree,\n  path: Path,\n  tag: number\n): Event[] {\n  const queryKey = syncTreeQueryKeyForTag_(syncTree, tag);\n  if (queryKey) {\n    const r = syncTreeParseQueryKey_(queryKey);\n    const queryPath = r.path,\n      queryId = r.queryId;\n    const relativePath = newRelativePath(queryPath, path);\n    const op = new ListenComplete(\n      newOperationSourceServerTaggedQuery(queryId),\n      relativePath\n    );\n    return syncTreeApplyTaggedOperation_(syncTree, queryPath, op);\n  } else {\n    // We've already removed the query. No big deal, ignore the update\n    return [];\n  }\n}\n\n/**\n * Remove event callback(s).\n *\n * If query is the default query, we'll check all queries for the specified eventRegistration.\n * If eventRegistration is null, we'll remove all callbacks for the specified query/queries.\n *\n * @param eventRegistration If null, all callbacks are removed.\n * @param cancelError If a cancelError is provided, appropriate cancel events will be returned.\n * @return Cancel events, if cancelError was provided.\n */\nexport function syncTreeRemoveEventRegistration(\n  syncTree: SyncTree,\n  query: Query,\n  eventRegistration: EventRegistration | null,\n  cancelError?: Error\n): Event[] {\n  // Find the syncPoint first. Then deal with whether or not it has matching listeners\n  const path = query.path;\n  const maybeSyncPoint = syncTree.syncPointTree_.get(path);\n  let cancelEvents: Event[] = [];\n  // A removal on a default query affects all queries at that location. A removal on an indexed query, even one without\n  // other query constraints, does *not* affect all queries at that location. So this check must be for 'default', and\n  // not loadsAllData().\n  if (\n    maybeSyncPoint &&\n    (query.queryIdentifier() === 'default' ||\n      syncPointViewExistsForQuery(maybeSyncPoint, query))\n  ) {\n    const removedAndEvents = syncPointRemoveEventRegistration(\n      maybeSyncPoint,\n      query,\n      eventRegistration,\n      cancelError\n    );\n    if (syncPointIsEmpty(maybeSyncPoint)) {\n      syncTree.syncPointTree_ = syncTree.syncPointTree_.remove(path);\n    }\n    const removed = removedAndEvents.removed;\n    cancelEvents = removedAndEvents.events;\n    // We may have just removed one of many listeners and can short-circuit this whole process\n    // We may also not have removed a default listener, in which case all of the descendant listeners should already be\n    // properly set up.\n    //\n    // Since indexed queries can shadow if they don't have other query constraints, check for loadsAllData(), instead of\n    // queryId === 'default'\n    const removingDefault =\n      -1 !==\n      removed.findIndex(query => {\n        return query.getQueryParams().loadsAllData();\n      });\n    const covered = syncTree.syncPointTree_.findOnPath(\n      path,\n      (relativePath, parentSyncPoint) =>\n        syncPointHasCompleteView(parentSyncPoint)\n    );\n\n    if (removingDefault && !covered) {\n      const subtree = syncTree.syncPointTree_.subtree(path);\n      // There are potentially child listeners. Determine what if any listens we need to send before executing the\n      // removal\n      if (!subtree.isEmpty()) {\n        // We need to fold over our subtree and collect the listeners to send\n        const newViews = syncTreeCollectDistinctViewsForSubTree_(subtree);\n\n        // Ok, we've collected all the listens we need. Set them up.\n        for (let i = 0; i < newViews.length; ++i) {\n          const view = newViews[i],\n            newQuery = view.getQuery();\n          const listener = syncTreeCreateListenerForView_(syncTree, view);\n          syncTree.listenProvider_.startListening(\n            syncTreeQueryForListening_(newQuery),\n            syncTreeTagForQuery_(syncTree, newQuery),\n            listener.hashFn,\n            listener.onComplete\n          );\n        }\n      } else {\n        // There's nothing below us, so nothing we need to start listening on\n      }\n    }\n    // If we removed anything and we're not covered by a higher up listen, we need to stop listening on this query\n    // The above block has us covered in terms of making sure we're set up on listens lower in the tree.\n    // Also, note that if we have a cancelError, it's already been removed at the provider level.\n    if (!covered && removed.length > 0 && !cancelError) {\n      // If we removed a default, then we weren't listening on any of the other queries here. Just cancel the one\n      // default. Otherwise, we need to iterate through and cancel each individual query\n      if (removingDefault) {\n        // We don't tag default listeners\n        const defaultTag: number | null = null;\n        syncTree.listenProvider_.stopListening(\n          syncTreeQueryForListening_(query),\n          defaultTag\n        );\n      } else {\n        removed.forEach((queryToRemove: Query) => {\n          const tagToRemove = syncTree.queryToTagMap.get(\n            syncTreeMakeQueryKey_(queryToRemove)\n          );\n          syncTree.listenProvider_.stopListening(\n            syncTreeQueryForListening_(queryToRemove),\n            tagToRemove\n          );\n        });\n      }\n    }\n    // Now, clear all of the tags we're tracking for the removed listens\n    syncTreeRemoveTags_(syncTree, removed);\n  } else {\n    // No-op, this listener must've been already removed\n  }\n  return cancelEvents;\n}\n\n/**\n * Apply new server data for the specified tagged query.\n *\n * @return Events to raise.\n */\nexport function syncTreeApplyTaggedQueryOverwrite(\n  syncTree: SyncTree,\n  path: Path,\n  snap: Node,\n  tag: number\n): Event[] {\n  const queryKey = syncTreeQueryKeyForTag_(syncTree, tag);\n  if (queryKey != null) {\n    const r = syncTreeParseQueryKey_(queryKey);\n    const queryPath = r.path,\n      queryId = r.queryId;\n    const relativePath = newRelativePath(queryPath, path);\n    const op = new Overwrite(\n      newOperationSourceServerTaggedQuery(queryId),\n      relativePath,\n      snap\n    );\n    return syncTreeApplyTaggedOperation_(syncTree, queryPath, op);\n  } else {\n    // Query must have been removed already\n    return [];\n  }\n}\n\n/**\n * Apply server data to be merged in for the specified tagged query.\n *\n * @return Events to raise.\n */\nexport function syncTreeApplyTaggedQueryMerge(\n  syncTree: SyncTree,\n  path: Path,\n  changedChildren: { [k: string]: Node },\n  tag: number\n): Event[] {\n  const queryKey = syncTreeQueryKeyForTag_(syncTree, tag);\n  if (queryKey) {\n    const r = syncTreeParseQueryKey_(queryKey);\n    const queryPath = r.path,\n      queryId = r.queryId;\n    const relativePath = newRelativePath(queryPath, path);\n    const changeTree = ImmutableTree.fromObject(changedChildren);\n    const op = new Merge(\n      newOperationSourceServerTaggedQuery(queryId),\n      relativePath,\n      changeTree\n    );\n    return syncTreeApplyTaggedOperation_(syncTree, queryPath, op);\n  } else {\n    // We've already removed the query. No big deal, ignore the update\n    return [];\n  }\n}\n\n/**\n * Add an event callback for the specified query.\n *\n * @return Events to raise.\n */\nexport function syncTreeAddEventRegistration(\n  syncTree: SyncTree,\n  query: Query,\n  eventRegistration: EventRegistration\n): Event[] {\n  const path = query.path;\n\n  let serverCache: Node | null = null;\n  let foundAncestorDefaultView = false;\n  // Any covering writes will necessarily be at the root, so really all we need to find is the server cache.\n  // Consider optimizing this once there's a better understanding of what actual behavior will be.\n  syncTree.syncPointTree_.foreachOnPath(path, (pathToSyncPoint, sp) => {\n    const relativePath = newRelativePath(pathToSyncPoint, path);\n    serverCache =\n      serverCache || syncPointGetCompleteServerCache(sp, relativePath);\n    foundAncestorDefaultView =\n      foundAncestorDefaultView || syncPointHasCompleteView(sp);\n  });\n  let syncPoint = syncTree.syncPointTree_.get(path);\n  if (!syncPoint) {\n    syncPoint = new SyncPoint();\n    syncTree.syncPointTree_ = syncTree.syncPointTree_.set(path, syncPoint);\n  } else {\n    foundAncestorDefaultView =\n      foundAncestorDefaultView || syncPointHasCompleteView(syncPoint);\n    serverCache =\n      serverCache || syncPointGetCompleteServerCache(syncPoint, newEmptyPath());\n  }\n\n  let serverCacheComplete;\n  if (serverCache != null) {\n    serverCacheComplete = true;\n  } else {\n    serverCacheComplete = false;\n    serverCache = ChildrenNode.EMPTY_NODE;\n    const subtree = syncTree.syncPointTree_.subtree(path);\n    subtree.foreachChild((childName, childSyncPoint) => {\n      const completeCache = syncPointGetCompleteServerCache(\n        childSyncPoint,\n        newEmptyPath()\n      );\n      if (completeCache) {\n        serverCache = serverCache.updateImmediateChild(\n          childName,\n          completeCache\n        );\n      }\n    });\n  }\n\n  const viewAlreadyExists = syncPointViewExistsForQuery(syncPoint, query);\n  if (!viewAlreadyExists && !query.getQueryParams().loadsAllData()) {\n    // We need to track a tag for this query\n    const queryKey = syncTreeMakeQueryKey_(query);\n    assert(\n      !syncTree.queryToTagMap.has(queryKey),\n      'View does not exist, but we have a tag'\n    );\n    const tag = syncTreeGetNextQueryTag_();\n    syncTree.queryToTagMap.set(queryKey, tag);\n    syncTree.tagToQueryMap.set(tag, queryKey);\n  }\n  const writesCache = syncTree.pendingWriteTree_.childWrites(path);\n  let events = syncPointAddEventRegistration(\n    syncPoint,\n    query,\n    eventRegistration,\n    writesCache,\n    serverCache,\n    serverCacheComplete\n  );\n  if (!viewAlreadyExists && !foundAncestorDefaultView) {\n    const view = syncPointViewForQuery(syncPoint, query);\n    events = events.concat(syncTreeSetupListener_(syncTree, query, view));\n  }\n  return events;\n}\n\n/**\n * Returns a complete cache, if we have one, of the data at a particular path. If the location does not have a\n * listener above it, we will get a false \"null\". This shouldn't be a problem because transactions will always\n * have a listener above, and atomic operations would correctly show a jitter of <increment value> ->\n *     <incremented total> as the write is applied locally and then acknowledged at the server.\n *\n * Note: this method will *include* hidden writes from transaction with applyLocally set to false.\n *\n * @param path The path to the data we want\n * @param writeIdsToExclude A specific set to be excluded\n */\nexport function syncTreeCalcCompleteEventCache(\n  syncTree: SyncTree,\n  path: Path,\n  writeIdsToExclude?: number[]\n): Node {\n  const includeHiddenSets = true;\n  const writeTree = syncTree.pendingWriteTree_;\n  const serverCache = syncTree.syncPointTree_.findOnPath(\n    path,\n    (pathSoFar, syncPoint) => {\n      const relativePath = newRelativePath(pathSoFar, path);\n      const serverCache = syncPointGetCompleteServerCache(\n        syncPoint,\n        relativePath\n      );\n      if (serverCache) {\n        return serverCache;\n      }\n    }\n  );\n  return writeTree.calcCompleteEventCache(\n    path,\n    serverCache,\n    writeIdsToExclude,\n    includeHiddenSets\n  );\n}\n\nexport function syncTreeGetServerValue(\n  syncTree: SyncTree,\n  query: Query\n): Node | null {\n  const path = query.path;\n  let serverCache: Node | null = null;\n  // Any covering writes will necessarily be at the root, so really all we need to find is the server cache.\n  // Consider optimizing this once there's a better understanding of what actual behavior will be.\n  syncTree.syncPointTree_.foreachOnPath(path, (pathToSyncPoint, sp) => {\n    const relativePath = newRelativePath(pathToSyncPoint, path);\n    serverCache =\n      serverCache || syncPointGetCompleteServerCache(sp, relativePath);\n  });\n  let syncPoint = syncTree.syncPointTree_.get(path);\n  if (!syncPoint) {\n    syncPoint = new SyncPoint();\n    syncTree.syncPointTree_ = syncTree.syncPointTree_.set(path, syncPoint);\n  } else {\n    serverCache =\n      serverCache || syncPointGetCompleteServerCache(syncPoint, newEmptyPath());\n  }\n  const serverCacheComplete = serverCache != null;\n  const serverCacheNode: CacheNode | null = serverCacheComplete\n    ? new CacheNode(serverCache, true, false)\n    : null;\n  const writesCache: WriteTreeRef | null = syncTree.pendingWriteTree_.childWrites(\n    query.path\n  );\n  const view: View = syncPointGetView(\n    syncPoint,\n    query,\n    writesCache,\n    serverCacheComplete ? serverCacheNode.getNode() : ChildrenNode.EMPTY_NODE,\n    serverCacheComplete\n  );\n  return view.getCompleteNode();\n}\n\n/**\n * A helper method that visits all descendant and ancestor SyncPoints, applying the operation.\n *\n * NOTES:\n * - Descendant SyncPoints will be visited first (since we raise events depth-first).\n *\n * - We call applyOperation() on each SyncPoint passing three things:\n *   1. A version of the Operation that has been made relative to the SyncPoint location.\n *   2. A WriteTreeRef of any writes we have cached at the SyncPoint location.\n *   3. A snapshot Node with cached server data, if we have it.\n *\n * - We concatenate all of the events returned by each SyncPoint and return the result.\n */\nfunction syncTreeApplyOperationToSyncPoints_(\n  syncTree: SyncTree,\n  operation: Operation\n): Event[] {\n  return syncTreeApplyOperationHelper_(\n    operation,\n    syncTree.syncPointTree_,\n    /*serverCache=*/ null,\n    syncTree.pendingWriteTree_.childWrites(newEmptyPath())\n  );\n}\n\n/**\n * Recursive helper for applyOperationToSyncPoints_\n */\nfunction syncTreeApplyOperationHelper_(\n  operation: Operation,\n  syncPointTree: ImmutableTree<SyncPoint>,\n  serverCache: Node | null,\n  writesCache: WriteTreeRef\n): Event[] {\n  if (pathIsEmpty(operation.path)) {\n    return syncTreeApplyOperationDescendantsHelper_(\n      operation,\n      syncPointTree,\n      serverCache,\n      writesCache\n    );\n  } else {\n    const syncPoint = syncPointTree.get(newEmptyPath());\n\n    // If we don't have cached server data, see if we can get it from this SyncPoint.\n    if (serverCache == null && syncPoint != null) {\n      serverCache = syncPointGetCompleteServerCache(syncPoint, newEmptyPath());\n    }\n\n    let events: Event[] = [];\n    const childName = pathGetFront(operation.path);\n    const childOperation = operation.operationForChild(childName);\n    const childTree = syncPointTree.children.get(childName);\n    if (childTree && childOperation) {\n      const childServerCache = serverCache\n        ? serverCache.getImmediateChild(childName)\n        : null;\n      const childWritesCache = writesCache.child(childName);\n      events = events.concat(\n        syncTreeApplyOperationHelper_(\n          childOperation,\n          childTree,\n          childServerCache,\n          childWritesCache\n        )\n      );\n    }\n\n    if (syncPoint) {\n      events = events.concat(\n        syncPointApplyOperation(syncPoint, operation, writesCache, serverCache)\n      );\n    }\n\n    return events;\n  }\n}\n\n/**\n * Recursive helper for applyOperationToSyncPoints_\n */\nfunction syncTreeApplyOperationDescendantsHelper_(\n  operation: Operation,\n  syncPointTree: ImmutableTree<SyncPoint>,\n  serverCache: Node | null,\n  writesCache: WriteTreeRef\n): Event[] {\n  const syncPoint = syncPointTree.get(newEmptyPath());\n\n  // If we don't have cached server data, see if we can get it from this SyncPoint.\n  if (serverCache == null && syncPoint != null) {\n    serverCache = syncPointGetCompleteServerCache(syncPoint, newEmptyPath());\n  }\n\n  let events: Event[] = [];\n  syncPointTree.children.inorderTraversal((childName, childTree) => {\n    const childServerCache = serverCache\n      ? serverCache.getImmediateChild(childName)\n      : null;\n    const childWritesCache = writesCache.child(childName);\n    const childOperation = operation.operationForChild(childName);\n    if (childOperation) {\n      events = events.concat(\n        syncTreeApplyOperationDescendantsHelper_(\n          childOperation,\n          childTree,\n          childServerCache,\n          childWritesCache\n        )\n      );\n    }\n  });\n\n  if (syncPoint) {\n    events = events.concat(\n      syncPointApplyOperation(syncPoint, operation, writesCache, serverCache)\n    );\n  }\n\n  return events;\n}\n\nfunction syncTreeCreateListenerForView_(\n  syncTree: SyncTree,\n  view: View\n): { hashFn(): string; onComplete(a: string, b?: unknown): Event[] } {\n  const query = view.getQuery();\n  const tag = syncTreeTagForQuery_(syncTree, query);\n\n  return {\n    hashFn: () => {\n      const cache = view.getServerCache() || ChildrenNode.EMPTY_NODE;\n      return cache.hash();\n    },\n    onComplete: (status: string): Event[] => {\n      if (status === 'ok') {\n        if (tag) {\n          return syncTreeApplyTaggedListenComplete(syncTree, query.path, tag);\n        } else {\n          return syncTreeApplyListenComplete(syncTree, query.path);\n        }\n      } else {\n        // If a listen failed, kill all of the listeners here, not just the one that triggered the error.\n        // Note that this may need to be scoped to just this listener if we change permissions on filtered children\n        const error = errorForServerCode(status, query);\n        return syncTreeRemoveEventRegistration(\n          syncTree,\n          query,\n          /*eventRegistration*/ null,\n          error\n        );\n      }\n    }\n  };\n}\n\n/**\n * Return the tag associated with the given query.\n */\nfunction syncTreeTagForQuery_(syncTree: SyncTree, query: Query): number | null {\n  const queryKey = syncTreeMakeQueryKey_(query);\n  return syncTree.queryToTagMap.get(queryKey);\n}\n\n/**\n * Given a query, computes a \"queryKey\" suitable for use in our queryToTagMap_.\n */\nfunction syncTreeMakeQueryKey_(query: Query): string {\n  return query.path.toString() + '$' + query.queryIdentifier();\n}\n\n/**\n * Return the query associated with the given tag, if we have one\n */\nfunction syncTreeQueryKeyForTag_(\n  syncTree: SyncTree,\n  tag: number\n): string | null {\n  return syncTree.tagToQueryMap.get(tag);\n}\n\n/**\n * Given a queryKey (created by makeQueryKey), parse it back into a path and queryId.\n */\nfunction syncTreeParseQueryKey_(\n  queryKey: string\n): { queryId: string; path: Path } {\n  const splitIndex = queryKey.indexOf('$');\n  assert(\n    splitIndex !== -1 && splitIndex < queryKey.length - 1,\n    'Bad queryKey.'\n  );\n  return {\n    queryId: queryKey.substr(splitIndex + 1),\n    path: new Path(queryKey.substr(0, splitIndex))\n  };\n}\n\n/**\n * A helper method to apply tagged operations\n */\nfunction syncTreeApplyTaggedOperation_(\n  syncTree: SyncTree,\n  queryPath: Path,\n  operation: Operation\n): Event[] {\n  const syncPoint = syncTree.syncPointTree_.get(queryPath);\n  assert(syncPoint, \"Missing sync point for query tag that we're tracking\");\n  const writesCache = syncTree.pendingWriteTree_.childWrites(queryPath);\n  return syncPointApplyOperation(syncPoint, operation, writesCache, null);\n}\n\n/**\n * This collapses multiple unfiltered views into a single view, since we only need a single\n * listener for them.\n */\nfunction syncTreeCollectDistinctViewsForSubTree_(\n  subtree: ImmutableTree<SyncPoint>\n): View[] {\n  return subtree.fold<View[]>((relativePath, maybeChildSyncPoint, childMap) => {\n    if (maybeChildSyncPoint && syncPointHasCompleteView(maybeChildSyncPoint)) {\n      const completeView = syncPointGetCompleteView(maybeChildSyncPoint);\n      return [completeView];\n    } else {\n      // No complete view here, flatten any deeper listens into an array\n      let views: View[] = [];\n      if (maybeChildSyncPoint) {\n        views = syncPointGetQueryViews(maybeChildSyncPoint);\n      }\n      each(childMap, (_key: string, childViews: View[]) => {\n        views = views.concat(childViews);\n      });\n      return views;\n    }\n  });\n}\n\n/**\n * Normalizes a query to a query we send the server for listening\n *\n * @return The normalized query\n */\nfunction syncTreeQueryForListening_(query: Query): Query {\n  if (\n    query.getQueryParams().loadsAllData() &&\n    !query.getQueryParams().isDefault()\n  ) {\n    // We treat queries that load all data as default queries\n    // Cast is necessary because ref() technically returns Firebase which is actually fb.api.Firebase which inherits\n    // from Query\n    return query.getRef()!;\n  } else {\n    return query;\n  }\n}\n\nfunction syncTreeRemoveTags_(syncTree: SyncTree, queries: Query[]) {\n  for (let j = 0; j < queries.length; ++j) {\n    const removedQuery = queries[j];\n    if (!removedQuery.getQueryParams().loadsAllData()) {\n      // We should have a tag for this\n      const removedQueryKey = syncTreeMakeQueryKey_(removedQuery);\n      const removedQueryTag = syncTree.queryToTagMap.get(removedQueryKey);\n      syncTree.queryToTagMap.delete(removedQueryKey);\n      syncTree.tagToQueryMap.delete(removedQueryTag);\n    }\n  }\n}\n\n/**\n * Static accessor for query tags.\n */\nfunction syncTreeGetNextQueryTag_(): number {\n  return syncTreeNextQueryTag_++;\n}\n\n/**\n * For a given new listen, manage the de-duplication of outstanding subscriptions.\n *\n * @return This method can return events to support synchronous data sources\n */\nfunction syncTreeSetupListener_(\n  syncTree: SyncTree,\n  query: Query,\n  view: View\n): Event[] {\n  const path = query.path;\n  const tag = syncTreeTagForQuery_(syncTree, query);\n  const listener = syncTreeCreateListenerForView_(syncTree, view);\n\n  const events = syncTree.listenProvider_.startListening(\n    syncTreeQueryForListening_(query),\n    tag,\n    listener.hashFn,\n    listener.onComplete\n  );\n\n  const subtree = syncTree.syncPointTree_.subtree(path);\n  // The root of this subtree has our query. We're here because we definitely need to send a listen for that, but we\n  // may need to shadow other listens as well.\n  if (tag) {\n    assert(\n      !syncPointHasCompleteView(subtree.value),\n      \"If we're adding a query, it shouldn't be shadowed\"\n    );\n  } else {\n    // Shadow everything at or below this location, this is a default listener.\n    const queriesToStop = subtree.fold<Query[]>(\n      (relativePath, maybeChildSyncPoint, childMap) => {\n        if (\n          !pathIsEmpty(relativePath) &&\n          maybeChildSyncPoint &&\n          syncPointHasCompleteView(maybeChildSyncPoint)\n        ) {\n          return [syncPointGetCompleteView(maybeChildSyncPoint).getQuery()];\n        } else {\n          // No default listener here, flatten any deeper queries into an array\n          let queries: Query[] = [];\n          if (maybeChildSyncPoint) {\n            queries = queries.concat(\n              syncPointGetQueryViews(maybeChildSyncPoint).map(view =>\n                view.getQuery()\n              )\n            );\n          }\n          each(childMap, (_key: string, childQueries: Query[]) => {\n            queries = queries.concat(childQueries);\n          });\n          return queries;\n        }\n      }\n    );\n    for (let i = 0; i < queriesToStop.length; ++i) {\n      const queryToStop = queriesToStop[i];\n      syncTree.listenProvider_.stopListening(\n        syncTreeQueryForListening_(queryToStop),\n        syncTreeTagForQuery_(syncTree, queryToStop)\n      );\n    }\n  }\n  return events;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert } from '@firebase/util';\nimport { Path, pathChild } from './Path';\nimport { LeafNode } from '../snap/LeafNode';\nimport { nodeFromJSON } from '../snap/nodeFromJSON';\nimport { PRIORITY_INDEX } from '../snap/indexes/PriorityIndex';\nimport { Node } from '../snap/Node';\nimport { ChildrenNode } from '../snap/ChildrenNode';\nimport { SyncTree, syncTreeCalcCompleteEventCache } from '../SyncTree';\nimport { Indexable } from './misc';\n\n/* It's critical for performance that we do not calculate actual values from a SyncTree\n * unless and until the value is needed. Because we expose both a SyncTree and Node\n * version of deferred value resolution, we ned a wrapper class that will let us share\n * code.\n *\n * @see https://github.com/firebase/firebase-js-sdk/issues/2487\n */\ninterface ValueProvider {\n  getImmediateChild(childName: string): ValueProvider;\n  node(): Node;\n}\n\nclass ExistingValueProvider implements ValueProvider {\n  constructor(readonly node_: Node) {}\n\n  getImmediateChild(childName: string): ValueProvider {\n    const child = this.node_.getImmediateChild(childName);\n    return new ExistingValueProvider(child);\n  }\n\n  node(): Node {\n    return this.node_;\n  }\n}\n\nclass DeferredValueProvider implements ValueProvider {\n  private syncTree_: SyncTree;\n  private path_: Path;\n\n  constructor(syncTree: SyncTree, path: Path) {\n    this.syncTree_ = syncTree;\n    this.path_ = path;\n  }\n\n  getImmediateChild(childName: string): ValueProvider {\n    const childPath = pathChild(this.path_, childName);\n    return new DeferredValueProvider(this.syncTree_, childPath);\n  }\n\n  node(): Node {\n    return syncTreeCalcCompleteEventCache(this.syncTree_, this.path_);\n  }\n}\n\n/**\n * Generate placeholders for deferred values.\n */\nexport const generateWithValues = function (\n  values: {\n    [k: string]: unknown;\n  } | null\n): { [k: string]: unknown } {\n  values = values || {};\n  values['timestamp'] = values['timestamp'] || new Date().getTime();\n  return values;\n};\n\n/**\n * Value to use when firing local events. When writing server values, fire\n * local events with an approximate value, otherwise return value as-is.\n */\nexport const resolveDeferredLeafValue = function (\n  value: { [k: string]: unknown } | string | number | boolean,\n  existingVal: ValueProvider,\n  serverValues: { [k: string]: unknown }\n): string | number | boolean {\n  if (!value || typeof value !== 'object') {\n    return value as string | number | boolean;\n  }\n  assert('.sv' in value, 'Unexpected leaf node or priority contents');\n\n  if (typeof value['.sv'] === 'string') {\n    return resolveScalarDeferredValue(value['.sv'], existingVal, serverValues);\n  } else if (typeof value['.sv'] === 'object') {\n    return resolveComplexDeferredValue(value['.sv'], existingVal, serverValues);\n  } else {\n    assert(false, 'Unexpected server value: ' + JSON.stringify(value, null, 2));\n  }\n};\n\nconst resolveScalarDeferredValue = function (\n  op: string,\n  existing: ValueProvider,\n  serverValues: { [k: string]: unknown }\n): string | number | boolean {\n  switch (op) {\n    case 'timestamp':\n      return serverValues['timestamp'] as string | number | boolean;\n    default:\n      assert(false, 'Unexpected server value: ' + op);\n  }\n};\n\nconst resolveComplexDeferredValue = function (\n  op: object,\n  existing: ValueProvider,\n  unused: { [k: string]: unknown }\n): string | number | boolean {\n  if (!op.hasOwnProperty('increment')) {\n    assert(false, 'Unexpected server value: ' + JSON.stringify(op, null, 2));\n  }\n  const delta = op['increment'];\n  if (typeof delta !== 'number') {\n    assert(false, 'Unexpected increment value: ' + delta);\n  }\n\n  const existingNode = existing.node();\n  assert(\n    existingNode !== null && typeof existingNode !== 'undefined',\n    'Expected ChildrenNode.EMPTY_NODE for nulls'\n  );\n\n  // Incrementing a non-number sets the value to the incremented amount\n  if (!existingNode.isLeafNode()) {\n    return delta;\n  }\n\n  const leaf = existingNode as LeafNode;\n  const existingVal = leaf.getValue();\n  if (typeof existingVal !== 'number') {\n    return delta;\n  }\n\n  // No need to do over/underflow arithmetic here because JS only handles floats under the covers\n  return existingVal + delta;\n};\n\n/**\n * Recursively replace all deferred values and priorities in the tree with the\n * specified generated replacement values.\n * @param path path to which write is relative\n * @param node new data written at path\n * @param syncTree current data\n */\nexport const resolveDeferredValueTree = function (\n  path: Path,\n  node: Node,\n  syncTree: SyncTree,\n  serverValues: Indexable\n): Node {\n  return resolveDeferredValue(\n    node,\n    new DeferredValueProvider(syncTree, path),\n    serverValues\n  );\n};\n\n/**\n * Recursively replace all deferred values and priorities in the node with the\n * specified generated replacement values.  If there are no server values in the node,\n * it'll be returned as-is.\n */\nexport const resolveDeferredValueSnapshot = function (\n  node: Node,\n  existing: Node,\n  serverValues: Indexable\n): Node {\n  return resolveDeferredValue(\n    node,\n    new ExistingValueProvider(existing),\n    serverValues\n  );\n};\n\nfunction resolveDeferredValue(\n  node: Node,\n  existingVal: ValueProvider,\n  serverValues: Indexable\n): Node {\n  const rawPri = node.getPriority().val() as\n    | Indexable\n    | boolean\n    | null\n    | number\n    | string;\n  const priority = resolveDeferredLeafValue(\n    rawPri,\n    existingVal.getImmediateChild('.priority'),\n    serverValues\n  );\n  let newNode: Node;\n\n  if (node.isLeafNode()) {\n    const leafNode = node as LeafNode;\n    const value = resolveDeferredLeafValue(\n      leafNode.getValue(),\n      existingVal,\n      serverValues\n    );\n    if (\n      value !== leafNode.getValue() ||\n      priority !== leafNode.getPriority().val()\n    ) {\n      return new LeafNode(value, nodeFromJSON(priority));\n    } else {\n      return node;\n    }\n  } else {\n    const childrenNode = node as ChildrenNode;\n    newNode = childrenNode;\n    if (priority !== childrenNode.getPriority().val()) {\n      newNode = newNode.updatePriority(new LeafNode(priority));\n    }\n    childrenNode.forEachChild(PRIORITY_INDEX, (childName, childNode) => {\n      const newChildNode = resolveDeferredValue(\n        childNode,\n        existingVal.getImmediateChild(childName),\n        serverValues\n      );\n      if (newChildNode !== childNode) {\n        newNode = newNode.updateImmediateChild(childName, newChildNode);\n      }\n    });\n    return newNode;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Path, pathGetFront, pathIsEmpty, pathPopFront } from './util/Path';\nimport { PRIORITY_INDEX } from './snap/indexes/PriorityIndex';\nimport { Node } from './snap/Node';\n\n/**\n * Helper class to store a sparse set of snapshots.\n */\nexport interface SparseSnapshotTree {\n  value: Node | null;\n  readonly children: Map<string, SparseSnapshotTree>;\n}\n\nexport function newSparseSnapshotTree(): SparseSnapshotTree {\n  return {\n    value: null,\n    children: new Map()\n  };\n}\n\n/**\n * Gets the node stored at the given path if one exists.\n * Only seems to be used in tests.\n *\n * @param path Path to look up snapshot for.\n * @return The retrieved node, or null.\n */\nexport function sparseSnapshotTreeFind(\n  sparseSnapshotTree: SparseSnapshotTree,\n  path: Path\n): Node | null {\n  if (sparseSnapshotTree.value != null) {\n    return sparseSnapshotTree.value.getChild(path);\n  } else if (!pathIsEmpty(path) && sparseSnapshotTree.children.size > 0) {\n    const childKey = pathGetFront(path);\n    path = pathPopFront(path);\n    if (sparseSnapshotTree.children.has(childKey)) {\n      const childTree = sparseSnapshotTree.children.get(childKey);\n      return sparseSnapshotTreeFind(childTree, path);\n    } else {\n      return null;\n    }\n  } else {\n    return null;\n  }\n}\n\n/**\n * Stores the given node at the specified path. If there is already a node\n * at a shallower path, it merges the new data into that snapshot node.\n *\n * @param path Path to look up snapshot for.\n * @param data The new data, or null.\n */\nexport function sparseSnapshotTreeRemember(\n  sparseSnapshotTree: SparseSnapshotTree,\n  path: Path,\n  data: Node\n): void {\n  if (pathIsEmpty(path)) {\n    sparseSnapshotTree.value = data;\n    sparseSnapshotTree.children.clear();\n  } else if (sparseSnapshotTree.value !== null) {\n    sparseSnapshotTree.value = sparseSnapshotTree.value.updateChild(path, data);\n  } else {\n    const childKey = pathGetFront(path);\n    if (!sparseSnapshotTree.children.has(childKey)) {\n      sparseSnapshotTree.children.set(childKey, newSparseSnapshotTree());\n    }\n\n    const child = sparseSnapshotTree.children.get(childKey);\n    path = pathPopFront(path);\n    sparseSnapshotTreeRemember(child, path, data);\n  }\n}\n\n/**\n * Purge the data at path from the cache.\n *\n * @param path Path to look up snapshot for.\n * @return True if this node should now be removed.\n */\nexport function sparseSnapshotTreeForget(\n  sparseSnapshotTree: SparseSnapshotTree,\n  path: Path\n): boolean {\n  if (pathIsEmpty(path)) {\n    sparseSnapshotTree.value = null;\n    sparseSnapshotTree.children.clear();\n    return true;\n  } else {\n    if (sparseSnapshotTree.value !== null) {\n      if (sparseSnapshotTree.value.isLeafNode()) {\n        // We're trying to forget a node that doesn't exist\n        return false;\n      } else {\n        const value = sparseSnapshotTree.value;\n        sparseSnapshotTree.value = null;\n\n        value.forEachChild(PRIORITY_INDEX, (key, tree) => {\n          sparseSnapshotTreeRemember(sparseSnapshotTree, new Path(key), tree);\n        });\n\n        return sparseSnapshotTreeForget(sparseSnapshotTree, path);\n      }\n    } else if (sparseSnapshotTree.children.size > 0) {\n      const childKey = pathGetFront(path);\n      path = pathPopFront(path);\n      if (sparseSnapshotTree.children.has(childKey)) {\n        const safeToRemove = sparseSnapshotTreeForget(\n          sparseSnapshotTree.children.get(childKey),\n          path\n        );\n        if (safeToRemove) {\n          sparseSnapshotTree.children.delete(childKey);\n        }\n      }\n\n      return sparseSnapshotTree.children.size === 0;\n    } else {\n      return true;\n    }\n  }\n}\n\n/**\n * Recursively iterates through all of the stored tree and calls the\n * callback on each one.\n *\n * @param prefixPath Path to look up node for.\n * @param func The function to invoke for each tree.\n */\nexport function sparseSnapshotTreeForEachTree(\n  sparseSnapshotTree: SparseSnapshotTree,\n  prefixPath: Path,\n  func: (a: Path, b: Node) => unknown\n): void {\n  if (sparseSnapshotTree.value !== null) {\n    func(prefixPath, sparseSnapshotTree.value);\n  } else {\n    sparseSnapshotTreeForEachChild(sparseSnapshotTree, (key, tree) => {\n      const path = new Path(prefixPath.toString() + '/' + key);\n      sparseSnapshotTreeForEachTree(tree, path, func);\n    });\n  }\n}\n\n/**\n * Iterates through each immediate child and triggers the callback.\n * Only seems to be used in tests.\n *\n * @param func The function to invoke for each child.\n */\nexport function sparseSnapshotTreeForEachChild(\n  sparseSnapshotTree: SparseSnapshotTree,\n  func: (a: string, b: SparseSnapshotTree) => void\n): void {\n  sparseSnapshotTree.children.forEach((tree, key) => {\n    func(key, tree);\n  });\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { ChildrenNode } from './snap/ChildrenNode';\nimport { Path } from './util/Path';\nimport { Node } from './snap/Node';\n\n/**\n * Mutable object which basically just stores a reference to the \"latest\" immutable snapshot.\n */\nexport class SnapshotHolder {\n  private rootNode_: Node = ChildrenNode.EMPTY_NODE;\n\n  getNode(path: Path): Node {\n    return this.rootNode_.getChild(path);\n  }\n\n  updateSnapshot(path: Path, newSnapshotNode: Node) {\n    this.rootNode_ = this.rootNode_.updateChild(path, newSnapshotNode);\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { deepCopy, contains } from '@firebase/util';\n\n/**\n * Tracks a collection of stats.\n */\nexport class StatsCollection {\n  private counters_: { [k: string]: number } = {};\n\n  incrementCounter(name: string, amount: number = 1) {\n    if (!contains(this.counters_, name)) {\n      this.counters_[name] = 0;\n    }\n\n    this.counters_[name] += amount;\n  }\n\n  get() {\n    return deepCopy(this.counters_);\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { StatsCollection } from './StatsCollection';\nimport { RepoInfo } from '../RepoInfo';\n\nconst collections: { [k: string]: StatsCollection } = {};\nconst reporters: { [k: string]: unknown } = {};\n\nexport function statsManagerGetCollection(repoInfo: RepoInfo): StatsCollection {\n  const hashString = repoInfo.toString();\n\n  if (!collections[hashString]) {\n    collections[hashString] = new StatsCollection();\n  }\n\n  return collections[hashString];\n}\n\nexport function statsManagerGetOrCreateReporter<T>(\n  repoInfo: RepoInfo,\n  creatorFunction: () => T\n): T {\n  const hashString = repoInfo.toString();\n\n  if (!reporters[hashString]) {\n    reporters[hashString] = creatorFunction();\n  }\n\n  return reporters[hashString] as T;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { StatsCollection } from './StatsCollection';\nimport { each } from '../util/util';\n\n/**\n * Returns the delta from the previous call to get stats.\n *\n * @param collection_ The collection to \"listen\" to.\n */\nexport class StatsListener {\n  private last_: { [k: string]: number } | null = null;\n\n  constructor(private collection_: StatsCollection) {}\n\n  get(): { [k: string]: number } {\n    const newStats = this.collection_.get();\n\n    const delta = { ...newStats };\n    if (this.last_) {\n      each(this.last_, (stat: string, value: number) => {\n        delta[stat] = delta[stat] - value;\n      });\n    }\n    this.last_ = newStats;\n\n    return delta;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { contains } from '@firebase/util';\nimport { setTimeoutNonBlocking, each } from '../util/util';\nimport { StatsListener } from './StatsListener';\nimport { StatsCollection } from './StatsCollection';\nimport { ServerActions } from '../ServerActions';\n\n// Assuming some apps may have a short amount of time on page, and a bulk of firebase operations probably\n// happen on page load, we try to report our first set of stats pretty quickly, but we wait at least 10\n// seconds to try to ensure the Firebase connection is established / settled.\nconst FIRST_STATS_MIN_TIME = 10 * 1000;\nconst FIRST_STATS_MAX_TIME = 30 * 1000;\n\n// We'll continue to report stats on average every 5 minutes.\nconst REPORT_STATS_INTERVAL = 5 * 60 * 1000;\n\nexport class StatsReporter {\n  private statsListener_: StatsListener;\n  statsToReport_: { [k: string]: boolean } = {};\n\n  /**\n   * @param collection\n   * @param server_\n   */\n  constructor(collection: StatsCollection, private server_: ServerActions) {\n    this.statsListener_ = new StatsListener(collection);\n\n    const timeout =\n      FIRST_STATS_MIN_TIME +\n      (FIRST_STATS_MAX_TIME - FIRST_STATS_MIN_TIME) * Math.random();\n    setTimeoutNonBlocking(this.reportStats_.bind(this), Math.floor(timeout));\n  }\n\n  private reportStats_() {\n    const stats = this.statsListener_.get();\n    const reportedStats: typeof stats = {};\n    let haveStatsToReport = false;\n\n    each(stats, (stat: string, value: number) => {\n      if (value > 0 && contains(this.statsToReport_, stat)) {\n        reportedStats[stat] = value;\n        haveStatsToReport = true;\n      }\n    });\n\n    if (haveStatsToReport) {\n      this.server_.reportStats(reportedStats);\n    }\n\n    // queue our next run.\n    setTimeoutNonBlocking(\n      this.reportStats_.bind(this),\n      Math.floor(Math.random() * 2 * REPORT_STATS_INTERVAL)\n    );\n  }\n}\n\nexport function statsReporterIncludeStat(\n  reporter: StatsReporter,\n  stat: string\n) {\n  reporter.statsToReport_[stat] = true;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Path, pathContains, pathEquals } from '../util/Path';\nimport { exceptionGuard, log, logger } from '../util/util';\nimport { Event } from './Event';\n\n/**\n * The event queue serves a few purposes:\n * 1. It ensures we maintain event order in the face of event callbacks doing operations that result in more\n *    events being queued.\n * 2. raiseQueuedEvents() handles being called reentrantly nicely.  That is, if in the course of raising events,\n *    raiseQueuedEvents() is called again, the \"inner\" call will pick up raising events where the \"outer\" call\n *    left off, ensuring that the events are still raised synchronously and in order.\n * 3. You can use raiseEventsAtPath and raiseEventsForChangedPath to ensure only relevant previously-queued\n *    events are raised synchronously.\n *\n * NOTE: This can all go away if/when we move to async events.\n *\n */\nexport class EventQueue {\n  eventLists_: EventList[] = [];\n\n  /**\n   * Tracks recursion depth of raiseQueuedEvents_, for debugging purposes.\n   */\n  recursionDepth_ = 0;\n}\n\n/**\n * @param eventDataList The new events to queue.\n */\nexport function eventQueueQueueEvents(\n  eventQueue: EventQueue,\n  eventDataList: Event[]\n) {\n  // We group events by path, storing them in a single EventList, to make it easier to skip over them quickly.\n  let currList: EventList | null = null;\n  for (let i = 0; i < eventDataList.length; i++) {\n    const data = eventDataList[i];\n    const path = data.getPath();\n    if (currList !== null && !pathEquals(path, currList.path)) {\n      eventQueue.eventLists_.push(currList);\n      currList = null;\n    }\n\n    if (currList === null) {\n      currList = { events: [], path };\n    }\n\n    currList.events.push(data);\n  }\n  if (currList) {\n    eventQueue.eventLists_.push(currList);\n  }\n}\n\n/**\n * Queues the specified events and synchronously raises all events (including previously queued ones)\n * for the specified path.\n *\n * It is assumed that the new events are all for the specified path.\n *\n * @param path The path to raise events for.\n * @param eventDataList The new events to raise.\n */\nexport function eventQueueRaiseEventsAtPath(\n  eventQueue: EventQueue,\n  path: Path,\n  eventDataList: Event[]\n) {\n  eventQueueQueueEvents(eventQueue, eventDataList);\n  eventQueueRaiseQueuedEventsMatchingPredicate(eventQueue, eventPath =>\n    pathEquals(eventPath, path)\n  );\n}\n\n/**\n * Queues the specified events and synchronously raises all events (including previously queued ones) for\n * locations related to the specified change path (i.e. all ancestors and descendants).\n *\n * It is assumed that the new events are all related (ancestor or descendant) to the specified path.\n *\n * @param changedPath The path to raise events for.\n * @param eventDataList The events to raise\n */\nexport function eventQueueRaiseEventsForChangedPath(\n  eventQueue: EventQueue,\n  changedPath: Path,\n  eventDataList: Event[]\n) {\n  eventQueueQueueEvents(eventQueue, eventDataList);\n  eventQueueRaiseQueuedEventsMatchingPredicate(\n    eventQueue,\n    eventPath =>\n      pathContains(eventPath, changedPath) ||\n      pathContains(changedPath, eventPath)\n  );\n}\n\nfunction eventQueueRaiseQueuedEventsMatchingPredicate(\n  eventQueue: EventQueue,\n  predicate: (path: Path) => boolean\n) {\n  eventQueue.recursionDepth_++;\n\n  let sentAll = true;\n  for (let i = 0; i < eventQueue.eventLists_.length; i++) {\n    const eventList = eventQueue.eventLists_[i];\n    if (eventList) {\n      const eventPath = eventList.path;\n      if (predicate(eventPath)) {\n        eventListRaise(eventQueue.eventLists_[i]);\n        eventQueue.eventLists_[i] = null;\n      } else {\n        sentAll = false;\n      }\n    }\n  }\n\n  if (sentAll) {\n    eventQueue.eventLists_ = [];\n  }\n\n  eventQueue.recursionDepth_--;\n}\n\ninterface EventList {\n  events: Event[];\n  path: Path;\n}\n\n/**\n * Iterates through the list and raises each event\n */\nfunction eventListRaise(eventList: EventList) {\n  for (let i = 0; i < eventList.events.length; i++) {\n    const eventData = eventList.events[i];\n    if (eventData !== null) {\n      eventList.events[i] = null;\n      const eventFn = eventData.getEventRunner();\n      if (logger) {\n        log('event: ' + eventData.toString());\n      }\n      exceptionGuard(eventFn);\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert } from '@firebase/util';\n\n/**\n * Base class to be used if you want to emit events. Call the constructor with\n * the set of allowed event names.\n */\nexport abstract class EventEmitter {\n  private listeners_: {\n    [eventType: string]: Array<{\n      callback(...args: unknown[]): void;\n      context: unknown;\n    }>;\n  } = {};\n\n  constructor(private allowedEvents_: string[]) {\n    assert(\n      Array.isArray(allowedEvents_) && allowedEvents_.length > 0,\n      'Requires a non-empty array'\n    );\n  }\n\n  /**\n   * To be overridden by derived classes in order to fire an initial event when\n   * somebody subscribes for data.\n   *\n   * @return {Array.<*>} Array of parameters to trigger initial event with.\n   */\n  abstract getInitialEvent(eventType: string): unknown[];\n\n  /**\n   * To be called by derived classes to trigger events.\n   */\n  protected trigger(eventType: string, ...varArgs: unknown[]) {\n    if (Array.isArray(this.listeners_[eventType])) {\n      // Clone the list, since callbacks could add/remove listeners.\n      const listeners = [...this.listeners_[eventType]];\n\n      for (let i = 0; i < listeners.length; i++) {\n        listeners[i].callback.apply(listeners[i].context, varArgs);\n      }\n    }\n  }\n\n  on(eventType: string, callback: (a: unknown) => void, context: unknown) {\n    this.validateEventType_(eventType);\n    this.listeners_[eventType] = this.listeners_[eventType] || [];\n    this.listeners_[eventType].push({ callback, context });\n\n    const eventData = this.getInitialEvent(eventType);\n    if (eventData) {\n      callback.apply(context, eventData);\n    }\n  }\n\n  off(eventType: string, callback: (a: unknown) => void, context: unknown) {\n    this.validateEventType_(eventType);\n    const listeners = this.listeners_[eventType] || [];\n    for (let i = 0; i < listeners.length; i++) {\n      if (\n        listeners[i].callback === callback &&\n        (!context || context === listeners[i].context)\n      ) {\n        listeners.splice(i, 1);\n        return;\n      }\n    }\n  }\n\n  private validateEventType_(eventType: string) {\n    assert(\n      this.allowedEvents_.find(et => {\n        return et === eventType;\n      }),\n      'Unknown event: ' + eventType\n    );\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { EventEmitter } from './EventEmitter';\nimport { assert } from '@firebase/util';\n\ndeclare const document: Document;\n\nexport class VisibilityMonitor extends EventEmitter {\n  private visible_: boolean;\n\n  static getInstance() {\n    return new VisibilityMonitor();\n  }\n\n  constructor() {\n    super(['visible']);\n    let hidden: string;\n    let visibilityChange: string;\n    if (\n      typeof document !== 'undefined' &&\n      typeof document.addEventListener !== 'undefined'\n    ) {\n      if (typeof document['hidden'] !== 'undefined') {\n        // Opera 12.10 and Firefox 18 and later support\n        visibilityChange = 'visibilitychange';\n        hidden = 'hidden';\n      } else if (typeof document['mozHidden'] !== 'undefined') {\n        visibilityChange = 'mozvisibilitychange';\n        hidden = 'mozHidden';\n      } else if (typeof document['msHidden'] !== 'undefined') {\n        visibilityChange = 'msvisibilitychange';\n        hidden = 'msHidden';\n      } else if (typeof document['webkitHidden'] !== 'undefined') {\n        visibilityChange = 'webkitvisibilitychange';\n        hidden = 'webkitHidden';\n      }\n    }\n\n    // Initially, we always assume we are visible. This ensures that in browsers\n    // without page visibility support or in cases where we are never visible\n    // (e.g. chrome extension), we act as if we are visible, i.e. don't delay\n    // reconnects\n    this.visible_ = true;\n\n    if (visibilityChange) {\n      document.addEventListener(\n        visibilityChange,\n        () => {\n          const visible = !document[hidden];\n          if (visible !== this.visible_) {\n            this.visible_ = visible;\n            this.trigger('visible', visible);\n          }\n        },\n        false\n      );\n    }\n  }\n\n  getInitialEvent(eventType: string): boolean[] {\n    assert(eventType === 'visible', 'Unknown event type: ' + eventType);\n    return [this.visible_];\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { assert, isMobileCordova } from '@firebase/util';\nimport { EventEmitter } from './EventEmitter';\n\n/**\n * Monitors online state (as reported by window.online/offline events).\n *\n * The expectation is that this could have many false positives (thinks we are online\n * when we're not), but no false negatives.  So we can safely use it to determine when\n * we definitely cannot reach the internet.\n */\nexport class OnlineMonitor extends EventEmitter {\n  private online_ = true;\n\n  static getInstance() {\n    return new OnlineMonitor();\n  }\n\n  constructor() {\n    super(['online']);\n\n    // We've had repeated complaints that Cordova apps can get stuck \"offline\", e.g.\n    // https://forum.ionicframework.com/t/firebase-connection-is-lost-and-never-come-back/43810\n    // It would seem that the 'online' event does not always fire consistently. So we disable it\n    // for Cordova.\n    if (\n      typeof window !== 'undefined' &&\n      typeof window.addEventListener !== 'undefined' &&\n      !isMobileCordova()\n    ) {\n      window.addEventListener(\n        'online',\n        () => {\n          if (!this.online_) {\n            this.online_ = true;\n            this.trigger('online', true);\n          }\n        },\n        false\n      );\n\n      window.addEventListener(\n        'offline',\n        () => {\n          if (this.online_) {\n            this.online_ = false;\n            this.trigger('online', false);\n          }\n        },\n        false\n      );\n    }\n  }\n\n  getInitialEvent(eventType: string): boolean[] {\n    assert(eventType === 'online', 'Unknown event type: ' + eventType);\n    return [this.online_];\n  }\n\n  currentlyOnline(): boolean {\n    return this.online_;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { exceptionGuard } from '../../core/util/util';\n\n/**\n * This class ensures the packets from the server arrive in order\n * This class takes data from the server and ensures it gets passed into the callbacks in order.\n */\nexport class PacketReceiver {\n  pendingResponses: unknown[] = [];\n  currentResponseNum = 0;\n  closeAfterResponse = -1;\n  onClose: (() => void) | null = null;\n\n  /**\n   * @param onMessage_\n   */\n  constructor(private onMessage_: (a: {}) => void) {}\n\n  closeAfter(responseNum: number, callback: () => void) {\n    this.closeAfterResponse = responseNum;\n    this.onClose = callback;\n    if (this.closeAfterResponse < this.currentResponseNum) {\n      this.onClose();\n      this.onClose = null;\n    }\n  }\n\n  /**\n   * Each message from the server comes with a response number, and an array of data. The responseNumber\n   * allows us to ensure that we process them in the right order, since we can't be guaranteed that all\n   * browsers will respond in the same order as the requests we sent\n   */\n  handleResponse(requestNum: number, data: unknown[]) {\n    this.pendingResponses[requestNum] = data;\n    while (this.pendingResponses[this.currentResponseNum]) {\n      const toProcess = this.pendingResponses[\n        this.currentResponseNum\n      ] as unknown[];\n      delete this.pendingResponses[this.currentResponseNum];\n      for (let i = 0; i < toProcess.length; ++i) {\n        if (toProcess[i]) {\n          exceptionGuard(() => {\n            this.onMessage_(toProcess[i]);\n          });\n        }\n      }\n      if (this.currentResponseNum === this.closeAfterResponse) {\n        if (this.onClose) {\n          this.onClose();\n          this.onClose = null;\n        }\n        break;\n      }\n      this.currentResponseNum++;\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  executeWhenDOMReady,\n  isChromeExtensionContentScript,\n  isWindowsStoreApp,\n  log,\n  logWrapper,\n  LUIDGenerator,\n  splitStringBySize\n} from '../core/util/util';\nimport { statsManagerGetCollection } from '../core/stats/StatsManager';\nimport { PacketReceiver } from './polling/PacketReceiver';\nimport {\n  APPLICATION_ID_PARAM,\n  FORGE_DOMAIN_RE,\n  FORGE_REF,\n  LAST_SESSION_PARAM,\n  LONG_POLLING,\n  PROTOCOL_VERSION,\n  REFERER_PARAM,\n  TRANSPORT_SESSION_PARAM,\n  VERSION_PARAM\n} from './Constants';\nimport { base64Encode, isNodeSdk, stringify } from '@firebase/util';\n\nimport { Transport } from './Transport';\nimport { RepoInfo, repoInfoConnectionURL } from '../core/RepoInfo';\nimport { StatsCollection } from '../core/stats/StatsCollection';\n\n// URL query parameters associated with longpolling\nexport const FIREBASE_LONGPOLL_START_PARAM = 'start';\nexport const FIREBASE_LONGPOLL_CLOSE_COMMAND = 'close';\nexport const FIREBASE_LONGPOLL_COMMAND_CB_NAME = 'pLPCommand';\nexport const FIREBASE_LONGPOLL_DATA_CB_NAME = 'pRTLPCB';\nexport const FIREBASE_LONGPOLL_ID_PARAM = 'id';\nexport const FIREBASE_LONGPOLL_PW_PARAM = 'pw';\nexport const FIREBASE_LONGPOLL_SERIAL_PARAM = 'ser';\nexport const FIREBASE_LONGPOLL_CALLBACK_ID_PARAM = 'cb';\nexport const FIREBASE_LONGPOLL_SEGMENT_NUM_PARAM = 'seg';\nexport const FIREBASE_LONGPOLL_SEGMENTS_IN_PACKET = 'ts';\nexport const FIREBASE_LONGPOLL_DATA_PARAM = 'd';\nexport const FIREBASE_LONGPOLL_DISCONN_FRAME_PARAM = 'disconn';\nexport const FIREBASE_LONGPOLL_DISCONN_FRAME_REQUEST_PARAM = 'dframe';\n\n//Data size constants.\n//TODO: Perf: the maximum length actually differs from browser to browser.\n// We should check what browser we're on and set accordingly.\nconst MAX_URL_DATA_SIZE = 1870;\nconst SEG_HEADER_SIZE = 30; //ie: &seg=8299234&ts=982389123&d=\nconst MAX_PAYLOAD_SIZE = MAX_URL_DATA_SIZE - SEG_HEADER_SIZE;\n\n/**\n * Keepalive period\n * send a fresh request at minimum every 25 seconds. Opera has a maximum request\n * length of 30 seconds that we can't exceed.\n */\nconst KEEPALIVE_REQUEST_INTERVAL = 25000;\n\n/**\n * How long to wait before aborting a long-polling connection attempt.\n */\nconst LP_CONNECT_TIMEOUT = 30000;\n\n/**\n * This class manages a single long-polling connection.\n */\nexport class BrowserPollConnection implements Transport {\n  bytesSent = 0;\n  bytesReceived = 0;\n  urlFn: (params: object) => string;\n  scriptTagHolder: FirebaseIFrameScriptHolder;\n  myDisconnFrame: HTMLIFrameElement;\n  curSegmentNum: number;\n  myPacketOrderer: PacketReceiver;\n  id: string;\n  password: string;\n  private log_: (...a: unknown[]) => void;\n  private stats_: StatsCollection;\n  private everConnected_ = false;\n  private isClosed_: boolean;\n  private connectTimeoutTimer_: number | null;\n  private onDisconnect_: ((a?: boolean) => void) | null;\n\n  /**\n   * @param connId An identifier for this connection, used for logging\n   * @param repoInfo The info for the endpoint to send data to.\n   * @param applicationId The Firebase App ID for this project.\n   * @param transportSessionId Optional transportSessionid if we are reconnecting for an existing\n   *                                         transport session\n   * @param lastSessionId Optional lastSessionId if the PersistentConnection has already created a\n   *                                     connection previously\n   */\n  constructor(\n    public connId: string,\n    public repoInfo: RepoInfo,\n    private applicationId?: string,\n    public transportSessionId?: string,\n    public lastSessionId?: string\n  ) {\n    this.log_ = logWrapper(connId);\n    this.stats_ = statsManagerGetCollection(repoInfo);\n    this.urlFn = (params: { [k: string]: string }) =>\n      repoInfoConnectionURL(repoInfo, LONG_POLLING, params);\n  }\n\n  /**\n   * @param onMessage Callback when messages arrive\n   * @param onDisconnect Callback with connection lost.\n   */\n  open(onMessage: (msg: {}) => void, onDisconnect: (a?: boolean) => void) {\n    this.curSegmentNum = 0;\n    this.onDisconnect_ = onDisconnect;\n    this.myPacketOrderer = new PacketReceiver(onMessage);\n    this.isClosed_ = false;\n\n    this.connectTimeoutTimer_ = setTimeout(() => {\n      this.log_('Timed out trying to connect.');\n      // Make sure we clear the host cache\n      this.onClosed_();\n      this.connectTimeoutTimer_ = null;\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    }, Math.floor(LP_CONNECT_TIMEOUT)) as any;\n\n    // Ensure we delay the creation of the iframe until the DOM is loaded.\n    executeWhenDOMReady(() => {\n      if (this.isClosed_) {\n        return;\n      }\n\n      //Set up a callback that gets triggered once a connection is set up.\n      this.scriptTagHolder = new FirebaseIFrameScriptHolder(\n        (...args) => {\n          const [command, arg1, arg2, arg3, arg4] = args;\n          this.incrementIncomingBytes_(args);\n          if (!this.scriptTagHolder) {\n            return; // we closed the connection.\n          }\n\n          if (this.connectTimeoutTimer_) {\n            clearTimeout(this.connectTimeoutTimer_);\n            this.connectTimeoutTimer_ = null;\n          }\n          this.everConnected_ = true;\n          if (command === FIREBASE_LONGPOLL_START_PARAM) {\n            this.id = arg1 as string;\n            this.password = arg2 as string;\n          } else if (command === FIREBASE_LONGPOLL_CLOSE_COMMAND) {\n            // Don't clear the host cache. We got a response from the server, so we know it's reachable\n            if (arg1) {\n              // We aren't expecting any more data (other than what the server's already in the process of sending us\n              // through our already open polls), so don't send any more.\n              this.scriptTagHolder.sendNewPolls = false;\n\n              // arg1 in this case is the last response number sent by the server. We should try to receive\n              // all of the responses up to this one before closing\n              this.myPacketOrderer.closeAfter(arg1 as number, () => {\n                this.onClosed_();\n              });\n            } else {\n              this.onClosed_();\n            }\n          } else {\n            throw new Error('Unrecognized command received: ' + command);\n          }\n        },\n        (...args) => {\n          const [pN, data] = args;\n          this.incrementIncomingBytes_(args);\n          this.myPacketOrderer.handleResponse(pN as number, data as unknown[]);\n        },\n        () => {\n          this.onClosed_();\n        },\n        this.urlFn\n      );\n\n      //Send the initial request to connect. The serial number is simply to keep the browser from pulling previous results\n      //from cache.\n      const urlParams: { [k: string]: string | number } = {};\n      urlParams[FIREBASE_LONGPOLL_START_PARAM] = 't';\n      urlParams[FIREBASE_LONGPOLL_SERIAL_PARAM] = Math.floor(\n        Math.random() * 100000000\n      );\n      if (this.scriptTagHolder.uniqueCallbackIdentifier) {\n        urlParams[\n          FIREBASE_LONGPOLL_CALLBACK_ID_PARAM\n        ] = this.scriptTagHolder.uniqueCallbackIdentifier;\n      }\n      urlParams[VERSION_PARAM] = PROTOCOL_VERSION;\n      if (this.transportSessionId) {\n        urlParams[TRANSPORT_SESSION_PARAM] = this.transportSessionId;\n      }\n      if (this.lastSessionId) {\n        urlParams[LAST_SESSION_PARAM] = this.lastSessionId;\n      }\n      if (this.applicationId) {\n        urlParams[APPLICATION_ID_PARAM] = this.applicationId;\n      }\n      if (\n        typeof location !== 'undefined' &&\n        location.hostname &&\n        FORGE_DOMAIN_RE.test(location.hostname)\n      ) {\n        urlParams[REFERER_PARAM] = FORGE_REF;\n      }\n      const connectURL = this.urlFn(urlParams);\n      this.log_('Connecting via long-poll to ' + connectURL);\n      this.scriptTagHolder.addTag(connectURL, () => {\n        /* do nothing */\n      });\n    });\n  }\n\n  /**\n   * Call this when a handshake has completed successfully and we want to consider the connection established\n   */\n  start() {\n    this.scriptTagHolder.startLongPoll(this.id, this.password);\n    this.addDisconnectPingFrame(this.id, this.password);\n  }\n\n  private static forceAllow_: boolean;\n\n  /**\n   * Forces long polling to be considered as a potential transport\n   */\n  static forceAllow() {\n    BrowserPollConnection.forceAllow_ = true;\n  }\n\n  private static forceDisallow_: boolean;\n\n  /**\n   * Forces longpolling to not be considered as a potential transport\n   */\n  static forceDisallow() {\n    BrowserPollConnection.forceDisallow_ = true;\n  }\n\n  // Static method, use string literal so it can be accessed in a generic way\n  static isAvailable() {\n    if (isNodeSdk()) {\n      return false;\n    } else if (BrowserPollConnection.forceAllow_) {\n      return true;\n    } else {\n      // NOTE: In React-Native there's normally no 'document', but if you debug a React-Native app in\n      // the Chrome debugger, 'document' is defined, but document.createElement is null (2015/06/08).\n      return (\n        !BrowserPollConnection.forceDisallow_ &&\n        typeof document !== 'undefined' &&\n        document.createElement != null &&\n        !isChromeExtensionContentScript() &&\n        !isWindowsStoreApp()\n      );\n    }\n  }\n\n  /**\n   * No-op for polling\n   */\n  markConnectionHealthy() {}\n\n  /**\n   * Stops polling and cleans up the iframe\n   */\n  private shutdown_() {\n    this.isClosed_ = true;\n\n    if (this.scriptTagHolder) {\n      this.scriptTagHolder.close();\n      this.scriptTagHolder = null;\n    }\n\n    //remove the disconnect frame, which will trigger an XHR call to the server to tell it we're leaving.\n    if (this.myDisconnFrame) {\n      document.body.removeChild(this.myDisconnFrame);\n      this.myDisconnFrame = null;\n    }\n\n    if (this.connectTimeoutTimer_) {\n      clearTimeout(this.connectTimeoutTimer_);\n      this.connectTimeoutTimer_ = null;\n    }\n  }\n\n  /**\n   * Triggered when this transport is closed\n   */\n  private onClosed_() {\n    if (!this.isClosed_) {\n      this.log_('Longpoll is closing itself');\n      this.shutdown_();\n\n      if (this.onDisconnect_) {\n        this.onDisconnect_(this.everConnected_);\n        this.onDisconnect_ = null;\n      }\n    }\n  }\n\n  /**\n   * External-facing close handler. RealTime has requested we shut down. Kill our connection and tell the server\n   * that we've left.\n   */\n  close() {\n    if (!this.isClosed_) {\n      this.log_('Longpoll is being closed.');\n      this.shutdown_();\n    }\n  }\n\n  /**\n   * Send the JSON object down to the server. It will need to be stringified, base64 encoded, and then\n   * broken into chunks (since URLs have a small maximum length).\n   * @param data The JSON data to transmit.\n   */\n  send(data: {}) {\n    const dataStr = stringify(data);\n    this.bytesSent += dataStr.length;\n    this.stats_.incrementCounter('bytes_sent', dataStr.length);\n\n    //first, lets get the base64-encoded data\n    const base64data = base64Encode(dataStr);\n\n    //We can only fit a certain amount in each URL, so we need to split this request\n    //up into multiple pieces if it doesn't fit in one request.\n    const dataSegs = splitStringBySize(base64data, MAX_PAYLOAD_SIZE);\n\n    //Enqueue each segment for transmission. We assign each chunk a sequential ID and a total number\n    //of segments so that we can reassemble the packet on the server.\n    for (let i = 0; i < dataSegs.length; i++) {\n      this.scriptTagHolder.enqueueSegment(\n        this.curSegmentNum,\n        dataSegs.length,\n        dataSegs[i]\n      );\n      this.curSegmentNum++;\n    }\n  }\n\n  /**\n   * This is how we notify the server that we're leaving.\n   * We aren't able to send requests with DHTML on a window close event, but we can\n   * trigger XHR requests in some browsers (everything but Opera basically).\n   */\n  addDisconnectPingFrame(id: string, pw: string) {\n    if (isNodeSdk()) {\n      return;\n    }\n    this.myDisconnFrame = document.createElement('iframe');\n    const urlParams: { [k: string]: string } = {};\n    urlParams[FIREBASE_LONGPOLL_DISCONN_FRAME_REQUEST_PARAM] = 't';\n    urlParams[FIREBASE_LONGPOLL_ID_PARAM] = id;\n    urlParams[FIREBASE_LONGPOLL_PW_PARAM] = pw;\n    this.myDisconnFrame.src = this.urlFn(urlParams);\n    this.myDisconnFrame.style.display = 'none';\n\n    document.body.appendChild(this.myDisconnFrame);\n  }\n\n  /**\n   * Used to track the bytes received by this client\n   */\n  private incrementIncomingBytes_(args: unknown) {\n    // TODO: This is an annoying perf hit just to track the number of incoming bytes.  Maybe it should be opt-in.\n    const bytesReceived = stringify(args).length;\n    this.bytesReceived += bytesReceived;\n    this.stats_.incrementCounter('bytes_received', bytesReceived);\n  }\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport interface IFrameElement extends HTMLIFrameElement {\n  doc: Document;\n}\n\n/*********************************************************************************************\n * A wrapper around an iframe that is used as a long-polling script holder.\n *********************************************************************************************/\nexport class FirebaseIFrameScriptHolder {\n  //We maintain a count of all of the outstanding requests, because if we have too many active at once it can cause\n  //problems in some browsers.\n  outstandingRequests = new Set<number>();\n\n  //A queue of the pending segments waiting for transmission to the server.\n  pendingSegs: Array<{ seg: number; ts: number; d: unknown }> = [];\n\n  //A serial number. We use this for two things:\n  // 1) A way to ensure the browser doesn't cache responses to polls\n  // 2) A way to make the server aware when long-polls arrive in a different order than we started them. The\n  //    server needs to release both polls in this case or it will cause problems in Opera since Opera can only execute\n  //    JSONP code in the order it was added to the iframe.\n  currentSerial = Math.floor(Math.random() * 100000000);\n\n  // This gets set to false when we're \"closing down\" the connection (e.g. we're switching transports but there's still\n  // incoming data from the server that we're waiting for).\n  sendNewPolls = true;\n\n  uniqueCallbackIdentifier: number;\n  myIFrame: IFrameElement;\n  alive: boolean;\n  myID: string;\n  myPW: string;\n  commandCB: (command: string, ...args: unknown[]) => void;\n  onMessageCB: (...args: unknown[]) => void;\n\n  /**\n   * @param commandCB - The callback to be called when control commands are recevied from the server.\n   * @param onMessageCB - The callback to be triggered when responses arrive from the server.\n   * @param onDisconnect - The callback to be triggered when this tag holder is closed\n   * @param urlFn - A function that provides the URL of the endpoint to send data to.\n   */\n  constructor(\n    commandCB: (command: string, ...args: unknown[]) => void,\n    onMessageCB: (...args: unknown[]) => void,\n    public onDisconnect: () => void,\n    public urlFn: (a: object) => string\n  ) {\n    if (!isNodeSdk()) {\n      //Each script holder registers a couple of uniquely named callbacks with the window. These are called from the\n      //iframes where we put the long-polling script tags. We have two callbacks:\n      //   1) Command Callback - Triggered for control issues, like starting a connection.\n      //   2) Message Callback - Triggered when new data arrives.\n      this.uniqueCallbackIdentifier = LUIDGenerator();\n      window[\n        FIREBASE_LONGPOLL_COMMAND_CB_NAME + this.uniqueCallbackIdentifier\n      ] = commandCB;\n      window[\n        FIREBASE_LONGPOLL_DATA_CB_NAME + this.uniqueCallbackIdentifier\n      ] = onMessageCB;\n\n      //Create an iframe for us to add script tags to.\n      this.myIFrame = FirebaseIFrameScriptHolder.createIFrame_();\n\n      // Set the iframe's contents.\n      let script = '';\n      // if we set a javascript url, it's IE and we need to set the document domain. The javascript url is sufficient\n      // for ie9, but ie8 needs to do it again in the document itself.\n      if (\n        this.myIFrame.src &&\n        this.myIFrame.src.substr(0, 'javascript:'.length) === 'javascript:'\n      ) {\n        const currentDomain = document.domain;\n        script = '<script>document.domain=\"' + currentDomain + '\";</script>';\n      }\n      const iframeContents = '<html><body>' + script + '</body></html>';\n      try {\n        this.myIFrame.doc.open();\n        this.myIFrame.doc.write(iframeContents);\n        this.myIFrame.doc.close();\n      } catch (e) {\n        log('frame writing exception');\n        if (e.stack) {\n          log(e.stack);\n        }\n        log(e);\n      }\n    } else {\n      this.commandCB = commandCB;\n      this.onMessageCB = onMessageCB;\n    }\n  }\n\n  /**\n   * Each browser has its own funny way to handle iframes. Here we mush them all together into one object that I can\n   * actually use.\n   */\n  private static createIFrame_(): IFrameElement {\n    const iframe = document.createElement('iframe') as IFrameElement;\n    iframe.style.display = 'none';\n\n    // This is necessary in order to initialize the document inside the iframe\n    if (document.body) {\n      document.body.appendChild(iframe);\n      try {\n        // If document.domain has been modified in IE, this will throw an error, and we need to set the\n        // domain of the iframe's document manually. We can do this via a javascript: url as the src attribute\n        // Also note that we must do this *after* the iframe has been appended to the page. Otherwise it doesn't work.\n        const a = iframe.contentWindow.document;\n        if (!a) {\n          // Apologies for the log-spam, I need to do something to keep closure from optimizing out the assignment above.\n          log('No IE domain setting required');\n        }\n      } catch (e) {\n        const domain = document.domain;\n        iframe.src =\n          \"javascript:void((function(){document.open();document.domain='\" +\n          domain +\n          \"';document.close();})())\";\n      }\n    } else {\n      // LongPollConnection attempts to delay initialization until the document is ready, so hopefully this\n      // never gets hit.\n      throw 'Document body has not initialized. Wait to initialize Firebase until after the document is ready.';\n    }\n\n    // Get the document of the iframe in a browser-specific way.\n    if (iframe.contentDocument) {\n      iframe.doc = iframe.contentDocument; // Firefox, Opera, Safari\n    } else if (iframe.contentWindow) {\n      iframe.doc = iframe.contentWindow.document; // Internet Explorer\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    } else if ((iframe as any).document) {\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      iframe.doc = (iframe as any).document; //others?\n    }\n\n    return iframe;\n  }\n\n  /**\n   * Cancel all outstanding queries and remove the frame.\n   */\n  close() {\n    //Mark this iframe as dead, so no new requests are sent.\n    this.alive = false;\n\n    if (this.myIFrame) {\n      //We have to actually remove all of the html inside this iframe before removing it from the\n      //window, or IE will continue loading and executing the script tags we've already added, which\n      //can lead to some errors being thrown. Setting innerHTML seems to be the easiest way to do this.\n      this.myIFrame.doc.body.innerHTML = '';\n      setTimeout(() => {\n        if (this.myIFrame !== null) {\n          document.body.removeChild(this.myIFrame);\n          this.myIFrame = null;\n        }\n      }, Math.floor(0));\n    }\n\n    // Protect from being called recursively.\n    const onDisconnect = this.onDisconnect;\n    if (onDisconnect) {\n      this.onDisconnect = null;\n      onDisconnect();\n    }\n  }\n\n  /**\n   * Actually start the long-polling session by adding the first script tag(s) to the iframe.\n   * @param id - The ID of this connection\n   * @param pw - The password for this connection\n   */\n  startLongPoll(id: string, pw: string) {\n    this.myID = id;\n    this.myPW = pw;\n    this.alive = true;\n\n    //send the initial request. If there are requests queued, make sure that we transmit as many as we are currently able to.\n    while (this.newRequest_()) {}\n  }\n\n  /**\n   * This is called any time someone might want a script tag to be added. It adds a script tag when there aren't\n   * too many outstanding requests and we are still alive.\n   *\n   * If there are outstanding packet segments to send, it sends one. If there aren't, it sends a long-poll anyways if\n   * needed.\n   */\n  private newRequest_() {\n    // We keep one outstanding request open all the time to receive data, but if we need to send data\n    // (pendingSegs.length > 0) then we create a new request to send the data.  The server will automatically\n    // close the old request.\n    if (\n      this.alive &&\n      this.sendNewPolls &&\n      this.outstandingRequests.size < (this.pendingSegs.length > 0 ? 2 : 1)\n    ) {\n      //construct our url\n      this.currentSerial++;\n      const urlParams: { [k: string]: string | number } = {};\n      urlParams[FIREBASE_LONGPOLL_ID_PARAM] = this.myID;\n      urlParams[FIREBASE_LONGPOLL_PW_PARAM] = this.myPW;\n      urlParams[FIREBASE_LONGPOLL_SERIAL_PARAM] = this.currentSerial;\n      let theURL = this.urlFn(urlParams);\n      //Now add as much data as we can.\n      let curDataString = '';\n      let i = 0;\n\n      while (this.pendingSegs.length > 0) {\n        //first, lets see if the next segment will fit.\n        const nextSeg = this.pendingSegs[0];\n        if (\n          (nextSeg.d as unknown[]).length +\n            SEG_HEADER_SIZE +\n            curDataString.length <=\n          MAX_URL_DATA_SIZE\n        ) {\n          //great, the segment will fit. Lets append it.\n          const theSeg = this.pendingSegs.shift();\n          curDataString =\n            curDataString +\n            '&' +\n            FIREBASE_LONGPOLL_SEGMENT_NUM_PARAM +\n            i +\n            '=' +\n            theSeg.seg +\n            '&' +\n            FIREBASE_LONGPOLL_SEGMENTS_IN_PACKET +\n            i +\n            '=' +\n            theSeg.ts +\n            '&' +\n            FIREBASE_LONGPOLL_DATA_PARAM +\n            i +\n            '=' +\n            theSeg.d;\n          i++;\n        } else {\n          break;\n        }\n      }\n\n      theURL = theURL + curDataString;\n      this.addLongPollTag_(theURL, this.currentSerial);\n\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  /**\n   * Queue a packet for transmission to the server.\n   * @param segnum - A sequential id for this packet segment used for reassembly\n   * @param totalsegs - The total number of segments in this packet\n   * @param data - The data for this segment.\n   */\n  enqueueSegment(segnum: number, totalsegs: number, data: unknown) {\n    //add this to the queue of segments to send.\n    this.pendingSegs.push({ seg: segnum, ts: totalsegs, d: data });\n\n    //send the data immediately if there isn't already data being transmitted, unless\n    //startLongPoll hasn't been called yet.\n    if (this.alive) {\n      this.newRequest_();\n    }\n  }\n\n  /**\n   * Add a script tag for a regular long-poll request.\n   * @param url - The URL of the script tag.\n   * @param serial - The serial number of the request.\n   */\n  private addLongPollTag_(url: string, serial: number) {\n    //remember that we sent this request.\n    this.outstandingRequests.add(serial);\n\n    const doNewRequest = () => {\n      this.outstandingRequests.delete(serial);\n      this.newRequest_();\n    };\n\n    // If this request doesn't return on its own accord (by the server sending us some data), we'll\n    // create a new one after the KEEPALIVE interval to make sure we always keep a fresh request open.\n    const keepaliveTimeout = setTimeout(\n      doNewRequest,\n      Math.floor(KEEPALIVE_REQUEST_INTERVAL)\n    );\n\n    const readyStateCB = () => {\n      // Request completed.  Cancel the keepalive.\n      clearTimeout(keepaliveTimeout);\n\n      // Trigger a new request so we can continue receiving data.\n      doNewRequest();\n    };\n\n    this.addTag(url, readyStateCB);\n  }\n\n  /**\n   * Add an arbitrary script tag to the iframe.\n   * @param url - The URL for the script tag source.\n   * @param loadCB - A callback to be triggered once the script has loaded.\n   */\n  addTag(url: string, loadCB: () => void) {\n    if (isNodeSdk()) {\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      (this as any).doNodeLongPoll(url, loadCB);\n    } else {\n      setTimeout(() => {\n        try {\n          // if we're already closed, don't add this poll\n          if (!this.sendNewPolls) {\n            return;\n          }\n          const newScript = this.myIFrame.doc.createElement('script');\n          newScript.type = 'text/javascript';\n          newScript.async = true;\n          newScript.src = url;\n          // eslint-disable-next-line @typescript-eslint/no-explicit-any\n          newScript.onload = (newScript as any).onreadystatechange = function () {\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            const rstate = (newScript as any).readyState;\n            if (!rstate || rstate === 'loaded' || rstate === 'complete') {\n              // eslint-disable-next-line @typescript-eslint/no-explicit-any\n              newScript.onload = (newScript as any).onreadystatechange = null;\n              if (newScript.parentNode) {\n                newScript.parentNode.removeChild(newScript);\n              }\n              loadCB();\n            }\n          };\n          newScript.onerror = () => {\n            log('Long-poll script failed to load: ' + url);\n            this.sendNewPolls = false;\n            this.close();\n          };\n          this.myIFrame.doc.body.appendChild(newScript);\n        } catch (e) {\n          // TODO: we should make this error visible somehow\n        }\n      }, Math.floor(1));\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2019 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/** The semver (www.semver.org) version of the SDK. */\nexport let SDK_VERSION = '';\n\n// SDK_VERSION should be set before any database instance is created\nexport function setSDKVersion(version: string): void {\n  SDK_VERSION = version;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { RepoInfo, repoInfoConnectionURL } from '../core/RepoInfo';\nimport { assert, isNodeSdk, jsonEval, stringify } from '@firebase/util';\nimport { logWrapper, splitStringBySize } from '../core/util/util';\nimport { statsManagerGetCollection } from '../core/stats/StatsManager';\nimport {\n  FORGE_DOMAIN_RE,\n  FORGE_REF,\n  LAST_SESSION_PARAM,\n  PROTOCOL_VERSION,\n  REFERER_PARAM,\n  TRANSPORT_SESSION_PARAM,\n  VERSION_PARAM,\n  WEBSOCKET\n} from './Constants';\nimport { PersistentStorage } from '../core/storage/storage';\nimport { Transport } from './Transport';\nimport { StatsCollection } from '../core/stats/StatsCollection';\nimport { SDK_VERSION } from '../core/version';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\ndeclare const MozWebSocket: any;\n\nconst WEBSOCKET_MAX_FRAME_SIZE = 16384;\nconst WEBSOCKET_KEEPALIVE_INTERVAL = 45000;\n\nlet WebSocketImpl = null;\nif (typeof MozWebSocket !== 'undefined') {\n  WebSocketImpl = MozWebSocket;\n} else if (typeof WebSocket !== 'undefined') {\n  WebSocketImpl = WebSocket;\n}\n\nexport function setWebSocketImpl(impl) {\n  WebSocketImpl = impl;\n}\n\n/**\n * Create a new websocket connection with the given callbacks.\n */\nexport class WebSocketConnection implements Transport {\n  keepaliveTimer: number | null = null;\n  frames: string[] | null = null;\n  totalFrames = 0;\n  bytesSent = 0;\n  bytesReceived = 0;\n  connURL: string;\n  onDisconnect: (a?: boolean) => void;\n  onMessage: (msg: {}) => void;\n  mySock: WebSocket | null;\n  private log_: (...a: unknown[]) => void;\n  private stats_: StatsCollection;\n  private everConnected_: boolean;\n  private isClosed_: boolean;\n  private nodeAdmin: boolean;\n\n  /**\n   * @param connId identifier for this transport\n   * @param repoInfo The info for the websocket endpoint.\n   * @param applicationId The Firebase App ID for this project.\n   * @param transportSessionId Optional transportSessionId if this is connecting to an existing transport\n   *                                         session\n   * @param lastSessionId Optional lastSessionId if there was a previous connection\n   */\n  constructor(\n    public connId: string,\n    repoInfo: RepoInfo,\n    private applicationId?: string,\n    transportSessionId?: string,\n    lastSessionId?: string\n  ) {\n    this.log_ = logWrapper(this.connId);\n    this.stats_ = statsManagerGetCollection(repoInfo);\n    this.connURL = WebSocketConnection.connectionURL_(\n      repoInfo,\n      transportSessionId,\n      lastSessionId\n    );\n    this.nodeAdmin = repoInfo.nodeAdmin;\n  }\n\n  /**\n   * @param repoInfo The info for the websocket endpoint.\n   * @param transportSessionId Optional transportSessionId if this is connecting to an existing transport\n   *                                         session\n   * @param lastSessionId Optional lastSessionId if there was a previous connection\n   * @return connection url\n   */\n  private static connectionURL_(\n    repoInfo: RepoInfo,\n    transportSessionId?: string,\n    lastSessionId?: string\n  ): string {\n    const urlParams: { [k: string]: string } = {};\n    urlParams[VERSION_PARAM] = PROTOCOL_VERSION;\n\n    if (\n      !isNodeSdk() &&\n      typeof location !== 'undefined' &&\n      location.hostname &&\n      FORGE_DOMAIN_RE.test(location.hostname)\n    ) {\n      urlParams[REFERER_PARAM] = FORGE_REF;\n    }\n    if (transportSessionId) {\n      urlParams[TRANSPORT_SESSION_PARAM] = transportSessionId;\n    }\n    if (lastSessionId) {\n      urlParams[LAST_SESSION_PARAM] = lastSessionId;\n    }\n    return repoInfoConnectionURL(repoInfo, WEBSOCKET, urlParams);\n  }\n\n  /**\n   * @param onMessage Callback when messages arrive\n   * @param onDisconnect Callback with connection lost.\n   */\n  open(onMessage: (msg: {}) => void, onDisconnect: (a?: boolean) => void) {\n    this.onDisconnect = onDisconnect;\n    this.onMessage = onMessage;\n\n    this.log_('Websocket connecting to ' + this.connURL);\n\n    this.everConnected_ = false;\n    // Assume failure until proven otherwise.\n    PersistentStorage.set('previous_websocket_failure', true);\n\n    try {\n      if (isNodeSdk()) {\n        const device = this.nodeAdmin ? 'AdminNode' : 'Node';\n        // UA Format: Firebase/<wire_protocol>/<sdk_version>/<platform>/<device>\n        const options: { [k: string]: object } = {\n          headers: {\n            'User-Agent': `Firebase/${PROTOCOL_VERSION}/${SDK_VERSION}/${process.platform}/${device}`,\n            'X-Firebase-GMPID': this.applicationId || ''\n          }\n        };\n\n        // Plumb appropriate http_proxy environment variable into faye-websocket if it exists.\n        const env = process['env'];\n        const proxy =\n          this.connURL.indexOf('wss://') === 0\n            ? env['HTTPS_PROXY'] || env['https_proxy']\n            : env['HTTP_PROXY'] || env['http_proxy'];\n\n        if (proxy) {\n          options['proxy'] = { origin: proxy };\n        }\n\n        this.mySock = new WebSocketImpl(this.connURL, [], options);\n      } else {\n        const options: { [k: string]: object } = {\n          headers: {\n            'X-Firebase-GMPID': this.applicationId || ''\n          }\n        };\n        this.mySock = new WebSocketImpl(this.connURL, [], options);\n      }\n    } catch (e) {\n      this.log_('Error instantiating WebSocket.');\n      const error = e.message || e.data;\n      if (error) {\n        this.log_(error);\n      }\n      this.onClosed_();\n      return;\n    }\n\n    this.mySock.onopen = () => {\n      this.log_('Websocket connected.');\n      this.everConnected_ = true;\n    };\n\n    this.mySock.onclose = () => {\n      this.log_('Websocket connection was disconnected.');\n      this.mySock = null;\n      this.onClosed_();\n    };\n\n    this.mySock.onmessage = m => {\n      this.handleIncomingFrame(m as {});\n    };\n\n    this.mySock.onerror = e => {\n      this.log_('WebSocket error.  Closing connection.');\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      const error = (e as any).message || (e as any).data;\n      if (error) {\n        this.log_(error);\n      }\n      this.onClosed_();\n    };\n  }\n\n  /**\n   * No-op for websockets, we don't need to do anything once the connection is confirmed as open\n   */\n  start() {}\n\n  static forceDisallow_: boolean;\n\n  static forceDisallow() {\n    WebSocketConnection.forceDisallow_ = true;\n  }\n\n  static isAvailable(): boolean {\n    let isOldAndroid = false;\n    if (typeof navigator !== 'undefined' && navigator.userAgent) {\n      const oldAndroidRegex = /Android ([0-9]{0,}\\.[0-9]{0,})/;\n      const oldAndroidMatch = navigator.userAgent.match(oldAndroidRegex);\n      if (oldAndroidMatch && oldAndroidMatch.length > 1) {\n        if (parseFloat(oldAndroidMatch[1]) < 4.4) {\n          isOldAndroid = true;\n        }\n      }\n    }\n\n    return (\n      !isOldAndroid &&\n      WebSocketImpl !== null &&\n      !WebSocketConnection.forceDisallow_\n    );\n  }\n\n  /**\n   * Number of response before we consider the connection \"healthy.\"\n   */\n  static responsesRequiredToBeHealthy = 2;\n\n  /**\n   * Time to wait for the connection te become healthy before giving up.\n   */\n  static healthyTimeout = 30000;\n\n  /**\n   * Returns true if we previously failed to connect with this transport.\n   */\n  static previouslyFailed(): boolean {\n    // If our persistent storage is actually only in-memory storage,\n    // we default to assuming that it previously failed to be safe.\n    return (\n      PersistentStorage.isInMemoryStorage ||\n      PersistentStorage.get('previous_websocket_failure') === true\n    );\n  }\n\n  markConnectionHealthy() {\n    PersistentStorage.remove('previous_websocket_failure');\n  }\n\n  private appendFrame_(data: string) {\n    this.frames.push(data);\n    if (this.frames.length === this.totalFrames) {\n      const fullMess = this.frames.join('');\n      this.frames = null;\n      const jsonMess = jsonEval(fullMess) as object;\n\n      //handle the message\n      this.onMessage(jsonMess);\n    }\n  }\n\n  /**\n   * @param frameCount The number of frames we are expecting from the server\n   */\n  private handleNewFrameCount_(frameCount: number) {\n    this.totalFrames = frameCount;\n    this.frames = [];\n  }\n\n  /**\n   * Attempts to parse a frame count out of some text. If it can't, assumes a value of 1\n   * @return Any remaining data to be process, or null if there is none\n   */\n  private extractFrameCount_(data: string): string | null {\n    assert(this.frames === null, 'We already have a frame buffer');\n    // TODO: The server is only supposed to send up to 9999 frames (i.e. length <= 4), but that isn't being enforced\n    // currently.  So allowing larger frame counts (length <= 6).  See https://app.asana.com/0/search/8688598998380/8237608042508\n    if (data.length <= 6) {\n      const frameCount = Number(data);\n      if (!isNaN(frameCount)) {\n        this.handleNewFrameCount_(frameCount);\n        return null;\n      }\n    }\n    this.handleNewFrameCount_(1);\n    return data;\n  }\n\n  /**\n   * Process a websocket frame that has arrived from the server.\n   * @param mess The frame data\n   */\n  handleIncomingFrame(mess: { [k: string]: unknown }) {\n    if (this.mySock === null) {\n      return; // Chrome apparently delivers incoming packets even after we .close() the connection sometimes.\n    }\n    const data = mess['data'] as string;\n    this.bytesReceived += data.length;\n    this.stats_.incrementCounter('bytes_received', data.length);\n\n    this.resetKeepAlive();\n\n    if (this.frames !== null) {\n      // we're buffering\n      this.appendFrame_(data);\n    } else {\n      // try to parse out a frame count, otherwise, assume 1 and process it\n      const remainingData = this.extractFrameCount_(data);\n      if (remainingData !== null) {\n        this.appendFrame_(remainingData);\n      }\n    }\n  }\n\n  /**\n   * Send a message to the server\n   * @param data The JSON object to transmit\n   */\n  send(data: {}) {\n    this.resetKeepAlive();\n\n    const dataStr = stringify(data);\n    this.bytesSent += dataStr.length;\n    this.stats_.incrementCounter('bytes_sent', dataStr.length);\n\n    //We can only fit a certain amount in each websocket frame, so we need to split this request\n    //up into multiple pieces if it doesn't fit in one request.\n\n    const dataSegs = splitStringBySize(dataStr, WEBSOCKET_MAX_FRAME_SIZE);\n\n    //Send the length header\n    if (dataSegs.length > 1) {\n      this.sendString_(String(dataSegs.length));\n    }\n\n    //Send the actual data in segments.\n    for (let i = 0; i < dataSegs.length; i++) {\n      this.sendString_(dataSegs[i]);\n    }\n  }\n\n  private shutdown_() {\n    this.isClosed_ = true;\n    if (this.keepaliveTimer) {\n      clearInterval(this.keepaliveTimer);\n      this.keepaliveTimer = null;\n    }\n\n    if (this.mySock) {\n      this.mySock.close();\n      this.mySock = null;\n    }\n  }\n\n  private onClosed_() {\n    if (!this.isClosed_) {\n      this.log_('WebSocket is closing itself');\n      this.shutdown_();\n\n      // since this is an internal close, trigger the close listener\n      if (this.onDisconnect) {\n        this.onDisconnect(this.everConnected_);\n        this.onDisconnect = null;\n      }\n    }\n  }\n\n  /**\n   * External-facing close handler.\n   * Close the websocket and kill the connection.\n   */\n  close() {\n    if (!this.isClosed_) {\n      this.log_('WebSocket is being closed');\n      this.shutdown_();\n    }\n  }\n\n  /**\n   * Kill the current keepalive timer and start a new one, to ensure that it always fires N seconds after\n   * the last activity.\n   */\n  resetKeepAlive() {\n    clearInterval(this.keepaliveTimer);\n    this.keepaliveTimer = setInterval(() => {\n      //If there has been no websocket activity for a while, send a no-op\n      if (this.mySock) {\n        this.sendString_('0');\n      }\n      this.resetKeepAlive();\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    }, Math.floor(WEBSOCKET_KEEPALIVE_INTERVAL)) as any;\n  }\n\n  /**\n   * Send a string over the websocket.\n   *\n   * @param str String to send.\n   */\n  private sendString_(str: string) {\n    // Firefox seems to sometimes throw exceptions (NS_ERROR_UNEXPECTED) from websocket .send()\n    // calls for some unknown reason.  We treat these as an error and disconnect.\n    // See https://app.asana.com/0/58926111402292/68021340250410\n    try {\n      this.mySock.send(str);\n    } catch (e) {\n      this.log_(\n        'Exception thrown from WebSocket.send():',\n        e.message || e.data,\n        'Closing connection.'\n      );\n      setTimeout(this.onClosed_.bind(this), 0);\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { BrowserPollConnection } from './BrowserPollConnection';\nimport { WebSocketConnection } from './WebSocketConnection';\nimport { warn } from '../core/util/util';\nimport { TransportConstructor } from './Transport';\nimport { RepoInfo } from '../core/RepoInfo';\n\n/**\n * Currently simplistic, this class manages what transport a Connection should use at various stages of its\n * lifecycle.\n *\n * It starts with longpolling in a browser, and httppolling on node. It then upgrades to websockets if\n * they are available.\n */\nexport class TransportManager {\n  private transports_: TransportConstructor[];\n\n  static get ALL_TRANSPORTS() {\n    return [BrowserPollConnection, WebSocketConnection];\n  }\n\n  /**\n   * @param repoInfo Metadata around the namespace we're connecting to\n   */\n  constructor(repoInfo: RepoInfo) {\n    this.initTransports_(repoInfo);\n  }\n\n  private initTransports_(repoInfo: RepoInfo) {\n    const isWebSocketsAvailable: boolean =\n      WebSocketConnection && WebSocketConnection['isAvailable']();\n    let isSkipPollConnection =\n      isWebSocketsAvailable && !WebSocketConnection.previouslyFailed();\n\n    if (repoInfo.webSocketOnly) {\n      if (!isWebSocketsAvailable) {\n        warn(\n          \"wss:// URL used, but browser isn't known to support websockets.  Trying anyway.\"\n        );\n      }\n\n      isSkipPollConnection = true;\n    }\n\n    if (isSkipPollConnection) {\n      this.transports_ = [WebSocketConnection];\n    } else {\n      const transports = (this.transports_ = [] as TransportConstructor[]);\n      for (const transport of TransportManager.ALL_TRANSPORTS) {\n        if (transport && transport['isAvailable']()) {\n          transports.push(transport);\n        }\n      }\n    }\n  }\n\n  /**\n   * @return The constructor for the initial transport to use\n   */\n  initialTransport(): TransportConstructor {\n    if (this.transports_.length > 0) {\n      return this.transports_[0];\n    } else {\n      throw new Error('No transports available');\n    }\n  }\n\n  /**\n   * @return The constructor for the next transport, or null\n   */\n  upgradeTransport(): TransportConstructor | null {\n    if (this.transports_.length > 1) {\n      return this.transports_[1];\n    } else {\n      return null;\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  error,\n  logWrapper,\n  requireKey,\n  setTimeoutNonBlocking,\n  warn\n} from '../core/util/util';\nimport { PersistentStorage } from '../core/storage/storage';\nimport { PROTOCOL_VERSION } from './Constants';\nimport { TransportManager } from './TransportManager';\nimport { RepoInfo } from '../core/RepoInfo';\nimport { Transport, TransportConstructor } from './Transport';\nimport { Indexable } from '../core/util/misc';\n\n// Abort upgrade attempt if it takes longer than 60s.\nconst UPGRADE_TIMEOUT = 60000;\n\n// For some transports (WebSockets), we need to \"validate\" the transport by exchanging a few requests and responses.\n// If we haven't sent enough requests within 5s, we'll start sending noop ping requests.\nconst DELAY_BEFORE_SENDING_EXTRA_REQUESTS = 5000;\n\n// If the initial data sent triggers a lot of bandwidth (i.e. it's a large put or a listen for a large amount of data)\n// then we may not be able to exchange our ping/pong requests within the healthy timeout.  So if we reach the timeout\n// but we've sent/received enough bytes, we don't cancel the connection.\nconst BYTES_SENT_HEALTHY_OVERRIDE = 10 * 1024;\nconst BYTES_RECEIVED_HEALTHY_OVERRIDE = 100 * 1024;\n\nconst enum RealtimeState {\n  CONNECTING,\n  CONNECTED,\n  DISCONNECTED\n}\n\nconst MESSAGE_TYPE = 't';\nconst MESSAGE_DATA = 'd';\nconst CONTROL_SHUTDOWN = 's';\nconst CONTROL_RESET = 'r';\nconst CONTROL_ERROR = 'e';\nconst CONTROL_PONG = 'o';\nconst SWITCH_ACK = 'a';\nconst END_TRANSMISSION = 'n';\nconst PING = 'p';\n\nconst SERVER_HELLO = 'h';\n\n/**\n * Creates a new real-time connection to the server using whichever method works\n * best in the current browser.\n */\nexport class Connection {\n  connectionCount = 0;\n  pendingDataMessages: unknown[] = [];\n  sessionId: string;\n\n  private conn_: Transport;\n  private healthyTimeout_: number;\n  private isHealthy_: boolean;\n  private log_: (...args: unknown[]) => void;\n  private primaryResponsesRequired_: number;\n  private rx_: Transport;\n  private secondaryConn_: Transport;\n  private secondaryResponsesRequired_: number;\n  private state_ = RealtimeState.CONNECTING;\n  private transportManager_: TransportManager;\n  private tx_: Transport;\n\n  /**\n   * @param id - an id for this connection\n   * @param repoInfo_ - the info for the endpoint to connect to\n   * @param applicationId_ - the Firebase App ID for this project\n   * @param onMessage_ - the callback to be triggered when a server-push message arrives\n   * @param onReady_ - the callback to be triggered when this connection is ready to send messages.\n   * @param onDisconnect_ - the callback to be triggered when a connection was lost\n   * @param onKill_ - the callback to be triggered when this connection has permanently shut down.\n   * @param lastSessionId - last session id in persistent connection. is used to clean up old session in real-time server\n   */\n  constructor(\n    public id: string,\n    private repoInfo_: RepoInfo,\n    private applicationId_: string | undefined,\n    private onMessage_: (a: {}) => void,\n    private onReady_: (a: number, b: string) => void,\n    private onDisconnect_: () => void,\n    private onKill_: (a: string) => void,\n    public lastSessionId?: string\n  ) {\n    this.log_ = logWrapper('c:' + this.id + ':');\n    this.transportManager_ = new TransportManager(repoInfo_);\n    this.log_('Connection created');\n    this.start_();\n  }\n\n  /**\n   * Starts a connection attempt\n   */\n  private start_(): void {\n    const conn = this.transportManager_.initialTransport();\n    this.conn_ = new conn(\n      this.nextTransportId_(),\n      this.repoInfo_,\n      this.applicationId_,\n      undefined,\n      this.lastSessionId\n    );\n\n    // For certain transports (WebSockets), we need to send and receive several messages back and forth before we\n    // can consider the transport healthy.\n    this.primaryResponsesRequired_ = conn['responsesRequiredToBeHealthy'] || 0;\n\n    const onMessageReceived = this.connReceiver_(this.conn_);\n    const onConnectionLost = this.disconnReceiver_(this.conn_);\n    this.tx_ = this.conn_;\n    this.rx_ = this.conn_;\n    this.secondaryConn_ = null;\n    this.isHealthy_ = false;\n\n    /*\n     * Firefox doesn't like when code from one iframe tries to create another iframe by way of the parent frame.\n     * This can occur in the case of a redirect, i.e. we guessed wrong on what server to connect to and received a reset.\n     * Somehow, setTimeout seems to make this ok. That doesn't make sense from a security perspective, since you should\n     * still have the context of your originating frame.\n     */\n    setTimeout(() => {\n      // this.conn_ gets set to null in some of the tests. Check to make sure it still exists before using it\n      this.conn_ && this.conn_.open(onMessageReceived, onConnectionLost);\n    }, Math.floor(0));\n\n    const healthyTimeoutMS = conn['healthyTimeout'] || 0;\n    if (healthyTimeoutMS > 0) {\n      this.healthyTimeout_ = setTimeoutNonBlocking(() => {\n        this.healthyTimeout_ = null;\n        if (!this.isHealthy_) {\n          if (\n            this.conn_ &&\n            this.conn_.bytesReceived > BYTES_RECEIVED_HEALTHY_OVERRIDE\n          ) {\n            this.log_(\n              'Connection exceeded healthy timeout but has received ' +\n                this.conn_.bytesReceived +\n                ' bytes.  Marking connection healthy.'\n            );\n            this.isHealthy_ = true;\n            this.conn_.markConnectionHealthy();\n          } else if (\n            this.conn_ &&\n            this.conn_.bytesSent > BYTES_SENT_HEALTHY_OVERRIDE\n          ) {\n            this.log_(\n              'Connection exceeded healthy timeout but has sent ' +\n                this.conn_.bytesSent +\n                ' bytes.  Leaving connection alive.'\n            );\n            // NOTE: We don't want to mark it healthy, since we have no guarantee that the bytes have made it to\n            // the server.\n          } else {\n            this.log_('Closing unhealthy connection after timeout.');\n            this.close();\n          }\n        }\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      }, Math.floor(healthyTimeoutMS)) as any;\n    }\n  }\n\n  private nextTransportId_(): string {\n    return 'c:' + this.id + ':' + this.connectionCount++;\n  }\n\n  private disconnReceiver_(conn) {\n    return everConnected => {\n      if (conn === this.conn_) {\n        this.onConnectionLost_(everConnected);\n      } else if (conn === this.secondaryConn_) {\n        this.log_('Secondary connection lost.');\n        this.onSecondaryConnectionLost_();\n      } else {\n        this.log_('closing an old connection');\n      }\n    };\n  }\n\n  private connReceiver_(conn: Transport) {\n    return (message: Indexable) => {\n      if (this.state_ !== RealtimeState.DISCONNECTED) {\n        if (conn === this.rx_) {\n          this.onPrimaryMessageReceived_(message);\n        } else if (conn === this.secondaryConn_) {\n          this.onSecondaryMessageReceived_(message);\n        } else {\n          this.log_('message on old connection');\n        }\n      }\n    };\n  }\n\n  /**\n   * @param dataMsg An arbitrary data message to be sent to the server\n   */\n  sendRequest(dataMsg: object) {\n    // wrap in a data message envelope and send it on\n    const msg = { t: 'd', d: dataMsg };\n    this.sendData_(msg);\n  }\n\n  tryCleanupConnection() {\n    if (this.tx_ === this.secondaryConn_ && this.rx_ === this.secondaryConn_) {\n      this.log_(\n        'cleaning up and promoting a connection: ' + this.secondaryConn_.connId\n      );\n      this.conn_ = this.secondaryConn_;\n      this.secondaryConn_ = null;\n      // the server will shutdown the old connection\n    }\n  }\n\n  private onSecondaryControl_(controlData: { [k: string]: unknown }) {\n    if (MESSAGE_TYPE in controlData) {\n      const cmd = controlData[MESSAGE_TYPE] as string;\n      if (cmd === SWITCH_ACK) {\n        this.upgradeIfSecondaryHealthy_();\n      } else if (cmd === CONTROL_RESET) {\n        // Most likely the session wasn't valid. Abandon the switch attempt\n        this.log_('Got a reset on secondary, closing it');\n        this.secondaryConn_.close();\n        // If we were already using this connection for something, than we need to fully close\n        if (\n          this.tx_ === this.secondaryConn_ ||\n          this.rx_ === this.secondaryConn_\n        ) {\n          this.close();\n        }\n      } else if (cmd === CONTROL_PONG) {\n        this.log_('got pong on secondary.');\n        this.secondaryResponsesRequired_--;\n        this.upgradeIfSecondaryHealthy_();\n      }\n    }\n  }\n\n  private onSecondaryMessageReceived_(parsedData: Indexable) {\n    const layer: string = requireKey('t', parsedData) as string;\n    const data: unknown = requireKey('d', parsedData);\n    if (layer === 'c') {\n      this.onSecondaryControl_(data as Indexable);\n    } else if (layer === 'd') {\n      // got a data message, but we're still second connection. Need to buffer it up\n      this.pendingDataMessages.push(data);\n    } else {\n      throw new Error('Unknown protocol layer: ' + layer);\n    }\n  }\n\n  private upgradeIfSecondaryHealthy_() {\n    if (this.secondaryResponsesRequired_ <= 0) {\n      this.log_('Secondary connection is healthy.');\n      this.isHealthy_ = true;\n      this.secondaryConn_.markConnectionHealthy();\n      this.proceedWithUpgrade_();\n    } else {\n      // Send a ping to make sure the connection is healthy.\n      this.log_('sending ping on secondary.');\n      this.secondaryConn_.send({ t: 'c', d: { t: PING, d: {} } });\n    }\n  }\n\n  private proceedWithUpgrade_() {\n    // tell this connection to consider itself open\n    this.secondaryConn_.start();\n    // send ack\n    this.log_('sending client ack on secondary');\n    this.secondaryConn_.send({ t: 'c', d: { t: SWITCH_ACK, d: {} } });\n\n    // send end packet on primary transport, switch to sending on this one\n    // can receive on this one, buffer responses until end received on primary transport\n    this.log_('Ending transmission on primary');\n    this.conn_.send({ t: 'c', d: { t: END_TRANSMISSION, d: {} } });\n    this.tx_ = this.secondaryConn_;\n\n    this.tryCleanupConnection();\n  }\n\n  private onPrimaryMessageReceived_(parsedData: { [k: string]: unknown }) {\n    // Must refer to parsedData properties in quotes, so closure doesn't touch them.\n    const layer: string = requireKey('t', parsedData) as string;\n    const data: unknown = requireKey('d', parsedData);\n    if (layer === 'c') {\n      this.onControl_(data as { [k: string]: unknown });\n    } else if (layer === 'd') {\n      this.onDataMessage_(data);\n    }\n  }\n\n  private onDataMessage_(message: unknown) {\n    this.onPrimaryResponse_();\n\n    // We don't do anything with data messages, just kick them up a level\n    this.onMessage_(message);\n  }\n\n  private onPrimaryResponse_() {\n    if (!this.isHealthy_) {\n      this.primaryResponsesRequired_--;\n      if (this.primaryResponsesRequired_ <= 0) {\n        this.log_('Primary connection is healthy.');\n        this.isHealthy_ = true;\n        this.conn_.markConnectionHealthy();\n      }\n    }\n  }\n\n  private onControl_(controlData: { [k: string]: unknown }) {\n    const cmd: string = requireKey(MESSAGE_TYPE, controlData) as string;\n    if (MESSAGE_DATA in controlData) {\n      const payload = controlData[MESSAGE_DATA];\n      if (cmd === SERVER_HELLO) {\n        this.onHandshake_(\n          payload as {\n            ts: number;\n            v: string;\n            h: string;\n            s: string;\n          }\n        );\n      } else if (cmd === END_TRANSMISSION) {\n        this.log_('recvd end transmission on primary');\n        this.rx_ = this.secondaryConn_;\n        for (let i = 0; i < this.pendingDataMessages.length; ++i) {\n          this.onDataMessage_(this.pendingDataMessages[i]);\n        }\n        this.pendingDataMessages = [];\n        this.tryCleanupConnection();\n      } else if (cmd === CONTROL_SHUTDOWN) {\n        // This was previously the 'onKill' callback passed to the lower-level connection\n        // payload in this case is the reason for the shutdown. Generally a human-readable error\n        this.onConnectionShutdown_(payload as string);\n      } else if (cmd === CONTROL_RESET) {\n        // payload in this case is the host we should contact\n        this.onReset_(payload as string);\n      } else if (cmd === CONTROL_ERROR) {\n        error('Server Error: ' + payload);\n      } else if (cmd === CONTROL_PONG) {\n        this.log_('got pong on primary.');\n        this.onPrimaryResponse_();\n        this.sendPingOnPrimaryIfNecessary_();\n      } else {\n        error('Unknown control packet command: ' + cmd);\n      }\n    }\n  }\n\n  /**\n   * @param handshake The handshake data returned from the server\n   */\n  private onHandshake_(handshake: {\n    ts: number;\n    v: string;\n    h: string;\n    s: string;\n  }): void {\n    const timestamp = handshake.ts;\n    const version = handshake.v;\n    const host = handshake.h;\n    this.sessionId = handshake.s;\n    this.repoInfo_.host = host;\n    // if we've already closed the connection, then don't bother trying to progress further\n    if (this.state_ === RealtimeState.CONNECTING) {\n      this.conn_.start();\n      this.onConnectionEstablished_(this.conn_, timestamp);\n      if (PROTOCOL_VERSION !== version) {\n        warn('Protocol version mismatch detected');\n      }\n      // TODO: do we want to upgrade? when? maybe a delay?\n      this.tryStartUpgrade_();\n    }\n  }\n\n  private tryStartUpgrade_() {\n    const conn = this.transportManager_.upgradeTransport();\n    if (conn) {\n      this.startUpgrade_(conn);\n    }\n  }\n\n  private startUpgrade_(conn: TransportConstructor) {\n    this.secondaryConn_ = new conn(\n      this.nextTransportId_(),\n      this.repoInfo_,\n      this.applicationId_,\n      this.sessionId\n    );\n    // For certain transports (WebSockets), we need to send and receive several messages back and forth before we\n    // can consider the transport healthy.\n    this.secondaryResponsesRequired_ =\n      conn['responsesRequiredToBeHealthy'] || 0;\n\n    const onMessage = this.connReceiver_(this.secondaryConn_);\n    const onDisconnect = this.disconnReceiver_(this.secondaryConn_);\n    this.secondaryConn_.open(onMessage, onDisconnect);\n\n    // If we haven't successfully upgraded after UPGRADE_TIMEOUT, give up and kill the secondary.\n    setTimeoutNonBlocking(() => {\n      if (this.secondaryConn_) {\n        this.log_('Timed out trying to upgrade.');\n        this.secondaryConn_.close();\n      }\n    }, Math.floor(UPGRADE_TIMEOUT));\n  }\n\n  private onReset_(host: string) {\n    this.log_('Reset packet received.  New host: ' + host);\n    this.repoInfo_.host = host;\n    // TODO: if we're already \"connected\", we need to trigger a disconnect at the next layer up.\n    // We don't currently support resets after the connection has already been established\n    if (this.state_ === RealtimeState.CONNECTED) {\n      this.close();\n    } else {\n      // Close whatever connections we have open and start again.\n      this.closeConnections_();\n      this.start_();\n    }\n  }\n\n  private onConnectionEstablished_(conn: Transport, timestamp: number) {\n    this.log_('Realtime connection established.');\n    this.conn_ = conn;\n    this.state_ = RealtimeState.CONNECTED;\n\n    if (this.onReady_) {\n      this.onReady_(timestamp, this.sessionId);\n      this.onReady_ = null;\n    }\n\n    // If after 5 seconds we haven't sent enough requests to the server to get the connection healthy,\n    // send some pings.\n    if (this.primaryResponsesRequired_ === 0) {\n      this.log_('Primary connection is healthy.');\n      this.isHealthy_ = true;\n    } else {\n      setTimeoutNonBlocking(() => {\n        this.sendPingOnPrimaryIfNecessary_();\n      }, Math.floor(DELAY_BEFORE_SENDING_EXTRA_REQUESTS));\n    }\n  }\n\n  private sendPingOnPrimaryIfNecessary_() {\n    // If the connection isn't considered healthy yet, we'll send a noop ping packet request.\n    if (!this.isHealthy_ && this.state_ === RealtimeState.CONNECTED) {\n      this.log_('sending ping on primary.');\n      this.sendData_({ t: 'c', d: { t: PING, d: {} } });\n    }\n  }\n\n  private onSecondaryConnectionLost_() {\n    const conn = this.secondaryConn_;\n    this.secondaryConn_ = null;\n    if (this.tx_ === conn || this.rx_ === conn) {\n      // we are relying on this connection already in some capacity. Therefore, a failure is real\n      this.close();\n    }\n  }\n\n  /**\n   * @param everConnected Whether or not the connection ever reached a server. Used to determine if\n   * we should flush the host cache\n   */\n  private onConnectionLost_(everConnected: boolean) {\n    this.conn_ = null;\n\n    // NOTE: IF you're seeing a Firefox error for this line, I think it might be because it's getting\n    // called on window close and RealtimeState.CONNECTING is no longer defined.  Just a guess.\n    if (!everConnected && this.state_ === RealtimeState.CONNECTING) {\n      this.log_('Realtime connection failed.');\n      // Since we failed to connect at all, clear any cached entry for this namespace in case the machine went away\n      if (this.repoInfo_.isCacheableHost()) {\n        PersistentStorage.remove('host:' + this.repoInfo_.host);\n        // reset the internal host to what we would show the user, i.e. <ns>.firebaseio.com\n        this.repoInfo_.internalHost = this.repoInfo_.host;\n      }\n    } else if (this.state_ === RealtimeState.CONNECTED) {\n      this.log_('Realtime connection lost.');\n    }\n\n    this.close();\n  }\n\n  private onConnectionShutdown_(reason: string) {\n    this.log_('Connection shutdown command received. Shutting down...');\n\n    if (this.onKill_) {\n      this.onKill_(reason);\n      this.onKill_ = null;\n    }\n\n    // We intentionally don't want to fire onDisconnect (kill is a different case),\n    // so clear the callback.\n    this.onDisconnect_ = null;\n\n    this.close();\n  }\n\n  private sendData_(data: object) {\n    if (this.state_ !== RealtimeState.CONNECTED) {\n      throw 'Connection is not connected';\n    } else {\n      this.tx_.send(data);\n    }\n  }\n\n  /**\n   * Cleans up this connection, calling the appropriate callbacks\n   */\n  close() {\n    if (this.state_ !== RealtimeState.DISCONNECTED) {\n      this.log_('Closing realtime connection.');\n      this.state_ = RealtimeState.DISCONNECTED;\n\n      this.closeConnections_();\n\n      if (this.onDisconnect_) {\n        this.onDisconnect_();\n        this.onDisconnect_ = null;\n      }\n    }\n  }\n\n  private closeConnections_() {\n    this.log_('Shutting down all connections');\n    if (this.conn_) {\n      this.conn_.close();\n      this.conn_ = null;\n    }\n\n    if (this.secondaryConn_) {\n      this.secondaryConn_.close();\n      this.secondaryConn_ = null;\n    }\n\n    if (this.healthyTimeout_) {\n      clearTimeout(this.healthyTimeout_);\n      this.healthyTimeout_ = null;\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Query } from '../api/Query';\n\n/**\n * Interface defining the set of actions that can be performed against the Firebase server\n * (basically corresponds to our wire protocol).\n *\n * @interface\n */\nexport abstract class ServerActions {\n  abstract listen(\n    query: Query,\n    currentHashFn: () => string,\n    tag: number | null,\n    onComplete: (a: string, b: unknown) => void\n  ): void;\n\n  /**\n   * Remove a listen.\n   */\n  abstract unlisten(query: Query, tag: number | null): void;\n\n  /**\n   * Get the server value satisfying this query.\n   */\n  abstract get(query: Query): Promise<string>;\n\n  put(\n    pathString: string,\n    data: unknown,\n    onComplete?: (a: string, b: string) => void,\n    hash?: string\n  ) {}\n\n  merge(\n    pathString: string,\n    data: unknown,\n    onComplete: (a: string, b: string | null) => void,\n    hash?: string\n  ) {}\n\n  /**\n   * Refreshes the auth token for the current connection.\n   * @param token The authentication token\n   */\n  refreshAuthToken(token: string) {}\n\n  onDisconnectPut(\n    pathString: string,\n    data: unknown,\n    onComplete?: (a: string, b: string) => void\n  ) {}\n\n  onDisconnectMerge(\n    pathString: string,\n    data: unknown,\n    onComplete?: (a: string, b: string) => void\n  ) {}\n\n  onDisconnectCancel(\n    pathString: string,\n    onComplete?: (a: string, b: string) => void\n  ) {}\n\n  reportStats(stats: { [k: string]: unknown }) {}\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  contains,\n  isEmpty,\n  safeGet,\n  stringify,\n  assert,\n  isAdmin,\n  isValidFormat,\n  isMobileCordova,\n  isReactNative,\n  isNodeSdk,\n  Deferred\n} from '@firebase/util';\n\nimport { error, log, logWrapper, warn, ObjectToUniqueKey } from './util/util';\nimport { Path } from './util/Path';\nimport { VisibilityMonitor } from './util/VisibilityMonitor';\nimport { OnlineMonitor } from './util/OnlineMonitor';\n\nimport { Connection } from '../realtime/Connection';\n\nimport { ServerActions } from './ServerActions';\nimport { AuthTokenProvider } from './AuthTokenProvider';\nimport { RepoInfo } from './RepoInfo';\nimport { Query } from '../api/Query';\nimport { SDK_VERSION } from './version';\n\nconst RECONNECT_MIN_DELAY = 1000;\nconst RECONNECT_MAX_DELAY_DEFAULT = 60 * 5 * 1000; // 5 minutes in milliseconds (Case: 1858)\nconst GET_CONNECT_TIMEOUT = 3 * 1000;\nconst RECONNECT_MAX_DELAY_FOR_ADMINS = 30 * 1000; // 30 seconds for admin clients (likely to be a backend server)\nconst RECONNECT_DELAY_MULTIPLIER = 1.3;\nconst RECONNECT_DELAY_RESET_TIMEOUT = 30000; // Reset delay back to MIN_DELAY after being connected for 30sec.\nconst SERVER_KILL_INTERRUPT_REASON = 'server_kill';\n\n// If auth fails repeatedly, we'll assume something is wrong and log a warning / back off.\nconst INVALID_AUTH_TOKEN_THRESHOLD = 3;\n\ninterface ListenSpec {\n  onComplete(s: string, p?: unknown): void;\n\n  hashFn(): string;\n\n  query: Query;\n  tag: number | null;\n}\n\ninterface OnDisconnectRequest {\n  pathString: string;\n  action: string;\n  data: unknown;\n  onComplete?: (a: string, b: string) => void;\n}\n\ninterface OutstandingPut {\n  action: string;\n  request: object;\n  queued?: boolean;\n  onComplete: (a: string, b?: string) => void;\n}\n\ninterface OutstandingGet {\n  request: object;\n  onComplete: (response: { [k: string]: unknown }) => void;\n}\n\n/**\n * Firebase connection.  Abstracts wire protocol and handles reconnecting.\n *\n * NOTE: All JSON objects sent to the realtime connection must have property names enclosed\n * in quotes to make sure the closure compiler does not minify them.\n */\nexport class PersistentConnection extends ServerActions {\n  // Used for diagnostic logging.\n  id = PersistentConnection.nextPersistentConnectionId_++;\n  private log_ = logWrapper('p:' + this.id + ':');\n\n  private interruptReasons_: { [reason: string]: boolean } = {};\n  /** Map<path, Map<queryId, ListenSpec>> */\n  private readonly listens: Map<\n    /* path */ string,\n    Map</* queryId */ string, ListenSpec>\n  > = new Map();\n  private outstandingPuts_: OutstandingPut[] = [];\n  private outstandingGets_: OutstandingGet[] = [];\n  private outstandingPutCount_ = 0;\n  private outstandingGetCount_ = 0;\n  private onDisconnectRequestQueue_: OnDisconnectRequest[] = [];\n  private connected_ = false;\n  private reconnectDelay_ = RECONNECT_MIN_DELAY;\n  private maxReconnectDelay_ = RECONNECT_MAX_DELAY_DEFAULT;\n  private securityDebugCallback_: ((a: object) => void) | null = null;\n  lastSessionId: string | null = null;\n\n  private establishConnectionTimer_: number | null = null;\n\n  private visible_: boolean = false;\n\n  // Before we get connected, we keep a queue of pending messages to send.\n  private requestCBHash_: { [k: number]: (a: unknown) => void } = {};\n  private requestNumber_ = 0;\n\n  private realtime_: {\n    sendRequest(a: object): void;\n    close(): void;\n  } | null = null;\n\n  private authToken_: string | null = null;\n  private forceTokenRefresh_ = false;\n  private invalidAuthTokenCount_ = 0;\n\n  private firstConnection_ = true;\n  private lastConnectionAttemptTime_: number | null = null;\n  private lastConnectionEstablishedTime_: number | null = null;\n\n  private static nextPersistentConnectionId_ = 0;\n\n  /**\n   * Counter for number of connections created. Mainly used for tagging in the logs\n   */\n  private static nextConnectionId_ = 0;\n\n  /**\n   * @param repoInfo_ Data about the namespace we are connecting to\n   * @param applicationId_ The Firebase App ID for this project\n   * @param onDataUpdate_ A callback for new data from the server\n   */\n  constructor(\n    private repoInfo_: RepoInfo,\n    private applicationId_: string,\n    private onDataUpdate_: (\n      a: string,\n      b: unknown,\n      c: boolean,\n      d: number | null\n    ) => void,\n    private onConnectStatus_: (a: boolean) => void,\n    private onServerInfoUpdate_: (a: unknown) => void,\n    private authTokenProvider_: AuthTokenProvider,\n    private authOverride_?: object | null\n  ) {\n    super();\n\n    if (authOverride_ && !isNodeSdk()) {\n      throw new Error(\n        'Auth override specified in options, but not supported on non Node.js platforms'\n      );\n    }\n    this.scheduleConnect_(0);\n\n    VisibilityMonitor.getInstance().on('visible', this.onVisible_, this);\n\n    if (repoInfo_.host.indexOf('fblocal') === -1) {\n      OnlineMonitor.getInstance().on('online', this.onOnline_, this);\n    }\n  }\n\n  protected sendRequest(\n    action: string,\n    body: unknown,\n    onResponse?: (a: unknown) => void\n  ) {\n    const curReqNum = ++this.requestNumber_;\n\n    const msg = { r: curReqNum, a: action, b: body };\n    this.log_(stringify(msg));\n    assert(\n      this.connected_,\n      \"sendRequest call when we're not connected not allowed.\"\n    );\n    this.realtime_.sendRequest(msg);\n    if (onResponse) {\n      this.requestCBHash_[curReqNum] = onResponse;\n    }\n  }\n\n  get(query: Query): Promise<string> {\n    const deferred = new Deferred<string>();\n    const request = {\n      p: query.path.toString(),\n      q: query.queryObject()\n    };\n    const outstandingGet = {\n      action: 'g',\n      request,\n      onComplete: (message: { [k: string]: unknown }) => {\n        const payload = message['d'] as string;\n        if (message['s'] === 'ok') {\n          this.onDataUpdate_(\n            request['p'],\n            payload,\n            /*isMerge*/ false,\n            /*tag*/ null\n          );\n          deferred.resolve(payload);\n        } else {\n          deferred.reject(payload);\n        }\n      }\n    };\n    this.outstandingGets_.push(outstandingGet);\n    this.outstandingGetCount_++;\n    const index = this.outstandingGets_.length - 1;\n\n    if (!this.connected_) {\n      setTimeout(() => {\n        const get = this.outstandingGets_[index];\n        if (get === undefined || outstandingGet !== get) {\n          return;\n        }\n        delete this.outstandingGets_[index];\n        this.outstandingGetCount_--;\n        if (this.outstandingGetCount_ === 0) {\n          this.outstandingGets_ = [];\n        }\n        this.log_('get ' + index + ' timed out on connection');\n        deferred.reject(new Error('Client is offline.'));\n      }, GET_CONNECT_TIMEOUT);\n    }\n\n    if (this.connected_) {\n      this.sendGet_(index);\n    }\n\n    return deferred.promise;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  listen(\n    query: Query,\n    currentHashFn: () => string,\n    tag: number | null,\n    onComplete: (a: string, b: unknown) => void\n  ) {\n    const queryId = query.queryIdentifier();\n    const pathString = query.path.toString();\n    this.log_('Listen called for ' + pathString + ' ' + queryId);\n    if (!this.listens.has(pathString)) {\n      this.listens.set(pathString, new Map());\n    }\n    assert(\n      query.getQueryParams().isDefault() ||\n        !query.getQueryParams().loadsAllData(),\n      'listen() called for non-default but complete query'\n    );\n    assert(\n      !this.listens.get(pathString)!.has(queryId),\n      'listen() called twice for same path/queryId.'\n    );\n    const listenSpec: ListenSpec = {\n      onComplete,\n      hashFn: currentHashFn,\n      query,\n      tag\n    };\n    this.listens.get(pathString)!.set(queryId, listenSpec);\n\n    if (this.connected_) {\n      this.sendListen_(listenSpec);\n    }\n  }\n\n  private sendGet_(index: number) {\n    const get = this.outstandingGets_[index];\n    this.sendRequest('g', get.request, (message: { [k: string]: unknown }) => {\n      delete this.outstandingGets_[index];\n      this.outstandingGetCount_--;\n      if (this.outstandingGetCount_ === 0) {\n        this.outstandingGets_ = [];\n      }\n      if (get.onComplete) {\n        get.onComplete(message);\n      }\n    });\n  }\n\n  private sendListen_(listenSpec: ListenSpec) {\n    const query = listenSpec.query;\n    const pathString = query.path.toString();\n    const queryId = query.queryIdentifier();\n    this.log_('Listen on ' + pathString + ' for ' + queryId);\n    const req: { [k: string]: unknown } = { /*path*/ p: pathString };\n\n    const action = 'q';\n\n    // Only bother to send query if it's non-default.\n    if (listenSpec.tag) {\n      req['q'] = query.queryObject();\n      req['t'] = listenSpec.tag;\n    }\n\n    req[/*hash*/ 'h'] = listenSpec.hashFn();\n\n    this.sendRequest(action, req, (message: { [k: string]: unknown }) => {\n      const payload: unknown = message[/*data*/ 'd'];\n      const status = message[/*status*/ 's'] as string;\n\n      // print warnings in any case...\n      PersistentConnection.warnOnListenWarnings_(payload, query);\n\n      const currentListenSpec =\n        this.listens.get(pathString) &&\n        this.listens.get(pathString)!.get(queryId);\n      // only trigger actions if the listen hasn't been removed and readded\n      if (currentListenSpec === listenSpec) {\n        this.log_('listen response', message);\n\n        if (status !== 'ok') {\n          this.removeListen_(pathString, queryId);\n        }\n\n        if (listenSpec.onComplete) {\n          listenSpec.onComplete(status, payload);\n        }\n      }\n    });\n  }\n\n  private static warnOnListenWarnings_(payload: unknown, query: Query) {\n    if (payload && typeof payload === 'object' && contains(payload, 'w')) {\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      const warnings = safeGet(payload as any, 'w');\n      if (Array.isArray(warnings) && ~warnings.indexOf('no_index')) {\n        const indexSpec =\n          '\".indexOn\": \"' + query.getQueryParams().getIndex().toString() + '\"';\n        const indexPath = query.path.toString();\n        warn(\n          `Using an unspecified index. Your data will be downloaded and ` +\n            `filtered on the client. Consider adding ${indexSpec} at ` +\n            `${indexPath} to your security rules for better performance.`\n        );\n      }\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  refreshAuthToken(token: string) {\n    this.authToken_ = token;\n    this.log_('Auth token refreshed');\n    if (this.authToken_) {\n      this.tryAuth();\n    } else {\n      //If we're connected we want to let the server know to unauthenticate us. If we're not connected, simply delete\n      //the credential so we dont become authenticated next time we connect.\n      if (this.connected_) {\n        this.sendRequest('unauth', {}, () => {});\n      }\n    }\n\n    this.reduceReconnectDelayIfAdminCredential_(token);\n  }\n\n  private reduceReconnectDelayIfAdminCredential_(credential: string) {\n    // NOTE: This isn't intended to be bulletproof (a malicious developer can always just modify the client).\n    // Additionally, we don't bother resetting the max delay back to the default if auth fails / expires.\n    const isFirebaseSecret = credential && credential.length === 40;\n    if (isFirebaseSecret || isAdmin(credential)) {\n      this.log_(\n        'Admin auth credential detected.  Reducing max reconnect time.'\n      );\n      this.maxReconnectDelay_ = RECONNECT_MAX_DELAY_FOR_ADMINS;\n    }\n  }\n\n  /**\n   * Attempts to authenticate with the given credentials. If the authentication attempt fails, it's triggered like\n   * a auth revoked (the connection is closed).\n   */\n  tryAuth() {\n    if (this.connected_ && this.authToken_) {\n      const token = this.authToken_;\n      const authMethod = isValidFormat(token) ? 'auth' : 'gauth';\n      const requestData: { [k: string]: unknown } = { cred: token };\n      if (this.authOverride_ === null) {\n        requestData['noauth'] = true;\n      } else if (typeof this.authOverride_ === 'object') {\n        requestData['authvar'] = this.authOverride_;\n      }\n      this.sendRequest(\n        authMethod,\n        requestData,\n        (res: { [k: string]: unknown }) => {\n          const status = res[/*status*/ 's'] as string;\n          const data = (res[/*data*/ 'd'] as string) || 'error';\n\n          if (this.authToken_ === token) {\n            if (status === 'ok') {\n              this.invalidAuthTokenCount_ = 0;\n            } else {\n              // Triggers reconnect and force refresh for auth token\n              this.onAuthRevoked_(status, data);\n            }\n          }\n        }\n      );\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  unlisten(query: Query, tag: number | null) {\n    const pathString = query.path.toString();\n    const queryId = query.queryIdentifier();\n\n    this.log_('Unlisten called for ' + pathString + ' ' + queryId);\n\n    assert(\n      query.getQueryParams().isDefault() ||\n        !query.getQueryParams().loadsAllData(),\n      'unlisten() called for non-default but complete query'\n    );\n    const listen = this.removeListen_(pathString, queryId);\n    if (listen && this.connected_) {\n      this.sendUnlisten_(pathString, queryId, query.queryObject(), tag);\n    }\n  }\n\n  private sendUnlisten_(\n    pathString: string,\n    queryId: string,\n    queryObj: object,\n    tag: number | null\n  ) {\n    this.log_('Unlisten on ' + pathString + ' for ' + queryId);\n\n    const req: { [k: string]: unknown } = { /*path*/ p: pathString };\n    const action = 'n';\n    // Only bother sending queryId if it's non-default.\n    if (tag) {\n      req['q'] = queryObj;\n      req['t'] = tag;\n    }\n\n    this.sendRequest(action, req);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  onDisconnectPut(\n    pathString: string,\n    data: unknown,\n    onComplete?: (a: string, b: string) => void\n  ) {\n    if (this.connected_) {\n      this.sendOnDisconnect_('o', pathString, data, onComplete);\n    } else {\n      this.onDisconnectRequestQueue_.push({\n        pathString,\n        action: 'o',\n        data,\n        onComplete\n      });\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  onDisconnectMerge(\n    pathString: string,\n    data: unknown,\n    onComplete?: (a: string, b: string) => void\n  ) {\n    if (this.connected_) {\n      this.sendOnDisconnect_('om', pathString, data, onComplete);\n    } else {\n      this.onDisconnectRequestQueue_.push({\n        pathString,\n        action: 'om',\n        data,\n        onComplete\n      });\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  onDisconnectCancel(\n    pathString: string,\n    onComplete?: (a: string, b: string) => void\n  ) {\n    if (this.connected_) {\n      this.sendOnDisconnect_('oc', pathString, null, onComplete);\n    } else {\n      this.onDisconnectRequestQueue_.push({\n        pathString,\n        action: 'oc',\n        data: null,\n        onComplete\n      });\n    }\n  }\n\n  private sendOnDisconnect_(\n    action: string,\n    pathString: string,\n    data: unknown,\n    onComplete: (a: string, b: string) => void\n  ) {\n    const request = { /*path*/ p: pathString, /*data*/ d: data };\n    this.log_('onDisconnect ' + action, request);\n    this.sendRequest(action, request, (response: { [k: string]: unknown }) => {\n      if (onComplete) {\n        setTimeout(() => {\n          onComplete(\n            response[/*status*/ 's'] as string,\n            response[/* data */ 'd'] as string\n          );\n        }, Math.floor(0));\n      }\n    });\n  }\n\n  /**\n   * @inheritDoc\n   */\n  put(\n    pathString: string,\n    data: unknown,\n    onComplete?: (a: string, b: string) => void,\n    hash?: string\n  ) {\n    this.putInternal('p', pathString, data, onComplete, hash);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  merge(\n    pathString: string,\n    data: unknown,\n    onComplete: (a: string, b: string | null) => void,\n    hash?: string\n  ) {\n    this.putInternal('m', pathString, data, onComplete, hash);\n  }\n\n  putInternal(\n    action: string,\n    pathString: string,\n    data: unknown,\n    onComplete: (a: string, b: string | null) => void,\n    hash?: string\n  ) {\n    const request: { [k: string]: unknown } = {\n      /*path*/ p: pathString,\n      /*data*/ d: data\n    };\n\n    if (hash !== undefined) {\n      request[/*hash*/ 'h'] = hash;\n    }\n\n    // TODO: Only keep track of the most recent put for a given path?\n    this.outstandingPuts_.push({\n      action,\n      request,\n      onComplete\n    });\n\n    this.outstandingPutCount_++;\n    const index = this.outstandingPuts_.length - 1;\n\n    if (this.connected_) {\n      this.sendPut_(index);\n    } else {\n      this.log_('Buffering put: ' + pathString);\n    }\n  }\n\n  private sendPut_(index: number) {\n    const action = this.outstandingPuts_[index].action;\n    const request = this.outstandingPuts_[index].request;\n    const onComplete = this.outstandingPuts_[index].onComplete;\n    this.outstandingPuts_[index].queued = this.connected_;\n\n    this.sendRequest(action, request, (message: { [k: string]: unknown }) => {\n      this.log_(action + ' response', message);\n\n      delete this.outstandingPuts_[index];\n      this.outstandingPutCount_--;\n\n      // Clean up array occasionally.\n      if (this.outstandingPutCount_ === 0) {\n        this.outstandingPuts_ = [];\n      }\n\n      if (onComplete) {\n        onComplete(\n          message[/*status*/ 's'] as string,\n          message[/* data */ 'd'] as string\n        );\n      }\n    });\n  }\n\n  /**\n   * @inheritDoc\n   */\n  reportStats(stats: { [k: string]: unknown }) {\n    // If we're not connected, we just drop the stats.\n    if (this.connected_) {\n      const request = { /*counters*/ c: stats };\n      this.log_('reportStats', request);\n\n      this.sendRequest(/*stats*/ 's', request, result => {\n        const status = result[/*status*/ 's'];\n        if (status !== 'ok') {\n          const errorReason = result[/* data */ 'd'];\n          this.log_('reportStats', 'Error sending stats: ' + errorReason);\n        }\n      });\n    }\n  }\n\n  private onDataMessage_(message: { [k: string]: unknown }) {\n    if ('r' in message) {\n      // this is a response\n      this.log_('from server: ' + stringify(message));\n      const reqNum = message['r'] as string;\n      const onResponse = this.requestCBHash_[reqNum];\n      if (onResponse) {\n        delete this.requestCBHash_[reqNum];\n        onResponse(message[/*body*/ 'b']);\n      }\n    } else if ('error' in message) {\n      throw 'A server-side error has occurred: ' + message['error'];\n    } else if ('a' in message) {\n      // a and b are action and body, respectively\n      this.onDataPush_(message['a'] as string, message['b'] as {});\n    }\n  }\n\n  private onDataPush_(action: string, body: { [k: string]: unknown }) {\n    this.log_('handleServerMessage', action, body);\n    if (action === 'd') {\n      this.onDataUpdate_(\n        body[/*path*/ 'p'] as string,\n        body[/*data*/ 'd'],\n        /*isMerge*/ false,\n        body['t'] as number\n      );\n    } else if (action === 'm') {\n      this.onDataUpdate_(\n        body[/*path*/ 'p'] as string,\n        body[/*data*/ 'd'],\n        /*isMerge=*/ true,\n        body['t'] as number\n      );\n    } else if (action === 'c') {\n      this.onListenRevoked_(\n        body[/*path*/ 'p'] as string,\n        body[/*query*/ 'q'] as unknown[]\n      );\n    } else if (action === 'ac') {\n      this.onAuthRevoked_(\n        body[/*status code*/ 's'] as string,\n        body[/* explanation */ 'd'] as string\n      );\n    } else if (action === 'sd') {\n      this.onSecurityDebugPacket_(body);\n    } else {\n      error(\n        'Unrecognized action received from server: ' +\n          stringify(action) +\n          '\\nAre you using the latest client?'\n      );\n    }\n  }\n\n  private onReady_(timestamp: number, sessionId: string) {\n    this.log_('connection ready');\n    this.connected_ = true;\n    this.lastConnectionEstablishedTime_ = new Date().getTime();\n    this.handleTimestamp_(timestamp);\n    this.lastSessionId = sessionId;\n    if (this.firstConnection_) {\n      this.sendConnectStats_();\n    }\n    this.restoreState_();\n    this.firstConnection_ = false;\n    this.onConnectStatus_(true);\n  }\n\n  private scheduleConnect_(timeout: number) {\n    assert(\n      !this.realtime_,\n      \"Scheduling a connect when we're already connected/ing?\"\n    );\n\n    if (this.establishConnectionTimer_) {\n      clearTimeout(this.establishConnectionTimer_);\n    }\n\n    // NOTE: Even when timeout is 0, it's important to do a setTimeout to work around an infuriating \"Security Error\" in\n    // Firefox when trying to write to our long-polling iframe in some scenarios (e.g. Forge or our unit tests).\n\n    this.establishConnectionTimer_ = setTimeout(() => {\n      this.establishConnectionTimer_ = null;\n      this.establishConnection_();\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    }, Math.floor(timeout)) as any;\n  }\n\n  private onVisible_(visible: boolean) {\n    // NOTE: Tabbing away and back to a window will defeat our reconnect backoff, but I think that's fine.\n    if (\n      visible &&\n      !this.visible_ &&\n      this.reconnectDelay_ === this.maxReconnectDelay_\n    ) {\n      this.log_('Window became visible.  Reducing delay.');\n      this.reconnectDelay_ = RECONNECT_MIN_DELAY;\n\n      if (!this.realtime_) {\n        this.scheduleConnect_(0);\n      }\n    }\n    this.visible_ = visible;\n  }\n\n  private onOnline_(online: boolean) {\n    if (online) {\n      this.log_('Browser went online.');\n      this.reconnectDelay_ = RECONNECT_MIN_DELAY;\n      if (!this.realtime_) {\n        this.scheduleConnect_(0);\n      }\n    } else {\n      this.log_('Browser went offline.  Killing connection.');\n      if (this.realtime_) {\n        this.realtime_.close();\n      }\n    }\n  }\n\n  private onRealtimeDisconnect_() {\n    this.log_('data client disconnected');\n    this.connected_ = false;\n    this.realtime_ = null;\n\n    // Since we don't know if our sent transactions succeeded or not, we need to cancel them.\n    this.cancelSentTransactions_();\n\n    // Clear out the pending requests.\n    this.requestCBHash_ = {};\n\n    if (this.shouldReconnect_()) {\n      if (!this.visible_) {\n        this.log_(\"Window isn't visible.  Delaying reconnect.\");\n        this.reconnectDelay_ = this.maxReconnectDelay_;\n        this.lastConnectionAttemptTime_ = new Date().getTime();\n      } else if (this.lastConnectionEstablishedTime_) {\n        // If we've been connected long enough, reset reconnect delay to minimum.\n        const timeSinceLastConnectSucceeded =\n          new Date().getTime() - this.lastConnectionEstablishedTime_;\n        if (timeSinceLastConnectSucceeded > RECONNECT_DELAY_RESET_TIMEOUT) {\n          this.reconnectDelay_ = RECONNECT_MIN_DELAY;\n        }\n        this.lastConnectionEstablishedTime_ = null;\n      }\n\n      const timeSinceLastConnectAttempt =\n        new Date().getTime() - this.lastConnectionAttemptTime_;\n      let reconnectDelay = Math.max(\n        0,\n        this.reconnectDelay_ - timeSinceLastConnectAttempt\n      );\n      reconnectDelay = Math.random() * reconnectDelay;\n\n      this.log_('Trying to reconnect in ' + reconnectDelay + 'ms');\n      this.scheduleConnect_(reconnectDelay);\n\n      // Adjust reconnect delay for next time.\n      this.reconnectDelay_ = Math.min(\n        this.maxReconnectDelay_,\n        this.reconnectDelay_ * RECONNECT_DELAY_MULTIPLIER\n      );\n    }\n    this.onConnectStatus_(false);\n  }\n\n  private establishConnection_() {\n    if (this.shouldReconnect_()) {\n      this.log_('Making a connection attempt');\n      this.lastConnectionAttemptTime_ = new Date().getTime();\n      this.lastConnectionEstablishedTime_ = null;\n      const onDataMessage = this.onDataMessage_.bind(this);\n      const onReady = this.onReady_.bind(this);\n      const onDisconnect = this.onRealtimeDisconnect_.bind(this);\n      const connId = this.id + ':' + PersistentConnection.nextConnectionId_++;\n      const self = this;\n      const lastSessionId = this.lastSessionId;\n      let canceled = false;\n      let connection: Connection | null = null;\n      const closeFn = function () {\n        if (connection) {\n          connection.close();\n        } else {\n          canceled = true;\n          onDisconnect();\n        }\n      };\n      const sendRequestFn = function (msg: object) {\n        assert(\n          connection,\n          \"sendRequest call when we're not connected not allowed.\"\n        );\n        connection.sendRequest(msg);\n      };\n\n      this.realtime_ = {\n        close: closeFn,\n        sendRequest: sendRequestFn\n      };\n\n      const forceRefresh = this.forceTokenRefresh_;\n      this.forceTokenRefresh_ = false;\n\n      // First fetch auth token, and establish connection after fetching the token was successful\n      this.authTokenProvider_\n        .getToken(forceRefresh)\n        .then(result => {\n          if (!canceled) {\n            log('getToken() completed. Creating connection.');\n            self.authToken_ = result && result.accessToken;\n            connection = new Connection(\n              connId,\n              self.repoInfo_,\n              self.applicationId_,\n              onDataMessage,\n              onReady,\n              onDisconnect,\n              /* onKill= */ reason => {\n                warn(reason + ' (' + self.repoInfo_.toString() + ')');\n                self.interrupt(SERVER_KILL_INTERRUPT_REASON);\n              },\n              lastSessionId\n            );\n          } else {\n            log('getToken() completed but was canceled');\n          }\n        })\n        .then(null, error => {\n          self.log_('Failed to get token: ' + error);\n          if (!canceled) {\n            if (this.repoInfo_.nodeAdmin) {\n              // This may be a critical error for the Admin Node.js SDK, so log a warning.\n              // But getToken() may also just have temporarily failed, so we still want to\n              // continue retrying.\n              warn(error);\n            }\n            closeFn();\n          }\n        });\n    }\n  }\n\n  interrupt(reason: string) {\n    log('Interrupting connection for reason: ' + reason);\n    this.interruptReasons_[reason] = true;\n    if (this.realtime_) {\n      this.realtime_.close();\n    } else {\n      if (this.establishConnectionTimer_) {\n        clearTimeout(this.establishConnectionTimer_);\n        this.establishConnectionTimer_ = null;\n      }\n      if (this.connected_) {\n        this.onRealtimeDisconnect_();\n      }\n    }\n  }\n\n  resume(reason: string) {\n    log('Resuming connection for reason: ' + reason);\n    delete this.interruptReasons_[reason];\n    if (isEmpty(this.interruptReasons_)) {\n      this.reconnectDelay_ = RECONNECT_MIN_DELAY;\n      if (!this.realtime_) {\n        this.scheduleConnect_(0);\n      }\n    }\n  }\n\n  private handleTimestamp_(timestamp: number) {\n    const delta = timestamp - new Date().getTime();\n    this.onServerInfoUpdate_({ serverTimeOffset: delta });\n  }\n\n  private cancelSentTransactions_() {\n    for (let i = 0; i < this.outstandingPuts_.length; i++) {\n      const put = this.outstandingPuts_[i];\n      if (put && /*hash*/ 'h' in put.request && put.queued) {\n        if (put.onComplete) {\n          put.onComplete('disconnect');\n        }\n\n        delete this.outstandingPuts_[i];\n        this.outstandingPutCount_--;\n      }\n    }\n\n    // Clean up array occasionally.\n    if (this.outstandingPutCount_ === 0) {\n      this.outstandingPuts_ = [];\n    }\n  }\n\n  private onListenRevoked_(pathString: string, query?: unknown[]) {\n    // Remove the listen and manufacture a \"permission_denied\" error for the failed listen.\n    let queryId;\n    if (!query) {\n      queryId = 'default';\n    } else {\n      queryId = query.map(q => ObjectToUniqueKey(q)).join('$');\n    }\n    const listen = this.removeListen_(pathString, queryId);\n    if (listen && listen.onComplete) {\n      listen.onComplete('permission_denied');\n    }\n  }\n\n  private removeListen_(pathString: string, queryId: string): ListenSpec {\n    const normalizedPathString = new Path(pathString).toString(); // normalize path.\n    let listen;\n    if (this.listens.has(normalizedPathString)) {\n      const map = this.listens.get(normalizedPathString)!;\n      listen = map.get(queryId);\n      map.delete(queryId);\n      if (map.size === 0) {\n        this.listens.delete(normalizedPathString);\n      }\n    } else {\n      // all listens for this path has already been removed\n      listen = undefined;\n    }\n    return listen;\n  }\n\n  private onAuthRevoked_(statusCode: string, explanation: string) {\n    log('Auth token revoked: ' + statusCode + '/' + explanation);\n    this.authToken_ = null;\n    this.forceTokenRefresh_ = true;\n    this.realtime_.close();\n    if (statusCode === 'invalid_token' || statusCode === 'permission_denied') {\n      // We'll wait a couple times before logging the warning / increasing the\n      // retry period since oauth tokens will report as \"invalid\" if they're\n      // just expired. Plus there may be transient issues that resolve themselves.\n      this.invalidAuthTokenCount_++;\n      if (this.invalidAuthTokenCount_ >= INVALID_AUTH_TOKEN_THRESHOLD) {\n        // Set a long reconnect delay because recovery is unlikely\n        this.reconnectDelay_ = RECONNECT_MAX_DELAY_FOR_ADMINS;\n\n        // Notify the auth token provider that the token is invalid, which will log\n        // a warning\n        this.authTokenProvider_.notifyForInvalidToken();\n      }\n    }\n  }\n\n  private onSecurityDebugPacket_(body: { [k: string]: unknown }) {\n    if (this.securityDebugCallback_) {\n      this.securityDebugCallback_(body);\n    } else {\n      if ('msg' in body) {\n        console.log(\n          'FIREBASE: ' + (body['msg'] as string).replace('\\n', '\\nFIREBASE: ')\n        );\n      }\n    }\n  }\n\n  private restoreState_() {\n    //Re-authenticate ourselves if we have a credential stored.\n    this.tryAuth();\n\n    // Puts depend on having received the corresponding data update from the server before they complete, so we must\n    // make sure to send listens before puts.\n    for (const queries of this.listens.values()) {\n      for (const listenSpec of queries.values()) {\n        this.sendListen_(listenSpec);\n      }\n    }\n\n    for (let i = 0; i < this.outstandingPuts_.length; i++) {\n      if (this.outstandingPuts_[i]) {\n        this.sendPut_(i);\n      }\n    }\n\n    while (this.onDisconnectRequestQueue_.length) {\n      const request = this.onDisconnectRequestQueue_.shift();\n      this.sendOnDisconnect_(\n        request.action,\n        request.pathString,\n        request.data,\n        request.onComplete\n      );\n    }\n\n    for (let i = 0; i < this.outstandingGets_.length; i++) {\n      if (this.outstandingGets_[i]) {\n        this.sendGet_(i);\n      }\n    }\n  }\n\n  /**\n   * Sends client stats for first connection\n   */\n  private sendConnectStats_() {\n    const stats: { [k: string]: number } = {};\n\n    let clientName = 'js';\n    if (isNodeSdk()) {\n      if (this.repoInfo_.nodeAdmin) {\n        clientName = 'admin_node';\n      } else {\n        clientName = 'node';\n      }\n    }\n\n    stats['sdk.' + clientName + '.' + SDK_VERSION.replace(/\\./g, '-')] = 1;\n\n    if (isMobileCordova()) {\n      stats['framework.cordova'] = 1;\n    } else if (isReactNative()) {\n      stats['framework.reactnative'] = 1;\n    }\n    this.reportStats(stats);\n  }\n\n  private shouldReconnect_(): boolean {\n    const online = OnlineMonitor.getInstance().currentlyOnline();\n    return isEmpty(this.interruptReasons_) && online;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  assert,\n  jsonEval,\n  safeGet,\n  querystring,\n  Deferred\n} from '@firebase/util';\nimport { logWrapper, warn } from './util/util';\n\nimport { ServerActions } from './ServerActions';\nimport { RepoInfo } from './RepoInfo';\nimport { AuthTokenProvider } from './AuthTokenProvider';\nimport { Query } from '../api/Query';\nimport { queryParamsToRestQueryStringParameters } from './view/QueryParams';\n\n/**\n * An implementation of ServerActions that communicates with the server via REST requests.\n * This is mostly useful for compatibility with crawlers, where we don't want to spin up a full\n * persistent connection (using WebSockets or long-polling)\n */\nexport class ReadonlyRestClient extends ServerActions {\n  reportStats(stats: { [k: string]: unknown }): void {\n    throw new Error('Method not implemented.');\n  }\n\n  /** @private {function(...[*])} */\n  private log_: (...args: unknown[]) => void = logWrapper('p:rest:');\n\n  /**\n   * We don't actually need to track listens, except to prevent us calling an onComplete for a listen\n   * that's been removed. :-/\n   */\n  private listens_: { [k: string]: object } = {};\n\n  static getListenId_(query: Query, tag?: number | null): string {\n    if (tag !== undefined) {\n      return 'tag$' + tag;\n    } else {\n      assert(\n        query.getQueryParams().isDefault(),\n        \"should have a tag if it's not a default query.\"\n      );\n      return query.path.toString();\n    }\n  }\n\n  /**\n   * @param repoInfo_ Data about the namespace we are connecting to\n   * @param onDataUpdate_ A callback for new data from the server\n   */\n  constructor(\n    private repoInfo_: RepoInfo,\n    private onDataUpdate_: (\n      a: string,\n      b: unknown,\n      c: boolean,\n      d: number | null\n    ) => void,\n    private authTokenProvider_: AuthTokenProvider\n  ) {\n    super();\n  }\n\n  /** @inheritDoc */\n  listen(\n    query: Query,\n    currentHashFn: () => string,\n    tag: number | null,\n    onComplete: (a: string, b: unknown) => void\n  ) {\n    const pathString = query.path.toString();\n    this.log_(\n      'Listen called for ' + pathString + ' ' + query.queryIdentifier()\n    );\n\n    // Mark this listener so we can tell if it's removed.\n    const listenId = ReadonlyRestClient.getListenId_(query, tag);\n    const thisListen = {};\n    this.listens_[listenId] = thisListen;\n\n    const queryStringParameters = queryParamsToRestQueryStringParameters(\n      query.getQueryParams()\n    );\n\n    this.restRequest_(\n      pathString + '.json',\n      queryStringParameters,\n      (error, result) => {\n        let data = result;\n\n        if (error === 404) {\n          data = null;\n          error = null;\n        }\n\n        if (error === null) {\n          this.onDataUpdate_(pathString, data, /*isMerge=*/ false, tag);\n        }\n\n        if (safeGet(this.listens_, listenId) === thisListen) {\n          let status;\n          if (!error) {\n            status = 'ok';\n          } else if (error === 401) {\n            status = 'permission_denied';\n          } else {\n            status = 'rest_error:' + error;\n          }\n\n          onComplete(status, null);\n        }\n      }\n    );\n  }\n\n  /** @inheritDoc */\n  unlisten(query: Query, tag: number | null) {\n    const listenId = ReadonlyRestClient.getListenId_(query, tag);\n    delete this.listens_[listenId];\n  }\n\n  get(query: Query): Promise<string> {\n    const queryStringParameters = queryParamsToRestQueryStringParameters(\n      query.getQueryParams()\n    );\n\n    const pathString = query.path.toString();\n\n    const deferred = new Deferred<string>();\n\n    this.restRequest_(\n      pathString + '.json',\n      queryStringParameters,\n      (error, result) => {\n        let data = result;\n\n        if (error === 404) {\n          data = null;\n          error = null;\n        }\n\n        if (error === null) {\n          this.onDataUpdate_(\n            pathString,\n            data,\n            /*isMerge=*/ false,\n            /*tag=*/ null\n          );\n          deferred.resolve(data as string);\n        } else {\n          deferred.reject(new Error(data as string));\n        }\n      }\n    );\n    return deferred.promise;\n  }\n\n  /** @inheritDoc */\n  refreshAuthToken(token: string) {\n    // no-op since we just always call getToken.\n  }\n\n  /**\n   * Performs a REST request to the given path, with the provided query string parameters,\n   * and any auth credentials we have.\n   */\n  private restRequest_(\n    pathString: string,\n    queryStringParameters: { [k: string]: string | number } = {},\n    callback: ((a: number | null, b?: unknown) => void) | null\n  ) {\n    queryStringParameters['format'] = 'export';\n\n    this.authTokenProvider_\n      .getToken(/*forceRefresh=*/ false)\n      .then(authTokenData => {\n        const authToken = authTokenData && authTokenData.accessToken;\n        if (authToken) {\n          queryStringParameters['auth'] = authToken;\n        }\n\n        const url =\n          (this.repoInfo_.secure ? 'https://' : 'http://') +\n          this.repoInfo_.host +\n          pathString +\n          '?' +\n          'ns=' +\n          this.repoInfo_.namespace +\n          querystring(queryStringParameters);\n\n        this.log_('Sending REST request for ' + url);\n        const xhr = new XMLHttpRequest();\n        xhr.onreadystatechange = () => {\n          if (callback && xhr.readyState === 4) {\n            this.log_(\n              'REST Response for ' + url + ' received. status:',\n              xhr.status,\n              'response:',\n              xhr.responseText\n            );\n            let res = null;\n            if (xhr.status >= 200 && xhr.status < 300) {\n              try {\n                res = jsonEval(xhr.responseText);\n              } catch (e) {\n                warn(\n                  'Failed to parse JSON response for ' +\n                    url +\n                    ': ' +\n                    xhr.responseText\n                );\n              }\n              callback(null, res);\n            } else {\n              // 401 and 404 are expected.\n              if (xhr.status !== 401 && xhr.status !== 404) {\n                warn(\n                  'Got unsuccessful REST response for ' +\n                    url +\n                    ' Status: ' +\n                    xhr.status\n                );\n              }\n              callback(xhr.status);\n            }\n            callback = null;\n          }\n        };\n\n        xhr.open('GET', url, /*asynchronous=*/ true);\n        xhr.send();\n      });\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { validateArgCount, validateCallback } from '@firebase/util';\nimport { validatePathString } from '../core/util/validation';\nimport { Path } from '../core/util/Path';\nimport { PRIORITY_INDEX } from '../core/snap/indexes/PriorityIndex';\nimport { Node } from '../core/snap/Node';\nimport { Reference } from './Reference';\nimport { Index } from '../core/snap/indexes/Index';\nimport { ChildrenNode } from '../core/snap/ChildrenNode';\n\n/**\n * Class representing a firebase data snapshot.  It wraps a SnapshotNode and\n * surfaces the public methods (val, forEach, etc.) we want to expose.\n */\nexport class DataSnapshot {\n  /**\n   * @param node_ A SnapshotNode to wrap.\n   * @param ref_ The ref of the location this snapshot came from.\n   * @param index_ The iteration order for this snapshot\n   */\n  constructor(\n    private readonly node_: Node,\n    private readonly ref_: Reference,\n    private readonly index_: Index\n  ) {}\n\n  /**\n   * Retrieves the snapshot contents as JSON.  Returns null if the snapshot is\n   * empty.\n   *\n   * @return JSON representation of the DataSnapshot contents, or null if empty.\n   */\n  val(): unknown {\n    validateArgCount('DataSnapshot.val', 0, 0, arguments.length);\n    return this.node_.val();\n  }\n\n  /**\n   * Returns the snapshot contents as JSON, including priorities of node.  Suitable for exporting\n   * the entire node contents.\n   * @return JSON representation of the DataSnapshot contents, or null if empty.\n   */\n  exportVal(): unknown {\n    validateArgCount('DataSnapshot.exportVal', 0, 0, arguments.length);\n    return this.node_.val(true);\n  }\n\n  // Do not create public documentation. This is intended to make JSON serialization work but is otherwise unnecessary\n  // for end-users\n  toJSON(): unknown {\n    // Optional spacer argument is unnecessary because we're depending on recursion rather than stringifying the content\n    validateArgCount('DataSnapshot.toJSON', 0, 1, arguments.length);\n    return this.exportVal();\n  }\n\n  /**\n   * Returns whether the snapshot contains a non-null value.\n   *\n   * @return Whether the snapshot contains a non-null value, or is empty.\n   */\n  exists(): boolean {\n    validateArgCount('DataSnapshot.exists', 0, 0, arguments.length);\n    return !this.node_.isEmpty();\n  }\n\n  /**\n   * Returns a DataSnapshot of the specified child node's contents.\n   *\n   * @param childPathString Path to a child.\n   * @return DataSnapshot for child node.\n   */\n  child(childPathString: string): DataSnapshot {\n    validateArgCount('DataSnapshot.child', 0, 1, arguments.length);\n    // Ensure the childPath is a string (can be a number)\n    childPathString = String(childPathString);\n    validatePathString('DataSnapshot.child', 1, childPathString, false);\n\n    const childPath = new Path(childPathString);\n    const childRef = this.ref_.child(childPath);\n    return new DataSnapshot(\n      this.node_.getChild(childPath),\n      childRef,\n      PRIORITY_INDEX\n    );\n  }\n\n  /**\n   * Returns whether the snapshot contains a child at the specified path.\n   *\n   * @param childPathString Path to a child.\n   * @return Whether the child exists.\n   */\n  hasChild(childPathString: string): boolean {\n    validateArgCount('DataSnapshot.hasChild', 1, 1, arguments.length);\n    validatePathString('DataSnapshot.hasChild', 1, childPathString, false);\n\n    const childPath = new Path(childPathString);\n    return !this.node_.getChild(childPath).isEmpty();\n  }\n\n  /**\n   * Returns the priority of the object, or null if no priority was set.\n   *\n   * @return The priority.\n   */\n  getPriority(): string | number | null {\n    validateArgCount('DataSnapshot.getPriority', 0, 0, arguments.length);\n\n    // typecast here because we never return deferred values or internal priorities (MAX_PRIORITY)\n    return this.node_.getPriority().val() as string | number | null;\n  }\n\n  /**\n   * Iterates through child nodes and calls the specified action for each one.\n   *\n   * @param action Callback function to be called\n   * for each child.\n   * @return True if forEach was canceled by action returning true for\n   * one of the child nodes.\n   */\n  forEach(action: (d: DataSnapshot) => boolean | void): boolean {\n    validateArgCount('DataSnapshot.forEach', 1, 1, arguments.length);\n    validateCallback('DataSnapshot.forEach', 1, action, false);\n\n    if (this.node_.isLeafNode()) {\n      return false;\n    }\n\n    const childrenNode = this.node_ as ChildrenNode;\n    // Sanitize the return value to a boolean. ChildrenNode.forEachChild has a weird return type...\n    return !!childrenNode.forEachChild(this.index_, (key, node) => {\n      return action(\n        new DataSnapshot(node, this.ref_.child(key), PRIORITY_INDEX)\n      );\n    });\n  }\n\n  /**\n   * Returns whether this DataSnapshot has children.\n   * @return True if the DataSnapshot contains 1 or more child nodes.\n   */\n  hasChildren(): boolean {\n    validateArgCount('DataSnapshot.hasChildren', 0, 0, arguments.length);\n\n    if (this.node_.isLeafNode()) {\n      return false;\n    } else {\n      return !this.node_.isEmpty();\n    }\n  }\n\n  get key() {\n    return this.ref_.getKey();\n  }\n\n  /**\n   * Returns the number of children for this DataSnapshot.\n   * @return The number of children that this DataSnapshot contains.\n   */\n  numChildren(): number {\n    validateArgCount('DataSnapshot.numChildren', 0, 0, arguments.length);\n\n    return this.node_.numChildren();\n  }\n\n  /**\n   * @return The Firebase reference for the location this snapshot's data came\n   * from.\n   */\n  getRef(): Reference {\n    validateArgCount('DataSnapshot.ref', 0, 0, arguments.length);\n\n    return this.ref_;\n  }\n\n  get ref() {\n    return this.getRef();\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { contains, safeGet } from '@firebase/util';\nimport { Path, pathGetFront, pathPopFront } from './Path';\n\nimport { each } from './util';\n\n/**\n * Node in a Tree.\n */\nexport interface TreeNode<T> {\n  // TODO: Consider making accessors that create children and value lazily or\n  // separate Internal / Leaf 'types'.\n  children: Record<string, TreeNode<T>>;\n  childCount: number;\n  value?: T;\n}\n\n/**\n * A light-weight tree, traversable by path.  Nodes can have both values and children.\n * Nodes are not enumerated (by forEachChild) unless they have a value or non-empty\n * children.\n */\nexport class Tree<T> {\n  /**\n   * @param name Optional name of the node.\n   * @param parent Optional parent node.\n   * @param node Optional node to wrap.\n   */\n  constructor(\n    readonly name: string = '',\n    readonly parent: Tree<T> | null = null,\n    public node: TreeNode<T> = { children: {}, childCount: 0 }\n  ) {}\n}\n\n/**\n * Returns a sub-Tree for the given path.\n *\n * @param pathObj Path to look up.\n * @return Tree for path.\n */\nexport function treeSubTree<T>(tree: Tree<T>, pathObj: string | Path): Tree<T> {\n  // TODO: Require pathObj to be Path?\n  let path = pathObj instanceof Path ? pathObj : new Path(pathObj);\n  let child = tree,\n    next = pathGetFront(path);\n  while (next !== null) {\n    const childNode = safeGet(child.node.children, next) || {\n      children: {},\n      childCount: 0\n    };\n    child = new Tree<T>(next, child, childNode);\n    path = pathPopFront(path);\n    next = pathGetFront(path);\n  }\n\n  return child;\n}\n\n/**\n * Returns the data associated with this tree node.\n *\n * @return The data or null if no data exists.\n */\nexport function treeGetValue<T>(tree: Tree<T>): T | undefined {\n  return tree.node.value;\n}\n\n/**\n * Sets data to this tree node.\n *\n * @param value Value to set.\n */\nexport function treeSetValue<T>(tree: Tree<T>, value: T | undefined): void {\n  tree.node.value = value;\n  treeUpdateParents(tree);\n}\n\n/**\n * @return Whether the tree has any children.\n */\nexport function treeHasChildren<T>(tree: Tree<T>): boolean {\n  return tree.node.childCount > 0;\n}\n\n/**\n * @return Whethe rthe tree is empty (no value or children).\n */\nexport function treeIsEmpty<T>(tree: Tree<T>): boolean {\n  return treeGetValue(tree) === undefined && !treeHasChildren(tree);\n}\n\n/**\n * Calls action for each child of this tree node.\n *\n * @param action Action to be called for each child.\n */\nexport function treeForEachChild<T>(\n  tree: Tree<T>,\n  action: (tree: Tree<T>) => void\n): void {\n  each(tree.node.children, (child: string, childTree: TreeNode<T>) => {\n    action(new Tree<T>(child, tree, childTree));\n  });\n}\n\n/**\n * Does a depth-first traversal of this node's descendants, calling action for each one.\n *\n * @param action Action to be called for each child.\n * @param includeSelf Whether to call action on this node as well. Defaults to\n *   false.\n * @param childrenFirst Whether to call action on children before calling it on\n *   parent.\n */\nexport function treeForEachDescendant<T>(\n  tree: Tree<T>,\n  action: (tree: Tree<T>) => void,\n  includeSelf?: boolean,\n  childrenFirst?: boolean\n): void {\n  if (includeSelf && !childrenFirst) {\n    action(tree);\n  }\n\n  treeForEachChild(tree, child => {\n    treeForEachDescendant(child, action, true, childrenFirst);\n  });\n\n  if (includeSelf && childrenFirst) {\n    action(tree);\n  }\n}\n\n/**\n * Calls action on each ancestor node.\n *\n * @param action Action to be called on each parent; return\n *   true to abort.\n * @param includeSelf Whether to call action on this node as well.\n * @return true if the action callback returned true.\n */\nexport function treeForEachAncestor<T>(\n  tree: Tree<T>,\n  action: (tree: Tree<T>) => unknown,\n  includeSelf?: boolean\n): boolean {\n  let node = includeSelf ? tree : tree.parent;\n  while (node !== null) {\n    if (action(node)) {\n      return true;\n    }\n    node = node.parent;\n  }\n  return false;\n}\n\n/**\n * Does a depth-first traversal of this node's descendants.  When a descendant with a value\n * is found, action is called on it and traversal does not continue inside the node.\n * Action is *not* called on this node.\n *\n * @param action Action to be called for each child.\n */\nexport function treeForEachImmediateDescendantWithValue<T>(\n  tree: Tree<T>,\n  action: (tree: Tree<T>) => void\n): void {\n  treeForEachChild(tree, child => {\n    if (treeGetValue(child) !== undefined) {\n      action(child);\n    } else {\n      treeForEachImmediateDescendantWithValue(child, action);\n    }\n  });\n}\n\n/**\n * @return The path of this tree node, as a Path.\n */\nexport function treeGetPath<T>(tree: Tree<T>) {\n  return new Path(\n    tree.parent === null\n      ? tree.name\n      : treeGetPath(tree.parent) + '/' + tree.name\n  );\n}\n\n/**\n * Adds or removes this child from its parent based on whether it's empty or not.\n */\nfunction treeUpdateParents<T>(tree: Tree<T>) {\n  if (tree.parent !== null) {\n    treeUpdateChild(tree.parent, tree.name, tree);\n  }\n}\n\n/**\n * Adds or removes the passed child to this tree node, depending on whether it's empty.\n *\n * @param childName The name of the child to update.\n * @param child The child to update.\n */\nfunction treeUpdateChild<T>(tree: Tree<T>, childName: string, child: Tree<T>) {\n  const childEmpty = treeIsEmpty(child);\n  const childExists = contains(tree.node.children, childName);\n  if (childEmpty && childExists) {\n    delete tree.node.children[childName];\n    tree.node.childCount--;\n    treeUpdateParents(tree);\n  } else if (!childEmpty && !childExists) {\n    tree.node.children[childName] = child.node;\n    tree.node.childCount++;\n    treeUpdateParents(tree);\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  generateWithValues,\n  resolveDeferredValueSnapshot,\n  resolveDeferredValueTree\n} from './util/ServerValues';\nimport { nodeFromJSON } from './snap/nodeFromJSON';\nimport {\n  newEmptyPath,\n  newRelativePath,\n  Path,\n  pathChild,\n  pathGetFront,\n  pathPopFront\n} from './util/Path';\nimport {\n  newSparseSnapshotTree,\n  sparseSnapshotTreeForEachTree,\n  sparseSnapshotTreeForget,\n  sparseSnapshotTreeRemember\n} from './SparseSnapshotTree';\nimport {\n  SyncTree,\n  syncTreeAckUserWrite,\n  syncTreeAddEventRegistration,\n  syncTreeApplyServerMerge,\n  syncTreeApplyServerOverwrite,\n  syncTreeApplyTaggedQueryMerge,\n  syncTreeApplyTaggedQueryOverwrite,\n  syncTreeApplyUserMerge,\n  syncTreeApplyUserOverwrite,\n  syncTreeCalcCompleteEventCache,\n  syncTreeGetServerValue,\n  syncTreeRemoveEventRegistration\n} from './SyncTree';\nimport { SnapshotHolder } from './SnapshotHolder';\nimport {\n  assert,\n  contains,\n  isEmpty,\n  map,\n  safeGet,\n  stringify\n} from '@firebase/util';\nimport {\n  beingCrawled,\n  each,\n  exceptionGuard,\n  log,\n  LUIDGenerator,\n  warn\n} from './util/util';\n\nimport { AuthTokenProvider } from './AuthTokenProvider';\nimport {\n  statsManagerGetCollection,\n  statsManagerGetOrCreateReporter\n} from './stats/StatsManager';\nimport { StatsReporter, statsReporterIncludeStat } from './stats/StatsReporter';\nimport { StatsListener } from './stats/StatsListener';\nimport {\n  EventQueue,\n  eventQueueQueueEvents,\n  eventQueueRaiseEventsAtPath,\n  eventQueueRaiseEventsForChangedPath\n} from './view/EventQueue';\nimport { PersistentConnection } from './PersistentConnection';\nimport { ReadonlyRestClient } from './ReadonlyRestClient';\nimport { RepoInfo } from './RepoInfo';\nimport { Database } from '../api/Database';\nimport { DataSnapshot } from '../api/DataSnapshot';\nimport { ServerActions } from './ServerActions';\nimport { Query } from '../api/Query';\nimport { EventRegistration } from './view/EventRegistration';\nimport { StatsCollection } from './stats/StatsCollection';\nimport { Event } from './view/Event';\nimport { Node } from './snap/Node';\nimport { Indexable } from './util/misc';\nimport {\n  Tree,\n  treeForEachAncestor,\n  treeForEachChild,\n  treeForEachDescendant,\n  treeGetPath,\n  treeGetValue,\n  treeHasChildren,\n  treeSetValue,\n  treeSubTree\n} from './util/Tree';\nimport { isValidPriority, validateFirebaseData } from './util/validation';\nimport { ChildrenNode } from './snap/ChildrenNode';\nimport { PRIORITY_INDEX } from './snap/indexes/PriorityIndex';\nimport { Reference } from '../api/Reference';\nimport { FirebaseAppLike } from './RepoManager';\n\nconst INTERRUPT_REASON = 'repo_interrupt';\n\n/**\n * If a transaction does not succeed after 25 retries, we abort it. Among other\n * things this ensure that if there's ever a bug causing a mismatch between\n * client / server hashes for some data, we won't retry indefinitely.\n */\nconst MAX_TRANSACTION_RETRIES = 25;\n\nconst enum TransactionStatus {\n  // We've run the transaction and updated transactionResultData_ with the result, but it isn't currently sent to the\n  // server. A transaction will go from RUN -> SENT -> RUN if it comes back from the server as rejected due to\n  // mismatched hash.\n  RUN,\n\n  // We've run the transaction and sent it to the server and it's currently outstanding (hasn't come back as accepted\n  // or rejected yet).\n  SENT,\n\n  // Temporary state used to mark completed transactions (whether successful or aborted).  The transaction will be\n  // removed when we get a chance to prune completed ones.\n  COMPLETED,\n\n  // Used when an already-sent transaction needs to be aborted (e.g. due to a conflicting set() call that was made).\n  // If it comes back as unsuccessful, we'll abort it.\n  SENT_NEEDS_ABORT,\n\n  // Temporary state used to mark transactions that need to be aborted.\n  NEEDS_ABORT\n}\n\ninterface Transaction {\n  path: Path;\n  update: (a: unknown) => unknown;\n  onComplete: (a: Error | null, b: boolean, c: DataSnapshot | null) => void;\n  status: TransactionStatus;\n  order: number;\n  applyLocally: boolean;\n  retryCount: number;\n  unwatcher: () => void;\n  abortReason: string | null;\n  currentWriteId: number;\n  currentInputSnapshot: Node | null;\n  currentOutputSnapshotRaw: Node | null;\n  currentOutputSnapshotResolved: Node | null;\n}\n\n/**\n * A connection to a single data repository.\n */\nexport class Repo {\n  /** Key for uniquely identifying this repo, used in RepoManager */\n  readonly key: string;\n\n  dataUpdateCount = 0;\n  infoSyncTree_: SyncTree;\n  serverSyncTree_: SyncTree;\n\n  stats_: StatsCollection;\n  statsListener_: StatsListener | null = null;\n  eventQueue_ = new EventQueue();\n  nextWriteId_ = 1;\n  server_: ServerActions;\n  statsReporter_: StatsReporter;\n  infoData_: SnapshotHolder;\n  interceptServerDataCallback_: ((a: string, b: unknown) => void) | null = null;\n  __database: Database;\n\n  /** A list of data pieces and paths to be set when this client disconnects. */\n  onDisconnect_ = newSparseSnapshotTree();\n\n  /** Stores queues of outstanding transactions for Firebase locations. */\n  transactionQueueTree_ = new Tree<Transaction[]>();\n\n  // TODO: This should be @private but it's used by test_access.js and internal.js\n  persistentConnection_: PersistentConnection | null = null;\n\n  constructor(\n    public repoInfo_: RepoInfo,\n    public forceRestClient_: boolean,\n    public app: FirebaseAppLike,\n    public authTokenProvider_: AuthTokenProvider\n  ) {\n    // This key is intentionally not updated if RepoInfo is later changed or replaced\n    this.key = this.repoInfo_.toURLString();\n  }\n\n  /**\n   * @return The URL corresponding to the root of this Firebase.\n   */\n  toString(): string {\n    return (\n      (this.repoInfo_.secure ? 'https://' : 'http://') + this.repoInfo_.host\n    );\n  }\n}\n\nexport function repoStart(repo: Repo): void {\n  repo.stats_ = statsManagerGetCollection(repo.repoInfo_);\n\n  if (repo.forceRestClient_ || beingCrawled()) {\n    repo.server_ = new ReadonlyRestClient(\n      repo.repoInfo_,\n      (\n        pathString: string,\n        data: unknown,\n        isMerge: boolean,\n        tag: number | null\n      ) => {\n        repoOnDataUpdate(repo, pathString, data, isMerge, tag);\n      },\n      repo.authTokenProvider_\n    );\n\n    // Minor hack: Fire onConnect immediately, since there's no actual connection.\n    setTimeout(() => repoOnConnectStatus(repo, /* connectStatus= */ true), 0);\n  } else {\n    const authOverride = repo.app.options['databaseAuthVariableOverride'];\n    // Validate authOverride\n    if (typeof authOverride !== 'undefined' && authOverride !== null) {\n      if (typeof authOverride !== 'object') {\n        throw new Error(\n          'Only objects are supported for option databaseAuthVariableOverride'\n        );\n      }\n      try {\n        stringify(authOverride);\n      } catch (e) {\n        throw new Error('Invalid authOverride provided: ' + e);\n      }\n    }\n\n    repo.persistentConnection_ = new PersistentConnection(\n      repo.repoInfo_,\n      repo.app.options.appId,\n      (\n        pathString: string,\n        data: unknown,\n        isMerge: boolean,\n        tag: number | null\n      ) => {\n        repoOnDataUpdate(repo, pathString, data, isMerge, tag);\n      },\n      (connectStatus: boolean) => {\n        repoOnConnectStatus(repo, connectStatus);\n      },\n      (updates: object) => {\n        repoOnServerInfoUpdate(repo, updates);\n      },\n      repo.authTokenProvider_,\n      authOverride\n    );\n\n    repo.server_ = repo.persistentConnection_;\n  }\n\n  repo.authTokenProvider_.addTokenChangeListener(token => {\n    repo.server_.refreshAuthToken(token);\n  });\n\n  // In the case of multiple Repos for the same repoInfo (i.e. there are multiple Firebase.Contexts being used),\n  // we only want to create one StatsReporter.  As such, we'll report stats over the first Repo created.\n  repo.statsReporter_ = statsManagerGetOrCreateReporter(\n    repo.repoInfo_,\n    () => new StatsReporter(repo.stats_, repo.server_)\n  );\n\n  // Used for .info.\n  repo.infoData_ = new SnapshotHolder();\n  repo.infoSyncTree_ = new SyncTree({\n    startListening: (query, tag, currentHashFn, onComplete) => {\n      let infoEvents: Event[] = [];\n      const node = repo.infoData_.getNode(query.path);\n      // This is possibly a hack, but we have different semantics for .info endpoints. We don't raise null events\n      // on initial data...\n      if (!node.isEmpty()) {\n        infoEvents = syncTreeApplyServerOverwrite(\n          repo.infoSyncTree_,\n          query.path,\n          node\n        );\n        setTimeout(() => {\n          onComplete('ok');\n        }, 0);\n      }\n      return infoEvents;\n    },\n    stopListening: () => {}\n  });\n  repoUpdateInfo(repo, 'connected', false);\n\n  repo.serverSyncTree_ = new SyncTree({\n    startListening: (query, tag, currentHashFn, onComplete) => {\n      repo.server_.listen(query, currentHashFn, tag, (status, data) => {\n        const events = onComplete(status, data);\n        eventQueueRaiseEventsForChangedPath(\n          repo.eventQueue_,\n          query.path,\n          events\n        );\n      });\n      // No synchronous events for network-backed sync trees\n      return [];\n    },\n    stopListening: (query, tag) => {\n      repo.server_.unlisten(query, tag);\n    }\n  });\n}\n\n/**\n * @return The time in milliseconds, taking the server offset into account if we have one.\n */\nexport function repoServerTime(repo: Repo): number {\n  const offsetNode = repo.infoData_.getNode(new Path('.info/serverTimeOffset'));\n  const offset = (offsetNode.val() as number) || 0;\n  return new Date().getTime() + offset;\n}\n\n/**\n * Generate ServerValues using some variables from the repo object.\n */\nexport function repoGenerateServerValues(repo: Repo): Indexable {\n  return generateWithValues({\n    timestamp: repoServerTime(repo)\n  });\n}\n\n/**\n * Called by realtime when we get new messages from the server.\n */\nfunction repoOnDataUpdate(\n  repo: Repo,\n  pathString: string,\n  data: unknown,\n  isMerge: boolean,\n  tag: number | null\n): void {\n  // For testing.\n  repo.dataUpdateCount++;\n  const path = new Path(pathString);\n  data = repo.interceptServerDataCallback_\n    ? repo.interceptServerDataCallback_(pathString, data)\n    : data;\n  let events = [];\n  if (tag) {\n    if (isMerge) {\n      const taggedChildren = map(\n        data as { [k: string]: unknown },\n        (raw: unknown) => nodeFromJSON(raw)\n      );\n      events = syncTreeApplyTaggedQueryMerge(\n        repo.serverSyncTree_,\n        path,\n        taggedChildren,\n        tag\n      );\n    } else {\n      const taggedSnap = nodeFromJSON(data);\n      events = syncTreeApplyTaggedQueryOverwrite(\n        repo.serverSyncTree_,\n        path,\n        taggedSnap,\n        tag\n      );\n    }\n  } else if (isMerge) {\n    const changedChildren = map(\n      data as { [k: string]: unknown },\n      (raw: unknown) => nodeFromJSON(raw)\n    );\n    events = syncTreeApplyServerMerge(\n      repo.serverSyncTree_,\n      path,\n      changedChildren\n    );\n  } else {\n    const snap = nodeFromJSON(data);\n    events = syncTreeApplyServerOverwrite(repo.serverSyncTree_, path, snap);\n  }\n  let affectedPath = path;\n  if (events.length > 0) {\n    // Since we have a listener outstanding for each transaction, receiving any events\n    // is a proxy for some change having occurred.\n    affectedPath = repoRerunTransactions(repo, path);\n  }\n  eventQueueRaiseEventsForChangedPath(repo.eventQueue_, affectedPath, events);\n}\n\n// TODO: This should be @private but it's used by test_access.js and internal.js\nexport function repoInterceptServerData(\n  repo: Repo,\n  callback: ((a: string, b: unknown) => unknown) | null\n): void {\n  repo.interceptServerDataCallback_ = callback;\n}\n\nfunction repoOnConnectStatus(repo: Repo, connectStatus: boolean): void {\n  repoUpdateInfo(repo, 'connected', connectStatus);\n  if (connectStatus === false) {\n    repoRunOnDisconnectEvents(repo);\n  }\n}\n\nfunction repoOnServerInfoUpdate(repo: Repo, updates: object): void {\n  each(updates, (key: string, value: unknown) => {\n    repoUpdateInfo(repo, key, value);\n  });\n}\n\nfunction repoUpdateInfo(repo: Repo, pathString: string, value: unknown): void {\n  const path = new Path('/.info/' + pathString);\n  const newNode = nodeFromJSON(value);\n  repo.infoData_.updateSnapshot(path, newNode);\n  const events = syncTreeApplyServerOverwrite(\n    repo.infoSyncTree_,\n    path,\n    newNode\n  );\n  eventQueueRaiseEventsForChangedPath(repo.eventQueue_, path, events);\n}\n\nfunction repoGetNextWriteId(repo: Repo): number {\n  return repo.nextWriteId_++;\n}\n\n/**\n * The purpose of `getValue` is to return the latest known value\n * satisfying `query`.\n *\n * This method will first check for in-memory cached values\n * belonging to active listeners. If they are found, such values\n * are considered to be the most up-to-date.\n *\n * If the client is not connected, this method will try to\n * establish a connection and request the value for `query`. If\n * the client is not able to retrieve the query result, it reports\n * an error.\n *\n * @param query - The query to surface a value for.\n */\nexport function repoGetValue(repo: Repo, query: Query): Promise<DataSnapshot> {\n  // Only active queries are cached. There is no persisted cache.\n  const cached = syncTreeGetServerValue(repo.serverSyncTree_, query);\n  if (cached != null) {\n    return Promise.resolve(\n      new DataSnapshot(\n        cached,\n        query.getRef(),\n        query.getQueryParams().getIndex()\n      )\n    );\n  }\n  return repo.server_.get(query).then(\n    payload => {\n      const node = nodeFromJSON(payload as string);\n      const events = syncTreeApplyServerOverwrite(\n        repo.serverSyncTree_,\n        query.path,\n        node\n      );\n      eventQueueRaiseEventsAtPath(repo.eventQueue_, query.path, events);\n      return Promise.resolve(\n        new DataSnapshot(\n          node,\n          query.getRef(),\n          query.getQueryParams().getIndex()\n        )\n      );\n    },\n    err => {\n      repoLog(repo, 'get for query ' + stringify(query) + ' failed: ' + err);\n      return Promise.reject(new Error(err as string));\n    }\n  );\n}\n\nexport function repoSetWithPriority(\n  repo: Repo,\n  path: Path,\n  newVal: unknown,\n  newPriority: number | string | null,\n  onComplete: ((status: Error | null, errorReason?: string) => void) | null\n): void {\n  repoLog(repo, 'set', {\n    path: path.toString(),\n    value: newVal,\n    priority: newPriority\n  });\n\n  // TODO: Optimize this behavior to either (a) store flag to skip resolving where possible and / or\n  // (b) store unresolved paths on JSON parse\n  const serverValues = repoGenerateServerValues(repo);\n  const newNodeUnresolved = nodeFromJSON(newVal, newPriority);\n  const existing = syncTreeCalcCompleteEventCache(repo.serverSyncTree_, path);\n  const newNode = resolveDeferredValueSnapshot(\n    newNodeUnresolved,\n    existing,\n    serverValues\n  );\n\n  const writeId = repoGetNextWriteId(repo);\n  const events = syncTreeApplyUserOverwrite(\n    repo.serverSyncTree_,\n    path,\n    newNode,\n    writeId,\n    true\n  );\n  eventQueueQueueEvents(repo.eventQueue_, events);\n  repo.server_.put(\n    path.toString(),\n    newNodeUnresolved.val(/*export=*/ true),\n    (status, errorReason) => {\n      const success = status === 'ok';\n      if (!success) {\n        warn('set at ' + path + ' failed: ' + status);\n      }\n\n      const clearEvents = syncTreeAckUserWrite(\n        repo.serverSyncTree_,\n        writeId,\n        !success\n      );\n      eventQueueRaiseEventsForChangedPath(repo.eventQueue_, path, clearEvents);\n      repoCallOnCompleteCallback(repo, onComplete, status, errorReason);\n    }\n  );\n  const affectedPath = repoAbortTransactions(repo, path);\n  repoRerunTransactions(repo, affectedPath);\n  // We queued the events above, so just flush the queue here\n  eventQueueRaiseEventsForChangedPath(repo.eventQueue_, affectedPath, []);\n}\n\nexport function repoUpdate(\n  repo: Repo,\n  path: Path,\n  childrenToMerge: { [k: string]: unknown },\n  onComplete: ((status: Error | null, errorReason?: string) => void) | null\n): void {\n  repoLog(repo, 'update', { path: path.toString(), value: childrenToMerge });\n\n  // Start with our existing data and merge each child into it.\n  let empty = true;\n  const serverValues = repoGenerateServerValues(repo);\n  const changedChildren: { [k: string]: Node } = {};\n  each(childrenToMerge, (changedKey: string, changedValue: unknown) => {\n    empty = false;\n    changedChildren[changedKey] = resolveDeferredValueTree(\n      pathChild(path, changedKey),\n      nodeFromJSON(changedValue),\n      repo.serverSyncTree_,\n      serverValues\n    );\n  });\n\n  if (!empty) {\n    const writeId = repoGetNextWriteId(repo);\n    const events = syncTreeApplyUserMerge(\n      repo.serverSyncTree_,\n      path,\n      changedChildren,\n      writeId\n    );\n    eventQueueQueueEvents(repo.eventQueue_, events);\n    repo.server_.merge(\n      path.toString(),\n      childrenToMerge,\n      (status, errorReason) => {\n        const success = status === 'ok';\n        if (!success) {\n          warn('update at ' + path + ' failed: ' + status);\n        }\n\n        const clearEvents = syncTreeAckUserWrite(\n          repo.serverSyncTree_,\n          writeId,\n          !success\n        );\n        const affectedPath =\n          clearEvents.length > 0 ? repoRerunTransactions(repo, path) : path;\n        eventQueueRaiseEventsForChangedPath(\n          repo.eventQueue_,\n          affectedPath,\n          clearEvents\n        );\n        repoCallOnCompleteCallback(repo, onComplete, status, errorReason);\n      }\n    );\n\n    each(childrenToMerge, (changedPath: string) => {\n      const affectedPath = repoAbortTransactions(\n        repo,\n        pathChild(path, changedPath)\n      );\n      repoRerunTransactions(repo, affectedPath);\n    });\n\n    // We queued the events above, so just flush the queue here\n    eventQueueRaiseEventsForChangedPath(repo.eventQueue_, path, []);\n  } else {\n    log(\"update() called with empty data.  Don't do anything.\");\n    repoCallOnCompleteCallback(repo, onComplete, 'ok', undefined);\n  }\n}\n\n/**\n * Applies all of the changes stored up in the onDisconnect_ tree.\n */\nfunction repoRunOnDisconnectEvents(repo: Repo): void {\n  repoLog(repo, 'onDisconnectEvents');\n\n  const serverValues = repoGenerateServerValues(repo);\n  const resolvedOnDisconnectTree = newSparseSnapshotTree();\n  sparseSnapshotTreeForEachTree(\n    repo.onDisconnect_,\n    newEmptyPath(),\n    (path, node) => {\n      const resolved = resolveDeferredValueTree(\n        path,\n        node,\n        repo.serverSyncTree_,\n        serverValues\n      );\n      sparseSnapshotTreeRemember(resolvedOnDisconnectTree, path, resolved);\n    }\n  );\n  let events: Event[] = [];\n\n  sparseSnapshotTreeForEachTree(\n    resolvedOnDisconnectTree,\n    newEmptyPath(),\n    (path, snap) => {\n      events = events.concat(\n        syncTreeApplyServerOverwrite(repo.serverSyncTree_, path, snap)\n      );\n      const affectedPath = repoAbortTransactions(repo, path);\n      repoRerunTransactions(repo, affectedPath);\n    }\n  );\n\n  repo.onDisconnect_ = newSparseSnapshotTree();\n  eventQueueRaiseEventsForChangedPath(repo.eventQueue_, newEmptyPath(), events);\n}\n\nexport function repoOnDisconnectCancel(\n  repo: Repo,\n  path: Path,\n  onComplete: ((status: Error | null, errorReason?: string) => void) | null\n): void {\n  repo.server_.onDisconnectCancel(path.toString(), (status, errorReason) => {\n    if (status === 'ok') {\n      sparseSnapshotTreeForget(repo.onDisconnect_, path);\n    }\n    repoCallOnCompleteCallback(repo, onComplete, status, errorReason);\n  });\n}\n\nexport function repoOnDisconnectSet(\n  repo: Repo,\n  path: Path,\n  value: unknown,\n  onComplete: ((status: Error | null, errorReason?: string) => void) | null\n): void {\n  const newNode = nodeFromJSON(value);\n  repo.server_.onDisconnectPut(\n    path.toString(),\n    newNode.val(/*export=*/ true),\n    (status, errorReason) => {\n      if (status === 'ok') {\n        sparseSnapshotTreeRemember(repo.onDisconnect_, path, newNode);\n      }\n      repoCallOnCompleteCallback(repo, onComplete, status, errorReason);\n    }\n  );\n}\n\nexport function repoOnDisconnectSetWithPriority(\n  repo: Repo,\n  path: Path,\n  value: unknown,\n  priority: unknown,\n  onComplete: ((status: Error | null, errorReason?: string) => void) | null\n): void {\n  const newNode = nodeFromJSON(value, priority);\n  repo.server_.onDisconnectPut(\n    path.toString(),\n    newNode.val(/*export=*/ true),\n    (status, errorReason) => {\n      if (status === 'ok') {\n        sparseSnapshotTreeRemember(repo.onDisconnect_, path, newNode);\n      }\n      repoCallOnCompleteCallback(repo, onComplete, status, errorReason);\n    }\n  );\n}\n\nexport function repoOnDisconnectUpdate(\n  repo: Repo,\n  path: Path,\n  childrenToMerge: { [k: string]: unknown },\n  onComplete: ((status: Error | null, errorReason?: string) => void) | null\n): void {\n  if (isEmpty(childrenToMerge)) {\n    log(\"onDisconnect().update() called with empty data.  Don't do anything.\");\n    repoCallOnCompleteCallback(repo, onComplete, 'ok', undefined);\n    return;\n  }\n\n  repo.server_.onDisconnectMerge(\n    path.toString(),\n    childrenToMerge,\n    (status, errorReason) => {\n      if (status === 'ok') {\n        each(childrenToMerge, (childName: string, childNode: unknown) => {\n          const newChildNode = nodeFromJSON(childNode);\n          sparseSnapshotTreeRemember(\n            repo.onDisconnect_,\n            pathChild(path, childName),\n            newChildNode\n          );\n        });\n      }\n      repoCallOnCompleteCallback(repo, onComplete, status, errorReason);\n    }\n  );\n}\n\nexport function repoAddEventCallbackForQuery(\n  repo: Repo,\n  query: Query,\n  eventRegistration: EventRegistration\n): void {\n  let events;\n  if (pathGetFront(query.path) === '.info') {\n    events = syncTreeAddEventRegistration(\n      repo.infoSyncTree_,\n      query,\n      eventRegistration\n    );\n  } else {\n    events = syncTreeAddEventRegistration(\n      repo.serverSyncTree_,\n      query,\n      eventRegistration\n    );\n  }\n  eventQueueRaiseEventsAtPath(repo.eventQueue_, query.path, events);\n}\n\nexport function repoRemoveEventCallbackForQuery(\n  repo: Repo,\n  query: Query,\n  eventRegistration: EventRegistration\n): void {\n  // These are guaranteed not to raise events, since we're not passing in a cancelError. However, we can future-proof\n  // a little bit by handling the return values anyways.\n  let events;\n  if (pathGetFront(query.path) === '.info') {\n    events = syncTreeRemoveEventRegistration(\n      repo.infoSyncTree_,\n      query,\n      eventRegistration\n    );\n  } else {\n    events = syncTreeRemoveEventRegistration(\n      repo.serverSyncTree_,\n      query,\n      eventRegistration\n    );\n  }\n  eventQueueRaiseEventsAtPath(repo.eventQueue_, query.path, events);\n}\n\nexport function repoInterrupt(repo: Repo): void {\n  if (repo.persistentConnection_) {\n    repo.persistentConnection_.interrupt(INTERRUPT_REASON);\n  }\n}\n\nexport function repoResume(repo: Repo): void {\n  if (repo.persistentConnection_) {\n    repo.persistentConnection_.resume(INTERRUPT_REASON);\n  }\n}\n\nexport function repoStats(repo: Repo, showDelta: boolean = false): void {\n  if (typeof console === 'undefined') {\n    return;\n  }\n\n  let stats: { [k: string]: unknown };\n  if (showDelta) {\n    if (!repo.statsListener_) {\n      repo.statsListener_ = new StatsListener(repo.stats_);\n    }\n    stats = repo.statsListener_.get();\n  } else {\n    stats = repo.stats_.get();\n  }\n\n  const longestName = Object.keys(stats).reduce(\n    (previousValue, currentValue) =>\n      Math.max(currentValue.length, previousValue),\n    0\n  );\n\n  each(stats, (stat: string, value: unknown) => {\n    let paddedStat = stat;\n    // pad stat names to be the same length (plus 2 extra spaces).\n    for (let i = stat.length; i < longestName + 2; i++) {\n      paddedStat += ' ';\n    }\n    console.log(paddedStat + value);\n  });\n}\n\nexport function repoStatsIncrementCounter(repo: Repo, metric: string): void {\n  repo.stats_.incrementCounter(metric);\n  statsReporterIncludeStat(repo.statsReporter_, metric);\n}\n\nfunction repoLog(repo: Repo, ...varArgs: unknown[]): void {\n  let prefix = '';\n  if (repo.persistentConnection_) {\n    prefix = repo.persistentConnection_.id + ':';\n  }\n  log(prefix, ...varArgs);\n}\n\nexport function repoCallOnCompleteCallback(\n  repo: Repo,\n  callback: ((status: Error | null, errorReason?: string) => void) | null,\n  status: string,\n  errorReason?: string | null\n): void {\n  if (callback) {\n    exceptionGuard(() => {\n      if (status === 'ok') {\n        callback(null);\n      } else {\n        const code = (status || 'error').toUpperCase();\n        let message = code;\n        if (errorReason) {\n          message += ': ' + errorReason;\n        }\n\n        const error = new Error(message);\n\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        (error as any).code = code;\n        callback(error);\n      }\n    });\n  }\n}\n\nexport function repoGetDatabase(repo: Repo): Database {\n  return repo.__database || (repo.__database = new Database(repo));\n}\n\n/**\n * Creates a new transaction, adds it to the transactions we're tracking, and\n * sends it to the server if possible.\n *\n * @param path Path at which to do transaction.\n * @param transactionUpdate Update callback.\n * @param onComplete Completion callback.\n * @param applyLocally Whether or not to make intermediate results visible\n */\nexport function repoStartTransaction(\n  repo: Repo,\n  path: Path,\n  transactionUpdate: (a: unknown) => unknown,\n  onComplete: ((a: Error, b: boolean, c: DataSnapshot) => void) | null,\n  applyLocally: boolean\n): void {\n  repoLog(repo, 'transaction on ' + path);\n\n  // Add a watch to make sure we get server updates.\n  const valueCallback = function () {};\n  const watchRef = new Reference(repo, path);\n  watchRef.on('value', valueCallback);\n  const unwatcher = function () {\n    watchRef.off('value', valueCallback);\n  };\n\n  // Initialize transaction.\n  const transaction: Transaction = {\n    path,\n    update: transactionUpdate,\n    onComplete,\n    // One of TransactionStatus enums.\n    status: null,\n    // Used when combining transactions at different locations to figure out\n    // which one goes first.\n    order: LUIDGenerator(),\n    // Whether to raise local events for this transaction.\n    applyLocally,\n    // Count of how many times we've retried the transaction.\n    retryCount: 0,\n    // Function to call to clean up our .on() listener.\n    unwatcher,\n    // Stores why a transaction was aborted.\n    abortReason: null,\n    currentWriteId: null,\n    currentInputSnapshot: null,\n    currentOutputSnapshotRaw: null,\n    currentOutputSnapshotResolved: null\n  };\n\n  // Run transaction initially.\n  const currentState = repoGetLatestState(repo, path, undefined);\n  transaction.currentInputSnapshot = currentState;\n  const newVal = transaction.update(currentState.val());\n  if (newVal === undefined) {\n    // Abort transaction.\n    transaction.unwatcher();\n    transaction.currentOutputSnapshotRaw = null;\n    transaction.currentOutputSnapshotResolved = null;\n    if (transaction.onComplete) {\n      // We just set the input snapshot, so this cast should be safe\n      const snapshot = new DataSnapshot(\n        transaction.currentInputSnapshot,\n        new Reference(repo, transaction.path),\n        PRIORITY_INDEX\n      );\n      transaction.onComplete(null, false, snapshot);\n    }\n  } else {\n    validateFirebaseData(\n      'transaction failed: Data returned ',\n      newVal,\n      transaction.path\n    );\n\n    // Mark as run and add to our queue.\n    transaction.status = TransactionStatus.RUN;\n    const queueNode = treeSubTree(repo.transactionQueueTree_, path);\n    const nodeQueue = treeGetValue(queueNode) || [];\n    nodeQueue.push(transaction);\n\n    treeSetValue(queueNode, nodeQueue);\n\n    // Update visibleData and raise events\n    // Note: We intentionally raise events after updating all of our\n    // transaction state, since the user could start new transactions from the\n    // event callbacks.\n    let priorityForNode;\n    if (\n      typeof newVal === 'object' &&\n      newVal !== null &&\n      contains(newVal, '.priority')\n    ) {\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n      priorityForNode = safeGet(newVal as any, '.priority');\n      assert(\n        isValidPriority(priorityForNode),\n        'Invalid priority returned by transaction. ' +\n          'Priority must be a valid string, finite number, server value, or null.'\n      );\n    } else {\n      const currentNode =\n        syncTreeCalcCompleteEventCache(repo.serverSyncTree_, path) ||\n        ChildrenNode.EMPTY_NODE;\n      priorityForNode = currentNode.getPriority().val();\n    }\n\n    const serverValues = repoGenerateServerValues(repo);\n    const newNodeUnresolved = nodeFromJSON(newVal, priorityForNode);\n    const newNode = resolveDeferredValueSnapshot(\n      newNodeUnresolved,\n      currentState,\n      serverValues\n    );\n    transaction.currentOutputSnapshotRaw = newNodeUnresolved;\n    transaction.currentOutputSnapshotResolved = newNode;\n    transaction.currentWriteId = repoGetNextWriteId(repo);\n\n    const events = syncTreeApplyUserOverwrite(\n      repo.serverSyncTree_,\n      path,\n      newNode,\n      transaction.currentWriteId,\n      transaction.applyLocally\n    );\n    eventQueueRaiseEventsForChangedPath(repo.eventQueue_, path, events);\n\n    repoSendReadyTransactions(repo, repo.transactionQueueTree_);\n  }\n}\n\n/**\n * @param excludeSets A specific set to exclude\n */\nfunction repoGetLatestState(\n  repo: Repo,\n  path: Path,\n  excludeSets?: number[]\n): Node {\n  return (\n    syncTreeCalcCompleteEventCache(repo.serverSyncTree_, path, excludeSets) ||\n    ChildrenNode.EMPTY_NODE\n  );\n}\n\n/**\n * Sends any already-run transactions that aren't waiting for outstanding\n * transactions to complete.\n *\n * Externally it's called with no arguments, but it calls itself recursively\n * with a particular transactionQueueTree node to recurse through the tree.\n *\n * @param node transactionQueueTree node to start at.\n */\nfunction repoSendReadyTransactions(\n  repo: Repo,\n  node: Tree<Transaction[]> = repo.transactionQueueTree_\n): void {\n  // Before recursing, make sure any completed transactions are removed.\n  if (!node) {\n    repoPruneCompletedTransactionsBelowNode(repo, node);\n  }\n\n  if (treeGetValue(node)) {\n    const queue = repoBuildTransactionQueue(repo, node);\n    assert(queue.length > 0, 'Sending zero length transaction queue');\n\n    const allRun = queue.every(\n      (transaction: Transaction) => transaction.status === TransactionStatus.RUN\n    );\n\n    // If they're all run (and not sent), we can send them.  Else, we must wait.\n    if (allRun) {\n      repoSendTransactionQueue(repo, treeGetPath(node), queue);\n    }\n  } else if (treeHasChildren(node)) {\n    treeForEachChild(node, childNode => {\n      repoSendReadyTransactions(repo, childNode);\n    });\n  }\n}\n\n/**\n * Given a list of run transactions, send them to the server and then handle\n * the result (success or failure).\n *\n * @param path The location of the queue.\n * @param queue Queue of transactions under the specified location.\n */\nfunction repoSendTransactionQueue(\n  repo: Repo,\n  path: Path,\n  queue: Transaction[]\n): void {\n  // Mark transactions as sent and increment retry count!\n  const setsToIgnore = queue.map(txn => {\n    return txn.currentWriteId;\n  });\n  const latestState = repoGetLatestState(repo, path, setsToIgnore);\n  let snapToSend = latestState;\n  const latestHash = latestState.hash();\n  for (let i = 0; i < queue.length; i++) {\n    const txn = queue[i];\n    assert(\n      txn.status === TransactionStatus.RUN,\n      'tryToSendTransactionQueue_: items in queue should all be run.'\n    );\n    txn.status = TransactionStatus.SENT;\n    txn.retryCount++;\n    const relativePath = newRelativePath(path, txn.path);\n    // If we've gotten to this point, the output snapshot must be defined.\n    snapToSend = snapToSend.updateChild(\n      relativePath /** @type {!Node} */,\n      txn.currentOutputSnapshotRaw\n    );\n  }\n\n  const dataToSend = snapToSend.val(true);\n  const pathToSend = path;\n\n  // Send the put.\n  repo.server_.put(\n    pathToSend.toString(),\n    dataToSend,\n    (status: string) => {\n      repoLog(repo, 'transaction put response', {\n        path: pathToSend.toString(),\n        status\n      });\n\n      let events: Event[] = [];\n      if (status === 'ok') {\n        // Queue up the callbacks and fire them after cleaning up all of our\n        // transaction state, since the callback could trigger more\n        // transactions or sets.\n        const callbacks = [];\n        for (let i = 0; i < queue.length; i++) {\n          queue[i].status = TransactionStatus.COMPLETED;\n          events = events.concat(\n            syncTreeAckUserWrite(repo.serverSyncTree_, queue[i].currentWriteId)\n          );\n          if (queue[i].onComplete) {\n            // We never unset the output snapshot, and given that this\n            // transaction is complete, it should be set\n            const node = queue[i].currentOutputSnapshotResolved as Node;\n            const ref = new Reference(repo, queue[i].path);\n            const snapshot = new DataSnapshot(node, ref, PRIORITY_INDEX);\n            callbacks.push(\n              queue[i].onComplete.bind(null, null, true, snapshot)\n            );\n          }\n          queue[i].unwatcher();\n        }\n\n        // Now remove the completed transactions.\n        repoPruneCompletedTransactionsBelowNode(\n          repo,\n          treeSubTree(repo.transactionQueueTree_, path)\n        );\n        // There may be pending transactions that we can now send.\n        repoSendReadyTransactions(repo, repo.transactionQueueTree_);\n\n        eventQueueRaiseEventsForChangedPath(repo.eventQueue_, path, events);\n\n        // Finally, trigger onComplete callbacks.\n        for (let i = 0; i < callbacks.length; i++) {\n          exceptionGuard(callbacks[i]);\n        }\n      } else {\n        // transactions are no longer sent.  Update their status appropriately.\n        if (status === 'datastale') {\n          for (let i = 0; i < queue.length; i++) {\n            if (queue[i].status === TransactionStatus.SENT_NEEDS_ABORT) {\n              queue[i].status = TransactionStatus.NEEDS_ABORT;\n            } else {\n              queue[i].status = TransactionStatus.RUN;\n            }\n          }\n        } else {\n          warn(\n            'transaction at ' + pathToSend.toString() + ' failed: ' + status\n          );\n          for (let i = 0; i < queue.length; i++) {\n            queue[i].status = TransactionStatus.NEEDS_ABORT;\n            queue[i].abortReason = status;\n          }\n        }\n\n        repoRerunTransactions(repo, path);\n      }\n    },\n    latestHash\n  );\n}\n\n/**\n * Finds all transactions dependent on the data at changedPath and reruns them.\n *\n * Should be called any time cached data changes.\n *\n * Return the highest path that was affected by rerunning transactions. This\n * is the path at which events need to be raised for.\n *\n * @param changedPath The path in mergedData that changed.\n * @return The rootmost path that was affected by rerunning transactions.\n */\nfunction repoRerunTransactions(repo: Repo, changedPath: Path): Path {\n  const rootMostTransactionNode = repoGetAncestorTransactionNode(\n    repo,\n    changedPath\n  );\n  const path = treeGetPath(rootMostTransactionNode);\n\n  const queue = repoBuildTransactionQueue(repo, rootMostTransactionNode);\n  repoRerunTransactionQueue(repo, queue, path);\n\n  return path;\n}\n\n/**\n * Does all the work of rerunning transactions (as well as cleans up aborted\n * transactions and whatnot).\n *\n * @param queue The queue of transactions to run.\n * @param path The path the queue is for.\n */\nfunction repoRerunTransactionQueue(\n  repo: Repo,\n  queue: Transaction[],\n  path: Path\n): void {\n  if (queue.length === 0) {\n    return; // Nothing to do!\n  }\n\n  // Queue up the callbacks and fire them after cleaning up all of our\n  // transaction state, since the callback could trigger more transactions or\n  // sets.\n  const callbacks = [];\n  let events: Event[] = [];\n  // Ignore all of the sets we're going to re-run.\n  const txnsToRerun = queue.filter(q => {\n    return q.status === TransactionStatus.RUN;\n  });\n  const setsToIgnore = txnsToRerun.map(q => {\n    return q.currentWriteId;\n  });\n  for (let i = 0; i < queue.length; i++) {\n    const transaction = queue[i];\n    const relativePath = newRelativePath(path, transaction.path);\n    let abortTransaction = false,\n      abortReason;\n    assert(\n      relativePath !== null,\n      'rerunTransactionsUnderNode_: relativePath should not be null.'\n    );\n\n    if (transaction.status === TransactionStatus.NEEDS_ABORT) {\n      abortTransaction = true;\n      abortReason = transaction.abortReason;\n      events = events.concat(\n        syncTreeAckUserWrite(\n          repo.serverSyncTree_,\n          transaction.currentWriteId,\n          true\n        )\n      );\n    } else if (transaction.status === TransactionStatus.RUN) {\n      if (transaction.retryCount >= MAX_TRANSACTION_RETRIES) {\n        abortTransaction = true;\n        abortReason = 'maxretry';\n        events = events.concat(\n          syncTreeAckUserWrite(\n            repo.serverSyncTree_,\n            transaction.currentWriteId,\n            true\n          )\n        );\n      } else {\n        // This code reruns a transaction\n        const currentNode = repoGetLatestState(\n          repo,\n          transaction.path,\n          setsToIgnore\n        );\n        transaction.currentInputSnapshot = currentNode;\n        const newData = queue[i].update(currentNode.val());\n        if (newData !== undefined) {\n          validateFirebaseData(\n            'transaction failed: Data returned ',\n            newData,\n            transaction.path\n          );\n          let newDataNode = nodeFromJSON(newData);\n          const hasExplicitPriority =\n            typeof newData === 'object' &&\n            newData != null &&\n            contains(newData, '.priority');\n          if (!hasExplicitPriority) {\n            // Keep the old priority if there wasn't a priority explicitly specified.\n            newDataNode = newDataNode.updatePriority(currentNode.getPriority());\n          }\n\n          const oldWriteId = transaction.currentWriteId;\n          const serverValues = repoGenerateServerValues(repo);\n          const newNodeResolved = resolveDeferredValueSnapshot(\n            newDataNode,\n            currentNode,\n            serverValues\n          );\n\n          transaction.currentOutputSnapshotRaw = newDataNode;\n          transaction.currentOutputSnapshotResolved = newNodeResolved;\n          transaction.currentWriteId = repoGetNextWriteId(repo);\n          // Mutates setsToIgnore in place\n          setsToIgnore.splice(setsToIgnore.indexOf(oldWriteId), 1);\n          events = events.concat(\n            syncTreeApplyUserOverwrite(\n              repo.serverSyncTree_,\n              transaction.path,\n              newNodeResolved,\n              transaction.currentWriteId,\n              transaction.applyLocally\n            )\n          );\n          events = events.concat(\n            syncTreeAckUserWrite(repo.serverSyncTree_, oldWriteId, true)\n          );\n        } else {\n          abortTransaction = true;\n          abortReason = 'nodata';\n          events = events.concat(\n            syncTreeAckUserWrite(\n              repo.serverSyncTree_,\n              transaction.currentWriteId,\n              true\n            )\n          );\n        }\n      }\n    }\n    eventQueueRaiseEventsForChangedPath(repo.eventQueue_, path, events);\n    events = [];\n    if (abortTransaction) {\n      // Abort.\n      queue[i].status = TransactionStatus.COMPLETED;\n\n      // Removing a listener can trigger pruning which can muck with\n      // mergedData/visibleData (as it prunes data). So defer the unwatcher\n      // until we're done.\n      (function (unwatcher) {\n        setTimeout(unwatcher, Math.floor(0));\n      })(queue[i].unwatcher);\n\n      if (queue[i].onComplete) {\n        if (abortReason === 'nodata') {\n          const ref = new Reference(repo, queue[i].path);\n          // We set this field immediately, so it's safe to cast to an actual snapshot\n          const lastInput /** @type {!Node} */ = queue[i].currentInputSnapshot;\n          const snapshot = new DataSnapshot(lastInput, ref, PRIORITY_INDEX);\n          callbacks.push(queue[i].onComplete.bind(null, null, false, snapshot));\n        } else {\n          callbacks.push(\n            queue[i].onComplete.bind(null, new Error(abortReason), false, null)\n          );\n        }\n      }\n    }\n  }\n\n  // Clean up completed transactions.\n  repoPruneCompletedTransactionsBelowNode(repo, repo.transactionQueueTree_);\n\n  // Now fire callbacks, now that we're in a good, known state.\n  for (let i = 0; i < callbacks.length; i++) {\n    exceptionGuard(callbacks[i]);\n  }\n\n  // Try to send the transaction result to the server.\n  repoSendReadyTransactions(repo, repo.transactionQueueTree_);\n}\n\n/**\n * Returns the rootmost ancestor node of the specified path that has a pending\n * transaction on it, or just returns the node for the given path if there are\n * no pending transactions on any ancestor.\n *\n * @param path The location to start at.\n * @return The rootmost node with a transaction.\n */\nfunction repoGetAncestorTransactionNode(\n  repo: Repo,\n  path: Path\n): Tree<Transaction[]> {\n  let front;\n\n  // Start at the root and walk deeper into the tree towards path until we\n  // find a node with pending transactions.\n  let transactionNode = repo.transactionQueueTree_;\n  front = pathGetFront(path);\n  while (front !== null && treeGetValue(transactionNode) === undefined) {\n    transactionNode = treeSubTree(transactionNode, front);\n    path = pathPopFront(path);\n    front = pathGetFront(path);\n  }\n\n  return transactionNode;\n}\n\n/**\n * Builds the queue of all transactions at or below the specified\n * transactionNode.\n *\n * @param transactionNode\n * @return The generated queue.\n */\nfunction repoBuildTransactionQueue(\n  repo: Repo,\n  transactionNode: Tree<Transaction[]>\n): Transaction[] {\n  // Walk any child transaction queues and aggregate them into a single queue.\n  const transactionQueue: Transaction[] = [];\n  repoAggregateTransactionQueuesForNode(\n    repo,\n    transactionNode,\n    transactionQueue\n  );\n\n  // Sort them by the order the transactions were created.\n  transactionQueue.sort((a, b) => a.order - b.order);\n\n  return transactionQueue;\n}\n\nfunction repoAggregateTransactionQueuesForNode(\n  repo: Repo,\n  node: Tree<Transaction[]>,\n  queue: Transaction[]\n): void {\n  const nodeQueue = treeGetValue(node);\n  if (nodeQueue) {\n    for (let i = 0; i < nodeQueue.length; i++) {\n      queue.push(nodeQueue[i]);\n    }\n  }\n\n  treeForEachChild(node, child => {\n    repoAggregateTransactionQueuesForNode(repo, child, queue);\n  });\n}\n\n/**\n * Remove COMPLETED transactions at or below this node in the transactionQueueTree_.\n */\nfunction repoPruneCompletedTransactionsBelowNode(\n  repo: Repo,\n  node: Tree<Transaction[]>\n): void {\n  const queue = treeGetValue(node);\n  if (queue) {\n    let to = 0;\n    for (let from = 0; from < queue.length; from++) {\n      if (queue[from].status !== TransactionStatus.COMPLETED) {\n        queue[to] = queue[from];\n        to++;\n      }\n    }\n    queue.length = to;\n    treeSetValue(node, queue.length > 0 ? queue : undefined);\n  }\n\n  treeForEachChild(node, childNode => {\n    repoPruneCompletedTransactionsBelowNode(repo, childNode);\n  });\n}\n\n/**\n * Aborts all transactions on ancestors or descendants of the specified path.\n * Called when doing a set() or update() since we consider them incompatible\n * with transactions.\n *\n * @param path Path for which we want to abort related transactions.\n */\nfunction repoAbortTransactions(repo: Repo, path: Path): Path {\n  const affectedPath = treeGetPath(repoGetAncestorTransactionNode(repo, path));\n\n  const transactionNode = treeSubTree(repo.transactionQueueTree_, path);\n\n  treeForEachAncestor(transactionNode, (node: Tree<Transaction[]>) => {\n    repoAbortTransactionsOnNode(repo, node);\n  });\n\n  repoAbortTransactionsOnNode(repo, transactionNode);\n\n  treeForEachDescendant(transactionNode, (node: Tree<Transaction[]>) => {\n    repoAbortTransactionsOnNode(repo, node);\n  });\n\n  return affectedPath;\n}\n\n/**\n * Abort transactions stored in this transaction queue node.\n *\n * @param node Node to abort transactions for.\n */\nfunction repoAbortTransactionsOnNode(\n  repo: Repo,\n  node: Tree<Transaction[]>\n): void {\n  const queue = treeGetValue(node);\n  if (queue) {\n    // Queue up the callbacks and fire them after cleaning up all of our\n    // transaction state, since the callback could trigger more transactions\n    // or sets.\n    const callbacks = [];\n\n    // Go through queue.  Any already-sent transactions must be marked for\n    // abort, while the unsent ones can be immediately aborted and removed.\n    let events: Event[] = [];\n    let lastSent = -1;\n    for (let i = 0; i < queue.length; i++) {\n      if (queue[i].status === TransactionStatus.SENT_NEEDS_ABORT) {\n        // Already marked.  No action needed.\n      } else if (queue[i].status === TransactionStatus.SENT) {\n        assert(\n          lastSent === i - 1,\n          'All SENT items should be at beginning of queue.'\n        );\n        lastSent = i;\n        // Mark transaction for abort when it comes back.\n        queue[i].status = TransactionStatus.SENT_NEEDS_ABORT;\n        queue[i].abortReason = 'set';\n      } else {\n        assert(\n          queue[i].status === TransactionStatus.RUN,\n          'Unexpected transaction status in abort'\n        );\n        // We can abort it immediately.\n        queue[i].unwatcher();\n        events = events.concat(\n          syncTreeAckUserWrite(\n            repo.serverSyncTree_,\n            queue[i].currentWriteId,\n            true\n          )\n        );\n        if (queue[i].onComplete) {\n          const snapshot: DataSnapshot | null = null;\n          callbacks.push(\n            queue[i].onComplete.bind(null, new Error('set'), false, snapshot)\n          );\n        }\n      }\n    }\n    if (lastSent === -1) {\n      // We're not waiting for any sent transactions.  We can clear the queue.\n      treeSetValue(node, undefined);\n    } else {\n      // Remove the transactions we aborted.\n      queue.length = lastSent + 1;\n    }\n\n    // Now fire the callbacks.\n    eventQueueRaiseEventsForChangedPath(\n      repo.eventQueue_,\n      treeGetPath(node),\n      events\n    );\n    for (let i = 0; i < callbacks.length; i++) {\n      exceptionGuard(callbacks[i]);\n    }\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  assert,\n  Deferred,\n  errorPrefix,\n  validateArgCount,\n  validateCallback,\n  validateContextObject\n} from '@firebase/util';\nimport { KEY_INDEX } from '../core/snap/indexes/KeyIndex';\nimport { PRIORITY_INDEX } from '../core/snap/indexes/PriorityIndex';\nimport { VALUE_INDEX } from '../core/snap/indexes/ValueIndex';\nimport { PathIndex } from '../core/snap/indexes/PathIndex';\nimport { MAX_NAME, MIN_NAME, ObjectToUniqueKey } from '../core/util/util';\nimport {\n  Path,\n  pathEquals,\n  pathIsEmpty,\n  pathToUrlEncodedString\n} from '../core/util/Path';\nimport {\n  isValidPriority,\n  validateEventType,\n  validateFirebaseDataArg,\n  validateKey,\n  validatePathString\n} from '../core/util/validation';\n\nimport {\n  ChildEventRegistration,\n  EventRegistration,\n  ValueEventRegistration\n} from '../core/view/EventRegistration';\n\nimport {\n  Repo,\n  repoAddEventCallbackForQuery,\n  repoGetValue,\n  repoRemoveEventCallbackForQuery\n} from '../core/Repo';\nimport {\n  QueryParams,\n  queryParamsEndAt,\n  queryParamsEndBefore,\n  queryParamsGetQueryObject,\n  queryParamsLimitToFirst,\n  queryParamsLimitToLast,\n  queryParamsOrderBy,\n  queryParamsStartAfter,\n  queryParamsStartAt\n} from '../core/view/QueryParams';\nimport { Reference } from './Reference';\nimport { DataSnapshot } from './DataSnapshot';\n\nlet __referenceConstructor: new (repo: Repo, path: Path) => Query;\n\nexport interface SnapshotCallback {\n  (a: DataSnapshot, b?: string | null): unknown;\n}\n\n/**\n * A Query represents a filter to be applied to a firebase location.  This object purely represents the\n * query expression (and exposes our public API to build the query).  The actual query logic is in ViewBase.js.\n *\n * Since every Firebase reference is a query, Firebase inherits from this object.\n */\nexport class Query {\n  static set __referenceConstructor(val) {\n    __referenceConstructor = val;\n  }\n\n  static get __referenceConstructor() {\n    assert(__referenceConstructor, 'Reference.ts has not been loaded');\n    return __referenceConstructor;\n  }\n\n  constructor(\n    public repo: Repo,\n    public path: Path,\n    private queryParams_: QueryParams,\n    private orderByCalled_: boolean\n  ) {}\n\n  /**\n   * Validates start/end values for queries.\n   */\n  private static validateQueryEndpoints_(params: QueryParams) {\n    let startNode = null;\n    let endNode = null;\n    if (params.hasStart()) {\n      startNode = params.getIndexStartValue();\n    }\n    if (params.hasEnd()) {\n      endNode = params.getIndexEndValue();\n    }\n\n    if (params.getIndex() === KEY_INDEX) {\n      const tooManyArgsError =\n        'Query: When ordering by key, you may only pass one argument to ' +\n        'startAt(), endAt(), or equalTo().';\n      const wrongArgTypeError =\n        'Query: When ordering by key, the argument passed to startAt(), startAfter(), ' +\n        'endAt(), endBefore(), or equalTo() must be a string.';\n      if (params.hasStart()) {\n        const startName = params.getIndexStartName();\n        if (startName !== MIN_NAME) {\n          throw new Error(tooManyArgsError);\n        } else if (typeof startNode !== 'string') {\n          throw new Error(wrongArgTypeError);\n        }\n      }\n      if (params.hasEnd()) {\n        const endName = params.getIndexEndName();\n        if (endName !== MAX_NAME) {\n          throw new Error(tooManyArgsError);\n        } else if (typeof endNode !== 'string') {\n          throw new Error(wrongArgTypeError);\n        }\n      }\n    } else if (params.getIndex() === PRIORITY_INDEX) {\n      if (\n        (startNode != null && !isValidPriority(startNode)) ||\n        (endNode != null && !isValidPriority(endNode))\n      ) {\n        throw new Error(\n          'Query: When ordering by priority, the first argument passed to startAt(), ' +\n            'startAfter() endAt(), endBefore(), or equalTo() must be a valid priority value ' +\n            '(null, a number, or a string).'\n        );\n      }\n    } else {\n      assert(\n        params.getIndex() instanceof PathIndex ||\n          params.getIndex() === VALUE_INDEX,\n        'unknown index type.'\n      );\n      if (\n        (startNode != null && typeof startNode === 'object') ||\n        (endNode != null && typeof endNode === 'object')\n      ) {\n        throw new Error(\n          'Query: First argument passed to startAt(), startAfter(), endAt(), endBefore(), or ' +\n            'equalTo() cannot be an object.'\n        );\n      }\n    }\n  }\n\n  /**\n   * Validates that limit* has been called with the correct combination of parameters\n   */\n  private static validateLimit_(params: QueryParams) {\n    if (\n      params.hasStart() &&\n      params.hasEnd() &&\n      params.hasLimit() &&\n      !params.hasAnchoredLimit()\n    ) {\n      throw new Error(\n        \"Query: Can't combine startAt(), startAfter(), endAt(), endBefore(), and limit(). Use \" +\n          'limitToFirst() or limitToLast() instead.'\n      );\n    }\n  }\n\n  /**\n   * Validates that no other order by call has been made\n   */\n  private validateNoPreviousOrderByCall_(fnName: string) {\n    if (this.orderByCalled_ === true) {\n      throw new Error(fnName + \": You can't combine multiple orderBy calls.\");\n    }\n  }\n\n  getQueryParams(): QueryParams {\n    return this.queryParams_;\n  }\n\n  getRef(): Reference {\n    validateArgCount('Query.ref', 0, 0, arguments.length);\n    // This is a slight hack. We cannot goog.require('fb.api.Firebase'), since Firebase requires fb.api.Query.\n    // However, we will always export 'Firebase' to the global namespace, so it's guaranteed to exist by the time this\n    // method gets called.\n    return new Query.__referenceConstructor(this.repo, this.path) as Reference;\n  }\n\n  on(\n    eventType: string,\n    callback: SnapshotCallback,\n    cancelCallbackOrContext?: ((a: Error) => unknown) | object | null,\n    context?: object | null\n  ): SnapshotCallback {\n    validateArgCount('Query.on', 2, 4, arguments.length);\n    validateEventType('Query.on', 1, eventType, false);\n    validateCallback('Query.on', 2, callback, false);\n\n    const ret = Query.getCancelAndContextArgs_(\n      'Query.on',\n      cancelCallbackOrContext,\n      context\n    );\n\n    if (eventType === 'value') {\n      this.onValueEvent(callback, ret.cancel, ret.context);\n    } else {\n      const callbacks: { [k: string]: typeof callback } = {};\n      callbacks[eventType] = callback;\n      this.onChildEvent(callbacks, ret.cancel, ret.context);\n    }\n    return callback;\n  }\n\n  protected onValueEvent(\n    callback: (a: DataSnapshot) => void,\n    cancelCallback: ((a: Error) => void) | null,\n    context: object | null\n  ) {\n    const container = new ValueEventRegistration(\n      callback,\n      cancelCallback || null,\n      context || null\n    );\n    repoAddEventCallbackForQuery(this.repo, this, container);\n  }\n\n  onChildEvent(\n    callbacks: { [k: string]: SnapshotCallback },\n    cancelCallback: ((a: Error) => unknown) | null,\n    context: object | null\n  ) {\n    const container = new ChildEventRegistration(\n      callbacks,\n      cancelCallback,\n      context\n    );\n    repoAddEventCallbackForQuery(this.repo, this, container);\n  }\n\n  off(\n    eventType?: string,\n    callback?: SnapshotCallback,\n    context?: object | null\n  ): void {\n    validateArgCount('Query.off', 0, 3, arguments.length);\n    validateEventType('Query.off', 1, eventType, true);\n    validateCallback('Query.off', 2, callback, true);\n    validateContextObject('Query.off', 3, context, true);\n\n    let container: EventRegistration | null = null;\n    let callbacks: { [k: string]: typeof callback } | null = null;\n    if (eventType === 'value') {\n      const valueCallback = callback || null;\n      container = new ValueEventRegistration(\n        valueCallback,\n        null,\n        context || null\n      );\n    } else if (eventType) {\n      if (callback) {\n        callbacks = {};\n        callbacks[eventType] = callback;\n      }\n      container = new ChildEventRegistration(callbacks, null, context || null);\n    }\n    repoRemoveEventCallbackForQuery(this.repo, this, container);\n  }\n\n  /**\n   * Get the server-value for this query, or return a cached value if not connected.\n   */\n  get(): Promise<DataSnapshot> {\n    return repoGetValue(this.repo, this);\n  }\n\n  /**\n   * Attaches a listener, waits for the first event, and then removes the listener\n   */\n  once(\n    eventType: string,\n    userCallback?: SnapshotCallback,\n    failureCallbackOrContext?: ((a: Error) => void) | object | null,\n    context?: object | null\n  ): Promise<DataSnapshot> {\n    validateArgCount('Query.once', 1, 4, arguments.length);\n    validateEventType('Query.once', 1, eventType, false);\n    validateCallback('Query.once', 2, userCallback, true);\n\n    const ret = Query.getCancelAndContextArgs_(\n      'Query.once',\n      failureCallbackOrContext,\n      context\n    );\n\n    // TODO: Implement this more efficiently (in particular, use 'get' wire protocol for 'value' event)\n    // TODO: consider actually wiring the callbacks into the promise. We cannot do this without a breaking change\n    // because the API currently expects callbacks will be called synchronously if the data is cached, but this is\n    // against the Promise specification.\n    let firstCall = true;\n    const deferred = new Deferred<DataSnapshot>();\n\n    // A dummy error handler in case a user wasn't expecting promises\n    deferred.promise.catch(() => {});\n\n    const onceCallback = (snapshot: DataSnapshot) => {\n      // NOTE: Even though we unsubscribe, we may get called multiple times if a single action (e.g. set() with JSON)\n      // triggers multiple events (e.g. child_added or child_changed).\n      if (firstCall) {\n        firstCall = false;\n        this.off(eventType, onceCallback);\n\n        if (userCallback) {\n          userCallback.bind(ret.context)(snapshot);\n        }\n        deferred.resolve(snapshot);\n      }\n    };\n\n    this.on(\n      eventType,\n      onceCallback,\n      /*cancel=*/ err => {\n        this.off(eventType, onceCallback);\n\n        if (ret.cancel) {\n          ret.cancel.bind(ret.context)(err);\n        }\n        deferred.reject(err);\n      }\n    );\n    return deferred.promise;\n  }\n\n  /**\n   * Set a limit and anchor it to the start of the window.\n   */\n  limitToFirst(limit: number): Query {\n    validateArgCount('Query.limitToFirst', 1, 1, arguments.length);\n    if (\n      typeof limit !== 'number' ||\n      Math.floor(limit) !== limit ||\n      limit <= 0\n    ) {\n      throw new Error(\n        'Query.limitToFirst: First argument must be a positive integer.'\n      );\n    }\n    if (this.queryParams_.hasLimit()) {\n      throw new Error(\n        'Query.limitToFirst: Limit was already set (by another call to limit, ' +\n          'limitToFirst, or limitToLast).'\n      );\n    }\n\n    return new Query(\n      this.repo,\n      this.path,\n      queryParamsLimitToFirst(this.queryParams_, limit),\n      this.orderByCalled_\n    );\n  }\n\n  /**\n   * Set a limit and anchor it to the end of the window.\n   */\n  limitToLast(limit: number): Query {\n    validateArgCount('Query.limitToLast', 1, 1, arguments.length);\n    if (\n      typeof limit !== 'number' ||\n      Math.floor(limit) !== limit ||\n      limit <= 0\n    ) {\n      throw new Error(\n        'Query.limitToLast: First argument must be a positive integer.'\n      );\n    }\n    if (this.queryParams_.hasLimit()) {\n      throw new Error(\n        'Query.limitToLast: Limit was already set (by another call to limit, ' +\n          'limitToFirst, or limitToLast).'\n      );\n    }\n\n    return new Query(\n      this.repo,\n      this.path,\n      queryParamsLimitToLast(this.queryParams_, limit),\n      this.orderByCalled_\n    );\n  }\n\n  /**\n   * Given a child path, return a new query ordered by the specified grandchild path.\n   */\n  orderByChild(path: string): Query {\n    validateArgCount('Query.orderByChild', 1, 1, arguments.length);\n    if (path === '$key') {\n      throw new Error(\n        'Query.orderByChild: \"$key\" is invalid.  Use Query.orderByKey() instead.'\n      );\n    } else if (path === '$priority') {\n      throw new Error(\n        'Query.orderByChild: \"$priority\" is invalid.  Use Query.orderByPriority() instead.'\n      );\n    } else if (path === '$value') {\n      throw new Error(\n        'Query.orderByChild: \"$value\" is invalid.  Use Query.orderByValue() instead.'\n      );\n    }\n    validatePathString('Query.orderByChild', 1, path, false);\n    this.validateNoPreviousOrderByCall_('Query.orderByChild');\n    const parsedPath = new Path(path);\n    if (pathIsEmpty(parsedPath)) {\n      throw new Error(\n        'Query.orderByChild: cannot pass in empty path.  Use Query.orderByValue() instead.'\n      );\n    }\n    const index = new PathIndex(parsedPath);\n    const newParams = queryParamsOrderBy(this.queryParams_, index);\n    Query.validateQueryEndpoints_(newParams);\n\n    return new Query(this.repo, this.path, newParams, /*orderByCalled=*/ true);\n  }\n\n  /**\n   * Return a new query ordered by the KeyIndex\n   */\n  orderByKey(): Query {\n    validateArgCount('Query.orderByKey', 0, 0, arguments.length);\n    this.validateNoPreviousOrderByCall_('Query.orderByKey');\n    const newParams = queryParamsOrderBy(this.queryParams_, KEY_INDEX);\n    Query.validateQueryEndpoints_(newParams);\n    return new Query(this.repo, this.path, newParams, /*orderByCalled=*/ true);\n  }\n\n  /**\n   * Return a new query ordered by the PriorityIndex\n   */\n  orderByPriority(): Query {\n    validateArgCount('Query.orderByPriority', 0, 0, arguments.length);\n    this.validateNoPreviousOrderByCall_('Query.orderByPriority');\n    const newParams = queryParamsOrderBy(this.queryParams_, PRIORITY_INDEX);\n    Query.validateQueryEndpoints_(newParams);\n    return new Query(this.repo, this.path, newParams, /*orderByCalled=*/ true);\n  }\n\n  /**\n   * Return a new query ordered by the ValueIndex\n   */\n  orderByValue(): Query {\n    validateArgCount('Query.orderByValue', 0, 0, arguments.length);\n    this.validateNoPreviousOrderByCall_('Query.orderByValue');\n    const newParams = queryParamsOrderBy(this.queryParams_, VALUE_INDEX);\n    Query.validateQueryEndpoints_(newParams);\n    return new Query(this.repo, this.path, newParams, /*orderByCalled=*/ true);\n  }\n\n  startAt(\n    value: number | string | boolean | null = null,\n    name?: string | null\n  ): Query {\n    validateArgCount('Query.startAt', 0, 2, arguments.length);\n    validateFirebaseDataArg('Query.startAt', 1, value, this.path, true);\n    validateKey('Query.startAt', 2, name, true);\n\n    const newParams = queryParamsStartAt(this.queryParams_, value, name);\n    Query.validateLimit_(newParams);\n    Query.validateQueryEndpoints_(newParams);\n    if (this.queryParams_.hasStart()) {\n      throw new Error(\n        'Query.startAt: Starting point was already set (by another call to startAt ' +\n          'or equalTo).'\n      );\n    }\n\n    // Calling with no params tells us to start at the beginning.\n    if (value === undefined) {\n      value = null;\n      name = null;\n    }\n\n    return new Query(this.repo, this.path, newParams, this.orderByCalled_);\n  }\n\n  startAfter(\n    value: number | string | boolean | null = null,\n    name?: string | null\n  ): Query {\n    validateArgCount('Query.startAfter', 0, 2, arguments.length);\n    validateFirebaseDataArg('Query.startAfter', 1, value, this.path, false);\n    validateKey('Query.startAfter', 2, name, true);\n\n    const newParams = queryParamsStartAfter(this.queryParams_, value, name);\n    Query.validateLimit_(newParams);\n    Query.validateQueryEndpoints_(newParams);\n    if (this.queryParams_.hasStart()) {\n      throw new Error(\n        'Query.startAfter: Starting point was already set (by another call to startAt, startAfter ' +\n          'or equalTo).'\n      );\n    }\n\n    return new Query(this.repo, this.path, newParams, this.orderByCalled_);\n  }\n\n  endAt(\n    value: number | string | boolean | null = null,\n    name?: string | null\n  ): Query {\n    validateArgCount('Query.endAt', 0, 2, arguments.length);\n    validateFirebaseDataArg('Query.endAt', 1, value, this.path, true);\n    validateKey('Query.endAt', 2, name, true);\n\n    const newParams = queryParamsEndAt(this.queryParams_, value, name);\n    Query.validateLimit_(newParams);\n    Query.validateQueryEndpoints_(newParams);\n    if (this.queryParams_.hasEnd()) {\n      throw new Error(\n        'Query.endAt: Ending point was already set (by another call to endAt, endBefore, or ' +\n          'equalTo).'\n      );\n    }\n\n    return new Query(this.repo, this.path, newParams, this.orderByCalled_);\n  }\n\n  endBefore(\n    value: number | string | boolean | null = null,\n    name?: string | null\n  ): Query {\n    validateArgCount('Query.endBefore', 0, 2, arguments.length);\n    validateFirebaseDataArg('Query.endBefore', 1, value, this.path, false);\n    validateKey('Query.endBefore', 2, name, true);\n\n    const newParams = queryParamsEndBefore(this.queryParams_, value, name);\n    Query.validateLimit_(newParams);\n    Query.validateQueryEndpoints_(newParams);\n    if (this.queryParams_.hasEnd()) {\n      throw new Error(\n        'Query.endBefore: Ending point was already set (by another call to endAt, endBefore, or ' +\n          'equalTo).'\n      );\n    }\n\n    return new Query(this.repo, this.path, newParams, this.orderByCalled_);\n  }\n\n  /**\n   * Load the selection of children with exactly the specified value, and, optionally,\n   * the specified name.\n   */\n  equalTo(value: number | string | boolean | null, name?: string) {\n    validateArgCount('Query.equalTo', 1, 2, arguments.length);\n    validateFirebaseDataArg('Query.equalTo', 1, value, this.path, false);\n    validateKey('Query.equalTo', 2, name, true);\n    if (this.queryParams_.hasStart()) {\n      throw new Error(\n        'Query.equalTo: Starting point was already set (by another call to startAt/startAfter or ' +\n          'equalTo).'\n      );\n    }\n    if (this.queryParams_.hasEnd()) {\n      throw new Error(\n        'Query.equalTo: Ending point was already set (by another call to endAt/endBefore or ' +\n          'equalTo).'\n      );\n    }\n    return this.startAt(value, name).endAt(value, name);\n  }\n\n  /**\n   * @return URL for this location.\n   */\n  toString(): string {\n    validateArgCount('Query.toString', 0, 0, arguments.length);\n\n    return this.repo.toString() + pathToUrlEncodedString(this.path);\n  }\n\n  // Do not create public documentation. This is intended to make JSON serialization work but is otherwise unnecessary\n  // for end-users.\n  toJSON() {\n    // An optional spacer argument is unnecessary for a string.\n    validateArgCount('Query.toJSON', 0, 1, arguments.length);\n    return this.toString();\n  }\n\n  /**\n   * An object representation of the query parameters used by this Query.\n   */\n  queryObject(): object {\n    return queryParamsGetQueryObject(this.queryParams_);\n  }\n\n  queryIdentifier(): string {\n    const obj = this.queryObject();\n    const id = ObjectToUniqueKey(obj);\n    return id === '{}' ? 'default' : id;\n  }\n\n  /**\n   * Return true if this query and the provided query are equivalent; otherwise, return false.\n   */\n  isEqual(other: Query): boolean {\n    validateArgCount('Query.isEqual', 1, 1, arguments.length);\n    if (!(other instanceof Query)) {\n      const error =\n        'Query.isEqual failed: First argument must be an instance of firebase.database.Query.';\n      throw new Error(error);\n    }\n\n    const sameRepo = this.repo === other.repo;\n    const samePath = pathEquals(this.path, other.path);\n    const sameQueryIdentifier =\n      this.queryIdentifier() === other.queryIdentifier();\n\n    return sameRepo && samePath && sameQueryIdentifier;\n  }\n\n  /**\n   * Helper used by .on and .once to extract the context and or cancel arguments.\n   * @param fnName The function name (on or once)\n   *\n   */\n  private static getCancelAndContextArgs_(\n    fnName: string,\n    cancelOrContext?: ((a: Error) => void) | object | null,\n    context?: object | null\n  ): { cancel: ((a: Error) => void) | null; context: object | null } {\n    const ret: {\n      cancel: ((a: Error) => void) | null;\n      context: object | null;\n    } = { cancel: null, context: null };\n    if (cancelOrContext && context) {\n      ret.cancel = cancelOrContext as (a: Error) => void;\n      validateCallback(fnName, 3, ret.cancel, true);\n\n      ret.context = context;\n      validateContextObject(fnName, 4, ret.context, true);\n    } else if (cancelOrContext) {\n      // we have either a cancel callback or a context.\n      if (typeof cancelOrContext === 'object' && cancelOrContext !== null) {\n        // it's a context!\n        ret.context = cancelOrContext;\n      } else if (typeof cancelOrContext === 'function') {\n        ret.cancel = cancelOrContext as (a: Error) => void;\n      } else {\n        throw new Error(\n          errorPrefix(fnName, 3, true) +\n            ' must either be a cancel callback or a context object.'\n        );\n      }\n    }\n    return ret;\n  }\n\n  get ref(): Reference {\n    return this.getRef();\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { Deferred, validateArgCount, validateCallback } from '@firebase/util';\nimport {\n  validateWritablePath,\n  validateFirebaseDataArg,\n  validatePriority,\n  validateFirebaseMergeDataArg\n} from '../core/util/validation';\nimport { warn } from '../core/util/util';\n\nimport {\n  Repo,\n  repoOnDisconnectCancel,\n  repoOnDisconnectSet,\n  repoOnDisconnectSetWithPriority,\n  repoOnDisconnectUpdate\n} from '../core/Repo';\nimport { Path } from '../core/util/Path';\nimport { Indexable } from '../core/util/misc';\n\nexport class OnDisconnect {\n  constructor(private repo_: Repo, private path_: Path) {}\n\n  cancel(onComplete?: (a: Error | null) => void): Promise<void> {\n    validateArgCount('OnDisconnect.cancel', 0, 1, arguments.length);\n    validateCallback('OnDisconnect.cancel', 1, onComplete, true);\n    const deferred = new Deferred<void>();\n    repoOnDisconnectCancel(\n      this.repo_,\n      this.path_,\n      deferred.wrapCallback(onComplete)\n    );\n    return deferred.promise;\n  }\n\n  remove(onComplete?: (a: Error | null) => void): Promise<void> {\n    validateArgCount('OnDisconnect.remove', 0, 1, arguments.length);\n    validateWritablePath('OnDisconnect.remove', this.path_);\n    validateCallback('OnDisconnect.remove', 1, onComplete, true);\n    const deferred = new Deferred<void>();\n    repoOnDisconnectSet(\n      this.repo_,\n      this.path_,\n      null,\n      deferred.wrapCallback(onComplete)\n    );\n    return deferred.promise;\n  }\n\n  set(value: unknown, onComplete?: (a: Error | null) => void): Promise<void> {\n    validateArgCount('OnDisconnect.set', 1, 2, arguments.length);\n    validateWritablePath('OnDisconnect.set', this.path_);\n    validateFirebaseDataArg('OnDisconnect.set', 1, value, this.path_, false);\n    validateCallback('OnDisconnect.set', 2, onComplete, true);\n    const deferred = new Deferred<void>();\n    repoOnDisconnectSet(\n      this.repo_,\n      this.path_,\n      value,\n      deferred.wrapCallback(onComplete)\n    );\n    return deferred.promise;\n  }\n\n  setWithPriority(\n    value: unknown,\n    priority: number | string | null,\n    onComplete?: (a: Error | null) => void\n  ): Promise<void> {\n    validateArgCount('OnDisconnect.setWithPriority', 2, 3, arguments.length);\n    validateWritablePath('OnDisconnect.setWithPriority', this.path_);\n    validateFirebaseDataArg(\n      'OnDisconnect.setWithPriority',\n      1,\n      value,\n      this.path_,\n      false\n    );\n    validatePriority('OnDisconnect.setWithPriority', 2, priority, false);\n    validateCallback('OnDisconnect.setWithPriority', 3, onComplete, true);\n\n    const deferred = new Deferred<void>();\n    repoOnDisconnectSetWithPriority(\n      this.repo_,\n      this.path_,\n      value,\n      priority,\n      deferred.wrapCallback(onComplete)\n    );\n    return deferred.promise;\n  }\n\n  update(\n    objectToMerge: Indexable,\n    onComplete?: (a: Error | null) => void\n  ): Promise<void> {\n    validateArgCount('OnDisconnect.update', 1, 2, arguments.length);\n    validateWritablePath('OnDisconnect.update', this.path_);\n    if (Array.isArray(objectToMerge)) {\n      const newObjectToMerge: { [k: string]: unknown } = {};\n      for (let i = 0; i < objectToMerge.length; ++i) {\n        newObjectToMerge['' + i] = objectToMerge[i];\n      }\n      objectToMerge = newObjectToMerge;\n      warn(\n        'Passing an Array to firebase.database.onDisconnect().update() is deprecated. Use set() if you want to overwrite the ' +\n          'existing data, or an Object with integer keys if you really do want to only update some of the children.'\n      );\n    }\n    validateFirebaseMergeDataArg(\n      'OnDisconnect.update',\n      1,\n      objectToMerge,\n      this.path_,\n      false\n    );\n    validateCallback('OnDisconnect.update', 2, onComplete, true);\n    const deferred = new Deferred<void>();\n    repoOnDisconnectUpdate(\n      this.repo_,\n      this.path_,\n      objectToMerge,\n      deferred.wrapCallback(onComplete)\n    );\n    return deferred.promise;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { DataSnapshot } from './DataSnapshot';\nimport { validateArgCount } from '@firebase/util';\n\nexport class TransactionResult {\n  /**\n   * A type for the resolve value of Firebase.transaction.\n   */\n  constructor(public committed: boolean, public snapshot: DataSnapshot) {}\n\n  // Do not create public documentation. This is intended to make JSON serialization work but is otherwise unnecessary\n  // for end-users\n  toJSON(): object {\n    validateArgCount('TransactionResult.toJSON', 0, 1, arguments.length);\n    return { committed: this.committed, snapshot: this.snapshot.toJSON() };\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { stringify } from '@firebase/util';\nimport { Path } from '../util/Path';\nimport { EventRegistration } from './EventRegistration';\nimport { DataSnapshot } from '../../api/DataSnapshot';\n\n/**\n * Encapsulates the data needed to raise an event\n * @interface\n */\nexport interface Event {\n  getPath(): Path;\n\n  getEventType(): string;\n\n  getEventRunner(): () => void;\n\n  toString(): string;\n}\n\nexport type EventType =\n  | 'value'\n  | ' child_added'\n  | ' child_changed'\n  | ' child_moved'\n  | ' child_removed';\n\n/**\n * Encapsulates the data needed to raise an event\n */\nexport class DataEvent implements Event {\n  /**\n   * @param eventType One of: value, child_added, child_changed, child_moved, child_removed\n   * @param eventRegistration The function to call to with the event data. User provided\n   * @param snapshot The data backing the event\n   * @param prevName Optional, the name of the previous child for child_* events.\n   */\n  constructor(\n    public eventType: EventType,\n    public eventRegistration: EventRegistration,\n    public snapshot: DataSnapshot,\n    public prevName?: string | null\n  ) {}\n\n  /**\n   * @inheritDoc\n   */\n  getPath(): Path {\n    const ref = this.snapshot.getRef();\n    if (this.eventType === 'value') {\n      return ref.path;\n    } else {\n      return ref.getParent().path;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getEventType(): string {\n    return this.eventType;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getEventRunner(): () => void {\n    return this.eventRegistration.getEventRunner(this);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  toString(): string {\n    return (\n      this.getPath().toString() +\n      ':' +\n      this.eventType +\n      ':' +\n      stringify(this.snapshot.exportVal())\n    );\n  }\n}\n\nexport class CancelEvent implements Event {\n  constructor(\n    public eventRegistration: EventRegistration,\n    public error: Error,\n    public path: Path\n  ) {}\n\n  /**\n   * @inheritDoc\n   */\n  getPath(): Path {\n    return this.path;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getEventType(): string {\n    return 'cancel';\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getEventRunner(): () => void {\n    return this.eventRegistration.getEventRunner(this);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  toString(): string {\n    return this.path.toString() + ':cancel';\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { DataSnapshot } from '../../api/DataSnapshot';\nimport { DataEvent, CancelEvent, Event, EventType } from './Event';\nimport { contains, assert } from '@firebase/util';\n\nimport { Path } from '../util/Path';\nimport { Change } from './Change';\nimport { Query } from '../../api/Query';\n\n/**\n * An EventRegistration is basically an event type ('value', 'child_added', etc.) and a callback\n * to be notified of that type of event.\n *\n * That said, it can also contain a cancel callback to be notified if the event is canceled.  And\n * currently, this code is organized around the idea that you would register multiple child_ callbacks\n * together, as a single EventRegistration.  Though currently we don't do that.\n */\nexport interface EventRegistration {\n  /**\n   * True if this container has a callback to trigger for this event type\n   */\n  respondsTo(eventType: string): boolean;\n\n  createEvent(change: Change, query: Query): Event;\n\n  /**\n   * Given event data, return a function to trigger the user's callback\n   */\n  getEventRunner(eventData: Event): () => void;\n\n  createCancelEvent(error: Error, path: Path): CancelEvent | null;\n\n  matches(other: EventRegistration): boolean;\n\n  /**\n   * False basically means this is a \"dummy\" callback container being used as a sentinel\n   * to remove all callback containers of a particular type.  (e.g. if the user does\n   * ref.off('value') without specifying a specific callback).\n   *\n   * (TODO: Rework this, since it's hacky)\n   *\n   */\n  hasAnyCallback(): boolean;\n}\n\n/**\n * Represents registration for 'value' events.\n */\nexport class ValueEventRegistration implements EventRegistration {\n  constructor(\n    private callback_: ((d: DataSnapshot) => void) | null,\n    private cancelCallback_: ((e: Error) => void) | null,\n    private context_: {} | null\n  ) {}\n\n  /**\n   * @inheritDoc\n   */\n  respondsTo(eventType: string): boolean {\n    return eventType === 'value';\n  }\n\n  /**\n   * @inheritDoc\n   */\n  createEvent(change: Change, query: Query): DataEvent {\n    const index = query.getQueryParams().getIndex();\n    return new DataEvent(\n      'value',\n      this,\n      new DataSnapshot(change.snapshotNode, query.getRef(), index)\n    );\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getEventRunner(eventData: CancelEvent | DataEvent): () => void {\n    const ctx = this.context_;\n    if (eventData.getEventType() === 'cancel') {\n      assert(\n        this.cancelCallback_,\n        'Raising a cancel event on a listener with no cancel callback'\n      );\n      const cancelCB = this.cancelCallback_;\n      return function () {\n        // We know that error exists, we checked above that this is a cancel event\n        cancelCB.call(ctx, (eventData as CancelEvent).error);\n      };\n    } else {\n      const cb = this.callback_;\n      return function () {\n        cb.call(ctx, (eventData as DataEvent).snapshot);\n      };\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  createCancelEvent(error: Error, path: Path): CancelEvent | null {\n    if (this.cancelCallback_) {\n      return new CancelEvent(this, error, path);\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  matches(other: EventRegistration): boolean {\n    if (!(other instanceof ValueEventRegistration)) {\n      return false;\n    } else if (!other.callback_ || !this.callback_) {\n      // If no callback specified, we consider it to match any callback.\n      return true;\n    } else {\n      return (\n        other.callback_ === this.callback_ && other.context_ === this.context_\n      );\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  hasAnyCallback(): boolean {\n    return this.callback_ !== null;\n  }\n}\n\n/**\n * Represents the registration of 1 or more child_xxx events.\n *\n * Currently, it is always exactly 1 child_xxx event, but the idea is we might let you\n * register a group of callbacks together in the future.\n */\nexport class ChildEventRegistration implements EventRegistration {\n  constructor(\n    private callbacks_: {\n      [k: string]: (d: DataSnapshot, s?: string | null) => void;\n    } | null,\n    private cancelCallback_: ((e: Error) => void) | null,\n    private context_?: {}\n  ) {}\n\n  /**\n   * @inheritDoc\n   */\n  respondsTo(eventType: string): boolean {\n    let eventToCheck =\n      eventType === 'children_added' ? 'child_added' : eventType;\n    eventToCheck =\n      eventToCheck === 'children_removed' ? 'child_removed' : eventToCheck;\n    return contains(this.callbacks_, eventToCheck);\n  }\n\n  /**\n   * @inheritDoc\n   */\n  createCancelEvent(error: Error, path: Path): CancelEvent | null {\n    if (this.cancelCallback_) {\n      return new CancelEvent(this, error, path);\n    } else {\n      return null;\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  createEvent(change: Change, query: Query): DataEvent {\n    assert(change.childName != null, 'Child events should have a childName.');\n    const ref = query.getRef().child(change.childName);\n    const index = query.getQueryParams().getIndex();\n    return new DataEvent(\n      change.type as EventType,\n      this,\n      new DataSnapshot(change.snapshotNode, ref, index),\n      change.prevName\n    );\n  }\n\n  /**\n   * @inheritDoc\n   */\n  getEventRunner(eventData: CancelEvent | DataEvent): () => void {\n    const ctx = this.context_;\n    if (eventData.getEventType() === 'cancel') {\n      assert(\n        this.cancelCallback_,\n        'Raising a cancel event on a listener with no cancel callback'\n      );\n      const cancelCB = this.cancelCallback_;\n      return function () {\n        // We know that error exists, we checked above that this is a cancel event\n        cancelCB.call(ctx, (eventData as CancelEvent).error);\n      };\n    } else {\n      const cb = this.callbacks_[(eventData as DataEvent).eventType];\n      return function () {\n        cb.call(\n          ctx,\n          (eventData as DataEvent).snapshot,\n          (eventData as DataEvent).prevName\n        );\n      };\n    }\n  }\n\n  /**\n   * @inheritDoc\n   */\n  matches(other: EventRegistration): boolean {\n    if (other instanceof ChildEventRegistration) {\n      if (!this.callbacks_ || !other.callbacks_) {\n        return true;\n      } else if (this.context_ === other.context_) {\n        const otherKeys = Object.keys(other.callbacks_);\n        const thisKeys = Object.keys(this.callbacks_);\n        const otherCount = otherKeys.length;\n        const thisCount = thisKeys.length;\n        if (otherCount === thisCount) {\n          // If count is 1, do an exact match on eventType, if either is defined but null, it's a match.\n          // If event types don't match, not a match\n          // If count is not 1, exact match across all\n\n          if (otherCount === 1) {\n            const otherKey = otherKeys[0];\n            const thisKey = thisKeys[0];\n            return (\n              thisKey === otherKey &&\n              (!other.callbacks_[otherKey] ||\n                !this.callbacks_[thisKey] ||\n                other.callbacks_[otherKey] === this.callbacks_[thisKey])\n            );\n          } else {\n            // Exact match on each key.\n            return thisKeys.every(\n              eventType =>\n                other.callbacks_[eventType] === this.callbacks_[eventType]\n            );\n          }\n        }\n      }\n    }\n\n    return false;\n  }\n\n  /**\n   * @inheritDoc\n   */\n  hasAnyCallback(): boolean {\n    return this.callbacks_ !== null;\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { OnDisconnect } from './onDisconnect';\nimport { TransactionResult } from './TransactionResult';\nimport { warn } from '../core/util/util';\nimport { nextPushId } from '../core/util/NextPushId';\nimport { Query } from './Query';\nimport {\n  Repo,\n  repoGetDatabase,\n  repoServerTime,\n  repoSetWithPriority,\n  repoStartTransaction,\n  repoUpdate\n} from '../core/Repo';\nimport {\n  Path,\n  pathChild,\n  pathGetBack,\n  pathGetFront,\n  pathIsEmpty,\n  pathParent\n} from '../core/util/Path';\nimport { QueryParams } from '../core/view/QueryParams';\nimport {\n  validateBoolean,\n  validateFirebaseDataArg,\n  validateFirebaseMergeDataArg,\n  validatePathString,\n  validatePriority,\n  validateRootPathString,\n  validateWritablePath\n} from '../core/util/validation';\nimport { Deferred, validateArgCount, validateCallback } from '@firebase/util';\n\nimport { syncPointSetReferenceConstructor } from '../core/SyncPoint';\nimport { Database } from './Database';\nimport { DataSnapshot } from './DataSnapshot';\n\nexport interface ReferenceConstructor {\n  new (repo: Repo, path: Path): Reference;\n}\n\nexport class Reference extends Query {\n  then: Promise<Reference>['then'];\n  catch: Promise<Reference>['catch'];\n\n  /**\n   * Call options:\n   *   new Reference(Repo, Path) or\n   *   new Reference(url: string, string|RepoManager)\n   *\n   * Externally - this is the firebase.database.Reference type.\n   */\n  constructor(repo: Repo, path: Path) {\n    if (!(repo instanceof Repo)) {\n      throw new Error(\n        'new Reference() no longer supported - use app.database().'\n      );\n    }\n\n    // call Query's constructor, passing in the repo and path.\n    super(repo, path, new QueryParams(), false);\n  }\n\n  /** @return {?string} */\n  getKey(): string | null {\n    validateArgCount('Reference.key', 0, 0, arguments.length);\n\n    if (pathIsEmpty(this.path)) {\n      return null;\n    } else {\n      return pathGetBack(this.path);\n    }\n  }\n\n  child(pathString: string | Path): Reference {\n    validateArgCount('Reference.child', 1, 1, arguments.length);\n    if (typeof pathString === 'number') {\n      pathString = String(pathString);\n    } else if (!(pathString instanceof Path)) {\n      if (pathGetFront(this.path) === null) {\n        validateRootPathString('Reference.child', 1, pathString, false);\n      } else {\n        validatePathString('Reference.child', 1, pathString, false);\n      }\n    }\n\n    return new Reference(this.repo, pathChild(this.path, pathString));\n  }\n\n  /** @return {?Reference} */\n  getParent(): Reference | null {\n    validateArgCount('Reference.parent', 0, 0, arguments.length);\n\n    const parentPath = pathParent(this.path);\n    return parentPath === null ? null : new Reference(this.repo, parentPath);\n  }\n\n  /** @return {!Reference} */\n  getRoot(): Reference {\n    validateArgCount('Reference.root', 0, 0, arguments.length);\n\n    let ref: Reference = this;\n    while (ref.getParent() !== null) {\n      ref = ref.getParent();\n    }\n    return ref;\n  }\n\n  /** @return {!Database} */\n  databaseProp(): Database {\n    return repoGetDatabase(this.repo);\n  }\n\n  set(\n    newVal: unknown,\n    onComplete?: (a: Error | null) => void\n  ): Promise<unknown> {\n    validateArgCount('Reference.set', 1, 2, arguments.length);\n    validateWritablePath('Reference.set', this.path);\n    validateFirebaseDataArg('Reference.set', 1, newVal, this.path, false);\n    validateCallback('Reference.set', 2, onComplete, true);\n\n    const deferred = new Deferred();\n    repoSetWithPriority(\n      this.repo,\n      this.path,\n      newVal,\n      /*priority=*/ null,\n      deferred.wrapCallback(onComplete)\n    );\n    return deferred.promise;\n  }\n\n  update(\n    objectToMerge: object,\n    onComplete?: (a: Error | null) => void\n  ): Promise<unknown> {\n    validateArgCount('Reference.update', 1, 2, arguments.length);\n    validateWritablePath('Reference.update', this.path);\n\n    if (Array.isArray(objectToMerge)) {\n      const newObjectToMerge: { [k: string]: unknown } = {};\n      for (let i = 0; i < objectToMerge.length; ++i) {\n        newObjectToMerge['' + i] = objectToMerge[i];\n      }\n      objectToMerge = newObjectToMerge;\n      warn(\n        'Passing an Array to Firebase.update() is deprecated. ' +\n          'Use set() if you want to overwrite the existing data, or ' +\n          'an Object with integer keys if you really do want to ' +\n          'only update some of the children.'\n      );\n    }\n    validateFirebaseMergeDataArg(\n      'Reference.update',\n      1,\n      objectToMerge,\n      this.path,\n      false\n    );\n    validateCallback('Reference.update', 2, onComplete, true);\n    const deferred = new Deferred();\n    repoUpdate(\n      this.repo,\n      this.path,\n      objectToMerge as { [k: string]: unknown },\n      deferred.wrapCallback(onComplete)\n    );\n    return deferred.promise;\n  }\n\n  setWithPriority(\n    newVal: unknown,\n    newPriority: string | number | null,\n    onComplete?: (a: Error | null) => void\n  ): Promise<unknown> {\n    validateArgCount('Reference.setWithPriority', 2, 3, arguments.length);\n    validateWritablePath('Reference.setWithPriority', this.path);\n    validateFirebaseDataArg(\n      'Reference.setWithPriority',\n      1,\n      newVal,\n      this.path,\n      false\n    );\n    validatePriority('Reference.setWithPriority', 2, newPriority, false);\n    validateCallback('Reference.setWithPriority', 3, onComplete, true);\n\n    if (this.getKey() === '.length' || this.getKey() === '.keys') {\n      throw (\n        'Reference.setWithPriority failed: ' +\n        this.getKey() +\n        ' is a read-only object.'\n      );\n    }\n\n    const deferred = new Deferred();\n    repoSetWithPriority(\n      this.repo,\n      this.path,\n      newVal,\n      newPriority,\n      deferred.wrapCallback(onComplete)\n    );\n    return deferred.promise;\n  }\n\n  remove(onComplete?: (a: Error | null) => void): Promise<unknown> {\n    validateArgCount('Reference.remove', 0, 1, arguments.length);\n    validateWritablePath('Reference.remove', this.path);\n    validateCallback('Reference.remove', 1, onComplete, true);\n\n    return this.set(null, onComplete);\n  }\n\n  transaction(\n    transactionUpdate: (a: unknown) => unknown,\n    onComplete?: (a: Error | null, b: boolean, c: DataSnapshot | null) => void,\n    applyLocally?: boolean\n  ): Promise<TransactionResult> {\n    validateArgCount('Reference.transaction', 1, 3, arguments.length);\n    validateWritablePath('Reference.transaction', this.path);\n    validateCallback('Reference.transaction', 1, transactionUpdate, false);\n    validateCallback('Reference.transaction', 2, onComplete, true);\n    // NOTE: applyLocally is an internal-only option for now.  We need to decide if we want to keep it and how\n    // to expose it.\n    validateBoolean('Reference.transaction', 3, applyLocally, true);\n\n    if (this.getKey() === '.length' || this.getKey() === '.keys') {\n      throw (\n        'Reference.transaction failed: ' +\n        this.getKey() +\n        ' is a read-only object.'\n      );\n    }\n\n    if (applyLocally === undefined) {\n      applyLocally = true;\n    }\n\n    const deferred = new Deferred<TransactionResult>();\n    if (typeof onComplete === 'function') {\n      deferred.promise.catch(() => {});\n    }\n\n    const promiseComplete = function (\n      error: Error,\n      committed: boolean,\n      snapshot: DataSnapshot\n    ) {\n      if (error) {\n        deferred.reject(error);\n      } else {\n        deferred.resolve(new TransactionResult(committed, snapshot));\n      }\n      if (typeof onComplete === 'function') {\n        onComplete(error, committed, snapshot);\n      }\n    };\n    repoStartTransaction(\n      this.repo,\n      this.path,\n      transactionUpdate,\n      promiseComplete,\n      applyLocally\n    );\n\n    return deferred.promise;\n  }\n\n  setPriority(\n    priority: string | number | null,\n    onComplete?: (a: Error | null) => void\n  ): Promise<unknown> {\n    validateArgCount('Reference.setPriority', 1, 2, arguments.length);\n    validateWritablePath('Reference.setPriority', this.path);\n    validatePriority('Reference.setPriority', 1, priority, false);\n    validateCallback('Reference.setPriority', 2, onComplete, true);\n\n    const deferred = new Deferred();\n    repoSetWithPriority(\n      this.repo,\n      pathChild(this.path, '.priority'),\n      priority,\n      null,\n      deferred.wrapCallback(onComplete)\n    );\n    return deferred.promise;\n  }\n\n  push(value?: unknown, onComplete?: (a: Error | null) => void): Reference {\n    validateArgCount('Reference.push', 0, 2, arguments.length);\n    validateWritablePath('Reference.push', this.path);\n    validateFirebaseDataArg('Reference.push', 1, value, this.path, true);\n    validateCallback('Reference.push', 2, onComplete, true);\n\n    const now = repoServerTime(this.repo);\n    const name = nextPushId(now);\n\n    // push() returns a ThennableReference whose promise is fulfilled with a regular Reference.\n    // We use child() to create handles to two different references. The first is turned into a\n    // ThennableReference below by adding then() and catch() methods and is used as the\n    // return value of push(). The second remains a regular Reference and is used as the fulfilled\n    // value of the first ThennableReference.\n    const thennablePushRef = this.child(name);\n    const pushRef = this.child(name);\n\n    let promise;\n    if (value != null) {\n      promise = thennablePushRef.set(value, onComplete).then(() => pushRef);\n    } else {\n      promise = Promise.resolve(pushRef);\n    }\n\n    thennablePushRef.then = promise.then.bind(promise);\n    thennablePushRef.catch = promise.then.bind(promise, undefined);\n\n    if (typeof onComplete === 'function') {\n      promise.catch(() => {});\n    }\n\n    return thennablePushRef;\n  }\n\n  onDisconnect(): OnDisconnect {\n    validateWritablePath('Reference.onDisconnect', this.path);\n    return new OnDisconnect(this.repo, this.path);\n  }\n\n  get database(): Database {\n    return this.databaseProp();\n  }\n\n  get key(): string | null {\n    return this.getKey();\n  }\n\n  get parent(): Reference | null {\n    return this.getParent();\n  }\n\n  get root(): Reference {\n    return this.getRoot();\n  }\n}\n\n/**\n * Define reference constructor in various modules\n *\n * We are doing this here to avoid several circular\n * dependency issues\n */\nQuery.__referenceConstructor = Reference;\nsyncPointSetReferenceConstructor(Reference);\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FirebaseAuthTokenData } from '@firebase/app-types/private';\nimport {\n  FirebaseAuthInternal,\n  FirebaseAuthInternalName\n} from '@firebase/auth-interop-types';\nimport { Provider } from '@firebase/component';\nimport { log, warn } from './util/util';\nimport { FirebaseAppLike } from './RepoManager';\n\nexport interface AuthTokenProvider {\n  getToken(forceRefresh: boolean): Promise<FirebaseAuthTokenData>;\n  addTokenChangeListener(listener: (token: string | null) => void): void;\n  removeTokenChangeListener(listener: (token: string | null) => void): void;\n  notifyForInvalidToken(): void;\n}\n\n/**\n * Abstraction around FirebaseApp's token fetching capabilities.\n */\nexport class FirebaseAuthTokenProvider implements AuthTokenProvider {\n  private auth_: FirebaseAuthInternal | null = null;\n  constructor(\n    private app_: FirebaseAppLike,\n    private authProvider_: Provider<FirebaseAuthInternalName>\n  ) {\n    this.auth_ = authProvider_.getImmediate({ optional: true });\n    if (!this.auth_) {\n      authProvider_.get().then(auth => (this.auth_ = auth));\n    }\n  }\n\n  getToken(forceRefresh: boolean): Promise<FirebaseAuthTokenData> {\n    if (!this.auth_) {\n      return Promise.resolve(null);\n    }\n\n    return this.auth_.getToken(forceRefresh).catch(error => {\n      // TODO: Need to figure out all the cases this is raised and whether\n      // this makes sense.\n      if (error && error.code === 'auth/token-not-initialized') {\n        log('Got auth/token-not-initialized error.  Treating as null token.');\n        return null;\n      } else {\n        return Promise.reject(error);\n      }\n    });\n  }\n\n  addTokenChangeListener(listener: (token: string | null) => void): void {\n    // TODO: We might want to wrap the listener and call it with no args to\n    // avoid a leaky abstraction, but that makes removing the listener harder.\n    if (this.auth_) {\n      this.auth_.addAuthTokenListener(listener);\n    } else {\n      setTimeout(() => listener(null), 0);\n      this.authProvider_\n        .get()\n        .then(auth => auth.addAuthTokenListener(listener));\n    }\n  }\n\n  removeTokenChangeListener(listener: (token: string | null) => void): void {\n    this.authProvider_\n      .get()\n      .then(auth => auth.removeAuthTokenListener(listener));\n  }\n\n  notifyForInvalidToken(): void {\n    let errorMessage =\n      'Provided authentication credentials for the app named \"' +\n      this.app_.name +\n      '\" are invalid. This usually indicates your app was not ' +\n      'initialized correctly. ';\n    if ('credential' in this.app_.options) {\n      errorMessage +=\n        'Make sure the \"credential\" property provided to initializeApp() ' +\n        'is authorized to access the specified \"databaseURL\" and is from the correct ' +\n        'project.';\n    } else if ('serviceAccount' in this.app_.options) {\n      errorMessage +=\n        'Make sure the \"serviceAccount\" property provided to initializeApp() ' +\n        'is authorized to access the specified \"databaseURL\" and is from the correct ' +\n        'project.';\n    } else {\n      errorMessage +=\n        'Make sure the \"apiKey\" and \"databaseURL\" properties provided to ' +\n        'initializeApp() match the values provided for your app at ' +\n        'https://console.firebase.google.com/.';\n    }\n    warn(errorMessage);\n  }\n}\n\n/* Auth token provider that the Admin SDK uses to connect to the Emulator. */\nexport class EmulatorAdminTokenProvider implements AuthTokenProvider {\n  private static EMULATOR_AUTH_TOKEN = 'owner';\n\n  getToken(forceRefresh: boolean): Promise<FirebaseAuthTokenData> {\n    return Promise.resolve({\n      accessToken: EmulatorAdminTokenProvider.EMULATOR_AUTH_TOKEN\n    });\n  }\n\n  addTokenChangeListener(listener: (token: string | null) => void): void {\n    // Invoke the listener immediately to match the behavior in Firebase Auth\n    // (see packages/auth/src/auth.js#L1807)\n    listener(EmulatorAdminTokenProvider.EMULATOR_AUTH_TOKEN);\n  }\n\n  removeTokenChangeListener(listener: (token: string | null) => void): void {}\n\n  notifyForInvalidToken(): void {}\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { FirebaseApp } from '@firebase/app-types';\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { FirebaseApp as FirebaseAppExp } from '@firebase/app-exp';\nimport { safeGet } from '@firebase/util';\nimport { Repo, repoGetDatabase, repoInterrupt } from './Repo';\nimport { fatal, log } from './util/util';\nimport { parseRepoInfo } from './util/libs/parser';\nimport { validateUrl } from './util/validation';\nimport { Database } from '../api/Database';\nimport { RepoInfo } from './RepoInfo';\nimport { FirebaseAuthInternalName } from '@firebase/auth-interop-types';\nimport { Provider } from '@firebase/component';\nimport {\n  AuthTokenProvider,\n  EmulatorAdminTokenProvider,\n  FirebaseAuthTokenProvider\n} from './AuthTokenProvider';\nimport { pathIsEmpty } from './util/Path';\n\n/**\n * This variable is also defined in the firebase node.js admin SDK. Before\n * modifying this definition, consult the definition in:\n *\n * https://github.com/firebase/firebase-admin-node\n *\n * and make sure the two are consistent.\n */\nconst FIREBASE_DATABASE_EMULATOR_HOST_VAR = 'FIREBASE_DATABASE_EMULATOR_HOST';\n\n/**\n * Intersection type that allows the SDK to be used from firebase-exp and\n * firebase v8.\n */\nexport type FirebaseAppLike = FirebaseApp | FirebaseAppExp;\n\n/**\n * Creates and caches Repo instances.\n */\nconst repos: {\n  [appName: string]: {\n    [dbUrl: string]: Repo;\n  };\n} = {};\n\n/**\n * If true, new Repos will be created to use ReadonlyRestClient (for testing purposes).\n */\nlet useRestClient = false;\n\n/**\n * Update an existing repo in place to point to a new host/port.\n */\nexport function repoManagerApplyEmulatorSettings(\n  repo: Repo,\n  host: string,\n  port: number\n): void {\n  repo.repoInfo_ = new RepoInfo(\n    `${host}:${port}`,\n    /* secure= */ false,\n    repo.repoInfo_.namespace,\n    repo.repoInfo_.webSocketOnly,\n    repo.repoInfo_.nodeAdmin,\n    repo.repoInfo_.persistenceKey,\n    repo.repoInfo_.includeNamespaceInQueryParams\n  );\n\n  if (repo.repoInfo_.nodeAdmin) {\n    repo.authTokenProvider_ = new EmulatorAdminTokenProvider();\n  }\n}\n\n/**\n * This function should only ever be called to CREATE a new database instance.\n */\nexport function repoManagerDatabaseFromApp(\n  app: FirebaseAppLike,\n  authProvider: Provider<FirebaseAuthInternalName>,\n  url?: string,\n  nodeAdmin?: boolean\n): Database {\n  let dbUrl: string | undefined = url || app.options.databaseURL;\n  if (dbUrl === undefined) {\n    if (!app.options.projectId) {\n      fatal(\n        \"Can't determine Firebase Database URL. Be sure to include \" +\n          ' a Project ID when calling firebase.initializeApp().'\n      );\n    }\n\n    log('Using default host for project ', app.options.projectId);\n    dbUrl = `${app.options.projectId}-default-rtdb.firebaseio.com`;\n  }\n\n  let parsedUrl = parseRepoInfo(dbUrl, nodeAdmin);\n  let repoInfo = parsedUrl.repoInfo;\n\n  let isEmulator: boolean;\n\n  let dbEmulatorHost: string | undefined = undefined;\n  if (typeof process !== 'undefined') {\n    dbEmulatorHost = process.env[FIREBASE_DATABASE_EMULATOR_HOST_VAR];\n  }\n\n  if (dbEmulatorHost) {\n    isEmulator = true;\n    dbUrl = `http://${dbEmulatorHost}?ns=${repoInfo.namespace}`;\n    parsedUrl = parseRepoInfo(dbUrl, nodeAdmin);\n    repoInfo = parsedUrl.repoInfo;\n  } else {\n    isEmulator = !parsedUrl.repoInfo.secure;\n  }\n\n  const authTokenProvider =\n    nodeAdmin && isEmulator\n      ? new EmulatorAdminTokenProvider()\n      : new FirebaseAuthTokenProvider(app, authProvider);\n\n  validateUrl('Invalid Firebase Database URL', 1, parsedUrl);\n  if (!pathIsEmpty(parsedUrl.path)) {\n    fatal(\n      'Database URL must point to the root of a Firebase Database ' +\n        '(not including a child path).'\n    );\n  }\n\n  const repo = repoManagerCreateRepo(repoInfo, app, authTokenProvider);\n\n  return repoGetDatabase(repo);\n}\n\n/**\n * Remove the repo and make sure it is disconnected.\n *\n */\nexport function repoManagerDeleteRepo(repo: Repo): void {\n  const appRepos = safeGet(repos, repo.app.name);\n  // This should never happen...\n  if (!appRepos || safeGet(appRepos, repo.key) !== repo) {\n    fatal(\n      `Database ${repo.app.name}(${repo.repoInfo_}) has already been deleted.`\n    );\n  }\n  repoInterrupt(repo);\n  delete appRepos[repo.key];\n}\n\n/**\n * Ensures a repo doesn't already exist and then creates one using the\n * provided app.\n *\n * @param repoInfo The metadata about the Repo\n * @return The Repo object for the specified server / repoName.\n */\nexport function repoManagerCreateRepo(\n  repoInfo: RepoInfo,\n  app: FirebaseAppLike,\n  authTokenProvider: AuthTokenProvider\n): Repo {\n  let appRepos = safeGet(repos, app.name);\n\n  if (!appRepos) {\n    appRepos = {};\n    repos[app.name] = appRepos;\n  }\n\n  let repo = safeGet(appRepos, repoInfo.toURLString());\n  if (repo) {\n    fatal(\n      'Database initialized multiple times. Please make sure the format of the database URL matches with each database() call.'\n    );\n  }\n  repo = new Repo(repoInfo, useRestClient, app, authTokenProvider);\n  appRepos[repoInfo.toURLString()] = repo;\n\n  return repo;\n}\n\n/**\n * Forces us to use ReadonlyRestClient instead of PersistentConnection for new Repos.\n */\nexport function repoManagerForceRestClient(forceRestClient: boolean): void {\n  useRestClient = forceRestClient;\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { fatal } from '../core/util/util';\nimport { parseRepoInfo } from '../core/util/libs/parser';\nimport { newEmptyPath } from '../core/util/Path';\nimport { Reference } from './Reference';\nimport { Repo, repoInterrupt, repoResume, repoStart } from '../core/Repo';\nimport {\n  repoManagerApplyEmulatorSettings,\n  repoManagerDeleteRepo\n} from '../core/RepoManager';\nimport { validateArgCount } from '@firebase/util';\nimport { validateUrl } from '../core/util/validation';\nimport { FirebaseApp } from '@firebase/app-types';\nimport { FirebaseService } from '@firebase/app-types/private';\n\n/**\n * Class representing a firebase database.\n */\nexport class Database implements FirebaseService {\n  /** Track if the instance has been used (root or repo accessed) */\n  private instanceStarted_: boolean = false;\n\n  /** Backing state for root_ */\n  private rootInternal_?: Reference;\n\n  static readonly ServerValue = {\n    TIMESTAMP: {\n      '.sv': 'timestamp'\n    },\n    increment: (delta: number) => {\n      return {\n        '.sv': {\n          'increment': delta\n        }\n      };\n    }\n  };\n\n  /**\n   * The constructor should not be called by users of our public API.\n   */\n  constructor(private repoInternal_: Repo) {\n    if (!(repoInternal_ instanceof Repo)) {\n      fatal(\n        \"Don't call new Database() directly - please use firebase.database().\"\n      );\n    }\n  }\n\n  INTERNAL = {\n    delete: async () => {\n      this.checkDeleted_('delete');\n      repoManagerDeleteRepo(this.repo_);\n      this.repoInternal_ = null;\n      this.rootInternal_ = null;\n    }\n  };\n\n  private get repo_(): Repo {\n    if (!this.instanceStarted_) {\n      repoStart(this.repoInternal_);\n      this.instanceStarted_ = true;\n    }\n    return this.repoInternal_;\n  }\n\n  get root_(): Reference {\n    if (!this.rootInternal_) {\n      this.rootInternal_ = new Reference(this.repo_, newEmptyPath());\n    }\n\n    return this.rootInternal_;\n  }\n\n  get app(): FirebaseApp {\n    return this.repo_.app as FirebaseApp;\n  }\n\n  /**\n   * Modify this instance to communicate with the Realtime Database emulator.\n   *\n   * <p>Note: This method must be called before performing any other operation.\n   *\n   * @param host the emulator host (ex: localhost)\n   * @param port the emulator port (ex: 8080)\n   */\n  useEmulator(host: string, port: number): void {\n    this.checkDeleted_('useEmulator');\n    if (this.instanceStarted_) {\n      fatal(\n        'Cannot call useEmulator() after instance has already been initialized.'\n      );\n      return;\n    }\n\n    // Modify the repo to apply emulator settings\n    repoManagerApplyEmulatorSettings(this.repoInternal_, host, port);\n  }\n\n  /**\n   * Returns a reference to the root or to the path specified in the provided\n   * argument.\n   *\n   * @param path The relative string path or an existing Reference to a database\n   * location.\n   * @throws If a Reference is provided, throws if it does not belong to the\n   * same project.\n   * @return Firebase reference.\n   */\n  ref(path?: string): Reference;\n  ref(path?: Reference): Reference;\n  ref(path?: string | Reference): Reference {\n    this.checkDeleted_('ref');\n    validateArgCount('database.ref', 0, 1, arguments.length);\n\n    if (path instanceof Reference) {\n      return this.refFromURL(path.toString());\n    }\n\n    return path !== undefined ? this.root_.child(path) : this.root_;\n  }\n\n  /**\n   * Returns a reference to the root or the path specified in url.\n   * We throw a exception if the url is not in the same domain as the\n   * current repo.\n   * @return Firebase reference.\n   */\n  refFromURL(url: string): Reference {\n    /** @const {string} */\n    const apiName = 'database.refFromURL';\n    this.checkDeleted_(apiName);\n    validateArgCount(apiName, 1, 1, arguments.length);\n    const parsedURL = parseRepoInfo(url, this.repo_.repoInfo_.nodeAdmin);\n    validateUrl(apiName, 1, parsedURL);\n\n    const repoInfo = parsedURL.repoInfo;\n    if (\n      !this.repo_.repoInfo_.isCustomHost() &&\n      repoInfo.host !== this.repo_.repoInfo_.host\n    ) {\n      fatal(\n        apiName +\n          ': Host name does not match the current database: ' +\n          '(found ' +\n          repoInfo.host +\n          ' but expected ' +\n          this.repo_.repoInfo_.host +\n          ')'\n      );\n    }\n\n    return this.ref(parsedURL.path.toString());\n  }\n\n  private checkDeleted_(apiName: string) {\n    if (this.repoInternal_ === null) {\n      fatal('Cannot call ' + apiName + ' on a deleted database.');\n    }\n  }\n\n  // Make individual repo go offline.\n  goOffline(): void {\n    validateArgCount('database.goOffline', 0, 0, arguments.length);\n    this.checkDeleted_('goOffline');\n    repoInterrupt(this.repo_);\n  }\n\n  goOnline(): void {\n    validateArgCount('database.goOnline', 0, 0, arguments.length);\n    this.checkDeleted_('goOnline');\n    repoResume(this.repo_);\n  }\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { WebSocketConnection } from '../realtime/WebSocketConnection';\nimport { BrowserPollConnection } from '../realtime/BrowserPollConnection';\nimport { Reference } from './Reference';\nimport { repoManagerDatabaseFromApp } from '../core/RepoManager';\nimport { setSDKVersion } from '../core/version';\nimport { FirebaseApp } from '@firebase/app-types';\nimport {\n  FirebaseAuthInternal,\n  FirebaseAuthInternalName\n} from '@firebase/auth-interop-types';\nimport * as types from '@firebase/database-types';\nimport {\n  Component,\n  ComponentContainer,\n  ComponentType,\n  Provider\n} from '@firebase/component';\nimport {\n  repoInterceptServerData,\n  repoStats,\n  repoStatsIncrementCounter\n} from '../core/Repo';\n\n/**\n * INTERNAL methods for internal-use only (tests, etc.).\n *\n * Customers shouldn't use these or else should be aware that they could break at any time.\n */\n\nexport const forceLongPolling = function () {\n  WebSocketConnection.forceDisallow();\n  BrowserPollConnection.forceAllow();\n};\n\nexport const forceWebSockets = function () {\n  BrowserPollConnection.forceDisallow();\n};\n\n/* Used by App Manager */\nexport const isWebSocketsAvailable = function (): boolean {\n  return WebSocketConnection['isAvailable']();\n};\n\nexport const setSecurityDebugCallback = function (\n  ref: Reference,\n  callback: (a: object) => void\n) {\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  (ref.repo.persistentConnection_ as any).securityDebugCallback_ = callback;\n};\n\nexport const stats = function (ref: Reference, showDelta?: boolean) {\n  repoStats(ref.repo, showDelta);\n};\n\nexport const statsIncrementCounter = function (ref: Reference, metric: string) {\n  repoStatsIncrementCounter(ref.repo, metric);\n};\n\nexport const dataUpdateCount = function (ref: Reference): number {\n  return ref.repo.dataUpdateCount;\n};\n\nexport const interceptServerData = function (\n  ref: Reference,\n  callback: ((a: string, b: unknown) => void) | null\n) {\n  return repoInterceptServerData(ref.repo, callback);\n};\n\n/**\n * Used by console to create a database based on the app,\n * passed database URL and a custom auth implementation.\n *\n * @param app A valid FirebaseApp-like object\n * @param url A valid Firebase databaseURL\n * @param version custom version e.g. firebase-admin version\n * @param customAuthImpl custom auth implementation\n */\nexport function initStandalone<T>({\n  app,\n  url,\n  version,\n  customAuthImpl,\n  namespace,\n  nodeAdmin = false\n}: {\n  app: FirebaseApp;\n  url: string;\n  version: string;\n  customAuthImpl: FirebaseAuthInternal;\n  namespace: T;\n  nodeAdmin?: boolean;\n}): {\n  instance: types.Database;\n  namespace: T;\n} {\n  setSDKVersion(version);\n\n  /**\n   * ComponentContainer('database-standalone') is just a placeholder that doesn't perform\n   * any actual function.\n   */\n  const authProvider = new Provider<FirebaseAuthInternalName>(\n    'auth-internal',\n    new ComponentContainer('database-standalone')\n  );\n  authProvider.setComponent(\n    new Component('auth-internal', () => customAuthImpl, ComponentType.PRIVATE)\n  );\n\n  return {\n    instance: repoManagerDatabaseFromApp(\n      app,\n      authProvider,\n      url,\n      nodeAdmin\n    ) as types.Database,\n    namespace\n  };\n}\n","/**\n * @license\n * Copyright 2017 Google LLC\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *   http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport { RepoInfo } from '../core/RepoInfo';\nimport { PersistentConnection } from '../core/PersistentConnection';\nimport { repoManagerForceRestClient } from '../core/RepoManager';\nimport { Connection } from '../realtime/Connection';\nimport { Query } from './Query';\n\nexport const DataConnection = PersistentConnection;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n(PersistentConnection.prototype as any).simpleListen = function (\n  pathString: string,\n  onComplete: (a: unknown) => void\n) {\n  this.sendRequest('q', { p: pathString }, onComplete);\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n(PersistentConnection.prototype as any).echo = function (\n  data: unknown,\n  onEcho: (a: unknown) => void\n) {\n  this.sendRequest('echo', { d: data }, onEcho);\n};\n\n// RealTimeConnection properties that we use in tests.\nexport const RealTimeConnection = Connection;\n\nexport const hijackHash = function (newHash: () => string) {\n  const oldPut = PersistentConnection.prototype.put;\n  PersistentConnection.prototype.put = function (\n    pathString,\n    data,\n    onComplete,\n    hash\n  ) {\n    if (hash !== undefined) {\n      hash = newHash();\n    }\n    oldPut.call(this, pathString, data, onComplete, hash);\n  };\n  return function () {\n    PersistentConnection.prototype.put = oldPut;\n  };\n};\n\nexport const ConnectionTarget = RepoInfo;\n\nexport const queryIdentifier = function (query: Query) {\n  return query.queryIdentifier();\n};\n\n/**\n * Forces the RepoManager to create Repos that use ReadonlyRestClient instead of PersistentConnection.\n */\nexport const forceRestClient = function (forceRestClient: boolean) {\n  repoManagerForceRestClient(forceRestClient);\n};\n","module.exports = function(originalModule) {\n\tif (!originalModule.webpackPolyfill) {\n\t\tvar module = Object.create(originalModule);\n\t\t// module.parent = undefined by default\n\t\tif (!module.children) module.children = [];\n\t\tObject.defineProperty(module, \"loaded\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.l;\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(module, \"id\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.i;\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(module, \"exports\", {\n\t\t\tenumerable: true\n\t\t});\n\t\tmodule.webpackPolyfill = 1;\n\t}\n\treturn module;\n};\n","'use strict';\n\nvar isArray = Array.isArray;\nvar keyList = Object.keys;\nvar hasProp = Object.prototype.hasOwnProperty;\nvar hasElementType = typeof Element !== 'undefined';\n\nfunction equal(a, b) {\n  // fast-deep-equal index.js 2.0.1\n  if (a === b) return true;\n\n  if (a && b && typeof a == 'object' && typeof b == 'object') {\n    var arrA = isArray(a)\n      , arrB = isArray(b)\n      , i\n      , length\n      , key;\n\n    if (arrA && arrB) {\n      length = a.length;\n      if (length != b.length) return false;\n      for (i = length; i-- !== 0;)\n        if (!equal(a[i], b[i])) return false;\n      return true;\n    }\n\n    if (arrA != arrB) return false;\n\n    var dateA = a instanceof Date\n      , dateB = b instanceof Date;\n    if (dateA != dateB) return false;\n    if (dateA && dateB) return a.getTime() == b.getTime();\n\n    var regexpA = a instanceof RegExp\n      , regexpB = b instanceof RegExp;\n    if (regexpA != regexpB) return false;\n    if (regexpA && regexpB) return a.toString() == b.toString();\n\n    var keys = keyList(a);\n    length = keys.length;\n\n    if (length !== keyList(b).length)\n      return false;\n\n    for (i = length; i-- !== 0;)\n      if (!hasProp.call(b, keys[i])) return false;\n    // end fast-deep-equal\n\n    // start react-fast-compare\n    // custom handling for DOM elements\n    if (hasElementType && a instanceof Element && b instanceof Element)\n      return a === b;\n\n    // custom handling for React\n    for (i = length; i-- !== 0;) {\n      key = keys[i];\n      if (key === '_owner' && a.$$typeof) {\n        // React-specific: avoid traversing React elements' _owner.\n        //  _owner contains circular references\n        // and is not needed when comparing the actual elements (and not their owners)\n        // .$$typeof and ._store on just reasonable markers of a react element\n        continue;\n      } else {\n        // all other properties should be traversed as usual\n        if (!equal(a[key], b[key])) return false;\n      }\n    }\n    // end react-fast-compare\n\n    // fast-deep-equal index.js 2.0.1\n    return true;\n  }\n\n  return a !== a && b !== b;\n}\n// end fast-deep-equal\n\nmodule.exports = function exportedEqual(a, b) {\n  try {\n    return equal(a, b);\n  } catch (error) {\n    if ((error.message && error.message.match(/stack|recursion/i)) || (error.number === -2146828260)) {\n      // warn on circular references, don't crash\n      // browsers give this different errors name and messages:\n      // chrome/safari: \"RangeError\", \"Maximum call stack size exceeded\"\n      // firefox: \"InternalError\", too much recursion\"\n      // edge: \"Error\", \"Out of stack space\"\n      console.warn('Warning: react-fast-compare does not handle circular references.', error.name, error.message);\n      return false;\n    }\n    // some other error. we should definitely know about these\n    throw error;\n  }\n};\n","module.exports = Array.isArray || function (arr) {\n  return Object.prototype.toString.call(arr) == '[object Array]';\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';\nmodule.exports = function (str) {\n\treturn encodeURIComponent(str).replace(/[!'()*]/g, function (c) {\n\t\treturn '%' + c.charCodeAt(0).toString(16).toUpperCase();\n\t});\n};\n"],"sourceRoot":""}